## FEATURES:

- Free-running CLKA and CLKB can be asynchronous or coincident (simultaneous reading and writing of data on a single clock edge is permitted)
- Two independent clocked FIFOs (64 x 36 storage capacity each) buffering data in opposite directions
- Mailbox bypass Register for each FIFO
- Dynamic Port B bus sizing of 36-bits (long word), 18-bits (word), and 9-bits (byte)
- Selection of Big- or Little-Endian format for word and byte bus sizes
- Three modes of byte-order swapping on port B
- Programmable Almost-Full and Almost-Empty Flags
- Microprocessor interface control logic
- $\overline{\mathrm{EFA}}, \overline{\mathrm{FFA}}, \overline{\mathrm{AEA}}$, and $\overline{\mathrm{AFA}}$ flags synchronized by CLKA
- $\overline{\mathrm{EFB}}, \overline{\mathrm{FFB}}, \overline{\mathrm{AEB}}$, and $\overline{\mathrm{AFB}}$ flags synchronized by CLKB
- Passive parity checking on each port
- Parity generation can be selected for each port
- Low-power advanced BiCMOS technology
- Supports clock frequencies up to 67 MHz
- Fast access times of 10 ns
- Available in 132-pin plastic quad flat package (PQF) or space-saving 120-pin thin quad flat package (TQFP)
- Industrial temperature range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ is available, tested to military electrical specifications


## FUNCTIONAL BLOCK DIAGRAM



The IDT logo is a registered trademark and SyncBiFIFO is a trademark of Integrated Device Technology, Inc.

## DESCRIPTION:

The IDT723614 is a monolithic, high-speed, low-power BiCMOS bidirectional clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read access times as fast as 10 ns . Two independent $64 \times 36$ dual-port SRAM FIFOs on board the chip buffer data in opposite directions. Each FIFO has flags to indicate empty and full conditions and two programmable flags (almost-full and almost-empty) to indicate when a selected number of words is stored in memory. FIFO data on port B can be input and output in 36-bit, 18-bit, and 9 -bit formats with a choice of big- or little-endian configurations. Three modes of byte-order swapping are possible
with any bus size selection. Communication between each port can bypass the FIFOs via two 36-bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Parity is checked passively on each port and may be ignored if not desired. Parity generation can be selected for data read from each port. Two or more devices can be used in parallel to create wider data paths.

The IDT723614 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the LOW-to-HIGH transition of a continuous (free-running) port clock by enable signals. The clocks for each port are independent of one another and can be asyn-

## PIN CONFIGURATIONS



[^0]
## NOTES:

1. NC - No internal connection.
2. Uses Yamaichi socket IC51-1324-828.
chronous or coincident. The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and/or buses controlled by a synchronous interface.

The full flag ( $\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}}$ ) and almost-full flag ( $\overline{\mathrm{AFA}}, \overline{\mathrm{AFB}}$ ) of a FIFO are two-stage synchronized to the port clock that
writes data to its array. The empty flag ( $\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}}$ ) and almostempty ( $\overline{\mathrm{AEA}}, \overline{\mathrm{AEB}}$ ) flag of a FIFO are two stage synchronized to the port clock that reads data from its array.

The IDT723614 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## PIN CONFIGURATIONS (CONT.)



TQFP (PN120-1, order code: PF) TOP VIEW

## PIN DESCRIPTION

| Symbol | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| A0-A35 | Port A Data | I/O | 36-bit bidirectional data port for side A. |
| $\overline{\text { AEA }}$ | Port A Almost-Empty Flag | $\underset{(\text { Port A) }}{\mathrm{O}}$ | Programmable almost-empty flag synchronized to CLKA. It is LOW when the number of 36 -bit words in FIFO2 is less than or equal to the value in the offset register, X . |
| $\overline{\text { AEB }}$ | Port B Almost-Empty Flag | $\begin{gathered} \mathrm{O} \\ \text { (Port B) } \end{gathered}$ | Programmable almost-empty flag synchronized to CLKB. It is LOW when the number of 36 -bit words in FIFO1 is less than or equal to the value in the offset register, X. |
| $\overline{\text { AFA }}$ | Port A Almost-Full Flag | $\begin{gathered} \mathrm{O} \\ \text { (Port A) } \end{gathered}$ | Programmable almost-full flag synchronized to CLKA. It is LOW when the number of 36 -bit empty locations in FIFO1 is less than or equal to the value in the offset register, $X$. |
| $\overline{\text { AFB }}$ | Port B Almost-Full Flag | $\underset{(\text { Port B) }}{\mathrm{O}}$ | Programmable almost-full flag synchronized to CLKB. It is LOW when the number of 36 -bit empty locations in FIFO2 is less than or equal to the value in the offset register, X . |
| B0-B35 | Port B Data. | I/O | 36 -bit bidirectional data port for side B. |
| $\overline{B E}$ | Big-endian select | I | Selects the bytes on port B used during byte or word data transfer. A LOW on BE selects the most significant bytes on B0-B35 for use, and a HIGH selects the least significant bytes |
| CLKA | Port A Clock | 1 | CLKA is a continuous clock that synchronizes all data transfers through port A and can be asynchronous or coincident to CLKB. EFA, FFA, AFA, and AEA are synchronized to the LOW-to-HIGH transition of CLKA. |
| CLKB | Port B Clock | I | CLKB is a continuous clock that synchronizes all data transfers through port B and can be asynchronous or coincident to CLKA. Port B byte swapping and data port sizing operations are also synchronous to the LOW-to-HIGH transition of CLKB. EFB, $\overline{F F B}, \overline{A F B}$, and $\overline{A E B}$ are synchronized to the LOW-to-HIGH transition of CLKB. |
| $\overline{\text { CSA }}$ | Port A Chip Select | 1 | $\overline{\text { CSA }}$ must be LOW to enable a LOW-to-HIGH transition of CLKA to read or write data on port A. The A0-A35 outputs are in the high-impedance state when CSA is HIGH. |
| $\overline{\mathrm{CSB}}$ | Port B Chip Select | 1 | $\overline{\text { CSB }}$ must be LOW to enable a LOW-to-HIGH transition of CLKB to read or write data on port B. The B0-B35 outputs are in the high-impedance state when CSB is HIGH. |
| EFA | Port A Empty Flag | $\underset{(\text { Port A })}{\mathrm{O}}$ | EFA is synchronized to the LOW-to-HIGH transition of CLKA. When EFA is LOW, FIFO2 is empty, and reads from its memory are disabled. Data can be read from FIFO2 to the output register when EFA is HIGH. EFA is forced LOW when the device is reset and is set HIGH by the second LOW-to-HIGH transition of CLKA after data is loaded into empty FIFO2 memory. |
| $\overline{\mathrm{EFB}}$ | Port B Empty Flag | $\underset{(\text { Port B) }}{\mathrm{O}}$ | $\overline{\mathrm{EFB}}$ is synchronized to the LOW-to-HIGH transition of CLKB. When EFB is LOW, the FIFO1 is empty, and reads from its memory are disabled. Data can be read from FIFO1 to the output register when EFB is HIGH. EFB is forced LOW when the device is reset and is set HIGH by the second LOW-to-HIGH transition of CLKB after data is loaded into empty FIFO1 memory. |
| ENA | Port A Enable | I | ENA must be HIGH to enable a LOW-to-HIGH transition of CLKA to read or write data on port A. |
| ENB | Port B Enable | 1 | ENB must be HIGH to enable a LOW-to-HIGH transition of CLKB to read or write data on port B . |
| FFA | Port A Full Flag | $\underset{(\text { Port A) }}{\mathrm{O}}$ | $\overline{\text { FFA }}$ is synchronized to the LOW-to-HIGH transition of CLKA. When FFA is LOW, FIFO1 is full, and writes to its memory are disabled. FFA is forced LOW when the device is reset and is set HIGH by the second LOW-to-HIGH transition of CLKA after reset. |
| $\overline{\mathrm{FFB}}$ | Port B Full Flag | $\underset{\text { (Port B) }}{\mathrm{O}}$ | $\overline{\text { FFB }}$ is synchronized to the LOW-to-HIGH transition of CLKB. When $\overline{\text { FFB }}$ is LOW, FIFO2 is full, and writes to its memory are disabled. FFB is forced LOW when the device is reset and is set HIGH by the second LOW-to-HIGH transition of CLKB after reset. |

## PIN DESCRIPTION (CONTINUED)

