- Free-Running CLKA and CLKB Can Be Asynchronous or Coincident
- Clocked FIFO Buffering Data From Port A to Port B
- Memory Size: 1024 × 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 (AF) Flags Synchronized by CLKA

- Output-Ready (OR) and Almost-Empty (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
- Pin-to-Pin Compatible With the SN74ACT3631 and SN74ACT3651
- Available in Space-Saving 120-Pin Thin Quad Flat (PCB) and 132-Pin Plastic Quad Flat (PQ) Packages

## description

The SN74ACT3641 is a high-speed, 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  $1024 \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 stored in memory. Communication between each port can 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 can be used in parallel to create wider datapaths. Expansion is also possible in word depth.

The SN74ACT3641 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{AF})$  flag of the FIFO are two-stage synchronized to CLKA. The output-ready (OR) flag and almost-empty ( $\overline{AE}$ ) flag of the FIFO are two-stage 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.

The SN74ACT3641 is characterized for operation from 0°C to 70°C.

For more information on this device family, see the application reports *FIFO Patented Synchronous Retransmit: Programmable DSP-Interface Application for FIR Filtering* and *FIFO Mailbox-Bypass Registers: Using Bypass Registers to Initialize DMA Control* in the 1996 *High-Performance FIFO Memories Designer's Handbook*, literature number SCAA012A.



Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

PRODUCTION DATA information is current as of publication date. Products conform to specifications per the terms of Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.



Copyright  $\circledast$  1995, Texas Instruments Incorporated

FS0/SD FS1/<u>SEN</u> CSB W/RB CLKB CLKB VCC MBFZ MBFZ MBFZ MBA GND CC MBFT GND GND GND GND ENA W/RA CSA Я ഷ  $\begin{array}{c} & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\$ 🗆 ВЗ5 A35 🗆 90 1 89 🗖 B34 A34 🗆 2 A33 🗆 🗅 ВЗЗ 3 88 A32 🗆 4 87 D B32 V<sub>CC</sub> □ 5 A31 □ 6 86 🛛 GND 🛛 B31 85 A30 🗆 7 🛛 ВЗО 84 GND 🗆 8 83 🛛 B29 A29 □ 9 A28 □ 10 🗆 B28 82 🗆 B27 81 □ B26 □ V<sub>CC</sub> □ B25 A27 🗆 11 80 A26 □ A25 □ 79 12 13 78 🗆 B24 A24 🗆 14 77 A23 🗆 🗆 GND 76 15 🗆 B23 GND 🗆 75 16 A22 🗆 17 🗆 B22 74 V<sub>CC</sub> □ 18 A21 □ 19 73 🗆 B21 🗆 B20 72 A20 🗆 20 71 🗅 B19 A19 🗌 21 70 🛛 B18 A18 🗌 22 69 🛛 GND GND 23 68 🛛 B17 A17 🗆 24 67 🛛 B16 A16 🗆 25 66 □ v<sub>cc</sub> A15 🗆 26 65 🗆 B15 🗆 B14 A14 🗆 27 64 63 | B13 62 | B12 61 | GND A13 🗆 28 29 30  $\begin{array}{c} 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 3333 \\ 33$ 

PCB PACKAGE (TOP VIEW)

NC - No internal connection





NC – No internal connection

<sup>†</sup>Uses Yamaichi socket IC51-1324-828



## functional block diagram





## **Terminal Functions**

