Integrated Device Technology, Inc.

CMOS SyncFIFO ${ }^{\mathrm{mw}}$
IDT723631
$512 \times 36$, $1024 \times 36$, $2048 \times 36$

## FEATURES:

- Free-running CLKA and CLKB can be asynchronous or coincident (permits simultaneous reading and writing of data on a single clock edge)
- Clocked FIFO buffering data from Port A to Port B
- Storage capacity: IDT723631-512×36

IDT723641-1024 x 36
IDT723651-2048 x 36

- Synchronous read retransmit capability
- Mailbox register in each direction
- Programmable Almost-Full and Almost-Empty flags
- Microprocessor interface control logic
- Input-Ready (IR) and Almost-Full ( $\overline{\mathrm{AF}}$ ) flags synchronized by CLKA
- Output-Ready (OR) and Almost-Empty ( $\overline{\mathrm{AE}}$ ) flags synchronized by CLKB
- Low-power 0.8-micron advanced CMOS technology
- Supports clock frequencies up to 67 MHz
- Fast access times of 11 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


## DESCRIPTION:

The IDT723631/723641/723651 is a monolithic highspeed, low-power, CMOS clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read access times as fast as 12 ns. The $512 / 1024 / 2048 \times 36$ dual-port SRAM FIFO buffers data from port A to Port B. The FIFO memory has retransmit capability, which allows previously read data to be accessed again. The 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

## FUNCTIONAL BLOCK DIAGRAM



## DESCRIPTION (CONTINUED)

stored in memory. Communication between each port may take place with two 36-bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Two or more devices may be used in parallel to create wider data paths. Expansion is also possible in word depth.

The IDT723631/723641/723651 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 continuous clocks for each port are independent
of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple interface between microprocessors and/or buses with synchronous control.

The input-ready (IR) flag and almost-full ( $\overline{\mathrm{AF}}$ ) flag of the FIFO are two-stage synchronized to CLKA. The output-ready (OR) flag and almost-empty ( $\overline{\mathrm{AE}}$ ) flag of the FIFO are twostage synchronized to CLKB. Offset values for the almost-full and almost empty flags of the FIFO can be programmed from port A or through a serial input.

## PIN CONFIGURATION



```
*
Electrical pin 1 in center of beveled edge. Pin 1 identifier in corner.
```


## Notes:

1. NC - No internal connection
2. Uses Yamaichi socket IC51-1324-828

## PIN CONFIGURATION (CONTINUED)



## TQFP (PN120-1, order code: PF) <br> TOP VIEW

## Note:

1. NC - No internal connection