| Symbol | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| FS1, FS0 | Flag-Offset Selects | I | The LOW-to-HIGH transition of $\overline{\text { RST }}$ latches the values of FS0 and FS1, which selects one of four preset values for the almost-full flag and almost-empty flag offset. |
| MBA | Port A Mailbox Select | 1 | A HIGH level on MBA chooses a mailbox register for a port A read or write operation. When the A0-A35 outputs are active, a HIGH level on MBA selects data from the mail2 register for output, and a LOW level selects FIFO2 output register data for output. |
| $\overline{\text { MBF1 }}$ | Mail1 Register Flag | O | $\overline{\text { MBF1 }}$ is set LOW by a LOW-to-HIGH transition of CLKA that writes data to the mail1 register. Writes to the mail1 register are inhibited while MBF1 is set LOW. $\overline{\text { MBF1 }}$ is set HIGH by a LOW-to-HIGH transition of CLKB when a port B read is selected and both SIZ1 and SIZO are HIGH. $\overline{\text { MBF1 }}$ is set HIGH when the device is reset. |
| $\overline{\text { MBF2 }}$ | Mail2 Register Flag | 0 | $\overline{\text { MBF2 }}$ is set LOW by a LOW-to-HIGH transition of CLKB that writes data to the mail2 register. Writes to the mail2 register are inhibited while MBF2 is set LOW. $\overline{\text { MBF2 }}$ is set HIGH by a LOW-to-HIGH transition of CLKA when a port A read is selected and MBA is HIGH. MBF2 is set HIGH when the device is reset. |
| $\frac{\text { ODD/ }}{\text { EVEN }}$ | Odd/Even Parity Select | 1 | Odd parity is checked on each port when ODD/EVEN is HIGH, and even parity is checked when ODD/EVEN is LOW. ODD/EVEN also selects the type of parity generated for each port if parity generation is enabled for a readoperation. |
| $\overline{\text { PEFA }}$ | Port A Parity Error Flag | 0 (Port A) | When any byte applied to terminals A0-A35 fails parity, $\overline{\text { PEFA }}$ is LOW. Bytes are organized as A0-A8, A9-A17, A18-A26, and A27-A35, with the most significant bit of each byte serving as the parity bit. The type of parity checked is deter mined by the state of the ODD/EVEN input. <br> The parity trees used to check the A0-A35 inputs are shared by the mail2 register to generate parity if parity generation is selected by PGA. Therefore, if a mail2 read parity generation is setup by having W/RA LOW, MBA HIGH, and PGA HIGH, the PEFA flag is forced HIGH regardless of the A0-A35 inputs. |
| $\overline{\text { PEFB }}$ | Port B Parity Error Flag | O (Port B) | When any valid byte applied to terminals B0-B35 fails parity, $\overline{\text { PEFB }}$ is LOW. Bytes are organized as B0-B8, B9-B17, B18-B26, B27-B35 with the most significant bit of each byte serving as the parity bit. A byte is valid when it is used by the bus size selected for Port B. The type of parity checked is determined by the state of the ODD/EVEN input. <br> The parity trees used to check the B0-B35 inputs are sharedby the mail 1 register to generate parity if parity generation isselected by PGB. Therefore, if a mail1 read with parity generation is setup by having W/RB LOW, SIZ1 and SIZO HIGH, and PGB HIGH, the PEFB flag is forced HIGH regardless of the state of the B0-B35 inputs. |
| PGA | Port A Parity Generation | I | Parity is generated for data reads from port A when PGA is HIGH. The type of parity generated is selected by the state of the ODD/EVEN input. Bytes are organized as A0-A8, A9-A17, A18-A26, and A27-A35. The generated parity bits are output in the most significant bit of each byte. |
| PGB | Port B Parity Generation | I | Parity is generated for data reads from port B when PGB is HIGH. The type of parity generated is selected by the state of the ODD/EVEN input. Bytes are organized as B0-B8, B9-B17, B18-B26, and B27-B35. The generated parity bits are output in the most significant bit of each byte. |
| $\overline{\mathrm{RST}}$ | Reset | 1 | To reset the device, four LOW-to-HIGH transitions of CLKA and four LOW-toHIGH transitions of CLKB must occur while RST is LOW. This sets the AFA, $\overline{\mathrm{AFB}}, \overline{\mathrm{MBF}}$, and $\overline{\mathrm{MBF}}$ flags HIGH and the EFA, $\overline{\mathrm{EFB}}, \overline{\mathrm{AEA}}, \overline{\mathrm{AEB}}, \overline{\mathrm{FFA}}$, and $\overline{\text { FFB }}$ flags LOW. The LOW-to-HIGH transition of $\overline{\text { RST }}$ latches the status of the FS1 and FS0 inputs to select almost-full and almost-empty flag offsets |
| SIZ0, SIZ1 | Port B bus size selects | (Port B) | A LOW-to-HIGH transition of CLKB latches the states of SIZO, SIZ1, and $\overline{\mathrm{BE}}$, and the following LOW-to-HIGH transition of CLKB implements the latched states as a port B bus size. Port B bus sizes can be long word, word, or byte. A high on both SIZO and SIZ1 accesses the mailbox reegisters for a port B 36-bit write or read. |

## PIN DESCRIPTION (CONTINUED)

| Symbol | Name | I/O | Description |
| :---: | :--- | :---: | :--- |
| SW0, SW1 | Port B byte swap <br> Select | I <br> (Port B) | At the beginning of each long word transfer, one of four modes of byte-order <br> swapping is selected by SW0 and SW1. The four modes are no swap, byte <br> swap, word swap, and byte-word swap. Byte-order swapping is possible with <br> any bus-size selection. |
| W/̄/RA | Port A Write/Read <br> Select | I | A HIGH selects a write operation and a LOW selects a read operation on <br> port A for a LOW-to-HIGH transition of CLKA. The A0-A35 outputs are in the <br> high-impedance state when W/RA is HIGH. |
| W/ $\bar{R} B$ | Port B Write/Read <br> Select | I | A HIGH selects a write operation and a LOW selects a read operation on <br> port B for a LOW-to-HIGH transition of CLKB. The B0-B35 outputs are in the <br> high-impedance state when W/RB is HIGH. |

## SIGNAL DESCRIPTIONS

## RESET

The IDT723614 is reset by taking the reset ( $\overline{\mathrm{RST}}$ ) input LOW for at least four port A clock (CLKA) and four port B clock (CLKB) LOW-to-HIGH transitions. The reset input can switch asynchronously to the clocks. A device reset initializes the internal read and write pointers of each FIFO and forces the full flags ( $\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}}$ ) LOW, the empty flags ( $\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}}$ ) LOW, the almost-empty flags (AEA, AEB) LOW and the almost-full flags ( $\overline{\mathrm{AFA}}, \overline{\mathrm{AFB}}$ ) HIGH. A reset also forces the mailbox flags ( $\overline{\mathrm{MBF}}, \overline{\mathrm{MBF}}$ ) HIGH . After a reset, $\overline{\mathrm{FFA}}$ is set HIGH after two LOW-to-HIGH transitions of CLKA and FFB is set HIGH after two LOW-to-HIGH transitions of CLKB. The device must be reset after power up before data is written to its memory.

A LOW-to-HIGH transition on the RST input loads the almost-full and almost-empty offset register ( X ) with the values selected by the flag-select (FS0, FS1) inputs. The values that can be loaded into the registers are shown in Table 1.

## FIFO WRITE/READ OPERATION

The state of port A data A0-A35 outputs is controlled by the port A chip select ( $\overline{\mathrm{CSA}}$ ) and the port A write/read select (W/ $\overline{\mathrm{R}} \mathrm{A})$. The A0-A35 outputs are in the high-impedance state when either $\overline{\mathrm{CSA}}$ or W/RA is HIGH. The A0-A35 outputs are active when both $\overline{C S A}$ and $W / \bar{R} A$ are LOW. Data is loaded into FIFO1 from the A0-A35 inputs on a LOW-to-HIGH transition of CLKA when $\overline{C S A}$ is LOW, W/ $\bar{R} A$ is HIGH, ENA is HIGH, MBA is LOW, and FFA is HIGH. Data is read from FIFO2 to the A0-A35 outputs by a LOW-to-HIGH transition of CLKA when CSA is LOW, W/RA is LOW, ENA is HIGH, MBA is LOW, and EFA is HIGH (see Table 2).

The port B control signals are identical to those of port A . The state of the port B data ( $\mathrm{B} 0-\mathrm{B} 35$ ) outputs is controlled by the port $B$ chip select (CSB) and the port $B$ write/read select (W/RB). The B0-B35 outputs are in the high-impedance state when either $\overline{\mathrm{CSB}}$ or W/ $\overline{\mathrm{R} B}$ is HIGH. The B0-B35 outputs are active when both $\overline{\mathrm{CSB}}$ and $\mathrm{W} / \overline{\mathrm{R} B}$ are LOW. Data is loaded into FIFO2 from the B0-B35 inputs on a LOW-to-HIGH transition of CLKB when $\overline{\mathrm{CSB}}$ is LOW, $\mathrm{W} / \overline{\mathrm{RB}}$ is $\mathrm{HIGH}, \mathrm{ENB}$ is HIGH, $\overline{\mathrm{EFB}}$ is HIGH, and either SIZO or SIZ1 is LOW. Data is read from

FIFO1 to the B0-B35 outputs by a LOW-to-HIGH transition of CLKB when $\overline{C S B}$ is LOW, W/ $\bar{R} B$ is LOW, ENB is HIGH, $\overline{E F B}$ is HIGH, and either SIZO or SIZ1 is LOW (see Table 3).