| TERMINAL<br>NAME | <i>I</i> /O | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0-A35           | I/O         | Port-A data. The 36-bit bidirectional data port for side A.                                                                                                                                                                                                                                                                                                                                                                               |
| ĀĒ               | 0           | Almost-empty flag. Programmable flag synchronized to CLKB. $\overline{AE}$ is low when the number of words in the FIFO is less than or equal to the value in the almost-empty offset register (X).                                                                                                                                                                                                                                        |
| AF               | 0           | Almost-full flag. Programmable flag synchronized to CLKA. AF 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           | I/O         | Port-B data. The 36-bit bidirectional data port for side B.                                                                                                                                                                                                                                                                                                                                                                               |
| CLKA             | I           | Port-A clock. CLKA is a continuous clock that synchronizes all data transfers through port A and can be asynchronous or coincident to CLKB. IR and $\overline{AF}$ are synchronous to the low-to-high transition of CLKA.                                                                                                                                                                                                                 |
| CLKB             | I           | Port-B clock. CLKB is a continuous clock that synchronizes all data transfers through port B and can be asynchronous or coincident to CLKA. OR and AE are synchronous to the low-to-high transition of CLKB.                                                                                                                                                                                                                              |
| CSA              | I           | Port-A chip select. 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.                                                                                                                                                                                                                                                      |
| CSB              | I           | Port-B chip select. 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.                                                                                                                                                                                                                                                      |
| ENA              | I           | Port-A master enable. ENA must be high to enable a low-to-high transition of CLKA to read or write data on port A.                                                                                                                                                                                                                                                                                                                        |
| ENB              | I           | Port-B master enable. ENB must be high to enable a low-to-high transition of CLKB to read or write data on port B.                                                                                                                                                                                                                                                                                                                        |
| FS1/SEN,         | I           | Flag-offset select 1/serial enable, flag-offset select 0/serial data. FS1/SEN and FS0/SD are dual-purpose inputs used for flag-offset register programming. During a device reset, FS1/SEN and FS0/SD select 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.                                        |
| FS0/SD           |             | 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 loads the bit present on FS0/SD into the X and Y offset registers. The number of bit writes required to program the offset registers is 20. The first bit write stores the Y-register MSB and the last bit write stores the X-register LSB. |
| IR               | ο           | Input-ready flag. 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              | I           | Port-A mailbox select. A high level on MBA chooses a mailbox register for a port-A read or write operation.                                                                                                                                                                                                                                                                                                                               |
| MBB              | I           | Port-B mailbox select. A high level on MBB 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.                                                                                                                                                                         |
| MBF1             | 0           | Mail1 register flag. 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.                                                                                                                                                                                      |
| MBF2             | 0           | Mail2 register flag. MBF2 is set low by the low-to-high transition of CLKB that writes data to the mail2 register. 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 by a reset.                                                                                                                                                                                      |
| OR               | ο           | Output-ready flag. OR is synchronized to the low-to-high transition of CLKB. When OR is low, the FIFO is empty and reads are disabled. Ready data is present in the output register of the FIFO when OR is high. OR is forced low during the reset and goes high on the third low-to-high transition of CLKB after a word is loaded to empty memory.                                                                                      |
| RFM              | I           | Read from mark. When the FIFO is in retransmit mode, a high on RFM enables a low-to-high transition of CLKB to reset the read pointer to the beginning retransmit location and output the first selected retransmit data.                                                                                                                                                                                                                 |
| RST              | I           | Reset. To reset the device, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must occur while RST is low. The low-to-high transition of RST latches the status of FS0 and FS1 for AF and AE offset selection.                                                                                                                                                                                                |
| RTM              | I           | Retransmit mode. When RTM is high and valid data is present in the FIFO output register (OR is high), a low-to-high transition of CLKB selects the data for the beginning of a retransmit and puts the FIFO in retransmit mode. The selected word remains the initial retransmit point until a low-to-high transition of CLKB occurs while RTM is low, taking the FIFO out of retransmit mode.                                            |

## SN74ACT3641 $1024 \times 36$ CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCAS338B - JANUARY 1994 - RÉVISED SEPTEMBER 1995

| TERMINAL<br>NAME | I/O | DESCRIPTION                                                                                                                                                                                                                                            |
|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| W/RA             | I   | Port-A write/read select. A high on $W/\overline{R}A$ selects a write operation and a low selects a read operation on port A for a low-to-high transition of CLKA. The A0–A35 outputs are in the high-impedance state when $W/\overline{R}A$ is high.  |
| W/RB             | I   | Port-B write/read select. A low on $\overline{W}$ /RB selects a write operation and a high selects a read operation on port B for a low-to-high transition of CLKB. The B0–B35 outputs are in the high-impedance state when $\overline{W}$ /RB is low. |

## **Terminal Functions (Continued)**

## detailed description

#### reset

The SN74ACT3641 is reset by taking the reset (RST) input low for at least four port-A clock (CLKA) and four port-B clock (CLKB) low-to-high transitions. RST can 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 (AE) flag low, and the almost-full (AF) flag high. Resetting the device also forces the mailbox flags (MBF1, MBF2) 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 SN74ACT3641 are used to hold the offset values for the almost-empty and almost-full flags. The almost-empty  $\overline{(AE)}$  flag offset register is labeled X, and the almost-full  $\overline{(AF)}$  flag offset register is labeled Y. The offset registers 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, FS0) inputs during a low-to-high transition on RST (see Table 1).

| FS1 | FS0 | RST        | X AND Y REGISTERS <sup>†</sup> |  |  |  |
|-----|-----|------------|--------------------------------|--|--|--|
| н   | Н   | ↑          | Serial load                    |  |  |  |
| н   | L   | $\uparrow$ | 64                             |  |  |  |
| L   | Н   | $\uparrow$ | 8                              |  |  |  |
| L   | L   | $\uparrow$ | Parallel load from port A      |  |  |  |

#### Table 1. Flag Programming

† X register holds the offset for  $\overline{AE}$ ; Y register holds the offset for AF.

## preset values

