# 512 x 18, 1K x 18, and 2K x 18 Cascadable Clocked FIFOs with Programmable Flags #### **Features** - High-speed, low-power, first-in first-out (FIFO) memories - 512 x 18 (CY7C455) - 1,024 x 18 (CY7C456) - 2,048 x 18 (CY7C457) - 0.65 micron CMOS for optimum speed/power - High-speed 83-MHz operation (12 ns read/write cycle time) - Low power I<sub>CC</sub>=90 mA - Fully asynchronous and simultaneous read and write operation - Empty, Full, Half Full, and programmable Almost Empty and Almost Full status flags - TTL compatible - · Retransmit function - · Parity generation/checking - Output Enable (OE) pins - Independent read and write enable pins - · Center power and ground pins for reduced noise - · Supports free-running 50% duty cycle clock inputs - Width Expansion Capability - · Depth Expansion Capability - 52-pin PLCC and 52-pin PQFP ### **Functional Description** The CY7C455, CY7C456, and CY7C457 are high-speed, low-power, first-in first-out (FIFO) memories with clocked read and write interfaces. All are 18 bits wide. The CY7C455 has a 512-word memory array, the CY7C456 has a 1,024-word memory array, and the CY7C457 has a 2,048-word memory array. The CY7C455, CY7C456, and CY7C457 can be cascaded to increase FIFO depth. Programmable features include Almost Full/Empty flags and generation/checking of parity. These FIFOs provide solutions for a wide variety of data buffering needs, including high-speed data acquisition, multiprocessor interfaces, and communications buffering. These FIFOs have 18-bit input and output ports that are controlled by separate clock and enable signals. The input port is controlled by a free-running clock (CKW) and a write enable pin (ENW). ### Pin Configurations (continued) # Functional Description (continued) In the standalone and width expansion configurations, a LOW on the retransmit (RT) input causes the FIFOs to retransmit the data. Read enable (ENR) and the write enable (ENW) must both be HIGH during the retransmit, and then ENR is used to access the data. When ENW is asserted, data is written into the FIFO on the rising edge of the CKW signal. While $\overline{\text{ENW}}$ is held active, data is continually written into the FIFO on each CKW cycle. The output port is controlled in a similar manner by a free-running read clock (CKR) and a read enable pin (ENR). In addition, the CY7C455, CY7C456, and CY7C457 have an output enable pin (OE). The read (CKR) and write (CKW) clocks may be tied together for single-clock operation or the two clocks may be run independently for asynchronous read/write applications. Clock frequencies up to 83.3 MHz are achievable in the standalone configuration, and up to 83.3 MHz is achievable when FIFOs are cascaded for depth expan- Depth expansion is possible using the cascade input $(\overline{XI})$ , cascade output $(\overline{XO})$ , and First Load $(\overline{FL})$ pins. The $\overline{XO}$ pin is connected to the $\overline{XI}$ pin of the next device, and the $\overline{XO}$ pin of the last device should be connected to the $\overline{XI}$ pin of the first device. The $\overline{FL}$ pin of the first device is tied to $V_{SS}$ . The CY7C455, CY7C456, and CY7C457 provide three status pins. These pins are decoded to determine one of six states: Empty, Almost Empty, Less than or Equal to Half Full, Greater than Half Full, Almost Full, and Full (see *Table 1*). The Almost Empty/Full flag ( $\overline{PAFE}$ ) shares the $\overline{XO}$ pin on the CY7C455, CY7C456, and CY7C457. This flag is valid in the standalone and width-expansion configurations. In the depth expansion, this pin provides the expansion out ( $\overline{XO}$ ) information that is used to signal the next FIFO when it will be activated. The flags are synchronous, i.e., they change state relative to either the read clock (CKR) or the write clock (CKW). When entering or exiting the Empty and Almost Empty states, the flags are updated exclusively by the CKR. The flags denoting Half Full, Almost Full, and Full states are updated exclusively by CKW. The synchronous flag architecture guarantees that the flags maintain their status for some minimum time. This time is typically equal to approximately one cycle time. The CY7C455/6/7 uses center power and ground for reduced noise. All configurations are fabricated using an advanced 0.65u CMOS technology. Input ESD protection is greater than 2001V, and latch-up is prevented by the use of guard rings. ### **Selection Guide** | | | 7C455/6/7-12 | 7C455/6/7-14 | 7C455/6/7-20 | 7C455/6/7-30 | |-------------------------|------------------|--------------|--------------|--------------|--------------| | Maximum Frequency (MHz) | | 83.3 | 71.4 | 50 | 33.3 | | Maximum Cascadable | e Frequency | 83.3 | 71.4 | 50 | 33.3 | | Maximum Access Tim | ne (ns) | 9 | 10 | 15 | 20 | | Minimum Cycle Time | (ns) | 12 | 14 | 20 | 30 | | Minimum Clock HIGH | Time (ns) | 5 | 6.5 | 9 | 12 | | Minimum Clock LOW | Time (ns) | 5 | 6.5 | 9 | 12 | | Minimum Data or Ena | ıble Set-Up (ns) | 4 | 5 | 6 | 7 | | Minimum Data or Ena | ble Hold (ns) | 0 | 0 | 0 | 0 | | Maximum Flag Delay (ns) | | 9 | 10 | 15 | 20 | | Maximum Current | Commercial | 160 | 160 | 140 | 120 | | (mA) | Industrial | 180 | 180 | 160 | 140 | ### Selection Guide (continued) | | CY7C455 | CY7C456 | CY7C457 | |----------------------|------------------|------------------|------------------| | Density | 512 x 18 | 1,024 x 18 | 2,048 x 18 | | OE, Depth Cascadable | Yes | Yes | Yes | | Package | 52-Pin PLCC/PQFP | 52-Pin PLCC/PQFP | 52-Pin PLCC/PQFP | ## **Maximum Ratings** Storage Temperature ......-65 $^{\circ}$ C to +150 $^{\circ}$ C | Ambient Temperature with Power Applied | 55°C to +125°C | |----------------------------------------|----------------| | Supply Voltage to Ground Potential | 0.5V to +7.0V | | DC Voltage Applied to Outputs | | | in High Z State | –0.5V to +7.0V | | DC Input Voltage | 3.0V to +7.0V | Output Current into Outputs (LOW) ......20 mA Static Discharge Voltage ......>2001V (per MIL-STD-883, Method 3015) Latch-Up Current .....>200 mA # **Operating Range** | Range | Ambient<br>Temperature | v <sub>cc</sub> | | | |---------------------------|------------------------|-----------------|--|--| | Commercial | 0°C to +70°C | 5V ± 10% | | | | Industrial <sup>[1]</sup> | –40°C to +85°C | 5V ± 10% | | | #### Note <sup>1.</sup> T<sub>A</sub> is the "instant on" case temperature. # **Pin Definitions** | Signal Name | 1/0 | Description | |---------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D <sub>0 - 17</sub> | I | Data Inputs: When the FIFO is not full and $\overline{\text{ENW}}$ is active, CKW (rising edge) writes data (D <sub>0-17</sub> ) into the FIFO's memory. If $\overline{\text{MR}}$ is asserted at the rising edge of CKW, data is written into the FIFO's programming register. D <sub>8</sub> , <sub>17</sub> are ignored if the device is configured for parity generation. | | $Q_{0-7} \\ Q_{9-16}$ | 0 | Data Outputs: When the FIFO is not empty and $\overline{\text{ENR}}$ is active, CKR (rising edge) reads data (Q <sub>0-7</sub> , Q <sub>9-16</sub> ) out of the FIFO's memory. If $\overline{\text{MR}}$ is active at the rising edge of CKR, data is read from the programming register. | | Q <sub>8</sub> /PG1/ <u>PE1</u><br>Q <sub>17</sub> /PG2/ <u>PE2</u> | 0 | Function varies according to mode: Parity disabled – same function as $Q_{0-7}$ and $Q_{9-16}$ Parity enabled, generation – parity generation bit (PG <sub>x</sub> ) Parity enabled, check – Parity Error Flag ( $\overline{PE}_x$ ) | | ENW | - | Enable Write: Enables the CKW input (for both non-program and program modes). | | ENR | ı | Enable Read: Enables the CKR input (for both non-program and program modes). | | CKW | I | Write Clock: The rising edge clocks data into the FIFO when $\overline{\text{ENW}}$ is LOW; updates Half Full, Almost Full, and Full flag states. When $\overline{\text{MR}}$ is asserted, CKW writes data into the program register. | | CKR | I | Read Clock: The rising edge clocks data out of the FIFO when $\overline{\sf ENR}$ is LOW; updates the Empty and Almost Empty flag states. When $\overline{\sf MR}$ is asserted, CKR reads data out of the program register. | | HF | 0 | Half Full Flag: Synchronized to CKW. | | Ē/F | 0 | Empty or Full Flag: $\overline{E}$ is synchronized to CKR; $\overline{F}$ is synchronized to CKW. | | PAFE/XO | 0 | Dual-Mode Pin: Not Cascaded – programmable Almost Full is synchronized to CKW; Programmable Almost Empty is synchronized to CKR. Cascaded – expansion out signal, connected to $\overline{\text{XI}}$ of next device. | | XI | I | Expansion-In Pin: Not Cascaded $-\overline{XI}$ is tied to $V_{SS}$ . Cascaded $-$ expansion Input, connected to $\overline{XO}$ of previous device. | | FL/RT | I | First Load/Retransmit Pin: Cascaded – the first device in the daisy chain will have $\overline{FL}$ tied to $V_{SS}$ ; all other devices will have $\overline{FL}$ tied to $V_{CC}$ (Figure 1). Not Cascaded – tied to $V_{CC}$ . Retransmit function is also available in standalone mode by strobing $\overline{RT}$ . | | MR | _ | Master Reset: Resets device to empty condition. Non-Programming Mode: Program register is reset to default condition of no parity and $\overline{PAFE}$ active at 16 or less locations from Full/Empty. Programming Mode: Data present on D <sub>0 - 9,10, or 11</sub> and D <sub>15-17</sub> is written into the programmable register on the rising edge of CKW. Program register contents appear on Q <sub>0 - 9,10, or 11</sub> and Q <sub>15-17</sub> after the rising edge of CKR. | | ŌĒ | | Output Enable for Q <sub>0 - 7</sub> , Q <sub>9 - 16</sub> , Q <sub>8</sub> /PG1/PE1 and Q <sub>17</sub> /PG2/PE2 pins. | ### **Electrical Characteristics** Over the Operating Range | | | | | 5/6/7–<br>2 | 7C455/6/7-<br>14 | | 7C455/6/7-<br>20 | | 7C455/6/7-<br>30 | | | | |--------------------------------------|---------------------------------|-----------------------------------------------|----------------------------------|-------------|------------------|------|------------------|------|------------------|------|----------|----| | Parameter | Description | Test Condi | Min. | Max | Min. | Max | Min. | Max | Min. | Max | Unit | | | V <sub>OH</sub> | Output HIGH<br>Voltage | $V_{CC} = Min., I_{OH} =$ | = –2.0 mA | 2.4 | | 2.4 | | 2.4 | | 2.4 | | V | | V <sub>OL</sub> | Output LOW<br>Voltage | V <sub>CC</sub> = Min., I <sub>OL</sub> | = 8.0 mA | | 0.4 | | 0.4 | | 0.4 | | 0.4 | V | | V <sub>IH</sub> <sup>[2]</sup> | Input HIGH Voltage | | | 2.2 | $V_{CC}$ | 2.2 | $V_{CC}$ | 2.2 | V <sub>CC</sub> | 2.2 | $V_{CC}$ | V | | V <sub>IL</sub> [2] | Input LOW Voltage | | | | 0.8 | -0.5 | 0.8 | -0.5 | 0.8 | -0.5 | 0.8 | V | | I <sub>IX</sub> | Input Leakage<br>Current | V <sub>CC</sub> = Max. | | -10 | +10 | -10 | +10 | -10 | +10 | -10 | +10 | μА | | l <sub>OS</sub> <sup>[3]</sup> | Output Short<br>Circuit Current | $V_{CC} = Max., V_{OI}$ | <sub>JT</sub> = GND | -90 | | -90 | | -90 | | -90 | | mA | | I <sub>OZL</sub><br>I <sub>OZH</sub> | Output OFF, High Z<br>Current | $\overline{OE} \ge V_{IH}, V_{SS} <$ | V <sub>O</sub> < V <sub>CC</sub> | -10 | +10 | -10 | +10 | -10 | +10 | -10 | +10 | μΑ | | I <sub>CC1</sub> <sup>[4]</sup> | Operating Current | V <sub>CC</sub> = Max., | Com'l | | 160 | | 160 | | 140 | | 120 | mA | | | | $I_{OUT} = 0 \text{ mA}$ | Ind | | 180 | | 180 | | 160 | | 140 | mA | | I <sub>CC2</sub> <sup>[5]</sup> | Operating Current | V <sub>CC</sub> = Max., | Com'l | | 90 | | 90 | | 90 | | 90 | mA | | | | $I_{OUT} = 0 \text{ mA}$ | Ind | | 100 | | 100 | | 100 | | 100 | mA | | I <sub>SB</sub> <sup>[6]</sup> | Standby Current | $V_{CC} = Max.,$ $I_{OUT} = 0 \text{ mA}$ Ind | | | 40 | | 40 | | 40 | | 40 | mA | | | | | | | 40 | | 40 | | 40 | | 40 | mA | # Capacitance<sup>[7]</sup> | Parameter | Description | Test Conditions | Max. | Unit | |------------------|--------------------|-----------------------------------------|------|------| | C <sub>IN</sub> | Input Capacitance | $T_A = 25^{\circ}C, f = 1 \text{ MHz},$ | 10 | pF | | C <sub>OUT</sub> | Output Capacitance | $V_{CC} = 5.0V$ | 12 | pF | # AC Test Loads and Waveforms<sup>[8, 9, 10, 11, 12]</sup> Equivalent to: THÉVENIN EQUIVALENT $200\Omega$ OUTPUT - - The VIH and VIL specifications apply for all inputs except $\overline{XI}$ . The $\overline{XI}$ pin is not a TTL input. It is connected to either $\overline{XO}$ of the previous device or VSS. - Test no more than one output at a time for not more than one second. Input signals switch from 0V to 3V with a rise/fall time of less than 3 ns, clocks and clock enables switch at maximum frequency (f<sub>MAX</sub>), while data inputs switch at f<sub>MAX</sub>/2. Outputs are unloaded. - Input signals switch from 0V to 3V with a rise/fall time less than 3 ns, clocks and clock enables switch at 20 MHz, while the data inputs switch at 10 MHz. Outputs are unloaded. All input signals are connected to V<sub>CC</sub>. All outputs are unloaded. Read and write clocks switch at maximum frequency (f<sub>MAX</sub>). - Tested initially and after any design or process changes that may affect these parameters. $C_L = 30 \text{ pF}$ for all AC parameters except for $t_{OHZ}$ . - 9. C<sub>L</sub> = 5 pF for t<sub>OHZ</sub>. 10. All AC measurements are referenced to 1.5V except t<sub>OE</sub>, t<sub>OLZ</sub>, and t<sub>OHZ</sub>. - $t_{\text{OE}}$ and $t_{\text{OLZ}}$ are measured at $\pm$ 100 mV from the steady state. - 12. t<sub>OHZ</sub> is measured at +500 mV from V<sub>OL</sub> and 500 mV from V<sub>OH</sub>. # Switching Characteristics Over the Operating Range<sup>[13]</sup> | | | | 5/6/7-<br>2 | 7C455/6/7-<br>14 | | 7C455/6/7-<br>20 | | 7C455/6/7-<br>30 | | | |-------------------------------------|--------------------------------------------------------------------|------|-------------|------------------|------|------------------|------|------------------|------|------| | Parameter | Description | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | t <sub>CKW</sub> | Write Clock Cycle | 12 | | 14 | | 20 | | 30 | | ns | | t <sub>CKR</sub> | Read Clock Cycle | 12 | | 14 | | 20 | | 30 | | ns | | t <sub>CKH</sub> | Clock HIGH | 5 | | 6.5 | | 9 | | 12 | | ns | | t <sub>CKL</sub> | Clock LOW | 5 | | 6.5 | | 9 | | 12 | | ns | | t <sub>A</sub> | Data Access Time | | 9 | | 10 | | 15 | | 20 | ns | | t <sub>OH</sub> | Previous Output Data Hold After Read HIGH | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>FH</sub> | Previous Flag Hold After Read/Write HIGH | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>SD</sub> | Data Set-Up | 4 | | 5 | | 6 | | 7 | | ns | | t <sub>HD</sub> | Data Hold | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>SEN</sub> | Enable Set-Up | 4 | | 5 | | 6 | | 7 | | ns | | t <sub>HEN</sub> | Enable Hold | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>OE</sub> | OE LOW to Output Data Valid | | 9 | | 10 | | 15 | | 20 | ns | | t <sub>OLZ</sub> <sup>[7, 14]</sup> | OE LOW to Output Data in Low Z | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>OHZ</sub> <sup>[7, 14]</sup> | OE HIGH to Output Data in High Z | | 9 | | 10 | | 15 | | 20 | ns | | t <sub>PG</sub> | Read HIGH to Parity Generation | | 9 | | 10 | | 15 | | 20 | ns | | t <sub>PE</sub> | Read HIGH to Parity Error Flag | | 9 | | 10 | | 15 | | 20 | ns | | t <sub>FD</sub> | Flag Delay | | 9 | | 10 | | 15 | | 20 | ns | | t <sub>SKEW1</sub> <sup>[15]</sup> | Opposite Clock After Clock | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>SKEW2</sub> <sup>[16]</sup> | Opposite Clock Before Clock | 12 | | 14 | | 20 | | 30 | | ns | | t <sub>PMR</sub> | Master Reset Pulse Width (MR LOW) | 14 | | 14 | | 20 | | 30 | | ns | | t <sub>SCMR</sub> | Last Valid Clock LOW Set-Up to MR LOW | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>OHMR</sub> | Data Hold From MR LOW | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>MRR</sub> | Master Reset Recovery (MR HIGH Set-Up to First Enabled Write/Read) | 12 | | 14 | | 20 | | 30 | | ns | | t <sub>MRF</sub> | MR HIGH to Flags Valid | | 12 | | 14 | | 20 | | 30 | ns | | t <sub>AMR</sub> | MR HIGH to Data Outputs LOW | | 12 | | 14 | | 20 | | 30 | ns | | t <sub>SMRP</sub> | Program Mode—MR LOW Set-Up | | | 14 | | 20 | | 30 | | ns | | t <sub>HMRP</sub> | Program Mode—MR LOW Hold | | | 10 | | 15 | | 20 | | ns | | t <sub>FTP</sub> | Program Mode—Write HIGH to Read HIGH | | | 14 | | 20 | | 30 | | ns | | t <sub>AP</sub> | Program Mode—Data Access Time | | 12 | | 14 | | 20 | | 30 | ns | | t <sub>OHP</sub> | Program Mode—Data Hold Time from MR HIGH | 0 | | 0 | | 0 | | 0 | | ns | | t <sub>PRT</sub> | Retransmit Pulse Width | 12 | | 14 | | 20 | | 30 | | ns | | t <sub>RTR</sub> | Retransmit Recovery Time | 12 | | 14 | | 20 | | 30 | | ns | <sup>13.</sup> Test conditions assume signal transition time of 3 ns or less, timing reference levels of 1.5V, and output loading as shown in AC Test Loads and Waveforms and canacitance as in notes 8 and 9 unless otherwise specified Waveforms and capacitance as in notes 8 and 9, unless otherwise specified. 14. At any given temperature and voltage condition, t<sub>OLZ</sub> is greater than t<sub>OHZ</sub> for any given device. <sup>15.</sup> t<sub>SKEW1</sub> is the minimum time an opposite clock can occur after a clock and still be guaranteed not to be included in the current clock cycle (for purposes of flag update). If the opposite clock occurs less than t<sub>SKEW1</sub> after the clock, the decision of whether or not to include the opposite clock in the current clock cycle is arbitrary. *Note*: The opposite clock is the signal to which a flag is not synchronized; i.e., CKW is the opposite clock for Empty and Almost Empty flags, CKR is the opposite clock for the Almost Full, Half Full, and Full flags. The clock is the signal to which a flag is synchronized; i.e., CKW is the clock for the Half Full, Almost Full, and Full flags, CKR is the clock for Empty and Almost Empty flags. 16. t<sub>SKEW2</sub> is the minimum time an opposite clock can occur before a clock and still be guaranteed to be included in the current clock cycle (for <sup>16.</sup> t<sub>SKEW2</sub> is the minimum time an opposite clock or the Hall Full, Almost Full, and Full Halls, CKR is the clock for Empty and Almost Empty halds. 16. t<sub>SKEW2</sub> is the minimum time an opposite clock can occur before a clock and still be guaranteed to be included in the current clock cycle (for purposes of flag update). If the opposite clock occurs less than t<sub>SKEW2</sub> before the clock, the decision of whether or not to include the opposite clock in the current clock cycle is arbitrary. See Note 15 for definition of clock and opposite clock. # **Switching Waveforms** # $\textbf{MasterReset (Default with Free-Running Clocks) Timing Diagram}^{[17,\ 18,\ 19,\ 20]}$ - To only perform reset (no programming), the following criteria must be met: <u>ENW</u> or CKW must be inactive while <u>MR</u> is LOW. To only perform reset (no programming), the following criteria must be <u>met</u>: <u>ENR</u> or CKR must be inactive while <u>MR</u> is LOW. All data outputs (Q<sub>0 17</sub>) go LOW as a result of the rising edge of <u>MR</u> after t<sub>AMR</sub>. In this example, Q<sub>0 17</sub> will remain valid until t<sub>OHMR</sub> if either the first read shown did not occur or if the read occurred soon enough such that the valid data was caused by it. # $\textbf{Master Reset (Programming Mode) Timing Diagram}^{[19,\,20]}$ # $\textbf{Master Reset (Programming Mode with Free-Running Clocks) Timing Diagram}^{[19,\,20]}$ # Read to Empty Timing Diagram $^{\left[21,\,24,\,25\right]}$ # Read to Empty Timing Diagram with Free-Running Clocks $^{[21,\,22,\,23,\,24]}$ - "Count" is the number of words in the FIFO. The FIFO is assumed to be programmed with P>0 (i.e., PAFE does not transition at Empty or Full). R2 is ignored because the FIFO is empty (count = 0). It is important to note that R3 is also ignored because W3, the first enabled write after empty, occurs less than t<sub>SKEW2</sub> before R3. Therefore, the FIFO still appears empty when R3 occurs. Because W3 occurs greater than t<sub>SKEW2</sub> before R4, R4 includes - W3 in the flag update. CKR is clock and CKW is opposite clock. R3 updates the flag to the Empty state by asserting E/F. Because W1 occurs greater than t<sub>SKEW1</sub> after R3, R3 does not recognize W1 when updating flag status. But because W1 occurs t<sub>SKEW2</sub> before R4, R4 includes W1 in the flag update and, therefore, updates FIFO to Almost Empty state. It is important to note that R4 is a latent cycle; i.e., it only updates the flag status regardless of the state of ENR. It does not change the count or the FIFO's data outputs. # Read to Almost Empty Timing Diagram with Free-Running Clocks $^{[21,\;24,\;26]}$ Read to Almost Empty Timing Diagram with Read Flag Update Cycle with Free-Running Clocks [21, 24, 26, 27, 28] - The FIFO in this example is assumed to be programmed to its default flag values. Almost Empty is 16 words from Empty; Almost Full is 16 locations from Full. R4 only updates the flag status. It does not affect the count because ENR is HIGH. When making the transition from Almost Empty to Intermediate, the count must increase by two (16 Á18; two enabled writes: W2, W3) before a read (R4) can update flags to the Less Than Half Full state. # Write to Half Full Timing Diagram with Free-Running Clocks $^{[21,\ 29,\ 30,\ 31]}$ # $\textbf{Write to Half Full Timing Diagram with Write Flag Update Cycle with Free-Running Clocks}^{[21,\,29,\,30,\,31,\,32,\,33]}$ - 29. CKW is clock and CKR is opposite clock. 30. Count = 1,025 indicates Half Full for the CY7C446 and CY7C456. Count = 513 indicates Half Full for the CY7C447 and CY7C457. Count = 257 indicates Half Full for the CY7C448 and CY7C458. - When the FIFO contains 1,024 [512] [256] words, the rising edge of the next enabled write causes the HF to be true (LOW). The HF write flag update cycle does not affect the count because ENW is HIGH. It only updates HF to HIGH. When making the transition from Half Full to Less Than Half Full, the count must decrease by two (i.e., 1,025 \(\delta\)1,023; two enabled reads: R2 and R3) before a write (W4) can update flags to less than Half Full. # Write to Almost Full Timing Diagram $^{[21,\,26,\,29,\,34,\,35]}$ c455-18 # Write to Almost Full Timing Diagram with Free-Running Clocks $^{[21,\ 26,\ 29]}$ - 34. W2 updates the flag to the Almost Full state by asserting PAFE. Because R1 occurs greater than t<sub>SKEW1</sub> after W2, W2 does not recognize R1 when updating flag status. W3 includes R2 in the flag update because R2 occurs greater than t<sub>SKEW2</sub> before W3. Note that W3 does not have to be enabled to update flags. The dashed lines show W3 as a flag update write rather than an enabled write because ENW is HIGH. # Write to Almost Full Timing Diagram with Write Flag Update Cycle and Free-Running Clocks $^{[21,\ 26,\ 29]}$ # Write to Full Flag Timing Diagram with Free-Running Clocks $^{[21,\,29,\,36]}$ <sup>36.</sup> W2 is ignored because the FIFO is full (count = 2,048 [1,024] [512]). It is important to note that W3 is also ignored because R3, the first enabled read after full, occurs less than t<sub>SKEW2</sub> before W3. Therefore, the FIFO still appears full when W3 occurs. Because R3 occurs greater than t<sub>SKEW2</sub> before W4, W4 includes R3 in the flag update. # Even Parity Generation Timing Diagram $^{[37,\ 38]}$ # Even Parity Generation Timing Diagram $^{[37,\ 39]}$ - 37. In this example, the FIFO is assumed to be programmed to generate even parity. The Q<sub>0-7</sub> word is shown. The example is similar for the Q<sub>9-16</sub> word. 38. If Q<sub>0-7</sub> "new word" also has an even number of 1s, then PG1 stays LOW. 39. If Q<sub>0-7</sub> "new word" also has odd number of 1s, then PG1 stays HIGH. - 40. In this example, the FIFO is assumed to be programmed to check for even parity. The Q<sub>0-7</sub> word is shown. 41. This example assumes that the time from the CKR rising edge to valid word M+1 ≥ t<sub>A</sub>. The Q<sub>0-7</sub> word is shown. 42. If ENR was HIGH around the rising edge of CKR (i.e., read disabled), the valid data at the far right would once again be word M instead of word M+1. 43. Clocks are free running in this case. 44. The flags may change state during Retransmit as a result of the offset of the read and write pointers, but flags will be valid at t<sub>RTR</sub>. #### **Architecture** The CY7C455/6/7 consists of an array of 512, 1024, or 2048 words of 18 bits each (implemented by a dual-port array of SRAM cells), a read pointer, a write pointer, control signals (CKR, CKW, ENR, ENW, and MR), and flags (HF, E/F, PAFE). The CY7C455/6/7 also includes the control signals OE, FL, XI, and XO for depth expansion. ### Resetting the FIFO Upon power-up, the FIFO must be reset with a Master Reset ( $\overline{\text{MR}}$ ) cycle. This causes the FIFO to enter the Empty condition signified by $\overline{\text{E/F}}$ and $\overline{\text{PAFE}}$ being LOW and $\overline{\text{HF}}$ being HIGH. All data outputs ( $Q_{0-17}$ ) go low at the rising edge of $\overline{\text{MR}}$ . In order for the FIFO to reset to its default state, a falling edge must occur on $\overline{\text{MR}}$ and the user must not read or write while $\overline{\text{MR}}$ is LOW (unless $\overline{\text{ENR}}$ and $\overline{\text{ENW}}$ are HIGH or unless the device is being programmed). Upon completion of the master reset cycle, all data outputs will go LOW $t_{\text{AMR}}$ after $\overline{\text{MR}}$ is deasserted. All flags are guaranteed to be valid $t_{\text{MRF}}$ after $\overline{\text{MR}}$ is taken HIGH. ### **FIFO Operation** When the $\overline{\text{ENW}}$ signal is active (LOW), data present on the D<sub>0-17</sub> pins is written into the FIFO on each rising edge of the CKW signal. Similarly, when the $\overline{\text{ENR}}$ signal is active, data in the FIFO memory will be presented on the Q<sub>0-17</sub> outputs. New data will be presented on each rising edge of CKR while $\overline{\text{ENR}}$ is active. $\overline{\text{ENR}}$ must set up t<sub>SEN</sub> before CKR for it to be a valid read. $\overline{\text{ENW}}$ must occur t<sub>SEN</sub> before CKW for it to be a valid write. An output enable $(\overline{OE})$ pin is provided to three-state the $Q_{0-17}$ outputs when $\overline{OE}$ is asserted. When $\overline{OE}$ is enabled (low), data in the output register will be available to the $Q_{0-17}$ outputs after $t_{OE}$ . If devices are cascaded, the $\overline{OE}$ function will only output data on the FIFO that is read enabled. The FIFO contains overflow circuitry to disallow additional writes when the FIFO is full, and underflow circuitry to disallow additional reads when the FIFO is empty. An empty FIFO maintains the data of the last valid read on its $Q_{0-17}$ outputs even after additional reads occur. #### **Programming** The CY7C455/6/7 is programmed during a master reset cycle. If $\overline{\text{MR}}$ and $\overline{\text{ENW}}$ are LOW, a rising edge on CKW will write the $D_{0=7,8,\text{or9}}$ and $D_{15=17}$ inputs into the programming register [<sup>45</sup>]. $\overline{\text{MR}}$ must be set up a minimum of $t_{\text{SMRP}}$ before the program write rising edge and held $t_{\text{HMRP}}$ after the program write falling edge. The user has the ability to also perform a program read during the master reset cycle. This will occur at the rising edge of CKR when $\overline{\text{MR}}$ and $\overline{\text{ENR}}$ are asserted. The program read must be performed a minimum of $t_{\text{FTP}}$ after a program write, and the program word will be available $t_{\text{AP}}$ after the read occurs. If a program write does not occur, a program read may occur a minimum of $t_{\text{SMRP}}$ after $\overline{\text{MR}}$ is asserted. This will read the default program value. When free-running clocks are tied to CKW and CKR, programming can still occur during a master reset cycle with the adherence to a few additional timing parameters. The enable pins must be set-up $t_{\text{SEN}}$ before the rising edge of CKW or CKR. Hold times of $t_{\text{HEN}}$ must also be met for $\overline{\text{ENW}}$ and $\overline{\text{ENR}}$ . Data present on D $_{0-9}$ during a program write will determine the distance from Empty (Full) that the Almost Empty (Almost Full) flags will become active. See *Table 1* for a description of the six possible FIFO states. P in *Table 1* refers to the decimal equivalent of the binary number represented by D $_{0-7,~8}$ or 9. Programming options for the CY7C455/6/7 are listed in *Table 4*. The programmable PAFE function on the CY7C455/6/7 is only valid when not cascaded. If the user elects not to program the FIFO's flags, the default is as follows: the Almost Empty condition (Almost Full condition) is activated when the FIFO contains 16 or less words (empty locations). Parity is programmed with the $D_{15-17}$ bits. See *Table 4* for a summary of the various parity programming options. Data present on $D_{15-17}$ during a program write will determine whether the FIFO will generate or check even/odd parity for the data present on $D_{0-7}$ and $D_{9-16}$ thereafter. If the user elects not to program the FIFO, the parity function is disabled. Flag operation and parity are described in greater detail in subsequent sections. ### Flag Operation The CY7C455/6/7 provides three status pins when not cascaded. The three pins, $\overline{E}/\overline{F}$ , $\overline{\underline{PAFE}}$ , and $\overline{HF}$ , allow decoding of six FIFO states (Table 1). PAFE is not available when the CY7C455/6/7 is cascaded for depth expansion. All flags are synchronous, meaning that the change of states is relative to one of the clocks (CKR or CKW, as appropriate). [46] The Empty and Almost Empty flag states are exclusively updated by each rising edge of the read clock (CKR). For example, when the FIFO contains 1 word, the next read (rising edge of CKR while ENR=LOW) causes the flag pins to output a state that represents Empty. The Half Full, Almost Full, and Full flag states are updated exclusively by the write clock (CKW). For example, if the CY7C457 contains 2,047 words (2,048 words indicate Full for the CY7C457), the next write (rising edge of CKW while ENW=LOW) causes the flag pins to output a state that is decoded as Full. Since the flags denoting emptiness (Empty, Almost Empty) are only updated by CKR and the flags signifying fullness (Half Full, Almost Full, Full) are exclusively updated by CKW, careful attention must be given to the flag operation. The user must be aware that if a boundary (Empty, Almost Empty, Half Full, Almost Full, or Full) is crossed due to an operation from a clock that the flag is not synchronized to (i.e., CKW does not affect Empty or Almost Empty), a flag update cycle is necessary to represent the FIFO's new state. The signal to which a flag is not synchronized will be referred to as the opposite clock (CKW is opposite clock for Empty and Almost Empty flags; CKR is the opposite clock for Half Full, Almost Full, and Full flags). Until a proper flag update cycle is executed, the synchronous flags will not show the new state of the FIFO. - 45. CKW will write D<sub>0-9</sub> into the programming register. CKR will read D<sub>0-9</sub> during a programming register read. - 46. The synchronous architecture guarantees the flags valid for approximately one cycle of the clock they are synchronized to. When updating flags, the FIFO must make a decision as to whether or not the opposite clock was recognized when a clock updates the flag. For example (when updating the Empty flag), if a write occurs at least $t_{\rm SKEW1}$ after a read, the write is guaranteed not to be included when CKR updates the flag. If a write occurs at least $t_{\rm SKEW2}$ before a read, the write is guaranteed to be included when CKR updates flag. If a write occurs within $t_{\rm SKEW1}$ after or $t_{\rm SKEW2}$ before CKR, then the decision of whether or not to include the write when the flag is updated by CKR is arbitrary. The update cycle for non-boundary flags (Almost Empty, Half Full, Almost Full) is different from that used to update the boundary flags (Empty, Full). Both operations are described below. ### **Boundary and Non-Boundary Flags** #### **Boundary Flags (Empty)** The Empty flag is synchronized to the CKR signal (i.e., the Empty flag can only be updated by a clock pulse on the CKR pin). An empty FIFO that is written to will be described with an Empty flag state until a rising edge is presented to the CKR pin. When making the transition from Empty to Almost Empty (or Empty to Less than or Equal to Half Full), a clock cycle on CKR is necessary to update the flags to the current state. In such a state (flags showing Empty even though data has been written to the FIFO), two read clock cycles are required to read data out of the FIFO. The first read serves only to update the flags to the Almost Empty or Less than or Equal to Half Full state, while the second read outputs the data. This first read cycle is known as the latent or flag update cycle because it does not affect the data in the FIFO or the count (number of words in FIFO). It simply deasserts the Empty flag. The flag is updated regardless of the ENR state. Therefore, the update occurs even when ENR is deasserted (HIGH), so that a valid read is not necessary to update the flags to correctly describe the FIFO. In this example, the write must occur at least t<sub>SKFW2</sub> before the flag update cycle in order for the FIFO to guarantee that the write will be included in the count when CKR updates the flags. When a free-running clock is connected to CKR, the flag is updated each cycle. Table 2 shows an example of a sequence of operations that update the Empty flag. #### **Boundary Flags (Full)** The Full flag is synchronized to the CKW signal (i.e., the Full flag can only be updated by a clock pulse on the CKW pin). A full FIFO that is read will be described with a Full flag until a rising edge is presented to the CKW pin. When making the transition from Full to Almost Full (or Full to Greater Than Half Full), a clock cycle on CKW is necessary to update the flags to the current state. In such a state (flags showing Full even through data has been read from the FIFO), two write cycles are required to write data into the FIFO. The first write serves only to update the flags to the Almost Full or Greater Than Half Full state, while the second write inputs the data. This first write cycle is known as the latent or flag update cycle because it does not affect the data in the FIFO or the count (number of words in the FIFO). It simply deasserts the Full flag. The flag is updated regardless of the ENW state. Therefore, the update occurs even when ENW is deasserted (HIGH), so that a valid write is not necessary to update the flags to correctly describe the FIFO. In this example, the read must occur at least t<sub>SKFW2</sub> before the flag update cycle in order for the FIFO to guarantee that the read will be included in the count when CKW updates the flags. When a free-running clock is connected to CKW, the flag updates each cycle. Full flag operation is similar to the Empty flag operation described in Table 2. #### Non-Boundary Flags (Almost Empty, Half Full, Almost Full) The CY7C455/6/7 features programmable Almost Empty and Almost Full flags. Each flag can be programmed a specific distance from the corresponding boundary flags (Empty or Full). The flags can be programmed to be activated at the Empty or Full boundary, or at any distance from the Empty/Full boundary. When the FIFO contains the number of words or fewer for which the flags have been programmed, the PAFE flag will be asserted signifying that the FIFO is Almost Empty. When the FIFO is within that same number of empty locations from being Full, the PAFE will also be asserted signifying that the FIFO is Almost Full. The HF flag is decoded to distinguish the states. The default distance from where PAFE becomes active to the boundary (Empty, Full) is 16 words/locations. The Almost Full and Almost Empty flags can be programmed so that they are only active at Full and Empty boundaries. However, the operation will remain consistent with the non-boundary flag operation that is discussed below. Table 1. Flag Truth Table<sup>[47]</sup> | Ē/F | PAFE | HF | 7C455<br>State Words in FIFO | | 7C456<br>Words in FIFO | 7C457<br>Words in FIFO | |-----|------|----|---------------------------------|----------------|------------------------|------------------------| | 0 | 0 | 1 | Empty | 0 | 0 | 0 | | 1 | 0 | 1 | Almost Empty | 1 => P | 1 => P | 1 => P | | 1 | 1 | 1 | Less than or Equal to Half Full | P + 1 => 256 | P + 1 => 512 | P + 1 => 1024 | | 1 | 1 | 0 | Greater than Half Full | 257 => 511 - P | 513 => 1023 - P | 1025 => 2047 - P | | 1 | 0 | 0 | Almost Full | 512 – P => 511 | 1024 – P => 1023 | 2048 – P => 2047 | | 0 | 0 | 0 | Full | 512 | 1024 | 2048 | <sup>47.</sup> P is the decimal value of the binary number represented by $D_{0-7}$ for the CY7C455, $D_{0-8}$ for the CY7C456, and $D_{0-9}$ for the CY7C457. P = 0 signifies that the Almost Empty state = Empty state. Table 2. Empty Flag (Boundary Flag) Operation Example | Statu | ıs Bef | ore Op | eratio | n | | Status After Operation | | | | | | |-----------------------------|--------|--------|--------|----------------------------------|----------------------------------|--------------------------|-----|-----|----|----------------------------------|-------------------------------------------------| | Current<br>State of<br>FIFO | Ē/F | AFE | HF | Number<br>of<br>Words<br>in FIFO | Operation | Next<br>State<br>of FIFO | Ē/F | AFE | HF | Number<br>of<br>Words<br>in FIFO | Comments | | Empty | 0 | 0 | 1 | 0 | $\frac{\text{Write}}{(ENW} = 0)$ | Empty | 0 | 0 | 1 | 1 | Write | | Empty | 0 | 0 | 1 | 1 | $\frac{\text{Write}}{(ENW} = 0)$ | Empty | 0 | 0 | 1 | 2 | Write | | Empty | 0 | 0 | 1 | 2 | Read<br>(ENR = X) | AE | 1 | 0 | 1 | 2 | Flag Update | | AE | 1 | 0 | 1 | 2 | Read<br>(ENR = 0) | AE | 1 | 0 | 1 | 1 | Read | | AE | 1 | 0 | 1 | 1 | Read<br>(ENR = 0) | Empty | 0 | 0 | 1 | 0 | Read (transition from Almost Empty to Empty) | | Empty | 0 | 0 | 1 | 0 | Write<br>(ENR = 0) | Empty | 0 | 0 | 1 | 1 | Write | | Empty | 1 | 0 | 1 | 1 | Read<br>(ENR = X) | AE | 1 | 0 | 1 | 1 | Flag Update | | AE | 1 | 0 | 1 | 1 | Read<br>(ENR = 0) | Empty | 0 | 0 | 1 | 0 | Read (transition from<br>Almost Empty to Empty) | Almost Empty is only updated by CKR while Half Full and Almost Full are updated by CKW. Non-boundary flags employ flag update cycles similar to the boundary flag latent cycles in order to update the FIFO status. For example, if the FIFO just reaches the Greater than Half Full state, and then two words are read from the FIFO, a write clock (CKW) will be required to update the flags to the Less than Half Full state. However, unlike the boundary flag latent cycle, the state of the enable pin (ENW in this case) affects the operation. Therefore, set-up and hold times for the enable pins must be met ( $t_{SEN}$ and $t_{HEN}$ ). If the enable pin is active during the flag update cycle, the count and data are updated in addition to PAFE and HF. If the enable pin is not asserted during the flag update cycle, only the flags are updated. Table 3 shows an example of a sequence of operations that update the Almost Empty and Almost Full flags The CY7C455/6/7 also features even or odd parity checking and generation. $D_{15-17}$ are used during a program write to describe the parity option desired. *Table 4* summarizes programmable parity options. If the user elects not to program the device, then parity is disabled. Parity information is provided on two multi-mode output pins $(Q_8/PG1/\overline{PE1})$ and $Q_{17}/PG2/\overline{PE2}$ . The three possible modes are described in the following paragraphs. ### **Programmable Parity** #### Parity Disabled (Q<sub>8</sub>/Q<sub>17</sub> mode) When parity is disabled (or the user does not program parity option) the FIFO stores all 18 bits present on $D_{0-17}$ inputs internally and will output all 18 bits on $Q_{0-17}$ . #### Parity Generate (PG mode) This mode is used to generate either even or odd parity (as programmed) from $D_{0-7}$ and $D_{9-16}$ . $D_8$ and $D_{17}$ inputs are ignored. The parity bits are stored internally as $D_8$ and $D_{17}$ , and during a subsequent read will be available on the PG1 and PG2 pins along with the data words from which the parity was generated ( $Q_{0-7}$ and $Q_{9-16}$ ). For example, if parity generate is set to ODD and the $D_{0-7}$ inputs have an EVEN number of 1s, PG1 will be HIGH. ### Parity Check (PE mode) If the FIFO is programmed for parity checking, it will compare the parity of $\mathsf{D}_{0-8}$ and $\mathsf{D}_{9-17}$ with the program register. For example, $\mathsf{D}_8$ and $\mathsf{D}_{17}$ will be set according to the result of the parity check on each word. When these words are later read, $\overline{\mathsf{PE}}_1$ and $\overline{\mathsf{PE}}_2$ will reflect the result of the parity check. If a parity error occurs in $\mathsf{D}_{0-8}, \underline{\mathsf{D}}_8$ will be set LOW internally. When this word is later read, $\overline{\mathsf{PE}}_1$ will be LOW. #### Retransmit The retransmit feature is beneficial when transferring packets of data. It enables the receipt of data to be acknowledged by the receiver and retransmitted if necessary. The Retransmit ( $\overline{RT}$ ) input is active in the standalone and width expansion modes. The retransmit feature is intended for use when a number of writes equal to or less than the depth of the FIFO have occurred since the last $\overline{MR}$ cycle. A LOW pulse on $\overline{RT}$ resets the internal read pointer to the first physical location of the FIFO. WCLK and RCLK may be free running but must be disabled during and $t_{\overline{RTR}}$ after the retransmit pulse. With every valid read cycle after retransmit, previously accessed data is read and the read pointer is incremented until it is equal to the write pointer. Flags are governed by the relative locations of the read and write pointers and are updated during a retransmit cycle. Data written to the FIFO after activation of $\overline{RT}$ are transmitted also. The full depth of the FIFO can be repeatedly retransmitted. ## **Width Expansion Modes** During width expansion all flags (programmable and nonprogrammable) are available. These FIFOs can be expanded in width to provide word width greater than 18 in increments of 18. During width expansion mode all control line inputs are common. When the FIFO is being read near the Empty (Full) boundary, it is important to note that both sets of flags should be checked to see if they have been updated to the Not Empty (Not Full) condition to insure that the next read (write) will perform the same operation on all devices. Checking all sets of flags is critical so that data is not read from the FIFOs "staggered" by one clock cycle. This situation could occur when the first write to an empty FIFO and a read are very close together. If the read occurs less than $t_{SKEW2}$ after the first write to two width-expanded devices, A and B, device A may go Almost Empty (read recognized as flag update) while device B stays Empty (read ignored). This occurs because a read can be either recognized or ignored if it occurs within $t_{SKEW2}$ of a write. The next read cycle outputs the first half of the first word on device A while device B updates its flags to Almost Empty. Subsequent reads will continue to output "staggered" data assuming more data has been written to FIFOs. #### **Depth Expansion Mode** The CY7C455/6/7 can operate up to 83.3 MHz when cascaded. Depth expansion is accomplished by connecting expansion out $(\overline{XO})$ of the first device to expansion in $(\overline{XI})$ of the next device, with $\overline{\text{XO}}$ of the last device connected to $\overline{\text{XI}}$ of the first device. The first device has its first load pin ( $\overline{\text{FL}}$ ) tied to $V_{SS}$ while all other devices must have this pin tied to $V_{CC}$ . The first device will be the first to be write and read enabled after a master reset. Proper operation also requires that all cascaded devices have common CKW, CKR, $\overline{ENW}$ , $\overline{ENR}$ , $D_{0-17}$ , $Q_{0-17}$ , and $\overline{MR}$ pins. When cascaded, one device at a time will be read enabled so as to avoid bus contention. By asserting $\overline{XO}$ when appropriate, the currently enabled FIFO alerts the next FIFO that it should be enabled. The next rising edge on CKR puts $Q_{0-17}$ outputs of the first device into a high-impedance state. This occurs regardless of the state of $\overline{ENR}$ or the next FIFO's Empty flag. Therefore, if the next FIFO is empty or undergoing a latent cycle, the $Q_{0-17}$ bus will be in a high-impedance state until the next device receives its first read, which brings its data to the $Q_{0-17}$ bus. #### **Program Write/Read of Cascaded Devices** Programming of cascaded FIFOs is the same as for a single device. Because the controls of the FIFOs are in parallel when cascaded, they all get programmed the same. During program mode, only parity is programmed since Almost Full and Almost Empty flags are not available when CY7C455/6/7 is cascaded. Only the "first device" (FIFO with $\overline{\text{FL}}$ =LOW) will output its program register contents on $Q_{0-7}$ during a program read. $Q_{0-17}$ of all other devices will remain in a high-impedance state to avoid bus contention. Figure 1. Depth Expansion with CY7C455/6/7 Table 3. Almost Empty Flag (Non-Boundary Flag) Operation Example<sup>[48]</sup> | Statu | s Bef | ore Op | eratio | n | | Status After Operation | | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|--------|-------------------------|--------------------|-----------------------------------------------------------------------------------------------|-----|------|----|-------------------------|--------------------------------------------------------| | Current<br>State of FIFO | E/F | AFE | HF | Number of Words in FIFO | Operation | Next State of FIFO | E/F | PAFE | HF | Number of words in FIFO | Comments | | AE | 1 | 0 | 1 | 32 | Write<br>(ENW = 0) | AE | 1 | 0 | 1 | 33 | Write | | AE | 1 | 0 | 1 | 33 | Write<br>(ENW = 0) | AE | 1 | 0 | 1 | 34 | Write | | AE | 1 | 0 | 1 | 34 | Read<br>(ENR = 0) | <hf< td=""><td>1</td><td>1</td><td>1</td><td>33</td><td>Flag Update and Read</td></hf<> | 1 | 1 | 1 | 33 | Flag Update and Read | | <hf< td=""><td>1</td><td>1</td><td>1</td><td>33</td><td>Read<br/>(ENR = 1)</td><td><hf< td=""><td>1</td><td>1</td><td>1</td><td>33</td><td>Ignored Read<br/>(ENR = 1)</td></hf<></td></hf<> | 1 | 1 | 1 | 33 | Read<br>(ENR = 1) | <hf< td=""><td>1</td><td>1</td><td>1</td><td>33</td><td>Ignored Read<br/>(ENR = 1)</td></hf<> | 1 | 1 | 1 | 33 | Ignored Read<br>(ENR = 1) | | <hf< td=""><td>1</td><td>1</td><td>1</td><td>33</td><td>Read<br/>(ENR = 0)</td><td>AE</td><td>1</td><td>0</td><td>1</td><td>32</td><td>Read (transition from<br/><hf ae)<="" td="" to=""></hf></td></hf<> | 1 | 1 | 1 | 33 | Read<br>(ENR = 0) | AE | 1 | 0 | 1 | 32 | Read (transition from<br><hf ae)<="" td="" to=""></hf> | ### **Table 4. Programmable Parity Options** | D17 | D16 | D15 | Condition | | | | | |-----|-----|-----|---------------------------------------------------------|--|--|--|--| | 0 | Х | Х | Parity disabled. | | | | | | 1 | 0 | 0 | Generate even parity on PG output pin. | | | | | | 1 | 0 | 1 | Generate odd parity on PG output pin. | | | | | | 1 | 1 | 0 | Check for even parity. Indicate error on PE output pin. | | | | | | 1 | 1 | 1 | Check for odd parity. Indicate error on PE output pin. | | | | | #### Note: 48. Applies to CY7C455/6/7 operations when devices are programmed so that Almost Empty becomes active when the FIFO contains 32 or fewer words. # **Ordering Information** # 512x18 Clocked FIFO | Speed<br>(ns) | Ordering Code | Package<br>Name | Package<br>Type | Operating<br>Range | |---------------|---------------|-----------------|-------------------------------------|--------------------| | 12 | CY7C455-12JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C455-12NC | N52 | 52-Pin Plastic Quad Flatpack | ] | | | CY7C455-12JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 14 | CY7C455-14JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C455-14NC | N52 | 52-Pin Plastic Quad Flatpack | | | | CY7C455-14JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 20 | CY7C455-20JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C455-20NC | N52 | 52-Pin Plastic Quad Flatpack | | | | CY7C455-20JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 30 | CY7C455-30JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C455-30NC | N52 | 52-Pin Plastic Quad Flatpack | | | | CY7C455-30JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | #### 1Kx18 Clocked FIFO | Speed<br>(ns) | Ordering Code | Package<br>Name | Package<br>Type | Operating<br>Range | |---------------|---------------|-----------------|-------------------------------------|--------------------| | 12 | CY7C456-12JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C456-12NC | N52 | 52-Pin Plastic Quad Flatpack | | | | CY7C456-12JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 14 | CY7C456-14JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C456-14NC | N52 | 52-Pin Plastic Quad Flatpack | | | | CY7C456-14JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 20 | CY7C456-20JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C456-20NC | N52 | 52-Pin Plastic Quad Flatpack | ] | | | CY7C456-20JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 30 | CY7C456-30JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C456-30NC | N52 | 52-Pin Plastic Quad Flatpack | ] | | | CY7C456-30JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | ## 2Kx18 Clocked FIFO | Speed (ns) | Ordering Code | Package<br>Name | Package<br>Type | Operating<br>Range | |------------|---------------|-----------------|-------------------------------------|--------------------| | 12 | CY7C457-12JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C457-12NC | N52 | 52-Pin Plastic Quad Flatpack | ] | | | CY7C457-12JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 14 | CY7C457-14JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C457-14NC | N52 | 52-Pin Plastic Quad Flatpack | | | | CY7C457-14JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 20 | CY7C457-20JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C457-20NC | N52 | 52-Pin Plastic Quad Flatpack | | | | CY7C457-20JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | | 30 | CY7C457-30JC | J69 | 52-Lead Plastic Leaded Chip Carrier | Commercial | | | CY7C457-30NC | N52 | 52-Pin Plastic Quad Flatpack | | | | CY7C457-30JI | J69 | 52-Lead Plastic Leaded Chip Carrier | Industrial | Document #: 38-00211-E ## **Package Diagrams** #### 52-Lead Plastic Leaded Chip Carrier J69 #### 52-Lead Plastic Quad Flatpack N52 DIMENSIONS ARE IN MILLIMETERS LEAD COPLANARITY 0.102 MAX.