The setup and hold time constraints to the port clocks for the port chip selects (CSA, CSB) and write/read selects (W/ RA, W/RB) are only for enabling write and read operations and are not related to high-impedance control of the data outputs. If a port enable is LOW during a clock cycle, the port chip select and write/read select can change states during the setup and hold time window of the cycle.

## SYNCHRONIZED FIFO FLAGS

Each FIFO is synchronized to its port clock through two flip-flop stages. This is done to improve flag reliability by reducing the probability of metastable events on the output when CLKA and CLKB operate asynchronously to one another. $\overline{\mathrm{EFA}}, \overline{\mathrm{AEA}}, \overline{F F A}$, and $\overline{\mathrm{AFA}}$ are synchronized to CLKA. $\overline{\mathrm{EFB}}, \overline{\mathrm{AEB}}, \overline{\mathrm{FFB}}$, and $\overline{\mathrm{AFB}}$ are synchronized to CLKB. Tables 4 and 5 show the relationship of each port flag to FIFO1 and FIFO2.

## EMPTY FLAGS ( $\overline{E F A}, \overline{E F B})$

The empty flag of a FIFO is synchronized to the port clock that reads data from its array. When the empty flag is HIGH, new data can be read to the FIFO output register. When the empty flag is LOW, the FIFO is empty and attempted FIFO reads are ignored. When reading FIFO1 with a byte or word size on port B, EFB is set LOW when the fourth byte or second word of the last long word is read.

The read pointer of a FIFO is incremented each time a new word is clocked to the output register. The state machine that controls an empty flag monitors a write-pointer and readpointer comparator that indicates when the FIFO SRAM status is empty, empty +1 , or empty +2 . A word written to a FIFO can be read to the FIFO output register in a minimum of three cycles of the empty flag synchronizing clock. Therefore, an empty flag is LOW if a word in memory is the next data to be sent to the FIFO output register and two cycles of the port
clock that reads data from the FIFO have not elapsed since the time the word was written. The empty flag of the FIFO is set HIGH by the second LOW-to-HIGH transition of the synchronizing clock, and the new data word can be read to the FIFO output register in the following cycle.

A LOW-to-HIGH transition on an empty flag synchronizing clock begins the first synchronization cycle of a write if the clock transition occurs at time tSKEW1 or greater after the write. Otherwise, the subsequent clock cycle can be the first synchronization cycle (see Figure 13 and 14).

## TABLE 1: FLAG PROGRAMMING

| FS1 | FS0 | RST | ALMOST-FULL AND <br> ALMOST-EMPTY FLAG <br> OFFSET REGISTER (X) |
| :---: | :---: | :---: | :---: |
| $H$ | $H$ | $\uparrow$ | 16 |
| $H$ | $L$ | $\uparrow$ | 12 |
| $L$ | $H$ | $\uparrow$ | 8 |
| $L$ | $L$ | $\uparrow$ | 4 |

## FULL FLAG ( $\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}})$

The full flag of a FIFO is synchronized to the port clock that writes data to its array. When the full flag is HIGH, a memory location is free in the SRAM to receive new data. No memory locations are free when the full flag is LOW and attempted writes to the FIFO are ignored.

Each time a word is written to a FIFO, the write pointer is incremented. The state machine that controls a full flag monitors a write-pointer and read-pointer comparator that indicates when the FIFO SRAM status is full, full-1, or full-2. From the time a word is read from a FIFO, the previous memory location is ready to be written in a minimum of three cycles of the full flag synchronizing clock. Therefore, a full flag is LOW if less than two cycles of the full flag synchronizing clock have elapsed since the next memory write location has been read. The second LOW-to-HIGH transition on the full flag synchronization clock after the read sets the full flag HIGH and the data can be written in the following clock cycle.

A LOW-to-HIGH transition on a full flag synchronizing clock begins the first synchronization cycle of a read if the clock transition occurs at time tSKEW1 or greater after the read. Otherwise, the subsequent clock cycle can be the first synchronization cycle (see Figure 15 and 16).

TABLE 2: PORT-A ENABLE FUNCTION TABLE

| $\overline{\text { CSA }}$ | W/展A | ENA | MBA | CLKA | A0-A35 Outputs | Port Functions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | In High-Impedance State | None |
| L | H | L | X | X | In High-Impedance State | None |
| L | H | H | L | $\uparrow$ | In High-Impedance State | FIFO1 Write |
| L | H | H | H | $\uparrow$ | In High-Impedance State | Mail1 Write |
| L | L | L | L | X | Active, FIFO2 Output Register | None |
| L | L | H | L | $\uparrow$ | Active, FIFO2 Output Register | FIFO2 Read |
| L | L | L | H | X | Active, Mail2 Register | None |
| L | L | H | H | $\uparrow$ | Active, Mail2 Register | Mail2 Read (Set $\overline{\text { MBF2 HIGH) }}$ |

TABLE 3: PORT-B ENABLE FUNCTION TABLE

| $\overline{\text { CSB }}$ | W/R $\mathbf{R} \mathbf{B}$ | ENB | SIZ1, SIZO | CLKB | B0-B35 Outputs | Port Functions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | In High-Impedance State | None |
| L | H | L | X | X | In High-Impedance State | None |
| L | H | H | One, both LOW | $\uparrow$ | In High-Impedance State | FIFO2 Write |
| L | H | H | Both HIGH | $\uparrow$ | In High-Impedance State | Mail2 Write |
| L | L | L | One, both LOW | X | Active, FIFO1 Output Register | None |
| L | L | H | One, both LOW | $\uparrow$ | Active, FIFO1 Output Register | FIFO1 read |
| L | L | L | Both HIGH | X | Active, Mail1 Register | None |
| L | L | H | Both HIGH | $\uparrow$ | Active, Mail1 Register | Mail1 Read (Set MBF1 HIGH) |

## ALMOST EMPTY FLAGS ( $\overline{\mathrm{AEA}}, \overline{\mathrm{AEB}}$ )

The almost-empty flag of a FIFO is synchronized to the port clock that reads data from its array. The state machine that controls an almost-empty flag monitors a write-pointer and a read-pointer comparator that indicates when the FIFO SRAM status is almost empty, almost empty+1, or almost empty+2. The almost-empty state is defined by the value of the almost-full and almost-empty offset register (X). This register is loaded with one of four preset values during a device reset (see Reset above). An almost-empty flag is LOW when the FIFO contains $X$ or less long words in memory and is HIGH when the FIFO contains $(X+1)$ or more long words.

Two LOW-to-HIGH transitions of the almost-empty flag synchronizing clock are required after a FIFO write for the almost-empty flag to reflect the new level of fill. Therefore, the almost-empty flag of a FIFO containing ( $\mathrm{X}+1$ ) or more long words remains LOW if two cycles of the synchronizing clock have not elapsed since the write that filled the memory to the $(\mathrm{X}+1)$ level. An almost-empty flag is set HIGH by the second LOW-to-HIGH transition of the synchronizing clock after the FIFO write that fills memory to the $(\mathrm{X}+1)$ level. A LOW-toHIGH transition of an almost-empty flag synchronizing clock begins the first synchronization cycle if it occurs at time tSKEW2 or greater after the write that fills the FIFO to $(X+1)$ long words. Otherwise, the subsequent synchronizing clock cycle can be the first synchronization cycle (see Figure 17 and 18).

## ALMOST FULL FLAGS ( $\overline{\mathrm{AFA}}, \overline{\mathrm{AFB}}$ )

The almost-full flag of a FIFO is synchronized to the port clock that writes data to its array. The state machine that controls an almost-full flag monitors a write-pointer and readpointer comparator that indicates when the FIFO SRAM status is almost full, almost full-1, or almost full-2. The almostfull state is defined by the value of the almost-full and almostempty offset register ( X ). This register is loaded with one of four preset values during a device reset (see Reset above). An almost-full flag is LOW when the FIFO contains $(64-X)$ or
more long words in memory and is HIGH when the FIFO contains $[64-(X+1)]$ or less long words.

Two LOW-to-HIGH transitions of the almost-full flag synchronizing clock are required after a FIFO read for the almost-full flag to reflect the new level of fill. Therefore, the almost-full flag of a FIFO containing [64-(X+1)] or less words remains LOW if two cycles of the synchronizing clock have not elapsed since the read that reduced the number of long words in memory to [64-(X+1)]. An almost-full flag is set HIGH by the second LOW-to-HIGH transition of the synchronizing clock after the FIFO read that reduces the number of long words in memory to $[64-(X+1)]$. A LOW-to-HIGH transition of an almost-full flag synchronizing clock begins the first synchronization cycle if it occurs at time tSKEW2 or greater after the read that reduces the number of long words in memory to [64$(X+1)]$. Otherwise, the subsequent synchronizing clock cycle can be the first synchronization cycle (see Figure 19 and 20).

## MAILBOX REGISTERS