If a preset value of 8 or 64 is chosen by FS1 and FS0 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, IR 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 SN74ACT3641 uses port-A inputs (A9–A0). Data input A9 is used as the most significant bit of the binary number. Each register value can be programmed from 1 to 1020. 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 FS0/SD and FS1/SEN high during the low-to-high transition of RST. After this reset is complete, the X and Y register values are loaded bitwise through FS0/SD on each low-to-high transition of CLKA that FS1/SEN is low. Twenty-bit writes are needed to complete the programming. 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 the X register. Each register value can be programmed from 1 to 1020.

When the option to program the offset registers serially is chosen, the IR remains low until all 20 bits are written. IR is set high by the low-to-high 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 (A0–A35) outputs is controlled by the port-A chip select ( $\overline{CSA}$ ) and the port-A write/read select ( $W/\overline{RA}$ ). The A0–A35 outputs are in the high-impedance state when either  $\overline{CSA}$  or  $W/\overline{RA}$  is high. The A0–A35 outputs are active when both  $\overline{CSA}$  and  $W/\overline{RA}$  are low.

Data is loaded into the FIFO from the A0–A35 inputs on a low-to-high transition of CLKA when  $\overline{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 reads.

| CSA | W/RA | ENA | MBA | CLKA       | A0-A35 OUTPUTS PORT FUNCTION |                            |
|-----|------|-----|-----|------------|------------------------------|----------------------------|
| н   | Х    | Х   | Х   | Х          | In high-impedance state      | None                       |
| L   | н    | L   | х   | х          | In high-impedance state      | None                       |
| L   | н    | Н   | L   | $\uparrow$ | In high-impedance state      | FIFO write                 |
| L   | н    | Н   | н   | $\uparrow$ | In high-impedance state      | Mail1 write                |
| L   | L    | L   | L   | х          | Active, mail2 register None  |                            |
| L   | L    | Н   | L   | $\uparrow$ | Active, mail2 register       | None                       |
| L   | L    | L   | н   | х          | Active, mail2 register None  |                            |
| L   | L    | Н   | Н   | $\uparrow$ | Active, mail2 register       | Mail2 read (set MBF2 high) |

Table 2. Port-A Enable Function Table

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

Data is read from the FIFO to its output register on a low-to-high transition of CLKB when  $\overline{CSB}$  and the port-B mailbox select (MBB) are low,  $\overline{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.



## FIFO write/read operation (continued)

| CSB | W/RB | ENB | MBB | CLKB       | B0-B35 OUTPUTS PORT FUNCTION           |                            |
|-----|------|-----|-----|------------|----------------------------------------|----------------------------|
| н   | Х    | Х   | Х   | Х          | In high-impedance state                | None                       |
| L   | L    | L   | Х   | х          | In high-impedance state                | None                       |
| L   | L    | Н   | L   | $\uparrow$ | In high-impedance state None           |                            |
| L   | L    | Н   | н   | $\uparrow$ | In high-impedance state Mail2 write    |                            |
| L   | н    | L   | L   | х          | Active, FIFO output register None      |                            |
| L   | н    | Н   | L   | $\uparrow$ | Active, FIFO output register FIFO read |                            |
| L   | Н    | L   | Н   | х          | Active, mail1 register None            |                            |
| L   | Н    | Н   | Н   | $\uparrow$ | Active, mail1 register                 | Mail1 read (set MBF1 high) |

| Table 3. | Port-B | Enable | Function  | Table |
|----------|--------|--------|-----------|-------|
|          |        |        | i unction | Table |

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-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.

When the OR is low, the next data word is sent to the FIFO output register automatically by the CLKB low-to-high transition that sets OR high. When OR is high, an available data word is clocked to the FIFO output register only when a FIFO read is selected by  $\overline{\text{CSB}}$ ,  $\overline{\text{W}/\text{RB}}$ , ENB, and MBB.

## synchronized FIFO flags

Each 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 (see the application report *Metastability Performance of Clocked FIFOs* in the 1996 *High-Performance FIFO Memories Data Book*, literature number SCAD003C). OR and  $\overline{AE}$  are synchronized to CLKB. IR and  $\overline{AF}$  are synchronized to CLKA. Table 4 shows the relationship of each flag to the number of words stored in memory.

| NUMBER OF WORDS IN<br>FIF0†‡ |    | RONIZED<br>CLKB | SYNCHRONIZED<br>TO CLKA |    |  |
|------------------------------|----|-----------------|-------------------------|----|--|
| FIFUT <del>+</del>           | OR | AE              | AF                      | IR |  |
| 0                            | L  | L               | Н                       | Н  |  |
| 1 to X                       | Н  | L               | н                       | Н  |  |
| (X + 1) to [1024 – (Y + 1)]  | Н  | Н               | н                       | Н  |  |
| (1024 – Y) to 1023           | Н  | Н               | L                       | Н  |  |
| 1024                         | Н  | Н               | L                       | L  |  |

## Table 4. FIFO Flag Operation

 $\dagger X$  is the almost-empty offset for  $\overline{AE}$ . Y is the almost-full offset for  $\overline{AF}$ .

<sup>‡</sup> When a word is present in the FIFO output register, its previous memory location is free.



## 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 output-ready 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 output-ready 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 output-ready flag of the FIFO remains low until the third low-to-high 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  $t_{sk(1)}$ , or greater, after the write. Otherwise, the subsequent CLKB cycle can 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-ready flag is high, a memory location is free in the SRAM to write new data. No memory locations are free when the input-ready 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  $t_{sk(1)}$ , or greater, after the read. Otherwise, the subsequent CLKA cycle can be the first synchronization cycle (see Figure 7).

## almost-empty flag (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 write-pointer 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*). 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 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  $t_{sk(2)}$ , or greater, after the write that fills the FIFO to (X + 1) words. Otherwise, the subsequent CLKB cycle can be the first synchronization cycle (see Figure 8).



almost-full flag (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 almost-full 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 (1024 - Y). The almost-full flag is high when the number of words in the FIFO is less than or equal to [1024 - (Y + 1)]. 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 [1024 - (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 [1024 - (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 [1024 - (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 [1024 - (Y + 1)]. A low-to-high transition of CLKA begins the first synchronization cycle if it occurs at time  $t_{sk(2)}$ , or greater, after the read that reduces the number of words in memory to [1024 - (Y + 1)]. Otherwise, the subsequent CLKA cycle can be the first synchronization cycle (see Figure 9).

## synchronous retransmit

The synchronous retransmit feature of the SN74ACT3641 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 on-going 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. This 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{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{AF}$  flags. Data writes can proceed while the FIFO is in retransmit mode, but  $\overline{AF}$  is set low by the write that stores (1024 – Y) words after the first retransmit word. The IR flag is set low by the 1024th write after the first retransmit word.

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{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{AF}$  flags from the shadow to the current read pointer. If the change of read pointer used by IR and  $\overline{AF}$  should cause one or both flags to transition 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 t<sub>sk(1)</sub>, 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 IR if it occurs at time t<sub>sk(2)</sub>, or greater, after the rising CLKB edge (see Figure 14).



#### mailbox registers

Two 36-bit bypass registers are on the SN74ACT3641 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 CSA, W/RA, 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 CSB, W/RB, and ENB with MBB high. Writing data to a mail register sets its corresponding flag (MBF1 or 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{\text{MBF1}}$ ) is set high by a low-to-high transition on CLKB when a port-B read is selected by  $\overline{\text{CSB}}$ ,  $\overline{\text{W/RB}}$ , and  $\overline{\text{ENB}}$  with MBB high. The mail2 register flag ( $\overline{\text{MBF2}}$ ) is set high by a low-to-high transition on CLKB when a port-B read is selected by  $\overline{\text{CSB}}$ ,  $\overline{\text{W/RB}}$ , and  $\overline{\text{ENB}}$  with  $\overline{\text{MBB}}$  high. The mail2 register flag ( $\overline{\text{MBF2}}$ ) is set high by a low-to-high transition on CLKA when a port-A read is selected by  $\overline{\text{CSA}}$ ,  $\overline{\text{W/RA}}$ , and  $\overline{\text{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 A: CSA = L, W/RA = H, MBA = L. It is not necessary to program offset register on consecutive clock cycles.





NOTE A: 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





Figure 4. FIFO Write-Cycle Timing



Figure 5. FIFO Read-Cycle Timing



## SN74ACT3641 $1024 \times 36$ CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCAS338B - JANUARY 1994 - REVISED SEPTEMBER 1995



tsk(1) 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 t<sub>sk(1)</sub>, the transition of OR high and the first word load to the output register can occur one CLKB cycle later than shown.

## Figure 6. OR-Flag Timing and First-Data-Word Fallthrough When the FIFO Is Empty



| <sup>t</sup> w(CLK⊦<br>CLKB |                                                                                                                                                              |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CSB                         | Low                                                                                                                                                          |
| W/RB                        | High                                                                                                                                                         |
| MBB                         | Low                                                                                                                                                          |
| ENB                         | $\begin{array}{c c} t_{su(EN1)} & & & t_{h(EN1)} \\ \hline \end{array}$                                                                                      |
| OR                          | High<br>← t <sub>a</sub> →                                                                                                                                   |
| B0-B35                      | FIFO Output Register X Next Word From FIFO                                                                                                                   |
|                             | $ \begin{array}{c c} & t_{sk(1)}^{\dagger} & \xrightarrow{t_{c}} & \xrightarrow{t_{c}} & \xrightarrow{t_{w(CLKL)}} \\ & & & & & & \\ & & & & & & \\ & & & &$ |
| CLKA                        |                                                                                                                                                              |
| IR                          | FIFO Full                                                                                                                                                    |
| CSA                         | Low                                                                                                                                                          |
| W/RA                        | High                                                                                                                                                         |
| MBA                         |                                                                                                                                                              |
| ENA                         | tsu(EN1) ← th(EN1)                                                                                                                                           |
|                             | t <sub>su(D)</sub> th(D)                                                                                                                                     |
| A0-A35                      |                                                                                                                                                              |

 $t_{sk(1)}$  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  $t_{sk(1)}$ , IR can transition high one CLKA cycle later than shown.

Figure 7. IR-Flag Timing and First Available Write When the FIFO Is Full



CLKA  $t_{su(EN1)}$   $t_{th(EN1)}$ ENA  $t_{sk(2)}^{\dagger}$   $t_{th(EN1)}$ CLKB  $\overline{AE}$  X Words in FIFO ENB  $t_{pd(C-AE)}$   $t_{pd(C-AE)}$   $t_{pd(C-AE)}$   $t_{th(EN1)}$  $t_{su(EN1)}$   $t_{th(EN1)}$   $t_{th(EN1)}$ 

<sup>†</sup> t<sub>sk(2)</sub> is the minimum time between a rising CLKA edge and a rising CLKB edge for  $\overline{AE}$  to transition high in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than t<sub>sk(2)</sub>,  $\overline{AE}$  can transition high one CLKB cycle later than shown. NOTE A: FIFO write ( $\overline{CSA} = L$ ,  $W/\overline{RA} = H$ , MBA = L), FIFO read ( $\overline{CSB} = L$ ,  $\overline{W}/\overline{RB} = H$ , MBB = L)





<sup>†</sup>  $t_{sk(2)}$  is the minimum time between a rising CLKA edge and a rising CLKB edge for  $\overline{AF}$  to transition high in the next CLKA cycle. If the time between the rising CLKB edge and rising CLKA edge is less than  $t_{sk(2)}$ ,  $\overline{AF}$  can transition high one CLKA cycle later than shown. NOTE A: FIFO write (CSA = L, W/RA = H, MBA = L), FIFO read (CSB = L, W/RB = H, MBB = L)

Figure 9. Timing for AF When FIFO Is Almost Full



# $\begin{array}{c} \text{SN74ACT3641} \\ 1024 \times 36 \\ \text{CLOCKED FIRST-IN, FIRST-OUT MEMORY} \end{array}$

SCAS338B - JANUARY 1994 - REVISED SEPTEMBER 1995



NOTE A:  $\overline{CSB} = L$ ,  $\overline{W}/RB = H$ , MBB = L. 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

NOTE A: X is the value loaded in the almost-empty flag offset register.

## Figure 11. AE Maximum Latency When Retransmit Increases the Number of Stored Words Above X



## SN74ACT3641 1024 $\times$ 36 CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCAS338B – JANUARY 1994 – REVISED SEPTEMBER 1995



<sup>+</sup> t<sub>sk(1)</sub> 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 t<sub>sk(1)</sub>, IR can 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



t<sub>sk(2)</sub> 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 t<sub>sk(2)</sub>, AF can transition high one CLKA cycle later than shown.
 NOTE A: Y is the value loaded in the almost-full flag offset register.

## Figure 13. AF Timing From the End of Retransmit Mode When (Y + 1) or More Write Locations Are Available





Figure 14. Timing for Mail1 Register and MBF1 Flag



## SN74ACT3641 $\textbf{1024}\times\textbf{36}$ CLOCKED FIRST-IN, FIRST-OUT MEMORY SCAS338B – JANUARY 1994 – REVISED SEPTEMBER 1995

| CLKB   |                                         |                                       |                                   |
|--------|-----------------------------------------|---------------------------------------|-----------------------------------|
| CSB    | tsu(EN2)                                | th(EN2)                               |                                   |
| W/RB   | <i></i>                                 |                                       |                                   |
| MBB    |                                         |                                       |                                   |
| ENB    |                                         |                                       |                                   |
| B0-B35 | tsu(D) W1                               | i i f − th(D)                         | *****                             |
| CLKA   |                                         |                                       |                                   |
| MBF2   |                                         | ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓ | ← <sup>t</sup> pd(C-MF) →         |
| CSA    |                                         |                                       |                                   |
| W/RA   |                                         |                                       |                                   |
| MBA    | 7////////////////////////////////////// |                                       | ← th(EN1)                         |
| ENA    |                                         | <sup>t</sup> su(EN1)                  |                                   |
|        | <sup>t</sup> en <mark>◄ →</mark>        | ← <sup>t</sup> pd(C-MR)               | <sup>t</sup> dis ∣ <del>∢</del> ▶ |
| A0-A35 |                                         | W1 (remains valid i                   | in mail2 register after read)     |

Figure 15. Timing for Mail2 Register and MBF2 Flag



## SN74ACT3641 $1024 \times 36$ **CLOCKED FIRST-IN, FIRST-OUT MEMORY**

SCAS338B - JANUARY 1994 - REVISED SEPTEMBER 1995

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted)<sup>†</sup>

| Supply voltage range, $V_{CC}$ | CC + 0.5 V<br>CC + 0.5 V<br>. ±20 mA<br>. ±50 mA<br>. ±50 mA<br>±400 mA |
|--------------------------------|-------------------------------------------------------------------------|
|                                | ±400 mA<br>0°C to 70°C                                                  |

† 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.

NOTE 1: The input and output voltage ratings may be exceeded provided the input and output current ratings are observed.

## recommended operating conditions

|                |                                | 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    |
| ЮН             | High-level output current      |     | -4  | mA   |
| IOL            | Low-level output current       |     | 8   | mA   |
| Т <sub>А</sub> | Operating free-air temperature | 0   | 70  | °C   |

## electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER       |                                                  | TEST CONDITIONS                        |                       |        |     |   | MAX | UNIT |
|-----------------|--------------------------------------------------|----------------------------------------|-----------------------|--------|-----|---|-----|------|
| VOH             | V <sub>CC</sub> = 4.5 V,                         | $I_{OH} = -4 \text{ mA}$               |                       |        | 2.4 |   |     | V    |
| VOL             | V <sub>CC</sub> = 4.5 V,                         | I <sub>OL</sub> = 8 mA                 |                       |        |     |   | 0.5 | V    |
| lj              | V <sub>CC</sub> = 5.5 V,                         | $V_I = V_{CC} \text{ or } 0$           |                       |        |     |   | ±5  | μA   |
| I <sub>OZ</sub> | V <sub>CC</sub> = 5.5 V,                         | $V_{O} = V_{CC} \text{ or } 0$         |                       |        |     |   | ±5  | μA   |
| ICC             | V <sub>CC</sub> = 5.5 V,                         | $V_{I} = V_{CC} - 0.2 V \text{ or } 0$ | -                     |        |     |   | 400 | μΑ   |
|                 |                                                  | One input at 3.4 V,<br>r GND           | CSA = V <sub>IH</sub> | A0-A35 |     | 0 |     | mA   |
|                 |                                                  |                                        | $CSB = V_{IH}$        | B0-B35 |     | 0 |     |      |
| ∆ICC§           | $V_{CC} = 5.5 V$ ,<br>Other inputs at $V_{CC}$ o |                                        | $CSA = V_{IL}$        | A0-A35 |     |   | 1   |      |
|                 |                                                  |                                        | $CSB = V_{IL}$        | B0-B35 |     |   | 1   |      |
|                 |                                                  |                                        | All other input       | 6      |     |   | 1   |      |
| Ci              | V <sub>I</sub> = 0,                              | f = 1 MHz                              |                       |        |     | 4 |     | pF   |
| Co              | V <sub>O</sub> = 0,                              | f = 1 MHz                              |                       |        |     | 8 |     | pF   |

<sup>‡</sup> All typical values are at V<sub>CC</sub> = 5 V, T<sub>A</sub> =  $25^{\circ}$ C.

§ This is the supply current when each input is at one of the specified TTL voltage levels rather than 0 V or V<sub>CC</sub>.



## timing requirements over recommended ranges of supply voltage and operating free-air temperature (see Figures 1 through 15)

|                                   |                                                                                               | ′ACT3641-15 |      | ′ACT3641-20 |     | ′ACT3641-30 |      |      |
|-----------------------------------|-----------------------------------------------------------------------------------------------|-------------|------|-------------|-----|-------------|------|------|
|                                   |                                                                                               | MIN         | MAX  | MIN         | MAX | MIN         | MAX  | UNIT |
| fclock                            | Clock frequency, CLKA or CLKB                                                                 |             | 66.7 |             | 50  |             | 33.4 | MHz  |
| t <sub>c</sub>                    | Clock cycle time, CLKA or CLKB                                                                | 15          |      | 20          |     | 30          |      | ns   |
| <sup>t</sup> w(CH)                | Pulse duration, CLKA and CLKB high                                                            | 6           |      | 8           |     | 12          |      | ns   |
| <sup>t</sup> w(CL)                | Pulse duration, CLKA and CLKB low                                                             | 6           |      | 8           |     | 12          |      | ns   |
| <sup>t</sup> su(D)                | Setup time, A0–A35 before CLKA $\uparrow$ and B0–B35 before CLKB $\uparrow$                   | 5           |      | 6           |     | 7           |      | ns   |
| <sup>t</sup> su(EN1)              | Setup time, ENA to CLKA <sup>↑</sup> ; ENB to CLKB <sup>↑</sup>                               | 5           |      | 6           |     | 7           |      | ns   |
| <sup>t</sup> su(EN2)              | Setup time, CSA, W/RA, and MBA to CLKA↑;<br>CSB, W/RB, and MBB to CLKB↑                       | 7           |      | 7.5         |     | 8           |      | ns   |
| <sup>t</sup> su(RM)               | Setup time, RTM and RFM to CLKB↑                                                              | 6           |      | 6.5         |     | 7           |      | ns   |
| <sup>t</sup> su(RS)               | Setup time, RST low before CLKA↑ or CLKB↑†                                                    | 5           |      | 6           |     | 7           |      | ns   |
| <sup>t</sup> su(FS)               | Setup time, FS0 and FS1 before RST high                                                       | 9           |      | 10          |     | 11          |      | ns   |
| <sup>t</sup> su(SD) <sup>‡</sup>  | Setup time, FS0/SD before CLKA↑                                                               | 5           |      | 6           |     | 7           |      | ns   |
| <sup>t</sup> su(SEN) <sup>‡</sup> | Setup time, FS1/SEN before CLKA↑                                                              | 5           |      | 6           |     | 7           |      | ns   |
| <sup>t</sup> h(D)                 | Hold time, A0–A35 after CLKA $\uparrow$ and B0–B35 after CLKB $\uparrow$                      | 0           |      | 0           |     | 0           |      | ns   |
| <sup>t</sup> n(EN1)               | Hold time, ENA after CLKA↑; ENB after CLKB↑                                                   | 0           |      | 0           |     | 0           |      | ns   |
| <sup>t</sup> n(EN2)               | Hold time, CSA, W/RA, and MBA after CLKA1;<br>CSB, W/RB, and MBB after CLKB1                  | 0           |      | 0           |     | 0           |      | ns   |
| <sup>t</sup> n(RM)                | Hold time, RTM and RFM after CLKB↑                                                            | 0           |      | 0           |     | 0           |      | ns   |
| <sup>t</sup> h(RS)                | Hold time, RST low after CLKA↑ or CLKB↑ <sup>†</sup>                                          | 5           |      | 6           |     | 7           |      | ns   |
| <sup>t</sup> h(FS)                | Hold time, FS0 and FS1 after RST high                                                         | 0           |      | 0           |     | 0           |      | ns   |
| <sup>t</sup> h(SP) <sup>‡</sup>   | Hold time, FS1/SEN high after RST high                                                        | 0           |      | 0           |     | 0           |      | ns   |
| <sup>t</sup> h(SD) <sup>‡</sup>   | Hold time, FS0/SD after CLKA↑                                                                 | 0           |      | 0           |     | 0           |      | ns   |
| <sup>t</sup> h(SEN) <sup>‡</sup>  | Hold time, FS1/SEN after CLKA↑                                                                | 0           |      | 0           |     | 0           |      | ns   |
| <sup>t</sup> sk(1) <sup>§</sup>   | Skew time between CLKA $\uparrow$ and CLKB $\uparrow$ for OR and IR                           | 9           |      | 11          |     | 13          |      | ns   |
| t <sub>sk(2)</sub> §              | Skew time between CLKA $\uparrow$ and CLKB $\uparrow$ for $\overline{AE}$ and $\overline{AF}$ | 12          |      | 16          |     | 20          |      | ns   |

<sup>†</sup>Requirement to count the clock edge as one of at least four needed to reset a FIFO

‡Only applies when serial load method is used to program flag-offset registers

§ Skew time is not a timing 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, $C_L = 30 \text{ pF}$ (see Figures 1 through 15)

|                       | DADAMETED                                                                                                                                                             | ′ACT3641-15 |      | ′ACT3641-20 |     | ′ACT3641-30 |      |      |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------|-------------|-----|-------------|------|------|
|                       | PARAMETER                                                                                                                                                             |             | MAX  | MIN MA      | MAX | MIN         | MAX  | UNIT |
| fclock                | Clock frequency, CLKA or CLKB                                                                                                                                         |             | 66.7 |             | 50  |             | 33.4 | MHz  |
| ta                    | Access time, CLKB↑ to B0-B35                                                                                                                                          | 3           | 11   | 3           | 13  | 3           | 15   | ns   |
| <sup>t</sup> pd(C-IR) | Propagation delay time, CLKA↑ to IR                                                                                                                                   | 1           | 8    | 1           | 10  | 1           | 12   | ns   |
| <sup>t</sup> pd(C-OR) | Propagation delay time, CLKB↑ to OR                                                                                                                                   | 1           | 8    | 1           | 10  | 1           | 12   | ns   |
| <sup>t</sup> pd(C-AE) | Propagation delay time, CLKB↑ to AE                                                                                                                                   | 1           | 8    | 1           | 10  | 1           | 12   | ns   |
| <sup>t</sup> pd(C-AF) | Propagation delay time, CLKA↑ to AF                                                                                                                                   | 1           | 8    | 1           | 10  | 1           | 12   | ns   |
| <sup>t</sup> pd(C-MF) | Propagation delay time, CLKA <sup><math>\uparrow</math></sup> to MBF1 low or MBF2 high and CLKB <sup><math>\uparrow</math></sup> to MBF2 low or MBF1 high             | 0           | 8    | 0           | 10  | 0           | 12   | ns   |
| <sup>t</sup> pd(C-MR) | Propagation delay time, CLKA $\uparrow$ to B0–B35 $\dagger$ and CLKB $\uparrow$ to A0–A35 $\ddagger$                                                                  | 3           | 13.5 | 3           | 15  | 3           | 17   | ns   |
| <sup>t</sup> pd(M-DV) | Propagation delay time, MBB to B0-B35 valid                                                                                                                           | 3           | 13   | 3           | 15  | 3           | 17   | ns   |
| <sup>t</sup> pd(R-F)  | Propagation delay time, RST low to AE low and AF high                                                                                                                 | 1           | 15   | 1           | 20  | 1           | 30   | ns   |
| t <sub>en</sub>       | Enable time, $\overrightarrow{CSA}$ and $\overrightarrow{W/RA}$ low to A0–A35 active and $\overrightarrow{CSB}$ low and $\overrightarrow{W/RB}$ high to B0–B35 active | 2           | 12   | 2           | 13  | 2           | 14   | ns   |
| <sup>t</sup> dis      | Disable time, $\overline{CSA}$ or W/RA high to A0–A35 at high impedance<br>and $\overline{CSB}$ high or $\overline{W}$ /RB low to B0–B35 at high impedance            | 1           | 8    | 1           | 10  | 1           | 11   | ns   |

 $^\dagger$  Writing data to the mail1 register when the B0–B35 outputs are active and MBB is high

 $\ddagger$  Writing data to the mail2 register when the A0–A35 outputs are active and MBA is high



## TYPICAL CHARACTERISTICS



Figure 16

## calculating power dissipation

The  $I_{CC(f)}$  current in Figure 16 was taken while simultaneously reading and writing the FIFO on the SN74ACT3641 with CLKA and CLKB set to  $f_{clock}$ . All data inputs and data outputs change state during each clock cycle to consume the highest supply current. Data outputs are disconnected to normalize the graph to a zero-capacitance load. Once the capacitive load per data-output channel and the number of SN74ACT3641 inputs driven by TTL high levels are known, the power dissipation can be calculated with the equation below.

With  $I_{CC(f)}$  taken from Figure 16, the maximum power dissipation (P<sub>T</sub>) of the SN74ACT3641 can be calculated by:

$$\mathsf{P}_{\mathsf{T}} = \mathsf{V}_{\mathsf{C}\mathsf{C}} \times [\mathsf{I}_{\mathsf{C}\mathsf{C}(\mathsf{f})} + (\mathsf{N} \times \Delta \mathsf{I}_{\mathsf{C}\mathsf{C}} \times \mathsf{d}\mathsf{c})] + \Sigma(\mathsf{C}_{\mathsf{L}} \times \mathsf{V}_{\mathsf{C}\mathsf{C}}^2 \times \mathsf{f}_{\mathsf{o}})$$

where:

 $\begin{array}{lll} N & = & number \ of \ inputs \ driven \ by \ TTL \ levels \\ \Delta I_{CC} & = & 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 \ V \\ C_L & = & output \ capacitive \ load \\ f_0 & = & switching \ frequency \ of \ an \ output \end{array}$ 

When no reads or writes are occurring on the SN74ACT3641, the power dissipated by a single clock (CLKA or CLKB) input running at frequency  $f_{clock}$  is calculated by:

 $P_T = V_{CC} \times f_{clock} \times 0.29 \text{ mA/MHz}$ 



## PARAMETER MEASUREMENT INFORMATION



NOTE A: Includes probe and jig capacitance

Figure 17. Load Circuit and Voltage Waveforms



#### **IMPORTANT NOTICE**

Texas Instruments (TI) reserves the right to make changes to its products or to discontinue any semiconductor product or service without notice, and advises its customers to obtain the latest version of relevant information to verify, before placing orders, that the information being relied on is current.

TI warrants performance of its semiconductor products and related software to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by government requirements.

Certain applications using semiconductor products may involve potential risks of death, personal injury, or severe property or environmental damage ("Critical Applications").

TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, INTENDED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT APPLICATIONS, DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS.

Inclusion of TI products in such applications is understood to be fully at the risk of the customer. Use of TI products in such applications requires the written approval of an appropriate TI officer. Questions concerning potential risk applications should be directed to TI through a local SC sales office.

In order to minimize risks associated with the customer's applications, adequate design and operating safeguards should be provided by the customer to minimize inherent or procedural hazards.

TI assumes no liability for applications assistance, customer product design, software performance, or infringement of patents or services described herein. Nor does TI warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used.

Copyright © 1996, Texas Instruments Incorporated