## PIN DESCRIPTION

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| A0-A35 | Port-A Data | I/O | 36-bit bidirectional data port for side A. |
| $\overline{\mathrm{AE}}$ | Almost-Empty Flag | O | Programmable flag synchronized to CLKB. It is LOW when the number of words in the FIFO is less than or equal to the value in the almost-empty register (X). |
| $\overline{\mathrm{AF}}$ | Almost-Full Flag. | O | Programmable flag synchronized to CLKA. It is LOW when the number of empty locations in the FIFO is less than or equal to the value in the almost-full offset register (Y). |
| B0-B35 | Port-B Data. | I/O | 36-bit bidirectional data port for side B. |
| CLKA | Port-A Clock | I | CLKA is a continuous clock that synchronizes all data transfers through port-A and may be aynchronous or coincident to CLKB. IR ${ }^{-}$and $\overline{\mathrm{AF}}$ are synchronous to the LOW-to-HIGH transition of CLKA. |
| CLKB | Port-B Clock | 1 | CLKB is a continuous clock that synchronizes all data transfers through port-B and may be asynchronous or coincident to CLKA. OR and $\overline{\mathrm{AE}}$ are synchro nous to the LOW-to-HIGH transition of CLKB. |
| $\overline{\mathrm{CSA}}$ | Port-A Chip Select | 1 | $\overline{\mathrm{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 $\overline{\mathrm{CSA}}$ is HIGH. |
| $\overline{\mathrm{CSB}}$ | Port-B Chip Select | I | $\overline{\mathrm{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 $\overline{\mathrm{CSB}}$ is HIGH. |
| ENA | Port-A Enable | 1 | 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 | I | ENB must be HIGH to enable a LOW-to-HIGH transition of CLKB to read or write data on port-B. |
| $\begin{aligned} & \text { FS1/ } \overline{\text { SEN, }} \\ & \text { FS0/SD } \end{aligned}$ | Flag-Offset Select 1/ Serial Enable, Flag Offset 0 / Serial Data | I | FS1/ $\overline{\text { SEN }}$ and FS0/SD are dual-purpose inputs used for flag offset register programming. During a device reset, FS1/SEN and FS0/SD selects the flag offset programming method. Three offset register programming methods are available: automatically load one of two preset values, parallel load from port A, and serial load. When serial load is selected for flag offset register programming, FS1/SEN is used as an enable synchronous to the LOW-to-HIGH transition of CLKA. When FS1/SEN is LOW, a rising edge on CLKA load the bit present on FSO/SD into the $X$ and $Y$ registers. The number of bit writes required to program the offset registers is $18 / 20 / 22$. The first bit write stores the Y-register MSB and the last bit write stores the X-register LSB. |
| IR | Input-Ready Flag | O | IR is synchronized to the LOW-to-HIGH transition of CLKA. When IR is LOW, the FIFO is full and writes to its array are disabled. When the FIFO is in retransmit mode, IR indicates when the memory has been filled to the point of the retransmit data and prevents further writes. IR is set LOW during reset and is set HIGH after reset. |
| MBA | Port-A Mailbox Select | 1 | A HIGH level chooses a mailbox register for a port-A read or write operation. |
| MBB | Port-B Mailbox Select | I | A HIGH level chooses a mailbox register for a port-B read or write operation. When the B0-B35 outputs are active, a HIGH level on MBB selects data from the mail1 register for output and a LOW level selects FIFO data for output. |
| $\overline{\text { MBF1 }}$ | Mail1 Register Flag | O | $\overline{\text { MBF1 }}$ is set LOW by the LOW-to-HIGH transition of CLKA that writes data to the mail1 register. MBF1 is set HIGH by a LOW-to-HIGH transition of CLKB when a port-B read is selected and MBB is HIGH. MBF1 is set HIGH by a reset. |

## PIN DESCRIPTION (CONTINUED)

| Symbol | Name | I/O | Description |
| :---: | :--- | :---: | :--- |

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

| Symbol | Rating | Commercial | Unit |
| :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage Range | -0.5 to 7 | V |
| $\mathrm{V} \mathrm{I}^{(2)}$ | Input Voltage Range | -0.5 to Vcc+0.5 | V |
| $\mathrm{VO}^{(2)}$ | Output Voltage Range | -0.5 to Vcc+0.5 | V |
| IIK | Input Clamp Current, (Vı < 0 or $\mathrm{VI}>\mathrm{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 400$ | 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{IOH}=-4 \mathrm{~mA}$ |  |  | 2.4 |  |  | V |
| Vol | $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  |  |  | 0.5 | V |
| ILI | $\mathrm{VI}=\mathrm{Vcc}$ or 0 |  |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| ILO | $\mathrm{Vo}=\mathrm{Vcc}$ or 0 |  |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| Icc | V = Vcc -0.2 V or 0 |  |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{lcC}{ }^{(2)}$ | $\mathrm{Vcc}=5.5 \mathrm{~V}$, One Input at 3.4 V , Other Inputs at Vcc or GND | $\overline{\mathrm{CSA}}=\mathrm{V} \mathrm{H}$ | A0-A35 |  | 0 |  | mA |
|  |  | $\overline{\mathrm{CSB}}=\mathrm{V}$ IH | B0-B35 |  | 0 |  |  |
|  |  | $\overline{\mathrm{CSA}}=\mathrm{VIL}$ | A0-A35 |  |  | 1 |  |
|  |  | $\overline{\mathrm{CSB}}=\mathrm{VIL}$ | B0-35 |  |  | 1 |  |
|  |  | All Other Inputs |  |  |  | 1 |  |
| Cln | $\mathrm{VI}=0, \quad \mathrm{f}=1 \mathrm{MHz}$ |  |  |  | 4 |  | pF |
| Cout | $\mathrm{Vo}=0, \quad \mathrm{f}=1 \mathrm{MHZ}$ |  |  |  | 8 |  | pF |

NOTES:

1. All typical values are at $\mathrm{VCC}=5 \mathrm{~V}, \mathrm{TA}=25^{\circ} \mathrm{C}$.
2. This is the supply current when each input is at least one of the specified TTL voltage levels rather than 0 V or VCC

## AC ELECTRICAL CHARACTERISTICS OVER RECOMMENDED RANGES OF SUPPLY VOLTAGE AND OPERATING FREE-AIR TEMPERATURE

| Symbol | Parameter | IDT723631L15 IDT723641L15 IDT723651L15 |  | $\begin{array}{\|l\|} \text { IDT723631L20 } \\ \text { IDT723641L20 } \\ \text { IDT723651L20 } \\ \hline \end{array}$ |  | $\begin{array}{\|l} \text { IDT723631L30 } \\ \text { IDT723641L30 } \\ \text { IDT723651L30 } \\ \hline \end{array}$ |  | 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 or CLKB HIGH | 6 | - | 8 | - | 12 | - | ns |
| tCLKL | Pulse Duration, CLKA or CLKB LOW | 6 | - | 8 | - | 12 | - | ns |
| tDS | Setup Time, A0-A35 before CLKA $\uparrow$ and B0-B35 before CLKB $\uparrow$ | 5 | - | 6 | - | 7 | - | ns |
| tENS1 | Setup Time, ENA to CLKA $\uparrow$; ENB to CLKB $\uparrow$ | 5 | - | 6 | - | 7 | - | ns |
| tENS2 | Setup Time, $\overline{C S A}, W / \bar{R} A$, and MBA to CLKA $\uparrow$; $\overline{\mathrm{CSB}}, \overline{\mathrm{W}} / \mathrm{RB}$, and MBB to CLKB $\uparrow$ | 7 | - | 7.5 | - | 8 | - | ns |
| tRMS | Setup Time, RTM and RFM to CLKB $\uparrow$ | 6 | - | 6.5 | - | 7 | - | ns |
| tRSTS | Setup Time, $\overline{\text { RST }}$ LOW before CLKA $\uparrow$ or CLKB ${ }^{(1)}$ | 5 | - | 6 | - | 7 | - | ns |
| tFSS | Setup Time, FS0 and FS1 before $\overline{\text { RST }}$ HIGH | 9 | - | 10 | - | 11 | - | ns |
| tSDS ${ }^{(2)}$ | Setup Time, FS0/SD before CLKA $\uparrow$ | 5 | - | 6 | - | 7 | - | ns |
| tSENS ${ }^{(2)}$ | Setup Time, FS1//SEN before CLKA $\uparrow$ | 5 | - | 6 | - | 7 | - | ns |
| tDH | Hold Time, A0-A35 after CLKA $\uparrow$ and B0-B35 after CLKB $\uparrow$ | 0 | - | 0 | - | 0 | - | ns |
| tENH1 | Hold Time, ENA after CLKA $\uparrow$; ENB after CLKB $\uparrow$ | 0 | - | 0 | - | 0 | - | ns |
| tENH2 | Hold Time, $\overline{\mathrm{CSA}}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}$, and MBA after CLKA $\uparrow$; $\overline{\mathrm{CSB}}, \mathrm{W} / \mathrm{RB}$, and MBB after CLKB $\uparrow$ | 0 | - | 0 | - | 0 | - | ns |
| tRMH | Hold Time, RTM and RFM after CLKB $\uparrow$ | 0 | - | 0 | - | 0 | - | ns |
| tRSTH | Hold Time, $\overline{\mathrm{RST}}$ LOW after CLKA $\uparrow$ or CLKB $\uparrow^{(1)}$ | 5 | - | 6 | - | 7 | - | ns |
| tFSH | Hold Time, FS0 and FS1 after $\overline{\mathrm{RST}}$ HIGH | 0 | - | 0 | - | 0 | - | ns |
| tSPH ${ }^{(2)}$ | Hold Time, FS1/\SEN HIGH after $\overline{\text { RST }}$ HIGH | 0 | - | 0 | - | 0 | - | ns |
| tSDH ${ }^{(2)}$ | Hold Time, FS0/SD after CLKA $\uparrow$ | 0 | - | 0 | - | 0 | - | ns |
| tSENH ${ }^{(2)}$ | Hold Time, FS1/SEN after CLKA $\uparrow$ | 0 | - | 0 | - | 0 | - | ns |
| tSKEW1 ${ }^{(3)}$ | Skew Time, between CLKA $\uparrow$ and CLKB $\uparrow$ for OR and IR | 9 | - | 11 | - | 13 | - | ns |
| tSKEW2 ${ }^{(3)}$ | Skew Time, between CLKA $\uparrow$ and CLKB $\uparrow$ for $\overline{\mathrm{AE}}$ and $\overline{\mathrm{AF}}$ | 12 | - | 16 | - | 20 | - | ns |

## NOTES:

1. Requirement to count the clock edge as one of at least four needed to reset a FIFO.
2. Only applies when serial load method is used to program flag offset registers.
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.

## AC ELECTRICAL CHARACTERISTICS

| Symbol | Parameter | IDT723631L15 IDT723641L15 IDT723651L15 |  | $\begin{array}{\|l\|} \text { IDT723631L20 } \\ \text { IDT723641L20 } \\ \text { IDT723651L20 } \end{array}$ |  | IDT723631L30 <br> IDT723641L30 <br> IDT723651L30 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| fs | Clock Frequency, CLKA or CLKB | - | 66.7 | - | 50 | - | 33.4 | MHz |
| tA | Access Time, CLKB $\uparrow$ to B0-B35 | 3 | 11 | 3 | 13 | 3 | 15 | ns |
| tPIR | Propagation Delay Time, CLKA $\uparrow$ to IR | 1 | 8 | 1 | 10 | 1 | 12 | ns |
| tPOR | Propagation Delay Time, CLKB $\uparrow$ to OR | 1 | 8 | 1 | 10 | 1 | 12 | ns |
| tPAE | Propagation Delay Time, CLKB $\uparrow$ to $\overline{\mathrm{AE}}$ | 1 | 8 | 1 | 10 | 1 | 12 | ns |
| tPAF | Propagation Delay Time, CLKA $\uparrow$ to $\overline{\mathrm{AF}}$ | 1 | 8 | 1 | 10 | 1 | 12 | ns |
| tPMF | Propagation Delay Time, CLKA $\uparrow$ to $\overline{\mathrm{MBF}}$ LOW or MBF2 HIGH and CLKB $\uparrow$ to $\overline{\mathrm{MBF2}}$ LOW or MBF1 HIGH | 0 | 8 | 0 | 10 | 0 | 12 | ns |
| tPMR | Propagation Delay Time, CLKA $\uparrow$ to B0-B35 ${ }^{(1)}$ and CLKB $\uparrow$ to $\mathrm{A} 0-\mathrm{A} 35^{(2)}$ | 3 | 13.5 | 3 | 15 | 3 | 17 | ns |
| tMDV | Propagation Delay Time, MBB to B0-B35 Valid | 3 | 13 | 3 | 15 | 3 | 17 | ns |
| tRSF | Propagation Delay Time, $\overline{\mathrm{RST}}$ LOW to $\overline{\mathrm{AE}} \mathrm{LOW}$ and $\overline{\mathrm{AF}} \mathrm{HIGH}$ | 1 | 15 | 1 | 20 | 1 | 30 | ns |
| tEN | Enable Time, $\overline{\mathrm{CSA}}$ and W/RA LOW to A0-A35 Active and $\overline{\mathrm{CSB}}$ LOW and $\overline{\mathrm{W}} / \mathrm{RB}$ HIGH to B0-B35 Active | 2 | 12 | 2 | 13 | 2 | 14 | ns |
| tDIS | Disable Time, $\overline{\mathrm{CSA}}$ or W/쥬A HIGH to A0-A35 at high impedance and $\overline{\mathrm{CSB}} \mathrm{HIGH}$ or $\overline{\mathrm{W}} / \mathrm{RB}$ LOW to B0-B35 at high impedance | 1 | 8 | 1 | 10 | 1 | 11 | ns |

## NOTES:

1. Writing data to the mail1 register when the B0-B35 outputs are active and MBB is HIGH .
2. Writing data to the mail2 register when the AO-A35 outputs are active and MBA is HIGH.

## SIGNAL DESCRIPTION

## RESET

The IDT723631/723641/723651 is reset by taking the reset ( $\overline{\mathrm{RST}}$ ) input LOW for at least four port-A clock (CLKA) and four port-B (CLKB) LOW-to-HIGH transitions. The reset input may switch asynchronously to the clocks. A reset initializes the memory read and write pointers and forces the input-ready (IR) flag LOW, the output-ready (OR) flag LOW, the almost-empty ( $\overline{\mathrm{AE}}$ ) flag LOW, and the almost-full ( $\overline{\mathrm{AF}}$ ) flag HIGH. Resetting the device also forces the mailbox flags ( $\overline{\mathrm{MBF}} 1, \overline{\mathrm{MBF}}$ ) HIGH . After a FIFO is reset, its input-ready flag is set HIGH after at least two clock cycles to begin normal operation. A FIFO must be reset after power up before data is written to its memory.

## ALMOST-EMPTY FLAG AND ALMOST-FULL FLAG OFFSET PROGRAMMING

Two registers in the IDT723631/723641/723651 are used to hold the offset values for the almost-empty and almost full flags. The almost-empty ( $\overline{\mathrm{AE}}$ ) flag offset register is labeled X , and the almost-full ( $\overline{\mathrm{AF}}$ ) flag offset register is labeled Y . The offset register can be loaded with a value in three ways: one of two preset values are loaded into the offset registers, parallel load from port A, or serial load. The offset register programming mode is chosen by the flag select (FS1, FSO) inputs during a LOW-to-HIGH transition on the $\overline{\text { RST input (See }}$ Table 1).

## PRESET VALUES

If the preset value of 8 or 64 is chosen by the FS1 and FS0 inputs at the time of a RST LOW-to-HIGH transition according to Table 1, the preset value is automatically loaded into the $X$ and Y registers. No other device initialization is necessary to begin normal operation, and the IR flag is set HIGH after two LOW-to-HIGH transitions on CLKA.

## PARALLEL LOAD FROM PORT A

To program the $X$ and $Y$ registers from port $A$, the device is reset with FS0 and FS1 LOW during the LOW-to-HIGH transition of RST. After this reset is complete, the IR flag is set HIGH after two LOW-to-HIGH transitions on CLKA. The first two writes to the FIFO do not store data in its memory but load the offset registers in the order $Y, X$. Each offset register of the IDT723631, IDT723641, and IDT723651 uses port-A inputs (A8-A0), (A9-A0), and (A10-A0), respectively. The highest number input is used as the most significant bit of the binary number in each case. Each register value can be programmed from 1 to 508 (IDT723631), 1 to 1020 (IDT723641), and 1 to 2044 (IDT723651). After both offset registers are programmed from port A, subsequent FIFO writes store data in the SRAM.

## SERIAL LOAD

To program the $X$ and $Y$ registers serially, the device is reset with $\mathrm{FS} 0 / \mathrm{SD}$ and $\mathrm{FS} 1 /$ SEN HIGH during the LOW-toHIGH transition of RST. After this reset is complete, the $X$ and

Y register values are loaded bitwise through the FSO/SD input on each LOW-to-HIGH transition of CLKA that the FS1/SEN input is LOW. Eighteen-, 20-, or 22-bit writes are needed to complete the programming for the IDT723631, IDT723641, or IDT723651, respectively. The first-bit write stores the most significant bit of the Y register, and the last-bit write stores the least significant bit of the X register. Each register value can be programmed from 1 to 508 (IDT723631), 1 to 1020 (IDT723641), or 1 to 2044 (IDT723651).

When the option to program the offset registers serially is chosen, the input-ready (IR) flag remains LOW until all register bits are written. The IR flag is set HIGH by the LOW-toHIGH transition of CLKA after the last bit is loaded to allow normal FIFO operation.

## FIFO WRITE/READ OPERATION

The state of the port-A data (AO-A35) outputs is controlled by the port-A chip select ( $\overline{\mathrm{CSA}}$ ) and the port-A write/read select ( $\mathrm{W} / \overline{\mathrm{R}} \mathrm{A}$ ). The A0-A35 outputs are in the high-impedance state when either $\overline{\mathrm{CSA}}$ or $\mathrm{W} / \overline{\mathrm{R}} \mathrm{A}$ 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 the FIFO from the A0-A35 inputs on a LOW-to-HIGH transition of CLKA when $\overline{\mathrm{CSA}}$ and the port-A mailbox select (MBA) are LOW, W/RA, the port-A enable (ENA), and the input-ready (IR) flag are HIGH (see Table 2). Writes to the FIFO are independent of any concurrent FIFO read.

The port-B control signals are identical to those of port-A with the exception that the port-B write/read select ( $\bar{W} / R B$ ) is the inverse of the port-A write/read select ( $W / \bar{R} A$ ). The state of the port-B data (B0-B35) outputs is controlled by the port$B$ chip select ( $\overline{\mathrm{CSB}}$ ) and the port-B write/read select ( $\overline{\mathrm{W}} / \mathrm{RB}$ ). The B0-B35 outputs are in the high-impedance state when either $\overline{\mathrm{CSB}}$ is HIGH or $\overline{\mathrm{W}} / \mathrm{RB}$ is LOW. The B0-B35 outputs are active when $\overline{\mathrm{CSB}}$ is LOW and $\overline{\mathrm{W}} / \mathrm{RB}$ is HIGH.

Data is read from the FIFO to its output register on a LOW-to-HIGH transition of CLKB when CSB and the port-B mailbox select (MBB) are LOW, W/RB, the port-B enable (ENB), and the output-ready (OR) flag are HIGH (see Table 3). Reads from the FIFO are independent of any concurrent FIFO writes.

The setup- and hold-time constraints to the port clocks for the port-chip selects and write/read selects are only for enabling write and read operations and are not related to high-

| FS1 | FSO | $\overline{\mathrm{RST}}$ | $X$ and $Y$ Registers ${ }^{(1)}$ |
| :---: | :---: | :---: | :---: |
| H | H | $\uparrow$ | Serial Load |
| H | L | $\uparrow$ | 64 |
| L | H | $\uparrow$ | 8 |
| L | L | $\uparrow$ | Parallel Load From Port A |

NOTE:

1. X register holds the offset for AE ; Y register holds the offset for AF .

Table 1. Flag Programming
impedance control of the data outputs. If a port enable is LOW during a clock cycle, the port chip select and write/read select may change states during the setup- and hold time window of the cycle.

When the output-ready (OR) flag is LOW, the next data word is sent to the FIFO output register automatically by the CLKB LOW-to-HIGH transition that sets the output-ready flag HIGH. When OR is HIGH, an available data word is clocked to the FIFO output register only when a FIFO read is selected by the port-B chip select ( $\overline{\mathrm{CSB}}$ ), write/read select ( $\overline{\mathrm{W}} / \mathrm{RB}$ ), enable (ENB), and mailbox select (MBB).

## SYNCHRONIZED FIFO FLAGS

Each IDT723631/723641/723651 FIFO flag is synchronized to its port clock through at least two flip-flop stages. This is done to improve the flags' reliability by reducing the probability of metastable events on their outputs when CLKA and CLKB operate asynchronously to one another. OR and $\overline{\mathrm{AE}}$ are synchronized to CLKB. IR and $\overline{\mathrm{AF}}$ are synchronized to CLKA. Table 4 shows the relationship of each flag to the number of words stored in memory.

## OUTPUT-READY FLAG (OR)

The output-ready flag of a FIFO is synchronized to the port clock that reads data from its array (CLKB). When the outputready flag is HIGH, new data is present in the FIFO output
register. When the output-ready flag is LOW, the previous data word is present in the FIFO output register and attempted FIFO reads are ignored.

A FIFO read pointer is incremented each time a new word is clocked to its output register. The state machine that controls an output-ready flag monitors a write-pointer and read-pointer comparator that indicates when the FIFO SRAM status is empty, empty +1 , or empty +2 . From the time a word is written to a FIFO, it can be shifted to the FIFO output register in a minimum of three cycles of CLKB. Therefore, an outputready flag is LOW if a word in memory is the next data to be sent to the FIFO output register and three CLKB cycles have not elapsed since the time the word was written. The outputready flag of the FIFO remains LOW until the third LOW-toHIGH transition of CLKB occurs, simultaneously forcing the output-ready flag HIGH and shifting the word to the FIFO output register.

A LOW-to-HIGH transition on CLKB begins the first synchronization cycle of a write if the clock transition occurs at time tSkEw1 or greater after the write. Otherwise, the subsequent CLKB cycle may be the first synchronization cycle (see Figure 6).

## INPUT READY FLAG (IR)

The input ready flag of a FIFO is synchronized to the port clock that writes data to its array (CLKA). When the input-

| $\overline{\text { CSA }}$ | W/R̄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 | FIFO Write |
| L | H | H | H | $\uparrow$ | In High-Impedance State | Mail1 Write |
| L | L | L | L | X | Active, Mail2 Register | None |
| L | L | H | L | $\uparrow$ | Active, Mail2 Register | None |
| 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 2. Port-A Enable Function Table

| $\overline{\text { CSB }}$ | $\overline{\text { W } / R B ~}$ | ENB | MBB | CLKB | B0-A35 Outputs | Port Functions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | In High-Impedance State | None |
| L | L | L | X | X | In High-Impedance State | None |
| L | L | H | L | $\uparrow$ | In High-Impedance State | None |
| L | L | H | H | $\uparrow$ | In High-Impedance State | Mail2 Write |
| L | H | L | L | X | Active, FIFO Output Register | None |
| L | H | H | L | $\uparrow$ | Active, FIFO Output Register | FIFO read |
| L | H | L | H | X | Active, Mail1 Register | None |
| L | H | H | H | $\uparrow$ | Active, Mail1 Register | Mail1 Read (Set MBF1 HIGH) |

Table 3. Port-B Enable Function Table
ready flag is HIGH, a memory location is free in the SRAM to write new data. No memory locations are free when the inputready flag is LOW and attempted writes to the FIFO are ignored.

Each time a word is written to a FIFO, its write pointer is incremented. The state machine that controls an input-ready 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, its previous memory location is ready to be written in a minimum of three cycles of CLKA. Therefore, an input-ready flag is LOW if less than two cycles of CLKA have elapsed since the next memory write location has been read. The second LOW-to-HIGH transition on CLKA after the read sets the input-ready flag HIGH, and data can be written in the following cycle.

A LOW-to-HIGH transition on CLKA begins the first synchronization cycle of a read if the clock transition occurs at time tSKEW1 or greater after the read. Otherwise, the subsequent CLKA cycle may be the first synchronization cycle (see Figure 7).

## ALMOST-EMPTY FLAG ( $\overline{\mathrm{AE}})$

The almost-empty flag of a FIFO is synchronized to the port clock that reads data from its array (CLKB). The state machine that controls an almost-empty flag monitors a writepointer and 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 contents of register $X$. This register is loaded with a preset value during a FIFO reset, programmed from port A, or programmed serially (see almost-empty flag and almost-full flag offset programming above). The almost-empty flag is LOW when the FIFO contains $X$ or less words and is HIGH when the FIFO contains $(X+1)$ or more words. A data word present in the FIFO output register has been read from memory.

Two LOW-to-HIGH transitions of CLKB 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 $(X+1)$ or more words remains LOW if two cycles of CLKB have not elapsed since the write that filled the memory to the $(X+1)$
level. An almost-empty flag is set HIGH by the second LOW-to-HIGH transition of CLKB after the FIFO write that fills memory to the $(X+1)$ level. A LOW-to-HIGH transition of CLKB begins the first synchronization cycle if it occurs at time tSKEW2 or greater after the write that fills the FIFO to $(X+1)$ words. Otherwise, the subsequent CLKB cycle may be the first synchronization cycle (see Figure 8).

## ALMOST-FULL FLAG ( $\overline{\mathrm{AF}}$ )

The almost-full flag of a FIFO is synchronized to the port clock that writes data to its array (CLKA). The state machine that controls an almost-full flag monitors a write-pointer and read-pointer 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 contents of register Y . This register is loaded with a preset value during a FIFO reset, programmed from port A, or programmed serially (see almost-empty flag and almost-full flag offset programming). The almost-full flag is LOW when the number of words in the FIFO is greater than or equal to (512-Y), (1024-Y), OR (2048-Y) for the IDT723631, IDT723641, or IDT723651, respectively. The almost-full flag is HIGH when the number of words in the FIFO is less than or equal to [512-(Y+1)], [1024-(Y+1)], or [2048-(Y+1)] for the IDT723631, IDT723641, or IDT723651, respectively. A data word present in the FIFO output register has been read from memory.

Two LOW-to-HIGH transitions of CLKA are required after a FIFO read for its almost-full flag to reflect the new level of fill. Therefore, the almost-full flag of a FIFO containing [512/1024/ 2048-(Y+1)] or less words remains LOW if two cycles of CLKA have not elapsed since the read that reduced the number of words in memory to [512/1024/2048-(Y+1)]. An almost-full flag is set HIGH by the second LOW-to-HIGH transition of CLKA after the FIFO read that reduces the number of words in memory to [512/1024/2048-(Y+1)]. A LOW-to-HIGH transition of CLKA begins the first synchronization cycle if it occurs at time tSKEW2 or greater after the read that reduces the number of words in memory to [512/1024/2048-(Y+1)]. Otherwise, the subsequent CLKA cycle may be the first synchronization cycle (see Figure 9).

| Number of Words in the FIFO ${ }^{(1,2)}$ |  |  | Synchronized <br> to CLKB | Synchronized <br> to CLKA |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IDT723631 | IDT723641 | IDT723651 | OR | $\overline{\mathrm{AE}}$ | $\overline{\mathrm{AF}}$ |
| 0 | 0 | 0 | L | L | H |
| 1 to X | 1 to X | 1 to X | H |  |  |
| $(\mathrm{X}+1)$ to $[512-(\mathrm{Y}+1)]$ | $(\mathrm{X}+1)$ to $[1024-(\mathrm{Y}+1)]$ | $(\mathrm{X}+1)$ to $[2048-(\mathrm{Y}+1)]$ | H | H | H |
| $(512-\mathrm{Y})$ to 511 | $(1024-\mathrm{Y})$ to 1023 | $(2048-\mathrm{Y})$ to 2047 | H | H | L |
| 512 | 1024 | 2048 | H | H | L |

## NOTES:

1. $X$ is the almost-empty offset for $\overline{A E}$. $Y$ is the almost-full offset for $\overline{A F}$.
2. When a word is present in the FIFO output register, its previous memory location is free.

Table 4. FIFO Flag Operation

## SYNCHRONOUS RETRANSMIT

The synchronous retransmit feature of the IDT723631/ 723641/723651 allows FIFO data to be read repeatedly starting at a user-selected position. The FIFO is first put into retransmit mode to select a beginning word and prevent ongoing FIFO write operations from destroying retransmit data. Data vectors with a minimum length of three words can retransmit repeatedly starting at the selected word. The FIFO can be taken out of retransmit mode at any time and allow normal device operation.

The FIFO is put in retransmit mode by a LOW-to-HIGH transition on CLKB when the retransmit mode (RTM) input is HIGH and OR is HIGH. The rising CLKB edge marks the data present in the FIFO output register as the first retransmit data. The FIFO remains in retransmit mode until a LOW-to-HIGH transition occurs while RTM is LOW.

When two or more reads have been done past the initial retransmit word, a retransmit is initiated by a LOW-to-HIGH transition on CLKB when the read-from-mark (RFM) input is HIGH. This rising CLKB edge shifts the first retransmit word to the FIFO output register and subsequent reads can begin immediately. Retransmit loops can be done endlessly while the FIFO is in retransmit mode. RFM must be LOW during the CLKB rising edge that takes the FIFO out of retransmit mode.

When the FIFO is put into retransmit mode, it operates with two read pointers. The current read pointer operates normally, incrementing each time a new word is shifted to the FIFO output register and used by the OR and $\overline{\text { AE flags. The }}$ shadow read pointer stores the SRAM location at the time the device is put into retransmit mode and does not change until the device is taken out of retransmit mode. The shadow read pointer is used by the IR and $\overline{\mathrm{AF}}$ flags. Data writes can proceed while the FIFO is in retransmit mode, but $\overline{\mathrm{AF}}$ is set LOW by the write that stores (512-Y), (1024-Y), or (2048Y) words after the first retransmit word for the IDT723631, IDT723641, or IDT723651, respectively. The IR flag is set LOW by the 512th, 1024th, or 2048th write after the first retransmit word for the IDT723631, IDT723641, or IDT723651, respectively.

When the FIFO is in retransmit mode and RFM is HIGH, a rising CLKB edge loads the current read pointer with the shadow read-pointer value and the OR flag reflects the new
level of fill immediately. If the retransmit changes the FIFO status out of the almost-empty range, up to two CLKB rising edges after the retransmit cycle are needed to switch $\overline{\mathrm{AE}}$ high (see Figure 11). The rising CLKB edge that takes the FIFO out of retransmit mode shifts the read pointer used by the IR and $\overline{\mathrm{AF}}$ flags from the shadow to the current read pointer. If the change of read pointer used by IR and $\overline{\mathrm{AF}}$ should cause one or both flags to transmit HIGH, at least two CLKA synchronizing cycles are needed before the flags reflect the change. A rising CLKA edge after the FIFO is taken out of retransmit mode is the first synchronizing cycle of IR if it occurs at time tSKEW1 or greater after the rising CLKB edge (see Figure 12). A rising CLKA edge after the FIFO is taken out of retransmit mode is the first synchronizing cycle of $\overline{\mathrm{AF}}$ if it occurs at time tSKEW2 or greater after the rising CLKB edge (see Figure 14).

## MAILBOX REGISTERS

Two 36-bit bypass registers are on the IDT723631/723641/ 723651 to pass command and control information between port $A$ and port $B$. 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}} \mathrm{A}$, 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}, \bar{W} / R B$, and ENB with MBB HIGH. Writing data to a mail register sets its corresponding flag ( $\overline{\mathrm{MBF}}$ or $\overline{\text { MBF2 }}$ ) LOW. Attempted writes to a mail register are ignored while its mail flag is LOW.

When the port-B data (B0-B35) outputs are active, the data on the bus comes from the FIFO output register when the port-B mailbox select (MBB) input is LOW and from the mail1 register when MBB is HIGH. Mail2 data is always present on the port-A data (A0-A35) outputs when they are active. The mail1 register flag ( $\overline{\mathrm{MBF}}$ ) is set HIGH by a LOW-to-HIGH transition on CLKB when a port-B read is selected by $\overline{\mathrm{CSB}}, \overline{\mathrm{W}} /$ RB, and ENB with MBB HIGH. The mail2 register flag (MBF2) is set HIGH by a LOW-to-HIGH transition on CLKA when a port-A read is selected by $\overline{C S A}, W / \bar{R} A$, and ENA with MBA HIGH. The data in a mail register remains intact after it is read and changes only when new data is written to the register.


Figure 1. FIFO Reset Loading $X$ and $Y$ with a Preset Value of Eight


NOTE:

1. $\overline{\mathrm{CSA}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}=\mathrm{HIGH}, \mathrm{MBA}=\mathrm{LOW}$. It is not necessary to program offset register on consecutive clock cycles.

Figure 2. Programming the Almost-Full Flag and Almost-Empty Flag Offset Values from Port A


NOTE:

1. It is not necessary to program offset register bits on consecutive clock cycles. FIFO write attempts are ignored until IR is set HIGH.

Figure 3. Programming the Almost-Full Flag and Almost-Empty Flag Offset Values Serially


3023 drw 07


Figure 5. FIFO Read-Cycle Timing


NOTE:

1. TSKEW1 is the minimum time between a rising CLKA edge and a rising CLKB edge for OR to transition HIGH and to clock the next word to the FIFO output register in three CLKB cycles. If the time between the rising CLKA edge and rising CLKB edge is less than tSKEW1, then the transition of OR HIGH and the first word load to the output register may occur one CLKB cycle later than shown.

Figure 6. OR Flag Timing and First Data Word Fallthrough when the FIFO is Empty


Figure 7. IR Flag Timing and First Available Write when the FIFO is Full


## NOTES:

1. tSKEW2 is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{A E}$ 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{A E}$ may transition HIGH one CLKB cycle later than shown.
2. FIFO write $(\overline{\mathrm{CSA}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R} A}=\mathrm{HIGH}, \mathrm{MBA}=\mathrm{LOW})$, FIFO read $(\overline{\mathrm{CSB}}=\mathrm{LOW}, \overline{\mathrm{W}} / \mathrm{RB}=\mathrm{HIGH}, \mathrm{MBB}=\mathrm{LOW})$.

Figure 8. Timing for $\overline{\mathrm{AE}}$ when FIFO is Almost Empty


## NOTES:

1. tSKEW2 is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{\mathrm{AF}}$ 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{\mathrm{AF}}$ may transition HIGH one CLKA cycle later than shown.
2. Depth is 512 for the IDT723631, 1024 for the IDT723641, and 2048 for the IDT723651.
3. FIFO write $(\overline{\mathrm{CSA}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}=\mathrm{HIGH}, \mathrm{MBA}=\mathrm{LOW})$, FIFO read $(\overline{\mathrm{CSB}}=\mathrm{LOW}, \overline{\mathrm{W}} / \mathrm{RB}=\mathrm{HIGH}, \mathrm{MBB}=\mathrm{LOW})$.

Figure 9. Timing for $\overline{\mathrm{AF}}$ when FIFO is Almost Full


NOTE:

1. $\mathrm{CSB}=\mathrm{LOW}, \mathrm{W} / \mathrm{RB}=\mathrm{HIGH}, \mathrm{MBB}=\mathrm{LOW}$. No input enables other than RTM and RFM are needed to control retransmit mode or begin a retransmit. Other enables are shown only to relate retransmit operations to the FIFO output register.

Figure 10. Retransmit Timing Showing Minimum Retransmit Length


Figure 11. $\overline{A E}$ Maximum Latency When Retransmit Increases the Number of Stored Words Above X.


NOTE:

1. TSKEW1 is the minimum time between a rising CLKB edge and a rising CLKA edge for IR 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 IR may transition HIGH one CLKA cycle later than shown.

Figure 12. IR Timing from the End of Retransmit Mode when One or More Write Locations are Available


## NOTES:

1. SSKEW2 is the minimum time between a rising CLKB edge and a rising CLKA edge for AF 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 AF may transition HIGH one CLKA cycle later than shown.
2. Depth is 512 for the IDT723631, 1024 for the IDT723641, and 2048 for the IDT723651.
3. Y is the value loaded in the almost-full flag offset register.

Figure 13. $\overline{\mathrm{AF}}$ Timing from the End of Retransmit Mode when $(\mathrm{Y}+1)$ or More Write Locations are Available


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


Figure 15. Timing for Mail2 Register and $\overline{\text { MBF2 }}$ Flag

TYPICAL CHARACTERISTICS
SUPPLY CURRENT
CLOCK FREQUENCY


Figure 16

## CALCULATING POWER DISSIPATION

The ICC(f) current for the graph in Figure 16 was taken while simultaneously reading and writing the FIFO on the IDT723641 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 capacitance load per data-output channel and the number of IDT723631/723641/723651 inputs driven by TTL HIGH levels are known, the power dissipation can be calculated with the equation below.

With ICC(f) taken from Flgure 16, the maximum power dissipation (PT) of the IDT723631/723641/723651 may be calculated by:

$$
\mathrm{PT}=\operatorname{Vcc} \times[\operatorname{lcc}(\mathrm{f})+(\mathrm{N} \times \Delta \mathrm{lcc} \times \mathrm{dc})]+\sum\left(\mathrm{CL} \times \mathrm{VCC}^{2} \times \mathrm{fo}\right)
$$

where:

| N | $=$ | number of inputs driven by TTL levels |
| :--- | :--- | :--- |
| $\Delta \mathrm{ICC}$ | $=$ | increase in power supply current for each input at a TTL HIGH level |
| dc | $=$ | duty cycle of inputs at a TTL HIGH level of 3.4 |
| CL | $=$ | output capacitance load |
| fO | $=$ | switching frequency of an output |

When no reads or writes are occurring on the IDT723631/723641/723651, the power dissipated by a single clock (CLKA or CLKB) input running at frequency fS is calculated by:
$P T=V c c \times f s \times 0.209 \mathrm{~mA} / \mathrm{MHz}$

## PARAMETER MEASUREMENT INFORMATION



VOLTAGE WAVEFORMS
SETUP AND HOLD TIMES
VOLTAGE WAVEFORMS
PULSE DURATIONS


VOLTAGE WAVEFORMS ENABLE AND DISABLE TIMES


VOLTAGE WAVEFORMS PROPAGATION DELAY TIMES

NOTE:

1. Includes probe and jig capacitance

Figure 17. Load Circuit and Voltage Waveforms

## ORDERING INFORMATION