Each FIFO has a 36-bit bypass register to pass command and control information between port A and port B without putting it in queue. The mailbox-select (MBA, MBB) inputs choose between a mail register and a FIFO for a port data transfer operation. A LOW-to-HIGH transition on CLKA writes A0-A35 data to the mail1 register when a port A write is selected by $\overline{\mathrm{CSA}}, \mathrm{W} / \overline{\mathrm{R}}$, and ENA with MBA HIGH. A LOW-to-HIGH transition on CLKB writes B0-B35 data to the mail2 register when a port $B$ write is selected by $\overline{C S B}, W / \bar{R} B$, and ENB with both SIZ1 and SIZ0 HIGH. Writing data to a mail register sets the corresponding flag ( $\overline{\mathrm{MBF}}$ or $\overline{\mathrm{MBF}}$ ) LOW. Attempted writes to a mail register are ignored while the mail flag is LOW.

When the port A data outputs (A0-A35) are active, the data on the bus comes from the FIFO2 output register when MBA is LOW and from the mail2 register when MBA is HIGH. When the port B data outputs (B0-B35) are active, the data on the bus comes from the FIFO1 output register when either one

TABLE 4: FIFO1 FLAG OPERATION

| Number of 36-Bit Words in the FIFO1 ${ }^{(1)}$ | Synchronized to CLKB |  | Synchronized to CLKA |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { EFB }}$ | $\overline{\text { AEB }}$ | $\overline{\text { AFA }}$ | $\overline{F F A}$ |
| 0 | L | L | H | H |
| 1 to $X$ | H | L | H | H |
| $(\mathrm{X}+1)$ to [64-(X+1)] | H | H | H | H |
| $(64-X)$ to 63 | H | H | L | H |
| 64 | H | H | L | L |

TABLE 5: FIFO2 FLAG OPERATION

| Number of 36-Bit | Synchronized <br> to CLKA |  | Synchronized <br> to CLKB |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{EFA}}$ | $\overline{\mathrm{AEA}}$ | $\overline{\mathrm{AFB}}$ | $\overline{\mathrm{FFB}}$ |
| 0 | L | L | H | H |
| 1 to X | H | L | H | H |
| $(\mathrm{X}+1)$ to $[64-(\mathrm{X}+1)]$ | H | H | H | H |
| $(64-\mathrm{X})$ to 63 | H | H | L | H |
| 64 | H | H | L | L |

NOTE:

1. $X$ is the value in the almost-empty flag and almost-full flag offset register.

## ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED) ${ }^{(1)}$

| Symbol | Rating | Commercial | Unit |
| :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage Range | -0.5 to 7 | V |
| $\mathrm{VI}^{(2)}$ | Input Voltage Range | -0.5 to Vcc+0.5 | V |
| Vo ${ }^{(2)}$ | Output Voltage Range | -0.5 to Vcc+0.5 | V |
| IIK | Input Clamp Current, ( VI < 0 or $\mathrm{VI}>$ Vcc) | $\pm 20$ | mA |
| IOK | Output Clamp Current, (Vo < 0 or Vo > Vcc) | $\pm 50$ | mA |
| IOUT | Continuous Output Current, (Vo = 0 to Vcc) | $\pm 50$ | mA |
| IcC | Continuous Current Through Vcc or GND | $\pm 500$ | mA |
| TA | Operating Free Air Temperature Range | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| TstG | Storage Temperature Range | -65 to 150 | ${ }^{\circ} \mathrm{C}$ |

## NOTES:

1. Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those indicated under "Recommended Operating Conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
2. The input and output voltage ratings may be exceeded provided the input and output current ratings are observed.

## RECOMMENDED OPERATING CONDITIONS

| Symbol | Parameter | Min. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.5 | V |
| VIH | HIGH Level Input Voltage | 2 | - | V |
| VIL | LOW-Level Input Voltage | - | 0.8 | V |
| IOH | HIGH-Level Output Current | - | -4 | mA |
| IOL | LOW-Level Output Current | - | 8 | mA |
| TA | Operating Free-air <br> Temperature | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

## ELECTRICAL CHARACTERISTICS OVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED)

| Parameter | Test Conditions |  |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | $\mathrm{Vcc}=4.5 \mathrm{~V}$, | $\mathrm{IOH}=-4 \mathrm{~mA}$ |  | 2.4 |  |  | V |
| Vol | $\mathrm{Vcc}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  |  | 0.5 | V |
| 11 | $\mathrm{Vcc}=5.5 \mathrm{~V}$, | $\mathrm{VI}=\mathrm{Vcc}$ or 0 |  |  |  | $\pm 50$ | $\mu \mathrm{A}$ |
| Ioz | $\mathrm{Vcc}=5.5 \mathrm{~V}$, | $\mathrm{Vo}=\mathrm{Vcc}$ or 0 |  |  |  | $\pm 50$ | $\mu \mathrm{A}$ |
| ICC | $\mathrm{Vcc}=5.5 \mathrm{~V}$, | $\mathrm{IO}=0 \mathrm{~mA}$, | $\mathrm{VI}=\mathrm{Vcc}$ or GND |  |  | 1 | mA |
| CIn | $\mathrm{VI}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  |  | 4 |  | pF |
| Cout | $\mathrm{Vo}=0$, | $f=1 \mathrm{MHZ}$ |  |  | 8 |  | pF |

## NOTE:

1. All typical values are at $\mathrm{VCC}=5 \mathrm{~V}, \mathrm{TA}=25^{\circ} \mathrm{C}$.

## DC ELECTRICAL CHARACTERISTICS OVER RECOMMENDED RANGES OF SUPPLY VOLTAGE AND OPERATING FREE-AIR TEMPERATURE (See Figures 4 through 26)

| Symbol | Parameter | IDT723614L15 |  | IDT723614L20 |  | IDT723614L30 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| fs | Clock Frequency, CLKA or CLKB | - | 66.7 | - | 50 | - | 33.4 | MHz |
| tCLK | Clock Cycle Time, CLKA or CLKB | 15 | - | 20 | - | 30 | - | ns |
| tCLKH | Pulse Duration, CLKA and CLKB HIGH | 6 | - | 8 | - | 12 | - | ns |
| tCLKL | Pulse Duration, CLKA and CLKB LOW | 6 | - | 8 | - | 12 | - | ns |
| tDS | Setup Time, A0-A35 before CLKA个 and B0-B35 before CLKB $\uparrow$ | 4 | - | 5 | - | 6 | - | ns |
| tENS | Setup Time, $\overline{\mathrm{CSA}}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}$, ENA and MBA before CLKA $\uparrow ; \overline{\mathrm{CSB}}, \mathrm{W} / \overline{\mathrm{RB}}$ and ENB before CLKB $\uparrow$ | 5 | - | 5 | - | 6 | - | ns |
| tSZS | Setup Time, SIZO, SIZ1, and $\overline{\mathrm{BE}}$ before CLKB $\uparrow$ | 4 | - | 5 | - | 6 | - | ns |
| tSWS | Setup Time, SW0 and SW1 before CLKB $\uparrow$ | 5 | - | 7 | - | 8 | - | ns |
| tPGS | Setup Time, ODD/EVEN and PGA before CLKA $\uparrow$; ODD/EVEN and PGB before CLKB $\uparrow^{(1)}$ | 4 | - | 5 | - | 6 | - | ns |
| tRSTS | Setup Time, $\overline{\mathrm{RST}}$ LOW before CLKA $\uparrow$ or CLKB $\uparrow^{(2)}$ | 5 | - | 6 | - | 7 | - | ns |
| tFSS | Setup Time, FS0 and FS1 before $\overline{\text { RST }}$ HIGH | 5 | - | 6 | - | 7 | - | ns |
| tDH | Hold Time, A0-A35 after CLKA $\uparrow$ and B0-B35 after CLKB $\uparrow$ | 1 | - | 1 | - | 1 | - | ns |
| tENH | Hold Time, $\overline{\mathrm{CSA}}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}, ~ E N A ~ a n d ~ M B A ~ a f t e r ~$ CLKA $\uparrow$; $\overline{\mathrm{CSB}}, \mathrm{W} / \overline{\mathrm{R} B}$, and ENB after CLKB $\uparrow$ | 1 | - | 1 | - | 1 | - | ns |
| tSZH | Hold Time, SIZO, SIZ1, and $\overline{\overline{B E}}$ after CLKB $\uparrow$ | 2 | - | 2 | - | 2 | - | ns |
| tSWH | Hold Time, SW0 and SW1 after CLKB $\uparrow$ | 0 | - | 0 | - | 0 | - | ns |
| tPGH | Hold Time, ODD/EVEN and PGA after CLKA $\uparrow$; ODD/EVEN and PGB after CLKB $\uparrow^{(1)}$ | 0 | - | 0 | - | 0 | - | ns |
| tRSTH | Hold Time, $\overline{\mathrm{RST}}$ LOW after CLKA $\uparrow$ or CLKB $\uparrow^{(2)}$ | 5 | - | 6 | - | 7 | - | ns |
| tFSH | Hold Time, FS0 and FS1 after RST HIGH | 4 | - | 4 | - | 4 | - | ns |
| tSKEW1 ${ }^{(3)}$ | Skew Time, between CLKA $\uparrow$ and CLKB $\uparrow$ for $\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}}, \overline{\mathrm{FFA}}$, and $\overline{\mathrm{FFB}}$ | 8 | - | 8 | - | 10 | - | ns |
| tSKEW2 ${ }^{(3)}$ | Skew Time, between CLKA $\uparrow$ and CLKB $\uparrow$ for $\overline{\mathrm{AEA}}, \overline{\mathrm{AEB}}, \overline{\mathrm{AFA}}$, and $\overline{\mathrm{AFB}}$ | 9 | - | 16 | - | 20 | - | ns |

