## 3.3 VOLT CMOS SyncFIFO™ 64 x 36 IDT72V3611 ### **FEATURES:** - 64 x 36 storage capacity - . Supports clock frequencies up to 67MHz - · Fast access times of 10ns - Free-running CLKA and CLKB may be asynchronous or coincident (permits simultaneous reading and writing of data on a single clock edge) - Synchronous data buffering from Port A to Port B - · Mailbox bypass register in each direction - Programmable Almost-Full (AF) and Almost-Empty (AE) flags - Microprocessor Interface Control Logic - Full Flag (FF) and Almost-Full (AF) flags synchronized by CLKA - Empty Flag (EF) and Almost-Empty (AE) flags synchronized by CLKB - · Passive parity checking on each Port - · Parity Generation can be selected for each Port - Available in 132-pin Plastic Quad Flatpack (PQF) or space-saving 120-pin Thin Quad Flatpack (PF) - Industrial temperature range (-40°C to +85°C) is available - Pin and functionally compatible version of the 5V operating IDT723611 ## **DESCRIPTION:** The IDT72V3611 is a pin and functionally compatible version of the IDT723611, designed to run off a 3.3V supply for exceptionally low power consumption. This device is a monolithic, high-speed, low-power, CMOS Synchronous (clocked) FIFO memory which supports clock frequencies up to 67MHz and has read access times as fast as 10ns. The 64 x 36 dual-port FIFO buffers data from Port A to Port B. The FIFO operates in IDT Standard mode and has flags to indicate empty and full conditions, and two programmable flags, Almost-Full $(\overline{AF})$ and Almost-Empty $(\overline{AE})$ , to indicate when a selected number of words is stored in memory. Communication between each port can take place ## **FUNCTIONAL BLOCK DIAGRAM** IDT and the IDT logo are registered trademarks of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated Device Technology, Inc. SyncFIFO is a trademark of Integrated **COMMERCIAL TEMPERATURE RANGE** **MAY 2003** ## **DESCRIPTION (CONTINUED)** through two 36-bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Parity is checked passively on each port and may be ignored if not desired. Parity generation can be selected for data read from each port. Two or more devices may be used in parallel to create wider data paths. The IDT72V3611 is a synchronous (clocked) FIFO, meaning each port employs a synchronous interface. All data transfers through a port are gated to the LOW-to-HIGH transition of a port clock by enable signals. The 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 bidirectional interface between microprocessors and/or buses with synchronous control. The Full Flag (FF) and Almost-Full (AF) flag of the FIFO are two-stage synchronized to the port clock that writes data into its array (CLKA). The Empty Flag (EF) and Almost-Empty (AE) flag of the FIFO are two-stage synchronized to the port clock that reads data from its array. The IDT72V3611 is characterized for operation from 0°C to 70°C. Industrial temperature range (-40°C to +85°C) is available by special order. This device is fabricated using IDT's high speed, submicron CMOS technology. ## PIN CONFIGURATION NOTF: TQFP (PN120-1, order code: PF) **TOP VIEW** ## **PIN CONFIGURATION (CONTINUED)** #### NOTE: 1. NC = No internal connection PQFP (PQ132-1, order code: PQF) TOP VIEW Electrical pin 1 in center of beveled edge. Pin 1 identifier in corner. ## **PIN DESCRIPTION** | Symbol | Name | I/O | Description | |--------------|-----------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A0-A35 | Port-A Data | I/O | 36-bit bidirectional data port for side A. | | ĀĒ | Almost-Empty Flag | 0 | Programmable Almost-Empty 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 offset register, X. | | ĀF | Almost-Full Flag | 0 | Programmable Almost-Full 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 Offset register, X. | | 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 can be asynchronous or coincident to CLKB. FF and AF are synchronized to the LOW-to-HIGH transition of CLKA. | | CLKB | Port-B Clock | l | CLKB is a continuous clock that synchronizes all data transfers through port-B and can be asynchronous or coincident to CLKA. $\overline{\text{EF}}$ and $\overline{\text{AE}}$ are synchronized to the LOW-to-HIGH transition of CLKB. | | CSA | Port-A Chip Select | I | 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 | Port-B Chip Select | I | 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. | | 匪 | Empty Flag | 0 | EF is synchronized to the LOW-to-HIGH transition of CLKB. When EF is LOW, the FIFO is empty, and reads from its memory are disabled. Data can be read from the FIFO to its output register when EF is HIGH. EF is forced LOW when the device is reset and is set HIGH by the second LOW-to-HIGH transition of CLKB after data is loaded into empty FIFO memory. | | ENA | Port-A Enable | I | ENA must be HIGH to enable a LOW-to-HIGH transition of CLKA to read or write data on port-A. | | ENB | Port-B Enable | I | ENB must be HIGH to enable a LOW-to-HIGH transition of CLKB to read or write data on port-B. | | FF | Full Flag | 0 | $\overline{FF}$ is synchronized to the LOW-to-HIGH transition of CLKA. When $\overline{FF}$ is LOW, the FIFO is full, and writes to its memory are disabled. $\overline{FF}$ is forced LOW when the device is reset and is set HIGH by the second LOW-to-HIGH transition of CLKA after reset. | | FS1, FS0 | Flag-Offset Selects | I | The LOW-to-HIGH transition of RST latches the values of FS0 and FS1, which loads one of four preset values into the Almost-Full and Almost-Empty Offset register (X). | | MBA | Port-A Mailbox Select | - 1 | A HIGH level on MBA chooses a mailbox register for a port-A read or write operation. | | MBB | Port-B Mailbox Select | I | 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 the FIFO output register data for output. | | MBF1 | Mail1 Register Flag | 0 | MBF1 is set LOW by a LOW-to-HIGH transition of CLKA that writes data to the mail1 register. Writes to the mail1 register are inhibited while MBF1 is set LOW. 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 when the device is reset. | | MBF2 | Mail2 Register Flag | 0 | MBF2 is set LOW by a LOW-to-HIGH transition of CLKB that writes data to the mail2 register. Writes to the mail2 register are inhibited while MBF2 is LOW. MBF2 is set HIGH by a LOW-to-HIGH transition of CLKA when a port-A read is selected and MBA is HIGH. MBF2 is set HIGH when the device is reset. | | ODD/<br>EVEN | Odd/Even Parity<br>Select | I | Odd parity is checked on each port when ODD/EVEN is HIGH, and even parity is checked when ODD/EVEN is LOW. ODD/EVEN also selects the type of parity generated for each port if parity generation is enabled for a read operation. | | PEFA | Port-A Parity Error<br>Flag | O<br>[Port A) | When any byte applied to terminals A0-A35 fails parity, PEFA is LOW. Bytes are organized as A0-A8, A9-A17, A18-A26, and A27-A35, with the most significant bit of each byte serving as the parity bit. The type of parity checked is determined by the state of the ODD/EVEN input. The parity trees used to check the A0-A35 inputs are shared by the mail2 register to generate parity if parity generation is selected by PGA. Therefore, if a mail2 read with parity generation is setup by having CSA LOW, ENA HIGH, W/RA LOW, MBA HIGH, and PGA HIGH, the PEFA flag is forced HIGH regardless of the state of A0-A35 inputs. | ## PIN DESCRIPTION (CONTINUED) | Symbol | Name | I/O | Description | |--------|-----------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PEFB | Port-B Parity Error<br>Flag | O<br>(Port B) | When any byte applied to terminals B0-B35 fails parity, PEFB is LOW. Bytes are organized as B0-B8, B9-B17, B18-B26, B27-B35, with the most significant bit of each byte serving as the parity bit. The type of parity checked is determined by the state of the ODD/EVEN input. The parity trees used to check the B0-B35 inputs are shared by the mail1 register to generate parity if parity generation is selected by PGB. Therefore, if a mail1 read with parity generation is setup by having CSB LOW, ENB HIGH, W/RB LOW, MBB HIGH, and PGB HIGH, the PEFB flag is forced HIGH regardless of the state of the B0-B35 inputs | | PGA | Port-A Parity<br>Generation | I | Parity is generated for mail2 register reads from port A when PGA is HIGH. The type of parity generated is selected by the state of the ODD/EVEN input. Bytes are organized as A0-A8, A9-A17, A18-A26, and A27-A35. The generated parity bits are output in the most significant bit of each byte. | | PGB | Port-B Parity<br>Generation | I | Parity is generated for data reads from port B when PGB is HIGH. The type of parity generated is selected by the state of the ODD/EVEN input. Bytes are organized as B0-B8, B9-B17, B18-B26, and B27-B35. The generated parity bits are output in the most significant bit of each byte. | | RST | Reset | I | 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. This sets the AF, MBF1, and MBF2 flags HIGH and the EF, AE, and FF flags LOW. The LOW-to-HIGH transition of RST latches the status of the FS1 and FS0 inputs to select Almost-Full and Almost-Empty flag offset. | | W/RA | Port-A Write/Read<br>Select | I | A HIGH 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/RA is HIGH. | | W/RB | Port-B Write/Read<br>Select | I | A HIGH selects a write operation and a LOW 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 W/RB is HIGH. | ## ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (Unless otherwise noted)<sup>(1)</sup> | Symbol | Rating | Commercial | Unit | |-------------------|----------------------------------------------|-----------------|------| | Vcc | Supply Voltage Range | -0.5 to +4.6 | V | | VI <sup>(2)</sup> | Input Voltage Range | -0.5 to VCC+0.5 | V | | Vo <sup>(2)</sup> | Output Voltage Range | -0.5 to Vcc+0.5 | V | | lıĸ | Input Clamp Current, (VI < 0 or VI > VCC) | ±20 | mA | | Іок | Output Clamp Current, (Vo = < 0 or Vo > Vcc) | ±50 | mA | | lout | Continuous Output Current, (Vo = 0 to Vcc) | ±50 | mA | | Icc | Continuous Current Through Vcc or GND | ±500 | mA | | Tstg | Storage Temperature Range | -65 to 150 | °C | #### NOTES: ## RECOMMENDED OPERATING CONDITIONS | Symbol | Parameter | Min. | Тур. | Max. | Unit | |--------|-----------------------------------|------|------|---------|------| | Vcc | Supply Voltage | 3.0 | 3.3 | 3.6 | V | | ViH | High-Level Input Voltage | 2 | _ | Vcc+0.5 | ٧ | | VIL | Low-Level Input Voltage | _ | _ | 0.8 | ٧ | | Іон | High-Level Output Current | _ | _ | -4 | mA | | lol | Low-Level Output Current | _ | _ | 8 | mA | | TA | Operating Free-Air<br>Temperature | 0 | ı | 70 | °C | # ELECTRICAL CHARACTERISTICS OVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE (Unless otherwise noted) | | | | | C | IDT72V3611<br>Commercial<br>tclk = 15, 20 ns | | | | |--------------------|-----------------------------------|-------------|----------------------|------|----------------------------------------------|------|------|--| | Symbol | Parameter | | Test Conditions | Min. | Typ. <sup>(1)</sup> | Max. | Unit | | | Vон | Output Logic "1" Voltage | Vcc = 3.0V, | IOH = -4 mA | 2.4 | _ | _ | V | | | Vol | Output Logic "0" Voltage | Vcc = 3.0V, | IOL = 8 mA | _ | _ | 0.5 | V | | | lu | Input Leakage Current (Any Input) | Vcc = 3.6V, | VI = VCC or 0 | T — | _ | ±5 | μА | | | llo | Output Leakage Current | Vcc = 3.6V, | Vo = Vcc or 0 | T — | _ | ±5 | μА | | | ICC <sup>(2)</sup> | Standby Current | Vcc = 3.6V, | VI = VCC - 0.2V or 0 | _ | _ | 500 | μΑ | | | CIN | Input Capacitance | VI = 0, | f = 1 MHz | | 4 | _ | pF | | | Соит | Output Capacitance | Vo = 0, | f = 1 MHZ | | 8 | _ | pF | | <sup>1.</sup> 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. <sup>2.</sup> The input and output voltage ratings may be exceeded provided the input and output current ratings are observed. <sup>1.</sup> All typical values are at Vcc = 3.3V, TA = 25°C. <sup>2.</sup> For additional Icc information, see Figure 1, Typical Characteristics: Supply Current (Icc) vs. Clock Frequency (fs). ### DETERMINING ACTIVE CURRENT CONSUMPTION AND POWER DISSIPATION The Icc (f) data for the graph was taken while simultaneously reading and writing the FIFO on the IDT72V3611 with CLKA and CLKB operating at frequency 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 is known, the power dissipation can be calculated with the equation below. ### **CALCULATING POWER DISSIPATION** With ICC(f) taken from Figure 1, the maximum power dissipation (PT) of the IDT72V3611 may be calculated by: $PT = VCC x ICC(f) + \Sigma(CL x (VOH - VOL)^2 x fo)$ where: N = number of outputs = 36 CL = output capacitance load fo = switching frequency of an output VOH = output high-level voltage VOL = output low-level voltage When no read or writes are occurring on this device, the power dissipated by a single clock (CLKA or CLKB) input running at frequency fs is calculated by: PT = VCC x fs x 0.025 mA/MHz Figure 1. Typical Characteristics: Supply Current (Icc) vs. Clock Frequency (fs) ## TIMING REQUIREMENTS OVER RECOMMENDED RANGES OF SUPPLY VOLTAGE AND OPERATING FREE-AIR TEMPERATURES | | | IDT72V | 3611L15 | IDT72V3 | | | |-------------------------|---------------------------------------------------------------------|--------|---------|---------|------|------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Unit | | fs | Clock Frequency, CLKA or CLKB | - | 66.7 | - | 50 | Mhz | | tclk | Clock Cycle Time, CLKA or CLKB | 15 | - | 20 | - | Mhz | | tclkh | Pulse Duration, CLKA or CLKB HIGH | 6 | - | 8 | - | ns | | tclkl | Pulse Duration, CLKA or CLKB LOW | 6 | - | 8 | - | ns | | tDS | Setup Time, A0-A35 before CLKA↑ and B0-B35 before CLKB↑ | 4 | - | 5 | - | ns | | tens1 | CSA, W/RA, before CLKA↑; CSB, W/RB before CLKB↑ | 6 | _ | 6 | _ | ns | | tENS2 | ENA before CLKA↑; ENB before CLKB↑ | 4 | - | 5 | _ | ns | | tENS3 | MBA before CLKA↑; ENB before CLKB↑ | 4 | - | 5 | - | ns | | tpgs | Setup Time, ODD/EVEN and PGB before CLKB <sup>1</sup> | 4 | _ | 5 | _ | ns | | trsts | Setup Time, <del>RST</del> LOW before CLKA↑ or CLKB↑ <sup>(2)</sup> | 5 | _ | 6 | _ | ns | | tFSS | Setup Time, FS0 and FS1 before RST HIGH | 5 | _ | 6 | _ | ns | | tDH | Hold Time, A0-A35 after CLKA↑ and B0-B35 after CLKB↑ | 1 | - | 1 | _ | ns | | tenh1 | CSA, W/RA after CLKA↑; CSB, W/RB after CLKB↑ | 1 | _ | 1 | _ | ns | | tENH2 | ENA after CLKA1; ENB after CLKB1 | 1 | | 1 | | ns | | tENH3 | MBA after CLKA↑; MBB after CLKB↑ | 1 | | 1 | | ns | | tpgh | Hold Time, ODD/EVEN and PGB after CLKB <sup>↑(1)</sup> | 0 | - | 0 | _ | ns | | trsth | Hold Time, RST LOW after CLKA↑ or CLKB↑(2) | 6 | - | 6 | _ | ns | | tfsh | Hold Time, FS0 and FS1 after RST HIGH | 4 | - | 4 | _ | ns | | tskew1 <sup>(3)</sup> | Skew Time, between CLKA↑ and CLKB↑ for EF, FF | 8 | - | 8 | - | ns | | tskew2 <sup>(3,4)</sup> | Skew Time, between CLKA↑ and CLKB↑ for ĀĒ, ĀĒ | 14 | - | 16 | - | ns | - 1. Only applies for a rising edge of CLKB that does a FIFO read. $\label{eq:clkb}$ - 2. Requirement to count the clock edge as one of at least four needed to reset a FIFO. - 3. 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. - 4. Design simulated, not tested. ## SWITCHING CHARACTERISTICS OVER RECOMMENDED RANGES OF SUPPLY VOLTAGE AND OPERATING FREE-AIR TEMPERATURE, CL = 30 pF | | <del></del> | <del></del> | AI OILL, | | - Р- | | |----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------|---------|------|------| | | | IDT72V | 3611L15 | IDT72V3 | ] | | | Symbol | Parameter | Min. | Max. | Min. | Max. | Unit | | fs | Clock Frequency, CLKA or CLKB | _ | 66.7 | _ | 50 | MHz | | tA | Access Time, CLKB↑ to B0-B35 | 2 | 10 | 2 | 12 | ns | | twff | Propagation Delay Time, CLKA↑ to FF | 2 | 10 | 2 | 12 | ns | | tref | Propagation Delay Time, CLKB↑ to EF | 2 | 10 | 2 | 12 | ns | | <b>t</b> PAE | Propagation Delay Time, CLKB↑ to AE | 2 | 10 | 2 | 12 | ns | | tpaf | Propagation Delay Time, CLKA↑ to AF | 2 | 10 | 2 | 12 | ns | | tPMF | Propagation Delay Time, CLKA↑ to MBF1 LOW or MBF2 HIGH and CLKB↑ to MBF2 LOW or MBF1 HIGH | 1 | 9 | 1 | 12 | ns | | tPMR | Propagation Delay Time, CLKA <sup>↑</sup> to B0-B35 <sup>(1)</sup> and CLKB <sup>↑</sup> to A0-A35 <sup>(2)</sup> | 2 | 10 | 3 | 12 | ns | | tmdv | Propagation Delay Time, MBB to B0-B35 Valid | 1 | 10 | 1 | 11.5 | ns | | tPDPE | Propagation Delay Time, A0-A35 Valid to PEFA Valid; B0-B35 Valid to PEFB Valid | 2 | 10 | 2 | 11 | ns | | tpope | Propagation Delay Time, ODD/EVEN to PEFA and PEFB | 2 | 10 | 2 | 12 | ns | | tPOPB <sup>(3)</sup> | Propagation Delay Time, ODD/EVEN to Parity<br>Bits (A8, A17, A26, A35) and (B8, B17, B26, B35) | 2 | 10 | 2 | 12 | ns | | tpepe | Propagation Delay Time, CSA, ENA, W/RA,<br>MBA, or PGA to PEFA; CSB, ENB, W/RB,<br>MBB, or PGB to PEFB | 1 | 10 | 1 | 12 | ns | | tPEPB <sup>(3)</sup> | Propagation Delay Time, $\overline{CSA}$ , ENA W/ $\overline{R}A$ , MBA, or PGA to Parity Bits (A8, A17, A26, A35); $\overline{CSB}$ , ENB, W/ $\overline{R}B$ , MBB, or PGB to Parity Bits (B8, B17, B26, B35) | 2 | 10 | 2 | 12 | ns | | trsf | Propagation Delay Time, RST to AE LOW and (AF, MBF1, MBF2) HIGH | 1 | 15 | 1 | 20 | ns | | ten | Enable Time, $\overline{\text{CSA}}$ and $W/\overline{\text{RA}}$ LOW to A0-A35 Active and $\overline{\text{CSB}}$ LOW and $\overline{W}/\overline{\text{RB}}$ HIGH to B0-B35 Active | 2 | 10 | 2 | 12 | ns | | tdis | Disable Time, $\overline{\text{CSA}}$ or $W/\overline{\text{RA}}$ HIGH to A0-A35 at high impedance and $\overline{\text{CSB}}$ HIGH or $\overline{W}/\text{RB}$ LOW to B0-B35 at high impedance | 1 | 9 | 1 | 10 | ns | - 1. Writing data to the mail 1 register when the B0-B35 outputs are active and MBB is HIGH. - 2. Writing data to the mail2 register when the A0-A35 outputs are active and MBA is HIGH. - 3. Only applies when reading data from a mail register. ## SIGNAL DESCRIPTION ## RESET (RST) The IDT72V3611 is reset by taking the Reset ( $\overline{RST}$ ) input LOW for at least four port-A clock (CLKA) and four port B clock (CLKB) LOW-to-HIGH transitions. The reset input can switch asynchronously to the clocks. A device reset initializes the internal read and write pointers of the FIFO and forces the Full Flag ( $\overline{FF}$ ) LOW, the Empty Flag ( $\overline{EF}$ ) LOW, the Almost-Emptyflag ( $\overline{AE}$ ) LOW, and the Almost-Full flag ( $\overline{AF}$ ) HIGH. A reset also forces the Mailbox Flags ( $\overline{MBF1}$ , $\overline{MBF2}$ ) HIGH. After a reset, $\overline{FF}$ is set HIGH after two LOW-to-HIGH transitions of CLKA. The device must be reset after power up before data is written to its memory. A LOW-to-HIGH transition on the $\overline{RST}$ input loads the Almost-Full and Almost-Empty Offset register (X) with the value selected by the Flag Select ## **TABLE 1 – FLAG PROGRAMMING** | Almost-Full and<br>Almost-Empty Flag<br>Offset Register (X) | FS1 | FS0 | RST | |-------------------------------------------------------------|-----|-----|----------| | 16 | Н | Н | <b>↑</b> | | 12 | Н | L | <b>↑</b> | | 8 | L | Н | <b>↑</b> | | 4 | L | L | 1 | (FS0, FS1) inputs. The values that can be loaded into the register are shown in Table 1. For the relevant Reset timing and preset value loading timing diagram, see Figure 2. The relevant Write timing diagram for Port A can be found in Figure 3. ### 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{R}A$ ). The A0-A35 outputs are in the high-impedance state when either $\overline{CSA}$ or $W|\overline{R}A$ is HIGH. The A0-A35 outputs are active when both $\overline{CSA}$ and $W|\overline{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{CSA}$ is LOW, $W|\overline{R}A$ is HIGH, ENA is HIGH, MBA is LOW, and $\overline{FF}$ is HIGH (see Table 2). The port-B control signals are identical to those of port A. The state of the port-B data (B0-B35) outputs is controlled by the port-B Chip Select ( $\overline{CSB}$ ) and the port-B Write/Read select ( $\overline{W/RB}$ ). The B0-B35 outputs are in the high-impedance state when either $\overline{CSB}$ or $\overline{W/RB}$ is HIGH. The B0-B35 outputs are active when both $\overline{CSB}$ and $\overline{W/RB}$ are LOW. Data is read from the FIFO to the B0-B35 outputs by a LOW-to-HIGH transition of CLKB when $\overline{CSB}$ is LOW, $\overline{W/RB}$ is LOW, ENB is HIGH, MBB is LOW, and $\overline{EF}$ is HIGH (see Table 3). The relevant Read timing diagram for Port B can be found in Figure 4. The setup and hold-time constraints to the port clocks for the port Chip Selects ( $\overline{CSA}$ , $\overline{CSB}$ ) and Write/Read selects ( $W/\overline{RA}$ , $W/\overline{RB}$ ) are only for enabling write and read operations and are not related to HIGH-impedance control of the data outputs. If a port enable is LOW during a clock cycle, the port's Chip Select and Write/Read select can change states during the setup and hold-time window of the cycle. ## TABLE 2 – PORT-A ENABLE FUNCTION TABLE | CSA | W/RA | ENA | MBA | CLKA | Data A (A0-A35) I/O | Port Functions | |-----|------|-----|-----|----------|---------------------|----------------------------| | Н | Х | Х | Х | Х | Input | None | | L | Н | L | Х | Х | Input | None | | L | Н | Н | L | 1 | Input | FIFO Write | | L | Н | Н | Н | 1 | Input | Mail1 Write | | L | L | L | L | Х | Output | None | | L | L | Н | L | <b>↑</b> | Output | None | | L | Ĺ | Ĺ | Н | Х | Output | None | | L | L | Н | Н | <b>↑</b> | Output | Mail2 Read (set MBF2 HIGH) | ## **TABLE 3 – PORT-B ENABLE FUNCTION TABLE** | IADEL | | OKI D ENABLE I GNOTION TABLE | | | | | | | |-------|------|------------------------------|-----|------|---------------------|----------------------------|--|--| | CSB | W/RB | ENB | MBB | CLKB | Data B (B0-B35) I/O | Port Functions | | | | Н | Х | Х | Х | Х | Input | None | | | | L | Н | L | Х | Х | Input | None | | | | L | Н | Н | L | 1 | Input | None | | | | L | Н | Н | Н | 1 | Input | Mail2 Write | | | | L | L | L | L | Х | Output | None | | | | L | L | Н | L | 1 | Output | FIFO Read | | | | L | L | L | Н | Х | Output | None | | | | L | L | Н | Н | 1 | Output | Mail1 Read (set MBF1 HIGH) | | | | 1 | I | I | I | I | | | | | #### SYNCHRONIZED FIFO FLAGS Each FIFO flag is synchronized to its port clock through 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. $\overline{\text{FF}}$ and $\overline{\text{AF}}$ are synchronized to CLKA. $\overline{\text{EF}}$ and $\overline{\text{AE}}$ are synchronized to CLKB. Table 4 shows the relationship to the flags to the FIFO. ## EMPTY FLAG (EF) The FIFO Empty Flag is synchronized to the port clock that reads data from its array (CLKB). When the $\overline{\text{EF}}$ is HIGH, new data can be read to the FIFO output register. When the $\overline{\text{EF}}$ is LOW, the FIFO is empty and attempted FIFO reads are ignored. The FIFO read pointer is incremented each time a new word is clocked to its output register. The state machine that controls an $\overline{\sf EF}$ monitors a write pointer and read pointer comparator that indicates when the FIFO memory status is empty, empty+1, or empty+2. A word written to the FIFO can be read to the FIFO output register in a minimum of three port-B clock (CLKB) cycles. Therefore, an $\overline{\sf EF}$ is LOW if a word in memory is the next data to be sent to the FIFO output register and two CLKB cycles have not elapsed since the time the word was written. The $\overline{\sf EF}$ of the FIFO is set HIGH by the second LOW-to-HIGH transition of CLKB, and the new data word can be read to the FIFO output register in the following cycle. A LOW-to-HIGH transition on CLKB begins the first synchronized cycle of a write if the clock transition occurs at time tskew1 or greater after the write. Otherwise, the subsequent CLKB cycle can be the first synchronization cycle (see Figure 5). ## FULL FLAG (FF) The FIFO Full Flag is synchronized to the port clock that writes data to its array (CLKA). When the $\overline{\text{FF}}$ is HIGH, a FIFO memory location is free to receive new data. No memory locations are free when the $\overline{\text{FF}}$ is LOW and attempted writes to the FIFO are ignored. Each time a word is written to the FIFO, its write pointer is incremented. The state machine that controls the $\overline{FF}$ monitors a write pointer and read pointer comparator that indicates when the FIFO memory status is full, full-1, or full-2. From the time a word is read from the FIFO, its previous memory location is ready to be written in a minimum of three port-A clock cycles. Therefore, a $\overline{FF}$ is LOW if less than two CLKA cycles have elapsed since the next memory write location has been read. The second LOW-to-HIGH transition on CLKA after the read sets the $\overline{FF}$ HIGH and data can be written in the following clock cycle. **TABLE 4 – FIFO FLAG OPERATION** | Number of Words | 1 | ronized<br>CLKB | Synchronized to CLKA | | | |---------------------|----|-----------------|----------------------|----|--| | in the FIFO | ĒĒ | ĀĒ | ĀF | FF | | | 0 | L | L | Н | Н | | | 1 to X | Н | L | Н | Н | | | (X+1) to [64-(X+1)] | Н | Н | Н | Н | | | (64-X) to 63 | Н | Н | L | Н | | | 64 | Н | Н | L | L | | #### NOTE: 1. X is the value in the Almost-Empty flag and Almost-Full flag register. 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 clock cycle can be the first synchronization cycle (see Figure 6). ## ALMOST-EMPTY FLAG (AE) The FIFO Almost-Empty flag is synchronized to the port clock that reads data from its array (CLKB). The state machine that controls the $\overline{AE}$ flag monitors a write pointer and read pointer comparator that indicates when the FIFO memory status is almost-empty, almost-empty+1, or almost-empty+2. The almost-empty state is defined by the value of the Almost-Full and Almost-Empty Offset register (X). This register is loaded with one of four preset values during a device reset (see the Reset section). The $\overline{AE}$ flag is LOW when the FIFO contains X or less words in memory and is HIGH when the FIFO contains (X+1) or more words. Two LOW-to-HIGH transitions on the port-B clock (CLKB) are required after a FIFO write for the $\overline{AE}$ flag to reflect the new level of fill. Therefore, the $\overline{AE}$ flag of a FIFO containing (X+1) or more words remains LOW if two CLKB cycles have not elapsed since the write that filled the memory to the (X+1) level. The $\overline{AE}$ flag is set HIGH by the second CLKB LOW-to-HIGH transition after the FIFO write that fills memory to the (X+1) level. A LOW-to-HIGH transition on 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 can be the first synchronization cycle (see Figure 7). ### ALMOST-FULL FLAG (AF) The FIFO Almost-Full flag is synchronized to the port clock that writes data to its array (CLKA). The state machine that controls an $\overline{AF}$ flag monitors a write pointer and read pointer comparator that indicates when the FIFO memory status is almost-full, almost-full-1, or almost-full-2. The almost-full state is defined by the value of the Almost-Full and Almost-Empty Offset register (X). This register is loaded with one of four preset values during a device reset (see the Reset section). The $\overline{AF}$ flag is LOW when the FIFO contains (64-X) or more words in memory and is HIGH when the FIFO contains [64-(X+1)] or less words. Two LOW-to-HIGH transitions on the port-A clock (CLKA) are required after a FIFO read for the $\overline{AF}$ flag to reflect the new level of fill. Therefore, the $\overline{AF}$ flag of a FIFO containing [64-(X+1)] or less words remains LOW if two CLKA cycles have not elapsed since the read that reduced the number of words in memory to [64-(X+1)]. The $\overline{AF}$ flag is set HIGH by the second CLKA LOW-to-HIGH transition after the FIFO read that reduces the number of words in memory to [64-(X+1)]. A LOW-to-HIGH transition on 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 [64-(X+1)]. Otherwise, the subsequent CLKA cycle can be the first synchronization cycle (see Figure 8). #### **MAILBOX REGISTERS** Two 36-bit bypass registers are on the IDT72V3611 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 port-A write is selected by $\overline{\text{CSA}}$ , W/\$\bar{\text{R}}\$A, and ENA with MBA HIGH. A LOW-to-HIGH transition on CLKB writes B0-B35 data to the mail2 register when port-B write is selected by \$\bar{\text{CSB}}\$, W/\$\bar{\text{R}}\$B, and ENB with MBB HIGH. Writing data to a mail register sets its corresponding flag (\$\bar{\text{MBF1}}\$ or \$\bar{\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 (MBF1) is set HIGH by a LOW-to-HIGH transition on CLKB when a port-B read is selected by $\overline{\text{CSB}}$ , W/ $\overline{\text{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{\text{CSA}}$ , W/ $\overline{\text{RA}}$ , 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. For relevant mail register and mail register flag timing diagrams, see Figure 9 and Figure 10. #### **PARITY CHECKING** The port-A (A0-A35) inputs and port-B (B0-B35) inputs each have four parity trees to check the parity of incoming (or outgoing) data. A parity failure on one or more bytes of the input bus is reported by a LOW level on the port Parity Error Flag (PEFA, PEFB). Odd or even parity checking can be selected, and the Parity Error Flags can be ignored if this feature is not desired. Parity status is checked on each input bus according to the level of the Odd/ Even parity (ODD/ $\overline{\text{EVEN}}$ ) select input. A parity error on one or more bytes of a port is reported by a LOW level on the corresponding port Parity Error Flag ( $\overline{\text{PEFA}}$ , $\overline{\text{PEFB}}$ ) output. Port-A bytes are arranged as A0-A8, A9-A17, A18-A26, and A27-A35, and port-B bytes are arranged as B0-B8, B9-B17, B18-B26, and B27-B35. When Odd/Even parity is selected, a port Parity Error Flag ( $\overline{\text{PEFA}}$ , $\overline{\text{PEFB}}$ ) is LOW if any byte on the port has an odd/even number of LOW levels applied to its bits. The four parity trees used to check the A0-A35 inputs are shared by the mail2 register when parity generation is selected for port-A reads (PGA=HIGH). When port-A read from the mail2 register with parity generation is selected with $\overline{\text{CSA}}$ LOW, ENA HIGH, W/ $\overline{\text{RA}}$ LOW, MBA HIGH, and PGA HIGH, the port-A Parity Error Flag ( $\overline{\text{PEFA}}$ ) is held HIGH regardless of the levels applied to the A0-A35 inputs. Likewise, the parity trees used to check the B0-B35 inputs are shared by the mail1 register when parity generation is selected for port-B reads (PGB=HIGH). When a port-B read from the mail1 register with parity generation is selected with $\overline{\text{CSB}}$ LOW, ENB HIGH, W/ $\overline{\text{RB}}$ B LOW, MBB HIGH, and PGB HIGH, the port-B Parity Error Flag (PEFB) is held HIGH regardless of the levels applied to the B0-B35 inputs. #### **PARITY GENERATION** A HIGH level on the port-A Parity Generate select (PGA) or port-B Parity Generate select (PGB) enables the IDT72V3611 to generate parity bits for portreads from a FIFO or mailbox register. Port-A bytes are arranged as A0-A8, A9-A17, A18-A26, and A27-A35, with the most significant bit of each byte used as the parity bit. Port-B bytes are arranged as B0-B8, B9-B17, B18-B26, and B27-B35, with the most significant bit of each byte used as the parity bit. A write to a FIFO or mail register stores the levels applied to all thirty-six inputs regardless of the state of the Parity Generate select (PGA, PGB) inputs. When data is read from a port with parity generation selected, the lower eight bits of each byte are used to generate a parity bit according to the level on the ODD/EVEN select. The generated parity bits are substituted for the levels originally written to the most significant bits of each byte as the word is read to the data outputs. Parity bits for FIFO data are generated after the data is read from the FIFO RAM and before the data is written to the output register. Therefore, the port-B Parity Generate select (PGB) and ODD/EVEN have setup and hold time constraints to the port-B clock (CLKB) for a rising edge of CLKB used to read a new word to the FIFO output register. The circuit used to generate parity for the mail1 data is shared by the port-B bus (B0-B35) to check parity and the circuit used to generate parity for the mail2 data is shared by the port-A bus (A0-A35) to check parity. The shared parity trees of a port are used to generate parity bits for the data in a mail register when the port Write/Read select (W/RA, W/RB) input is LOW, the port Mail select (MBA, MBB) input is HIGH, Chip Select ( $\overline{CSA}$ , $\overline{CSB}$ ) is LOW, Enable (ENA, ENB) is HIGH, and the port Parity Generate select (PGA, PGB) is HIGH. Generating parity for mail register data does not change the contents of the register (see Figure 13 and Figure 14). Figure 2. Device Reset and Loading the X Register with the Value of Eight 4657 drw 05 **◆** tpae**→** ◆ tPAF-> tRSF → Figure 3. FIFO Write Cycle Timing Figure 4. FIFO Read Cycle Timing 1. ISKEW1 is the minimum time between a rising CLKA edge and a rising CLKB edge for EF to transition HIGH in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tskew1, then the transition of EF HIGH may occur one CLKB cycle later than shown. Figure 5. **EF** Flag Timing and First Data Read when the FIFO is Empty #### NOTE: Figure 6. FF Flag Timing and First Available Write when the FIFO is Full - 1. tskewa is the minimum time between a rising CLKA edge and a rising CLKB edge for AE 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{AE}$ may transition HIGH one CLKB cycle later than shown. 2. FIFO write $(\overline{CSA} = L, W/\overline{R}A = H, MBA = L)$ , FIFO read $(\overline{CSB} = L, W/\overline{R}B = L, MBB = L)$ . Figure 7. Timing for $\overline{AE}$ when the FIFO is Almost-Empty <sup>1.</sup> tskewi is the minimum time between a rising CLKB edge and a rising CLKA edge for FF to transition HIGH in the next CLKA cycle. If the time between the rising CLKB edge and rising CLKA edge is less than tskew1, then the transition of FF HIGH may occur one CLKA cycle later than shown. #### NOTES: - 1. tskewz 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 CLKA edge and rising CLKB edge is less than tskewz, then $\overline{AF}$ may transition HIGH one CLKA cycle later than shown. - 2. FIFO write $(\overline{CSA} = L, W/\overline{R}A = H, MBA = L)$ , FIFO read $(\overline{CSB} = L, W/\overline{R}B = L, MBB = L)$ . Figure 8. Timing for AF when the FIFO is Almost-Full #### NOTE: 1. Port-B parity generation off (PGB = L) Figure 9. Timing for Mail1 Register and MBF1 Flag NOTE: 1. $\overline{\text{CSA}} = L$ and ENA = H. Figure 11. ODD/EVEN, W/RA, MBA, and PGA to PEFA Timing 4657 drw 14 1. $\overline{\text{CSB}} = L$ and $\overline{\text{ENB}} = H$ . Figure 12. ODD/EVEN, W/RB, MBB, and PGB to PEFB Timing 1. ENB = H. Figure 13. Parity Generation Timing when reading from the Mail2 Register Figure 14. Parity Generation Timing when reading from the Mail1 Register ## PARAMETER MEASUREMENT INFORMATION #### NOTE: 1. Includes probe and jig capacitance. Figure 15. Load Circuit and Voltage Waveforms ## **ORDERING INFORMATION** #### NOTE: 1. Industrial temperature range is available by special order. ## **DATASHEET DOCUMENT HISTORY** 07/10/2000 pg. 1 05/27/2003 pg. 6. CORPORATE HEADQUARTERS 2975 Stender Way Santa Clara, CA 95054 for SALES: 800-345-7015 or 408-727-6116 fax: 408-492-8674 www.idt.com for Tech Support: 408-330-1753 email: FIFOhelp@idt.com