## NOTES:

1. Only applies for a clock edge that does a FIFO read.
2. Requirement to count the clock edge as one of at least four needed to reset a FIFO.
3. Skew time is not a timimg constraint for proper device operation and is only included to illustrate the timing relationship between CLKA cycle and CLKB cycle.

## SWITCHING CHARACTERISTICS OVER RECOMMENDED RANGES OF SUPPLY VOLTAGE AND OPERATING FREE-AIR TEMPERATURE, Cl = 30pF (See Figures 4 through 26)

| Symbol | Parameter | IDT723614L15 |  | IDT723614L20 |  | IDT723614L30 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| tA | Access Time, CLKA $\uparrow$ to A0-A35 and CLKB $\uparrow$ to B0-B35 | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| tWFF | Propagation Delay Time, CLKA $\uparrow$ to $\overline{\text { FFA }}$ and CLKB $\uparrow$ to $\overline{F F B}$ | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| tREF | Propagation Delay Time, CLKA $\uparrow$ to $\overline{\mathrm{EFA}}$ and and CLKB $\uparrow$ to $\overline{E F B}$ | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| tPAE | Propagation Delay Time, CLKA $\uparrow$ to $\overline{\mathrm{AEA}}$ and CLKB $\uparrow$ to $\overline{\mathrm{AEB}}$ | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| tPAF | Propagation Delay Time, CLKA to $\overline{\mathrm{AFA}}$ and CLKB $\uparrow$ to $\overline{\mathrm{AFB}}$ | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| tPMF | Propagation Delay Time, CLKA $\uparrow$ to $\overline{\mathrm{MBF}}$ LOW or MBF2 HIGH and CLKB $\uparrow$ to $\overline{\text { MBF2 }}$ LOW or MBF1 HIGH | 1 | 9 | 1 | 12 | 1 | 15 | ns |
| tPMR | Propagation Delay Time, CLKA $\uparrow$ to B0-B35 ${ }^{(1)}$ and CLKB $\uparrow$ to $\mathrm{A} 0-\mathrm{A} 35^{(2)}$ | 3 | 11 | 3 | 13 | 3 | 15 | ns |
| tPPE $^{(3)}$ | Propagation delay time, CLKB $\uparrow$ to $\overline{\text { PEFB }}$ | 2 | 11 | 2 | 12 | 2 | 13 | ns |
| tMDV | Propagation Delay Time, MBA to A0-A35 valid and SIZ1, SIZ0 to B0-B35 valid | 1 | 11 | 1 | 11.5 | 1 | 12 | ns |
| tPDPE | Propagation Delay Time, A0-A35 valid to $\overline{\text { PEFA }}$ valid; B0-B35 valid to $\overline{\text { PEFB }}$ valid | 3 | 10 | 3 | 11 | 3 | 13 | ns |
| tPOPE | Propagation Delay Time, ODD/EVEN to $\overline{\text { PEFA }}$ and PEFB | 3 | 11 | 3 | 12 | 3 | 14 | ns |
| tPOPB ${ }^{(4)}$ | Propagation Delay Time, ODD/EVEN to parity bits (A8, A17, A26, A35) and (B8, B17, B26, B35) | 2 | 11 | 2 | 12 | 2 | 14 | ns |
| tPEPE | Propagation Delay Time, $\overline{\mathrm{CSA}}, \mathrm{ENA}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}$, MBA, or PGA to $\overline{P E F A} ; \overline{\mathrm{CSB}}, \mathrm{ENB}, \mathrm{W} / \overline{\mathrm{R} B}, \mathrm{SIZ1}$, SIZO, or PGB to $\overline{\text { PEFB }}$ | 1 | 11 | 1 | 12 | 1 | 14 | ns |
| tPEPB ${ }^{(4)}$ | Propagation Delay Time, $\overline{\mathrm{CSA}}, \mathrm{ENA}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}$, MBA, or PGA to parity bits (A8, A17, A26, A35); $\overline{\mathrm{CSB}}, \mathrm{ENB}, \mathrm{W} / \overline{\mathrm{R} B}, \mathrm{SIZ1},$,SIZO , or PGB to parity bits (B8, B17, B26, B35) | 3 | 12 | 3 | 13 | 3 | 14 | ns |
| tRSF | Propagation Delay Time, $\overline{\mathrm{RST}}$ to ( $\overline{\mathrm{MBF}}, \overline{\mathrm{MBF}}$ ) HIGH | 1 | 15 | 1 | 20 | 1 | 30 | ns |
| tEN | Enable Time, $\overline{\mathrm{CSA}}$ and W/R$A$ LOW to A0-A35 active and $\overline{\mathrm{CSB}}$ LOW and $\overline{\mathrm{W}} / \mathrm{RB}$ HIGH to B0-B35 active | 2 | 10 | 2 | 12 | 2 | 14 | ns |
| tDIs | Disable Time, $\overline{\mathrm{CSA}}$ or W/ $\overline{\mathrm{R}} \mathrm{A}$ HIGH to A0-A35 at high impedance and $\overline{\mathrm{CSB}}$ HIGH or $\overline{\mathrm{W}} / \mathrm{RB}$ LOW to B0-B35 at high impedance | 1 | 8 | 1 | 9 | 1 | 11 | ns |

## NOTES:

1. Writing data to the mail1 register when the B0-B35 outputs are active and SIZ1, SIZ0 are HIGH .
2. Writing data to the mail2 register when the A0-A35 outputs are active and MBA is HIGH.
3. Only applies when a new port $B$ bus size is implemented by the rising CLKB edge.
4. Only applies when reading data from a mail register.
BYTE ORDER ON PORT A

| $\overline{\mathrm{BE}}$ | $\mathrm{SIZ1}$ | SIZO |
| :---: | :---: | :---: |
| $\mathbf{X}$ | L | L |


(a) LONG WORD SIZE

(b) WORD SIZE - BIG ENDIAN

| $\overline{\mathrm{BE}}$ | SIZ1 | SIZ0 |
| :---: | :---: | :---: |
| H | L | H |



1st: Read from FIFO1/
Write to FIFO2

B35-B27
B26-B18


B8-B0

(c) WORD SIZE - LITTLE ENDIAN

| $\overline{B E}$ | SIZ1 | SIZO |
| :---: | :---: | :---: |
| L | H | L |



4th: Read from FIFO1/ Write to FIFO2

3146 drw fig 01

Figure 1. Dynamic Bus Sizing

| $\overline{B E}$ | SIZ1 | SIZO |
| :---: | :---: | :---: |
| $\mathbf{H}$ | H | L |


(d) BYTE SIZE — LITTLE ENDIAN

1st: Read from FIFO1/ Write to FIFO2

2nd: Read from FIFO1/ Write to FIFO2

3rd: Read from FIFO1/ Write to FIFO2

4th: Read from FIFO1/ Write to FIFO2

3146 drw fig 01a

Figure 1. Dynamic Bus Sizing (continued)

## DESCRIPTION (CONTINUED)

or both SIZ1 and SIZO are LOW and from the mail2 register when both SIZ1 and SIZ0 are HIGH.The mail1 register flag (MBF1) is set HIGH by a rising CLKB edge when a port $B$ read is selected by $\overline{C S B}, \mathrm{~W} / \overline{\mathrm{RB}}$, and ENB with both $\mathrm{SIZ1}$ and SIZO HIGH. The mail2 register flag (MBF2) is set HIGH by a LOW-to-HIGH transition on CLKA when port A read is selected by $\overline{\mathrm{CSA}}, W / \bar{R} A$, and ENA and MBA is HIGH. The data in the mail register remains intact after it is read and changes only when new data is written to the register.

## DYNAMIC BUS SIZING

The port B bus can be configured in a 36 -bit long word, 18-bit word, or 9-bit byte format for data read from FIFO1 or written to FIFO2. Word- and byte-size bus selections can utilize the most significant bytes of the bus (big endian) or least significant bytes of the bus (little endian). Port B bus size can be changed dynamically and synchronous to CLKB to communicate with peripherals of various bus widths.

The levels applied to the port B bus size select (SIZO, SIZ1) inputs and the big-endian select ( $\overline{\mathrm{BE}}$ ) input are stored on each CLKB LOW-to-HIGH transition. The stored port B bus size selection is implemented by the next rising edge on CLKB according to Figure 1.

Only 36 -bit long-word data is written to or read from the two FIFO memories on the IDT723614. Bus-matching operations are done after data is read from the FIFO1 RAM and before data is written to the FIFO2 RAM. Port B bus sizing does not apply to mail register operations.

## BUS-MATCHING FIFO1 READS

Data is read from the FIFO1 RAM in 36 -bit long word increments. If a long word bus size is implemented, the entire long word immediately shifts to the FIFO1 output register. If
byte or word size is implemented on port B, only the first one or two bytes appear on the selected portion of the FIFO1 output register, with the rest of the long word stored in auxiliary registers. In this case, subsequent FIFO1 reads with the same bus-size implementation output the rest of the long word to the FIFO1 output register in the order shown by Figure1.

Each FIFO1 read with a new bus-size implementation automatically unloads data from the FIFO1 RAM to its output register and auxiliary registers. Therefore, implementing a new port B bus size and performing a FIFO1 read before all bytes or words stored in the auxiliary registers have been read results in a loss of the unread long word data.

When reading data from FIFO1 in byte or word format, the unused B0-B35 outputs remain inactive but static, with the unused FIFO1 output register bits holding the last data value to decrease power consumption.

## BUS-MATCHING FIFO2 WRITES

Data is written to the FIFO2 RAM in 36 -bit long word increments. FIFO2 writes, with a long-word bus size, immediately store each long word in FIFO2 RAM. Data written to FIFO2 with a byte or word bus size stores the initial bytes or words in auxiliary registers. The CLKB rising edge that writes the fourth byte or the second word of long word to FIFO2 also stores the entire long word in FIFO2 RAM. The bytes are arranged in the manner shown in Figure 1.

Each FIFO2 write with a new bus-size implementation resets the state machine that controls the data flow from the auxiliary registers to the FIFO2 RAM. Therefore, implementing a new bus size and performing a FIFO2 write before bytes or words stored in the auxiliary registers have been loaded to FIFO2 RAM results in a loss of data.

## PORT-B MAIL REGISTER ACCESS

In addition to selecting port-B bus sizes for FIFO reads and writes, the port $B$ bus size select (SIZO, SIZ1) inputs also access the mail registers. When both SIZ0 and SIZ1 are HIGH, the mail1 register is accessed for a port B long word read and the mail2 register is accessed for a port B long word write. The mail register is accessed immediately and any bussizing operation that may be underway is unaffected by the mail register access. After the mail register access is complete, the previous FIFO access can resume in the next CLKB cycle. The logic diagram in Figure 2 shows the previous bussize selection is preserved when the mail registers are accessed from port $B$. A port $B$ bus size is implemented on each rising CLKB edge according to the states of SIZO_Q, SIZ1_Q, and BE_Q.

## BYTE SWAPPING

The byte-order arrangement of data read from FIFO1 or data written to FIFO2 can be changed synchronous to the rising edge of CLKB. Byte-order swapping is not available for mail register data. Four modes of byte-order swapping (including no swap) can be done with any data port size selection. The order of the bytes are rearranged within the long word, but the bit order within the bytes remains constant.

Byte arrangement is chosen by the port B swap select (SW0, SW1) inputs on a CLKB rising edge that reads a new long word from FIFO1 or writes a new long word to FIFO2. The byte order chosen on the first byte or first word of a new long
word read from FIFO1 or written to FIFO2 is maintained until the entire long word is transferred, regardless of the SW0 and SW1 states during subsequent writes or reads. Figure 3 is an example of the byte-order swapping available for long words. Performing a byte swap and bus size simultaneously for a FIFO1 read first rearranges the bytes as shown in Figure 3, then outputs the bytes as shown in Figure 1. Simultaneous bus-sizing and byte-swapping operations for FIFO2 writes, first loads the data according to Figure 1, then swaps the bytes as shown in Figure 3 when the long word is loaded to FIFO2 RAM.

## PARITY CHECKING

The port A inputs (A0-A35) and port B inputs (B0-B35) each have four parity trees to check the parity of incoming (or outgoing) data. A parity failure on one or more bytes of the port A data bus is reported by a LOW level on the port parity error flag ( $\overline{\mathrm{PEFA}}$ ). A parity failure on one or more bytes of the port $B$ data input that are valid for the bus-size implementation is reported by a LOW level on the port B parity error flag ( $\overline{\text { PEFB }}$ ).Odd or even parity checking can be selected, and the parity error flags can be ignored if this feature is not desired.

Parity status is checked on each input bus according to the level of the odd/even parity (ODD/EVEN) select input. A parity error on one or more valid bytes of a port is reported by a LOW level on the corresponding port parity error flag ( $\overline{\mathrm{PEFA}}$, $\overline{\text { PEFB }}$ ) output. Port A bytes are arranged as A0-A8, A9-A17,


3146 drw fig 02
Figure 2. Logic Diagrams for SIZO, SIZ1, and $\overline{\mathrm{BE}}$ Register

| SW1 | SW0 |
| :---: | :---: |
| $\mathbf{L}$ | $\mathbf{L}$ |


(a) NO SWAP


| SW1 | SW0 |
| :---: | :---: |
| $H$ | L |


| SW1 | SW0 |
| :---: | :---: |
| $H$ | H |

(d) BYTE-WORD SWAP

(c) WORD SWAP


3146 drw fig 03
Figure 3. Byte Swapping (Long Word Size Example)

A18-A26, and A27-A35. Port B bytes are arranged as B0-B8, B9-B17, B18-B26, and B27-B35, and its valid bytes are those used in a port B bus-size implementation. When odd/even parity is selected, a port parity error flag ( $\overline{\text { PEFA }}, \overline{\text { PEFB }}$ ) is LOW if any byte on the port has an odd/even number of LOW levels applied to the bits.

The four parity trees used to check the A0-A35 inputs are shared by the mail2 register when parity generation is selected for port A reads ( $\mathrm{PGA}=\mathrm{HIGH}$ ). When a port A read from the mail2 register with parity generation is selected with $\overline{C S A}$ LOW, ENA HIGH, W/RA LOW, MBA HIGH, and PGA HIGH, the port A parity error flag ( $\overline{\text { PEFA }})$ is held HIGH regardless of the levels applied to the A0-A35 inputs. Likewise, the parity trees used to check the B0-B35 inputs are shared by the mail1 register when parity generation is selected for port $B$ reads (PGB = HIGH). When a port B read from the mail1 register with parity generation is selected with CSB LOW, ENB HIGH, W/ RB LOW, both SIZO and SIZ1 HIGH, and PGB HIGH, the port B parity error flag ( $\overline{\text { PEFB }}$ ) is held HIGH regardless of the levels applied to the B0-B35 inputs.

## PARITY GENERATION

A HIGH level on the port A parity generate select (PGA) or port B parity generate select (PGB) enables the IDT723614 to generate parity bits for port reads from a FIFO or mailbox register. Port A bytes are arranged as A0-A8, A9-A17, A1826 , and A27-A35, with the most significant bit of each byte used as the parity bit. Port B bytes are arranged as $\mathrm{B} 0-\mathrm{B} 8, \mathrm{B9}-$ B17, B18-B26, and B27-B35, with the most significant bit of
each byte used as the parity bit. A write to a FIFO or mail register stores the levels applied to all nine inputs of a byte regardless of the state of the parity generate select (PGA, PGB) inputs. When data is read from a port with parity generation selected, the lower eight bits of each byte are used to generate a parity bit according to the level on the ODD/ EVEN select. The generated parity bits are substituted for the levels originally written to the most significant bits of each byte as the word is read to the data outputs.

Parity bits for FIFO data are generated after the data is read from SRAM and before the data is written to the output register. Therefore, the port A parity generate select (PGA) and odd/even parity select (ODD/EVEN) have setup and hold time constraints to the port A clock (CLKA) and the port B parity generate select (PGB) and ODD/EVEN have setup and hold-time constraints to the port B clock (CLKB). These timing constraints only apply for a rising clock edge used to read a new long word to the FIFO output register.

The circuit used to generate parity for the mail1 data is shared by the port B bus (B0-B35) to check parity and the circuit used to generate parity for the mail2 data is shared by the port A bus (A0-A35) to check parity. The shared parity trees of a port are used to generate parity bits for the data in a mail register when the port chip select ( $\overline{\mathrm{CSA}}, \overline{\mathrm{CSB}}$ ) is LOW, enable (ENA, ENB) is HIGH, write/read select (W/RA, W/RB) input is LOW, the mail register is selected (MBA is HIGH for port A; both SIZO and SIZ1 are HIGH for port B), and port parity generate select (PGA, PGB) is HIGH. Generating parity for mail register data does not change the contents of the register.


Figure 4. Device Reset Loading the X Register with the Value of Eight


Figure 5. Port-A Write Cycle Timing for FIFO1


NOTE:

1. $\mathrm{SIZO}=\mathrm{HIGH}$ and $\mathrm{SIZ1}=\mathrm{HIGH}$ writes data to the mail2 register

DATA SWAP TABLE FOR LONG-WORD WRITES TO FIFO2

| SWAP MODE |  | DATA WRITTEN TO FIFO2 |  |  |  | DATA READ FROM FIFO2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SW1 | SW0 | B35-27 | B26-18 | B17-B9 | B8-B0 | A35-27 | A26-A18 | A17-A9 | A8-A0 |
| L | L | A | B | C | D | A | B | C | D |
| L | H | D | C | B | A | A | B | C | D |
| H | L | C | D | A | B | A | B | C | D |
| H | H | B | A | D | C | A | B | C | D |

Figure 6. Port-B Long-Word Write Cycle Timing for FIFO2


NOTES:
3146 drw 07

1. $\mathrm{SIZO}=\mathrm{HIGH}$ and $\mathrm{SIZ1}=\mathrm{HIGH}$ writes data to the mail2 register.
2. $\overline{P E F B}$ indicates parity error for the following bytes: B35-B27 and B26-B18 for big-endian bus, and B17-B9 and B-8-B0 for little-endian bus.

## DATA SWAP TABLE FOR WORD WRITES TO FIFO2

| SWAP MODE |  | WRITE <br> NO. | DATA WRITTEN TO FIFO2 |  |  |  | DATA READ FROM FIFO2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | BIG ENDIAN | LITTLE ENDIAN |  |  |  |  |  |
| SW1 | SW0 |  | B35-27 | B26-18 | B17-B9 | B8-B0 | A35-27 | A26-A18 | A17-A9 | A8-A0 |
| L | L |  | 1 | A | B | C | D | A | B | C | D |
|  |  | 2 | C | D | A | B |  |  |  |  |
| L | H | 1 | D | C | B | A | A | B | C | D |
|  |  | 2 | B | A | D | C |  |  |  |  |
| H | L | 1 | C | D | A | B | A | B | C | D |
|  |  | 2 | A | B | C | D |  |  |  |  |
| H | H | 1 | B | A | D | C | A | B | C | D |
|  |  | 2 | D | C | B | A |  |  |  |  |

Figure 7. Port-B Word Write Cycle Timing for FIFO2


## NOTES:

1. $\mathrm{SIZO}=\mathrm{HIGH}$ amd $\mathrm{SIZ1}=\mathrm{HIGH}$ writes data to the mail2 register.
2. PEFB indicates parity error for the following bytes: B35-B27 for big-endian bus and B17-B9 for little-endian bus.

Figure 8. Port-B Byte Write Cycle Timing for FIFO2

## DATA SWAP TABLE FOR BYTE WRITES TO FIFO2

| SWAP MODE |  | WRITE NO. | DATA WRITTEN TO FIFO2 |  | DATA READ FROM FIFO2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | BIGENDIANB35-B27 | LITTLE ENDIAN <br> B8-80 |  |  |  |  |
| SW1 | SW0 |  |  | A35-A27 | A26-A18 | A17-A9 | A8-A0 |
| L | L | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{gathered} \text { A } \\ \text { B } \\ \text { C } \\ \text { D } \end{gathered}$ | $\begin{aligned} & \mathrm{D} \\ & \mathrm{C} \\ & \mathrm{~B} \\ & \mathrm{~A} \end{aligned}$ | A | B | C | D |
| L | H | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \mathrm{D} \\ & \mathrm{C} \\ & \mathrm{~B} \\ & \mathrm{~A} \end{aligned}$ | $\begin{gathered} \mathrm{A} \\ \mathrm{~B} \\ \mathrm{C} \\ \mathrm{D} \end{gathered}$ | A | B | C | D |
| H | L | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{C} \\ & \mathrm{D} \\ & \mathrm{~A} \\ & \mathrm{~B} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{B} \\ & \mathrm{~A} \\ & \mathrm{D} \\ & \mathrm{C} \end{aligned}$ | A | B | C | D |
| H | H | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \mathrm{B} \\ & \mathrm{~A} \\ & \mathrm{D} \\ & \mathrm{C} \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & \mathrm{D} \\ & \mathrm{~A} \\ & \mathrm{~B} \end{aligned}$ | A | B | C | D |

Figure 8. Port-B Byte Write Cycle Timing for FIFO2 (continued)


NOTES:

1. $\mathrm{SIZ0}=\mathrm{HIGH}$ and $\mathrm{SIZ1}=\mathrm{HIGH}$ selects the mail1 register for output on B0-B35.
2. Data read from FIFO1.

## DATA SWAP TABLE FOR FIFO LONG-WORD READS FROM FIFO1

| DATA WRITTEN TO FIFO1 |  |  |  | SWAP MODE |  |  | DATA READ FROM FIFO1 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 | SW1 | SW0 | B35-B27 | B26-B18 | B17-B9 | B8-B0 |  |
| A | B | C | D | L | L | A | B | C | D |  |
| A | B | C | D | L | H | D | C | B | A |  |
| A | B | C | D | H | L | C | D | A | B |  |
| A | B | C | D | H | H | B | A | D | C |  |

Figure 9. Port-B Long-Word Read Cycle Timing for FIFO1


NOTES:

1. $\mathrm{SIZO}=\mathrm{HIGH}$ and $\mathrm{SIZ1}=\mathrm{HIGH}$ selects the mail1 register for output on $\mathrm{B} 0-\mathrm{B} 35$.
2. Unused word B0-B17 or B18-B35 holds last FIFO1 output register data for word-size reads.

DATA SWAP TABLE FOR WORD READS FROM FIFO1

| DATA WRITTEN TO FIFO1 |  |  |  | SWAP MODE |  | $\begin{aligned} & \text { READ } \\ & \text { NO. } \end{aligned}$ | DATA READ FROM FIFO1 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | BIG ENDIAN | LITTLE ENDIAN |  |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 |  |  | SW1 | SW0 | B35-B27 | B26-B18 | B17-B9 | B8-B0 |
| A | B | C | D | L | L |  | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { C } \end{aligned}$ | $\begin{aligned} & \mathrm{B} \\ & \mathrm{D} \end{aligned}$ | $\begin{aligned} & \text { C } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \mathrm{D} \\ & \mathrm{~B} \end{aligned}$ |
| A | B | C | D | L | H |  | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{D} \\ & \mathrm{~B} \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \mathrm{B} \\ & \mathrm{D} \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { C } \end{aligned}$ |
| A | B | C | D | H | L | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \mathrm{D} \\ & \mathrm{~B} \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { C } \end{aligned}$ | $\begin{aligned} & \mathrm{B} \\ & \mathrm{D} \end{aligned}$ |
| A | B | C | D | H | H | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{B} \\ & \mathrm{D} \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { C } \end{aligned}$ | $\begin{aligned} & \mathrm{D} \\ & \mathrm{~B} \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & \mathrm{~A} \end{aligned}$ |

Figure 10. Port-B Word Read Cycle Timing for FIFO1


NOTES:

1. $\mathrm{SIZO}=\mathrm{HIGH}$ and $\mathrm{SIZ1}=\mathrm{HIGH}$ selects the mail1 register for output on B0-B35.
2. Unused bytes hold last FIFO1 output regisger data for byte-size reads.

DATA SWAP TABLE FOR BYTE READS FROM FIFO1

| DATA WRITTEN TO FIFO 1 |  |  |  | SWAP MODE |  | $\begin{gathered} \text { READ } \\ \text { NO. } \end{gathered}$ | DATA READ FROM FIFO 1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | BIG | LITTLE |  |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 |  |  | SW1 | SWO |  | B35-B27 | B8-B0 |
| A | B | C | D | L | L | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{A} \\ & \mathrm{~B} \\ & \mathrm{C} \\ & \mathrm{D} \end{aligned}$ | $\begin{aligned} & \mathrm{D} \\ & \mathrm{C} \\ & \mathrm{~B} \\ & \mathrm{~A} \end{aligned}$ |
| A | B | C | D | L | H | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \mathrm{D} \\ & \mathrm{C} \\ & \mathrm{~B} \\ & \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { B } \\ & \text { C } \\ & \text { D } \end{aligned}$ |
| A | B | C | D | H | L | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \text { C } \\ & \text { D } \\ & \text { A } \\ & \text { B } \end{aligned}$ | $\begin{aligned} & \text { B } \\ & \text { A } \\ & \text { D } \\ & \text { C } \end{aligned}$ |
| A | B | C | D | H | H | 1 2 3 4 | $\begin{aligned} & \text { B } \\ & \text { A } \\ & \text { D } \\ & \text { C } \end{aligned}$ | $\begin{aligned} & \text { C } \\ & \text { D } \\ & \text { A } \\ & \text { B } \end{aligned}$ |

Figure 11. Port-B Byte Read Cycle Timing for FIFO1


NOTE:

1. Read from FIFO2..

Figure 12. Port-A Read Cycle Timing for FIFO2


## NOTES:

1. tsKEW1 is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{E F B}$ to transition HIGH in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tskEw1, then the transition of $\overline{\mathrm{EFB}}$ HIGH may occur one CLKB cycle later than shown.
2. Port-B size of long word is selected for FIFO1 read by SIZ1 = LOW, SIZO = LOW. If port-B size is word or byte, $\overline{\mathrm{EFB}}$ is set LOW by the last word or byte read from FIFO1, respectively.

Figure13. $\overline{\mathrm{EFB}}$ Flag Timing and First Data Read when FIFO1 is Empty


NOTES:

1. tsKEW1 is the minimum time between a rising CLKB edge and a rising CLKA edge for $\overline{E F A}$ to transition HIGH in the next CLKA cycle. If the time between the rising CLKB edge and rising CLKA edge is less than tsKEW1, then the transition of EFA HIGH may occur one CLKA cycle later than shown.
2. Port B size of long word is selected for FIFO2 write by SIZ1 = LOW, SIZO = LOW. If port B size is word or byte tskEw is referenced to the rising CLKB edge that writes the last word or byte of the long word, respectively.

Figure 14. $\overline{\text { EFA }}$ Flag Timing and First Data Read when FIFO2 is Empty


## NOTES:

1. tsKEw is the minimum time between a rising CLKB edge and a rising CLKA edge for $\overline{F F A}$ to transition HIGH in the next CLKA cycle. If the time between the rising CLKB edge and rising CLKA edge is less than tskEw1, then FFA may transition HIGH one CLKA cycle later than shown.
2. Port B size of long word is selected for FIFO1 read by SIZ1 = LOW, SIZO = LOW. If port B size is word or byte, tskEW1 is referenced from the rising CLKB edge that reads the last word or byte of the long word, respectively.

Figure 15. $\overline{\text { FFA }}$ Flag Timing and First Available Write when FIFO1 is Full.


## NOTES:

1. tSKEW1 is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{F F B}$ to transition HIGH in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tSKEW1, then FFB may transition HIGH one CLKB cycle later than shown.
2. Port B size of long word is selected for FIFO2 write by SIZ1 = LOW, SIZO = LOW. If port B size is word or byte, $\overline{\mathrm{FFB}}$ is set LOW by the last word or byte write of the long word, respectively.

Figure 16. $\overline{\text { FFB }}$ Flag Timing and First Available Write when FIFO2 is Full


## NOTES:

1. tSKEW2 is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{\mathrm{AE}} \bar{B}$ to transition HIGH in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tSKEW2, then $\overline{\mathrm{AEB}}$ may transition HIGH one CLKB cycle later than shown.
2. FIFO1 Write ( $\overline{\mathrm{CSA}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R} A}=\mathrm{HIGH}, \mathrm{MBA}=\mathrm{LOW})$, FIFO1 read ( $\overline{\mathrm{CSB}}=\mathrm{LOW}, W / \overline{\mathrm{R} B}=\mathrm{LOW}, \mathrm{MBB}=\mathrm{LOW})$.
3. Port B size of long word is selected for FIFO1 read by SIZ1 = LOW, SIZ0 = LOW. If port B size is word or byte, $\overline{\mathrm{AEB}}$ is set LOW by the last word or byte read of the long word, respectively.

Figure 17. Timing for $\overline{\mathrm{AEB}}$ when FIFO1 is Almost Empty


## NOTES:

1. tsKEW2 is the minimum time between a rising CLKB edge and a rising CLKA edge for $\overline{\mathrm{AEA}}$ to transition HIGH in the next CLKA cycle. If the time between the rising CLKB edge and rising CLKA edge is less than tsKEw2, then $\overline{A E A}$ may transition HIGH one CLKA cycle later than shown.
2. FIFO2 Write ( $\overline{\mathrm{CSB}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{B}=\mathrm{HIGH}, \mathrm{MBB}=\mathrm{LOW})$, FIFO2 read ( $\overline{\mathrm{CSA}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R} A}=\mathrm{LOW}, \mathrm{MBA}=\mathrm{LOW})$.
3. Port B size of long word is selected for FIFO2 write by SIZ1 = LOW, SIZ0 = LOW. If port B size is word or byte, tskew2 is referenced from the rising CLKB edge that writes the last word or byte of the long word, respectively.

Figure 18. Timing for $\overline{\text { AEA }}$ when FIFO2 is Almost Empty


## NOTES:

1. tSKEW2 is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{\mathrm{AFA}}$ to transition HIGH in the next CLKA cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tSKEW2, then $\overline{\mathrm{AFA}}$ may transition HIGH one CLKB cycle later than shown.
2. FIFO1 Write ( $\overline{\mathrm{CSA}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}=\mathrm{HIGH}, \mathrm{MBA}=\mathrm{LOW}$ ), FIFO1 read ( $\overline{\mathrm{CSB}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{RB}}=\mathrm{LOW}, \mathrm{MBB}=\mathrm{LOW}$ ).
3. Port $B$ size of long word is selected for FIFO1 read by SIZ1 $=\mathrm{LOW}, \mathrm{SIZO}=\mathrm{LOW}$. If port $B$ size is word or byte, tSkEW2 is referenced from the last word or byte read of the long word, respectively.

Figure 19. Timing for $\overline{\text { AFA }}$ when FIFO1 is Almost Full


## NOTES:

1. tSKEW2 is the minimum time between a rising CLKB edge and a rising CLKA edge for $\overline{\mathrm{AFB}}$ to transition HIGH in the next CLKB cycle. If the time between the rising CLKB edge and rising CLKA edge is less than tSKEw2, then AFB may transition HIGH one CLKA cycle later than shown.
2. FIFO2 Write ( $\overline{\mathrm{CSB}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{B}=\mathrm{HIGH}, \mathrm{MBB}=\mathrm{LOW}), \mathrm{FIFO} 2$ read $(\overline{\mathrm{CSA}}=\mathrm{LOW}, W / \overline{\mathrm{RA}}=\mathrm{LOW}, \mathrm{MBA}=\mathrm{LOW})$.
3. Port $B$ size of long word is selected for FIFO2 write by $\mathrm{SIZ1}=\mathrm{LOW}, \mathrm{SIZO}=\mathrm{LOW}$. If port $B$ size is word or byte, $\overline{\mathrm{AFB}}$ is set LOW by the last word or byte read of the long word, respectively.

Figure 20. Timing for $\overline{\mathrm{AFB}}$ when FIFO2 is Almost Full


NOTE:

1. Port $B$ parity generation off $(\mathrm{PGB}=\mathrm{LOW})$.

Figure 21. Timing for Mail1 Register and $\overline{\text { MBF1 }}$ Flag


NOTE:

1. Port-A parity generation off $(\mathrm{PGA}=\mathrm{LOW})$.

Figure 22. Timing for Mail2 Register and MBF2 Flag


Figure 23. ODD/EVEN. W/RA, MBA, and PGA to PEFA Timing


Figure 24. ODD/EVEN. W/RB, SIZ1, SIZO, and PGB to PEFB Timing


NOTE:

1. ENA is HIGH.

Figure 25. Parity Generation Timing when Reading from the Mail2 Register


Figure 26. Parity Generation Timing when Reading from the Mail1 Register

## TYPICAL CHARACTERISTICS

SUPPLY CURRENT
CLOCK FREQUENCY


3146 drw 27
Figure 27

## CALCULATING POWER DISSIPATION

The ICC(f) current for the graph in Figure 27 was taken while simultaneously reading and writing the FIFO on the IDT723614 with CLKA and CLKB set to fs. All data inputs and data outputs change state during each clock cycle to consume the highest supply current. Data outputs were disconnected to normalize the graph to a zero-capacitance load. Once the capacitive lead per data-output channel is known, the power dissipation can be calculated with the equation below.

With IcC(f) taken from Figure 28, the maximum power dissipation (PT) of the IDT723614 can be calculated by:
$\mathrm{PT}=\operatorname{Vcc} \times \operatorname{Icc}(f)+\sum\left(\operatorname{CL} \times \operatorname{VoH}^{2} \times\right.$ fo $)$
where:

| CL | $=$ | output capacitance load |
| :--- | :--- | :--- |
| $\mathrm{fo}_{\mathrm{o}}$ | $=$ | switching frequency of an output |
| VoH | $=$ | output high level voltage |

When no reads or writes are occurring on the IDT723614, the power dissipated by a single clock (CLKA or CLKB) input running at frequency fs is calculated by:

$$
\text { PT=VCC x fs x } 0.290 \mathrm{~mA} / \mathrm{MHz}
$$

## PARAMETER MEASUREMENT INFORMATION



## LOAD CIRCUIT



VOLTAGE WAVEFORMS SETUP AND HOLD TIMES

VOLTAGE WAVEFORMS PULSE DURATIONS


VOLTAGE WAVEFORMS
PROPAGATION DELAY TIMES

NOTE:

1. Includes probe and jig capacitance.

Figure 28. Load Circuit and Voltage Waveforms

## ORDERING INFORMATION




[^0]:    3146 drw 02
    *
    Electrical pin 1 in center of beveled edge. Pin 1 identifier in corner.

