## **FEATURES** - Fast Cycle Times: 25/30/35 ns - Two 256 × 36-bit FIFO Buffers - Full 36-bit Word Width - Selectable 36/18/9-bit Word Width on Port B - Independently-Synchronized ('Fully Asynchronous') Operation of Port A and Port B - 'Synchronous' Enable-Plus-Clock Control at Both Ports - R/W, Enable, Request, and Address Control Inputs are Sampled on the Rising Clock Edge - Synchronous Request/Acknowledge 'Handshake' Capability; Use is Optional - Device Comes Up Into a Known Default State at Reset; Programming is Allowed, but is not Required - Asynchronous Output Enables - Five Status Flags per Port: Full, Almost-Full, Half-Full, Almost-Empty, and Empty - Almost-Full Flag and Almost-Empty Flag are Programmable - Mailbox Registers with Synchronized Flags - Data-Bypass Function - Data-Retransmit Function - Automatic Byte Parity Checking - For PQFP-to-PGA conversion for thru-hole board designs, Sharp recommends ITT Pomona Electronics' SMT/PGA Generic Converter model #5853<sup>®</sup>. This converter maps the LH543620 132pin PQFP to a generic 13 × 13, 132-pin PGA (100-mil pitch). For more information, contact Sharp or ITT Pomona Electronics at 1500 East Ninth Street, Pomona, CA 91766, (909) 469-2900. - TTL/CMOS-Compatible I/O - Space-Saving PQFP Package - PQFP to PGA Package Conversion \* ### **FUNCTIONAL DESCRIPTION** The LH5420 contains two FIFO buffers, FIFO #1 and FIFO #2. These operate in parallel, but in opposite directions, for bidirectional data buffering. FIFO #1 and FIFO #2 each are organized as 256 words by 36 bits. The LH5420 is ideal either for wide unidirectional applications or for bidirectional data applications; component count and board area are reduced. The LH5420 has two 36-bit ports, Port A and Port B. Each port has its own port-synchronous clock, but the two ports may operate asynchronously relative to each other. Data flow is initiated at a port by the rising edge of the appropriate clock; it is gated by the corresponding edge-sampled enable, request, and read/write control signals. At the maximum operating frequency, the clock duty cycle may vary from 40% to 60%. At lower frequencies, the clock waveform may be quite asymmetric, as long as the minimum pulse-width conditions for clock-HIGH and clock-LOW remain satisfied; the LH5420 is a fully-static part. Conceptually, the port clocks CKA and CKB are freerunning, periodic 'clock' waveforms, used to control other signals which are edge-sampled. However, there actually is not any absolute requirement that these 'clock' waveforms *must* be periodic. An 'asynchronous' mode of operation is possible, in one or both directions, independently, if the appropriate enable and request inputs are continuously asserted, and enough aperiodic 'clock' pulses of suitable duration are generated by external logic to cause all necessary actions to occur. A synchronous request/acknowledge handshake facility is provided at each port for FIFO data access. This request/ acknowledge handshake resolves FIFO full and empty boundary conditions, when the two ports are operated asynchronously relative to each other. FIFO status flags monitor the extent to which each FIFO buffer has been filled. Full, Almost-Full, Half-Full, Almost-Empty, and Empty flags are included for *each* FIFO. The Almost-Full and Almost-Empty flags are programmable over the entire FIFO depth, but are automatically initialized to eight locations from the respective FIFO boundaries at reset. A data block of 256 or fewer words may be retransmitted any desired number of times. Two mailbox registers provide a separate path for passing control words or status words between ports. 1 ## FUNCTIONAL DESCRIPTION (cont'd) Each mailbox has a New-Mail-Alert Flag, which is synchronized to the reading port's clock. This mailbox function facilitates the synchronization of data transfers between asynchronous systems. Data-bypass mode allows Port A to directly transfer data to or from Port B at reset. In this mode, the device acts as a registered transceiver under the control of Port A. For instance, a master processor on Port A can use the data bypass feature to send or receive initializa- tion or configuration information directly, to or from a peripheral device on Port B, during system startup. A word-width-select option is provided on Port B for 36-bit, 18-bit, or 9-bit data access. This feature allows word-width matching between Port A and Port B, with no additional logic needed. It also ensures maximum utilization of bus bandwidths. A Byte Parity Check Flag at each port monitors data integrity. Control-Register bit 0 (zero) selects the parity mode, odd or even. This bit is initialized for odddata parity at reset; but it may be reprogrammed for even parity, or back again to odd parity, as desired. ## **PIN CONNECTIONS** Figure 1. Pin Connections for 132-Pin PQFP Package (TOP VIEW) www.DataSheet4U.com # **PIN LIST** | SIGNAL<br>NAME | PQFP<br>PIN NO. | |------------------|-----------------| | A <sub>OA</sub> | 1 | | A <sub>1A</sub> | 2 | | A <sub>2A</sub> | 3 | | OEA | 4 | | FF <sub>1</sub> | 6 | | AF <sub>1</sub> | 7 | | HF <sub>1</sub> | 8 | | PFA | 9 | | D <sub>17A</sub> | 10 | | D <sub>16A</sub> | 11 | | D <sub>15A</sub> | 12 | | D <sub>14A</sub> | 14 | | D <sub>13A</sub> | 15 | | D <sub>12A</sub> | 16 | | D <sub>11A</sub> | 17 | | D <sub>10A</sub> | 19 | | D <sub>9A</sub> | 20 | | D <sub>8A</sub> | 21 | | D <sub>7A</sub> | 23 | | D <sub>6A</sub> | 24 | | D <sub>5A</sub> | 25 | | D <sub>4A</sub> | 27 | | D <sub>3A</sub> | 28 | | D <sub>2A</sub> | 29 | | D <sub>1A</sub> | 31 | | D <sub>0A</sub> | 32 | | RS | 33 | | RT <sub>1</sub> | 34 | | D <sub>0B</sub> | 35 | | D <sub>1B</sub> | 36 | | D <sub>2B</sub> | 37 | | D <sub>3B</sub> | 39 | | D <sub>4B</sub> | 40 | | D <sub>5B</sub> | 41 | | D <sub>6B</sub> | 43 | | D <sub>7B</sub> | 44 | | D <sub>8B</sub> | 45 | | D <sub>9B</sub> | 47 | | D <sub>10B</sub> | 48 | | D <sub>11B</sub> | 49 | | D <sub>12B</sub> | 51 | | D <sub>13B</sub> | 52 | | D <sub>14B</sub> | 53 | | D <sub>15B</sub> | 54 | | SIGNAL | PQFP | |------------------|---------| | NAME | PIN NO. | | D <sub>16B</sub> | 56 | | D <sub>17B</sub> | 57 | | MBF <sub>1</sub> | 58 | | AE <sub>1</sub> | 59 | | EF <sub>1</sub> | 60 | | ACK <sub>B</sub> | 61 | | REQ <sub>B</sub> | 63 | | ENB | 64 | | R/W <sub>B</sub> | 65 | | CKB | 66 | | A <sub>OB</sub> | 67 | | WS <sub>0</sub> | 68 | | WS <sub>1</sub> | 69 | | OE <sub>B</sub> | 70 | | FF <sub>2</sub> | 72 | | AF <sub>2</sub> | 73 | | HF <sub>2</sub> | 74 | | PFB | 75 | | D <sub>18B</sub> | 76 | | D <sub>19B</sub> | 77 | | D <sub>20B</sub> | 78 | | D <sub>21B</sub> | 80 | | D <sub>22B</sub> | 81 | | D <sub>23B</sub> | 82 | | D <sub>24B</sub> | 83 | | D <sub>25B</sub> | 85 | | D <sub>26B</sub> | 86 | | D <sub>27B</sub> | 87 | | D <sub>28B</sub> | 89 | | D <sub>29B</sub> | 90 | | D <sub>30B</sub> | 91 | | D <sub>31B</sub> | 93 | | D <sub>32B</sub> | 94 | | D <sub>33B</sub> | 95 | | D <sub>33B</sub> | 97 | | D <sub>35B</sub> | 98 | | RT <sub>2</sub> | 100 | | D <sub>35A</sub> | 101 | | D <sub>35A</sub> | 101 | | D <sub>34A</sub> | 102 | | | † | | D <sub>32A</sub> | 105 | | D <sub>31A</sub> | 106 | | D <sub>30A</sub> | 107 | | D <sub>29A</sub> | 109 | | SIGNAL<br>NAME | PQFP<br>PIN NO. | |------------------|-----------------| | D <sub>28A</sub> | 110 | | D <sub>27A</sub> | 111 | | D <sub>26A</sub> | 113 | | D <sub>25A</sub> | 114 | | D <sub>24A</sub> | 115 | | D <sub>23A</sub> | 117 | | D <sub>22A</sub> | 118 | | D <sub>21A</sub> | 119 | | D <sub>20A</sub> | 120 | | D <sub>19A</sub> | 122 | | D <sub>18A</sub> | 123 | | MBF <sub>2</sub> | 124 | | AE <sub>2</sub> | 125 | | EF <sub>2</sub> | 126 | | ACKA | 127 | | REQA | 129 | | ENA | 130 | | R/W <sub>A</sub> | 131 | | CKA | 132 | | Vcc | 5 | | V <sub>SSA</sub> | 13 | | VCCA | 18 | | V <sub>SSA</sub> | 22 | | V <sub>CCA</sub> | 26 | | V <sub>SSA</sub> | 30 | | V <sub>SSB</sub> | 38 | | V <sub>CCB</sub> | 42 | | $V_{SSB}$ | 46 | | V <sub>CCB</sub> | 50 | | V <sub>SSB</sub> | 55 | | Vss | 62 | | Vcc | 71 | | V <sub>SSB</sub> | 79 | | V <sub>CCB</sub> | 84 | | V <sub>SSB</sub> | 88 | | V <sub>CCB</sub> | 92 | | V <sub>SSB</sub> | 96 | | Vss | 99 | | V <sub>SSA</sub> | 104 | | VCCA | 108 | | V <sub>SSA</sub> | 112 | | VCCA | 116 | | V <sub>SSA</sub> | 121 | | V <sub>SS</sub> | 128 | Figure 2a. Simplified LH5420 Block Diagram Figure 2b. Detailed LH5420 Block Diagram # **PIN DESCRIPTIONS** | PIN | PIN TYPE * | DESCRIPTION | | | | |------------------------------------|--------------------------------|--------------------------------------------------------|--|--|--| | GENERAL | | | | | | | V <sub>CC</sub> , V <sub>SS</sub> | V | Power, Ground | | | | | RS | I | Reset | | | | | · | | PORT A | | | | | CKA | KA I Port A Free-Running Clock | | | | | | R/W <sub>A</sub> | 1 | Port A Edge-Sampled Read/Write Control | | | | | ENA | 1 | Port A Edge-Sampled Enable | | | | | A0A, A1A, A2A | | Port A Edge-Sampled Address Pins | | | | | OEA | ı | Port A Level-Sensitive Output Enable | | | | | REQ | ı | Port A Request/Enable | | | | | RT <sub>2</sub> | ł | FIFO #2 Retransmit | | | | | D <sub>0A</sub> – D <sub>35A</sub> | I/O/Z | Port A Bidirectional Data Bus | | | | | FF <sub>1</sub> | 0 | FIFO #1 Full Flag (Write Boundary) | | | | | AF <sub>1</sub> | 0 | FIFO #1 Programmable Almost-Full Flag (Write Boundary) | | | | | HF <sub>1</sub> | 0 | FIFO #1 Half-Full Flag | | | | | AE <sub>2</sub> | 0 | FIFO #2 Programmable Almost-Empty Flag (Read Boundary) | | | | | EF <sub>2</sub> | 0 | FIFO #2 Empty Flag (Read Boundary) | | | | | MBF <sub>2</sub> | 0 | New-Mail-Alert Flag for Mailbox #2 | | | | | PFA | 0 | Port A Parity Flag | | | | | ACK <sub>A</sub> | 0 | Port A Acknowledge | | | | | | | PORT B | | | | | CKB | I | Port B Free-Running Clock | | | | | R/W <sub>B</sub> | l | Port B Edge-Sampled Read/Write Control | | | | | EN <sub>B</sub> | l | Port B Edge-Sampled Enable | | | | | A <sub>OB</sub> | 1 | Port B Edge-Sampled Address Pin | | | | | OE <sub>B</sub> | ı | Port B Level-Sensitive Output Enable | | | | | WS <sub>0</sub> , WS <sub>1</sub> | I | Port B Word-Width Select | | | | | REQ <sub>B</sub> | l | Port B Request/Enable | | | | | RT <sub>1</sub> | ı | FIFO #1 Retransmit | | | | | $D_{0B} - D_{35B}$ | I/O/Z | Port B Bidirectional Data Bus | | | | | FF <sub>2</sub> | 0 | FIFO #2 Full Flag (Write Boundary) | | | | | AF <sub>2</sub> | 0 | FIFO #2 Programmable Almost-Full Flag (Write Boundary) | | | | | HF <sub>2</sub> | 0 | FIFO #2 Half-Full Flag | | | | | AE <sub>1</sub> | 0 | FIFO #1 Programmable Almost-Empty Flag (Read Boundary) | | | | | EF <sub>1</sub> | 0 | FIFO #1 Empty Flag (Read Boundary) | | | | | MBF <sub>1</sub> | 0 | New-Mail-Alert Flag for Mailbox #1 | | | | | PFB | 0 | Port B Parity Flag | | | | | ACK <sub>B</sub> | 0 | Port B Acknowledge | | | | <sup>\*</sup> i = Input, O = Output, Z = High-Impedance, V = Power Voltage Level # ABSOLUTE MAXIMUM RATINGS 1 | PARAMETER | RATING | | | |---------------------------------------------------------------------------------------------|--------------------------|--|--| | Supply Voltage to Vss Potential | -0.5 V to 7 V | | | | Signal Pin Voltage to V <sub>SS</sub> Potential <sup>3</sup> -0.5 V to V <sub>CC</sub> + 0. | | | | | DC Output Current <sup>2</sup> | ± 40 mA | | | | Storage Temperature Range | -65°C to 150°C | | | | Power Dissipation (Package Limit) | 2 Watts (Quad Flat Pack) | | | #### NOTES: - Stresses greater than those listed under 'Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress rating for transient conditions only. Functional operation of the device at these or any other conditions outside those indicated in the 'Operating Range' of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. - Outputs should not be shorted for more than 30 seconds. No more than one output should be shorted at any time. - 3. Negative undershoot of 1.5 V in amplitude is permitted for up to 10 ns, once per cycle. ## **OPERATING RANGE** | SYMBOL | PARAMETER | MIN | MAX | UNIT | |-----------------|---------------------------|------|-----------|------| | T <sub>A</sub> | Temperature, Ambient | 0 | 70 | ٥С | | Vcc | Supply Voltage | 4.5 | 5.5 | ٧ | | Vss | Supply Voltage | 0 | 0 | ٧ | | VIL | Logic LOW Input Voltage 1 | -0.5 | 0.8 | ٧ | | V <sub>IH</sub> | Logic HIGH Input Voltage | 2.2 | Vcc + 0.5 | ٧ | #### NOTE: # DC ELECTRICAL CHARACTERISTICS (Over Operating Range) | SYMBOL | PARAMETER | TEST CONDITIONS | MIN | MAX | UNIT | |---------------------------------------|----------------------------------|------------------------------------------------------------------------------------------|-----|-----|------| | I <sub>LI</sub> Input Leakage Current | | $V_{CC} = 5.5 \text{ V}, V_{IN} = 0 \text{ V To } V_{CC}$ | -10 | 10 | μA | | ILO | I/O Leakage Current | $\overline{OE} \ge V_{IH}$ , $0 \ V \le V_{OUT} \le V_{CC}$ | -10 | 10 | μА | | V <sub>OL</sub> | Logic LOW Output Voltage | I <sub>OL</sub> = 8.0 mA | | 0.4 | V | | V <sub>OH</sub> | Logic HIGH Output Voltage | I <sub>OH</sub> = -2.0 mA | 2.4 | | ٧ | | lcc | Average Supply Current 1 | Measured at f <sub>C</sub> = max | | 280 | mA | | lcc2 | Average Standby Supply Current 1 | Average Standby Supply Current <sup>1</sup> All Inputs = V <sub>IHMIN</sub> (Clock idle) | | 30 | mA | | Іссз | Power-Down Supply Current 1 | Current <sup>1</sup> All Inputs = V <sub>CC</sub> – 0.2 V (Clock idle) | | 3 | mA | #### NOTE: 1. Icc, Icc, and Icc are dependent upon actual output loading, and Icc is also dependent on cycle rates. Specified values are with outputs open; and, for Icc, operating at minimum cycle times. 6 <sup>1.</sup> Negative undershoot of 1.5 V in amplitude is permitted for up to 10 ns, once per cycle. ## **AC TEST CONDITIONS** | PARAMETER | RATING | |-------------------------------------------|------------| | Input Pulse Levels | Vss to 3 V | | Input Rise and Fall Times<br>(10% to 90%) | 5 ns | | Output Reference Levels | 1.5 V | | Input Timing Reference Levels | 1.5 V | | Output Load, Timing Tests | Figure 3 | # CAPACITANCE 1,2 | PARAMETER | RATING | |---------------------------------------|--------| | C <sub>IN</sub> (Input Capacitance) | 8 pF | | C <sub>OUT</sub> (Output Capacitance) | 8 pF | Figure 3. Output Load Circuit ## NOTES: - 1. Sample tested only. - 2. Capacitances are maximum values at 25°C, measured at 1.0 MHz, with $V_{\text{IN}}$ = 0 V. # AC ELECTRICAL CHARACTERISTICS $^1$ (V<sub>CC</sub> = 5 V $\pm$ 10%, T<sub>A</sub> = 0°C to 70°C) | SYMBOL | DECRIPTION | | -25 | | -30 | | -35 | | |-----------------|---------------------------------------------------------------------------------------------------|----------|-----|----------|----------|----------|--------------|-------| | | | | MAX | MIN | MAX | MIN | MAX | UNITS | | fcc | Clock Cycle Frequency | _ | 40 | _ | 33 | _ | 28.5 | MHz | | tcc | Clock Cycle Time | 25 | _ | 30 | | 35 | _ | ns | | tсн | Clock HIGH Time | 10 | | 12 | | 15 | _ | ns | | <b>t</b> cL | Clock LOW Time | 10 | _ | 12 | _ | 15 | | ns | | tos | Data Setup Time | 12 | _ | 13 | _ | 15 | _ | ns | | tон | Data Hold Time | 0 | _ | 0 | _ | 0 | | ns | | tes | Enable Setup Time | 13 | _ | 15 | | 15 | _ | ns | | t <sub>EH</sub> | Enable Hold Time | 0 | _ | 0 | | 0 | | ns | | taws | Read/Write Setup Time | 13 | | 15 | | 18 | | ns | | trwH | Read/Write Hold Time | 0 | _ | 0 | _ | 0 | _ | ns | | taas | Request Setup Time | 15 | _ | 18 | _ | 21 | | ns | | trah | Request Hold Time | 0 | | 0 | _ | 0 | <del>-</del> | ns | | tas | Address Setup Time <sup>6</sup> | 15 | | 18 | _ | 21 | _ | ns | | <b>t</b> AH | Address Hold Time <sup>6</sup> | 0 | - | 0 | _ | 0 | _ | ns | | ta | Data Output Access Time | _ | 16 | | 20 | _ | 25 | ns | | tack | Acknowledge Access Time <sup>8</sup> | _ | _ | | 20 | _ | 25 | ns | | tон | Output Hold Time | 4 | _ | 4 | | 4 | _ | ns | | tzx | Output Enable Time, OE LOW to D <sub>0</sub> - D <sub>35</sub> Low-Z <sup>2</sup> | 5 | _ | 5 | _ | 5 | _ | ns | | txz | Output Disable Time, $\overline{OE}$ HIGH to D <sub>0</sub> – D <sub>35</sub> High-Z <sup>2</sup> | _ | 15 | | 20 | <u> </u> | 25 | ns | | ter | Clock to EF Flag Valid (Empty Flag) | <u> </u> | 22 | _ | 25 | _ | 30 | ns | | <b>t</b> FF | Clock to FF Flag Valid (Full Flag) | _ | 22 | | 25 | _ | 30 | ns | | tHF | Clock to HF Flag Valid (Half-Full) | _ | 22 | _ | 25 | _ | 30 | ns | | tae | Clock to AE Flag Valid (Almost-Empty) | | 20 | _ | 25 | _ | 30 | ns | | taf | Clock to AF Flag Valid (Almost-Full) | <u> </u> | 20 | _ | 25 | _ | 30 | ns | | tmbf | Clock to MBF Flag Valid (Mailbox Flag) | _ | 15 | _ | 20 | <b> </b> | 25 | ns | | tpF | Data to Parity Flag Valid | <b> </b> | 17 | _ | 20 | | 25 | ns | | tas | Reset/Retransmit Pulse Width <sup>7</sup> | 40/25 | | 52/30 | _ | 65/35 | _ | ns | | tass | Reset/Retransmit Setup Time 3 | 20 | _ | 25 | <b> </b> | 30 | | ns | | trsh | Reset/Retransmit Hold Time <sup>3</sup> | 10 | | 15 | | 20 | <u> </u> | ns | | tre | Reset LOW to Flag Valid | | 35 | _ | 40 | ļ | 45 | ns | | terl | First Read Latency <sup>4</sup> | 25 | _ | 30 | <u> </u> | 35 | _ | ns | | trwL | First Write Latency <sup>5</sup> | 25 | | 30 | <u> </u> | 35 | <u> </u> | ns | | tes | Bypass Data Setup | 15 | _ | 18 | _ | 21 | _ | ns | | tвн | Bypass Data Hold | 5 | | 5 | _ | 5 | _ | ns | | t <sub>BA</sub> | Bypass Data Access | | 20 | <u> </u> | 25 | _ | 30 | ns | #### NOTES: - 1. Timing measurements performed at 'AC Test Condition' levels. - 2. Values are guaranteed by design; not currently production tested. - 3. tass and/or tash need not be met unless a rising edge of CKa occurs while ENa is being asserted, or else a rising edge of CKB occurs while ENB is being asserted. - 4. tral is the minimum first-write-to-first-read delay, following an empty condition, which is required to assure valid read data. - 5. trwL is the minimum first-read-to-first-write delay, following a full condition, which is required to assure successful writing of data. - 6. tas, tah address setup times and hold times need only be satisfied at clock edges which occur while the corresponding enables are being asserted. - 7. First number used only when CKA or CKB is enabled; the = these + tch + thesh. - 8. The REQ/ACK facility is not available at cycle times less than 30 ns. ## **OPERATIONAL DESCRIPTION** #### Reset The device is reset whenever the asynchronous Reset $(\overline{RS})$ input is taken LOW, and at least one rising edge and one falling edge of both CKA and CKB occur while $\overline{RS}$ is LOW. A reset operation is required after power-up, before the first write operation may occur. The LH5420 is fully ready for operation after being reset. No device programming is required if the default states described below are acceptable. A reset operation initializes the read-address and write-address pointers for FIFO #1 and FIFO #2 to those FIFO's first physical memory locations. If the respective outputs are enabled, the initial contents of these first locations appear at the outputs. FIFO and mailbox status flags are updated to indicate an empty condition. In addition, the programmable-status-flag offset values are initialized to eight. Thus, the $\overline{AE}_1/\overline{AE}_2$ flags get asserted within eight locations of an empty condition, and the $\overline{AF}_1/\overline{AF}_2$ flags likewise get asserted within eight locations of a full condition, for FIFO #1/FIFO #2 respectively. ## **Bypass Operation** During reset (whenever $\overline{RS}$ is LOW) the device acts as a registered transceiver, bypassing the internal FIFO memories. Port A acts as the master port. A write or read operation on Port A during reset transfers data directly to or from Port B. Port B is considered to be the slave, and cannot perform write or read operations independently on its own during reset. The direction of the bypass data transmission is determined by th $R\overline{W}_A$ control input, which does not get overridden by the $\overline{RS}$ input. Here, a 'write' operation means passing data from Port A to Port B, and a 'read' operation means passing data from Port B to Port A. The bypass capability may be used to pass initialization or configuration data directly between a master processor and a peripheral device during reset. ## **Address Modes** Address pins select the device resource to be accessed by each port. Port A has three resource-register-select inputs, $A_{0A}$ , $A_{1A}$ , and $A_{2A}$ , which select between FIFO access, mailbox-register access, Control-Register access (write only), and Programmable Flag-Offset-Register access. Port B has a single address input, $A_{0B}$ , to select between FIFO access or mailbox-register access. The status of the resource-register-select inputs is sampled at the rising edge of an enabled clock (CKA or CKB). Resource-register select-input address definitions are summarized in Table 1. Table 1. Resource-Register Addresses | A <sub>2</sub> A | A1A | A1A A0A RESOURCE | | | | | |------------------|-----------------|------------------|--------------------------------------------------------------------------------------------------------------|--|--|--| | | PORT A | | | | | | | Н | Н | Н | FIFO | | | | | Н | Н | L | Mailbox | | | | | Н | L | Н | AF <sub>2</sub> , AE <sub>2</sub> , AF <sub>1</sub> , AE <sub>1</sub> Flag Offsets<br>Register (36-Bit Mode) | | | | | Н | L | L | Control Register (Parity Mode) | | | | | L | Н | Н | ĀĒ <sub>1</sub> Flag Offset Register | | | | | L | Н | L | ĀF <sub>1</sub> Flag Offset Register | | | | | L | L | Н | ĀĒ <sub>2</sub> Flag Offset Register | | | | | L | L | L | ĀF <sub>2</sub> Flag Offset Register | | | | | | A <sub>0B</sub> | | RESOURCE | | | | | | PORT B | | | | | | | | Н | | FIFO | | | | | | L | | Mailbox | | | | #### **FIFO Write** Port A writes to FIFO #1, and Port B writes to FIFO #2. A write operation is initiated on the rising edge of a clock (CKA or CKB) whenever: the appropriate enable (ENA or ENB) is held HIGH; the appropriate request (REQA or REQB) is held HIGH; the appropriate Read/Write control (RWA or RWB) is held LOW; the FIFO address is selected for the address inputs (A2A-A0A or A0B); and the prescribed setup times and hold times are observed for all of these signals. Setup times and hold times must also be observed on the data-bus pins (D0A - D35A or D0B - D35B). Normally, the appropriate Output Enable signal ( $\overline{OE}_A$ or $\overline{OE}_B$ ) is HIGH, to disable the outputs at that port, so that the data word present on the bus from external sources gets stored. However, a 'loopback' mode of operation also is possible, in which the data word supplied by the outputs of one internal FIFO is 'turned around' at the port and read back into the other FIFO. In this mode, the outputs at the port are not disabled. To remain within specification for all timing parameters, the Clock Cycle Frequency must be reduced slightly below the value which otherwise would be permissible for that speed grade of LH5420. When a FIFO full condition is reached, write operations are locked out. Following the first read operation from a full FIFO, another memory location is freed up, and the corresponding Full Flag is deasserted ( $\overline{\text{FF}}$ = HIGH). The first write operation should begin no earlier than a First Write Latency (t<sub>FWL</sub>) after the first read operation from a full FIFO, to ensure that correct read data are retrieved. ## **OPERATIONAL DESCRIPTION (cont'd)** #### **FIFO Read** Port A reads from FIFO #2, and Port B reads from FIFO #1. A read operation is initiated on the rising edge of a clock (CKA or CKB) whenever: the appropriate enable (ENA or ENB) is held HIGH; the appropriate request (REQA or REQB) is held HIGH; the appropriate Read/Write control (R/ $\overline{W}$ A or R/ $\overline{W}$ B) is held HIGH; the FIFO address is selected for the address inputs (A2A – A0A or A0B); and the prescribed setup times and hold times are observed for allof these signals. Read data becomes valid on the data-bus pins (D0A – D35A or D0B – D35B) by a time tA after the rising clock (CKA or CKB) edge, provided that the data outputs are enabled. OE<sub>A</sub> and OE<sub>B</sub> are assertive-LOW, asynchronous, Output Enable control input signals. Their effect is only to enable or disable the output drivers of the respective port. Disabling the outputs does *not* disable a read operation; data transmitted to the corresponding output register will remain available later, when the outputs again are enabled, unless it subsequently is overwritten. When an empty condition is reached, read operations are locked out until a valid write operation(s) has loaded additional data into the FIFO. Following the first write to an empty FIFO, the corresponding empty flag (EF) will be deasserted (HIGH). The first read operation should begin no earlier than a First Read Latency (tFRL) after the first write to an empty FIFO, to ensure that correct read data words are retrieved. ## **Dedicated FIFO Status Flags** Six dedicated FIFO status flags are included for Full ( $\overline{FF_1}$ and $\overline{FF_2}$ ), Half-Full ( $\overline{HF_1}$ and $\overline{HF_2}$ ), and Empty ( $\overline{EF_1}$ and $\overline{EF_2}$ ). $\overline{FF_1}$ , $\overline{HF_1}$ , and $\overline{EF_1}$ indicate the status of FIFO #1; and $\overline{FF_2}$ , $\overline{HF_2}$ , and $\overline{EF_2}$ indicate the status of FIFO #2. A Full Flag is asserted following the rising clock edge for a write operation that fills the FIFO. A Full Flag is deasserted following the falling clock edge for a read operation to a full FIFO. A Half-Full Flag is updated following the rising clock edge of a read or write operation to a FIFO. An Empty Flag is asserted following the rising clock edge for a read operation that empties the FIFO. An Empty Flag is deasserted following the falling clock edge for a write operation to an empty FIFO. ## **Programmable Status Flags** Four programmable FIFO status flags are provided, two for Almost-Full ( $\overline{AF}_1$ and $\overline{AF}_2$ ), and two for Almost-Empty ( $\overline{AE}_1$ and $\overline{AE}_2$ ). Thus, each port has two programmable flags to monitor the status of the two internal FIFO buffer memories. The offset values for these flags are initialized to eight locations from the respective FIFO boundaries during reset, but can be reprogrammed over the entire FIFO depth. An Almost-Full Flag is asserted following the rising clock edge for a write operation that fills the FIFO. An Almost-Full Flag is deasserted following the falling clock edge for a read operation to a full FIFO. An Almost-Empty Flag is asserted following the rising clock edge for a read operation that empties the FIFO. An Almost-Empty Flag is deasserted following the falling clock edge for a write operation to an empty FIFO. Flag offsets may be written or read through the Port A data bus. All four programmable FIFO status flag offsets can be set simultaneously through a single 36-bit status word; or, each programmable flag offset can be set individually, through one of four eight-bit status words. Table 3 illustrates the data format for flag-programming words, and Table 4 defines the meaning of each of the five flags. WARNING: Control inputs which may affect the computation of flag values at a port generally should not change while the clock for that port is HIGH, since some updating of flag values takes place on the *falling* edge of the clock. ## **Mailbox Operation** Two mailbox registers are provided for passing system hardware or software control/status words between ports. Each port can read its own mailbox and write to the other port's mailbox. Mailbox access is performed on the rising edge of the controlling FIFO's clock, with the mailbox address selected and the enable (ENA or ENB) HIGH. That is, writing to Mailbox Register #1, or reading from Mailbox Register #2, is synchronized to CKA; and writing to Mailbox Register #2, or reading from Mailbox Register #1, is synchronized to CKB. The R/WA/B and $\overline{OE}$ A/B pins control the direction and availability of mailbox-register accesses. Each mailbox register has its own New-Mail-Alert Flag (MBF<sub>1</sub> and MBF<sub>2</sub>), which is synchronized to the reading port's clock. These New-Mail-Alert Flags are status indicators only, and cannot inhibit mailbox-register read or write operations. ## Request/Acknowledge Handshake Synchronous, request/acknowledge handshake feature is provided for each port, to perform boundary synchronization between asynchronously-operated ports. It operates only during normal FIFO operation at that port. The use of this feature is optional. When it is used, the Request input (REQA/B) is sampled at a rising clock edge. With REQA/B HIGH, R/WA/B determines whether a FIFO read operation or a FIFO write operation is being requested. The Acknowledge output (ACKA/B) is updated during the following clock cycle(s). ACKA/B meets the setup and hold time requirements of the Enable input (ENA or ENB). Therefore, ACKA/B may be tied back to the enable input to directly gate FIFO accesses, at a slight decrease in maximum operating frequency. The assertion of ACKa/B signifies that REQa/B was asserted. However, ACKa/B does not depend logically on ENa/B; and thus the assertion of ACKa/B does not prove that a FIFO write access or a FIFO read access actually took place. While REQa/B and ENa/B are being held ## **OPERATIONAL DESCRIPTION (cont'd)** HIGH, ACK<sub>A/B</sub> may be considered as a synchronous, predictive boundary flag. That is, ACK<sub>A/B</sub> acts as a synchronized predictor of the Almost-Full Flag $\overline{AF}$ for write operations, or as a synchronized predictor of the Almost-Empty Flag $\overline{AE}$ for read operations. Outside the 'almost-full' region and the 'almost-empty' region, ACKA/B remains continuously HIGH whenever REQA/B is held continuously HIGH. Within the 'almost-full' region or the 'almost-empty' region, ACKA/B occurs only on every third cycle. Assuming that ACKA/B is being used to control ENA/B, this repetition-rate decrease can help to prevent an overrun of the FIFO's actual full or empty boundaries, and to ensure that the tFWL (first write latency) and tFRL (first read latency) specifications are satisfied before ACKA/B is received. The 'almost-full region' is defined as 'that region, where the Almost-Full Flag is being asserted'; and the 'almost-empty region' as 'that region, where the Almost-Empty Flag is being asserted.' Thus, the extent of these 'almost' regions depends on how the system has programmed the offset values for the Almost-Full Flags and the Almost-Empty Flags. If the system has *not* programmed them, then these offset values remain at their default values, eight in each case. If a write attempt is unsuccessful because the corresponding FIFO is full, or if a read attempt is unsuccessful because the corresponding FIFO is empty, ACKA/B is *not* asserted in response to REQA/B. If the REQ/ACK handshake is not used, then the REQA/B input may be used as a second enable input, at a possible minor loss in maximum operating speed. In this case, the ACKA/B output may be ignored. WARNING: Whether or not the REQ/ACK handshake is being used, the REQA/B input for a port *must* be asserted for the corresponding FIFO to operate. ## **Data Retransmit** A retransmit operation resets the read-address pointer of the corresponding FIFO (#1 or #2) back to the first FIFO physical memory location, so that data may be reread. The write pointer is not affected. The status flags are updated; and a block of up to 256 data words, which previously had been written into and read from a FIFO, can be retrieved. The block to be retransmitted is bounded by the first FIFO memory location, and the FIFO memory location addressed by the write pointer. FIFO #1 retransmit is initiated by strobing the $\overline{\text{RT}}_1$ pin LOW. FIFO #2 retransmit is initiated by strobing the $\overline{\text{RT}}_2$ pin LOW. Read and write operations to a FIFO should be stopped while the corresponding Retransmit signal is being asserted. ## **Parity Check** The Parity Check Flags, $\overline{PF}_A$ and $\overline{PF}_B$ , are asserted (LOW) whenever there is a parity error in the data word present on the Port A data bus or the Port B data bus respectively. The inputs to the parity-evaluation logic come directly (via isolation transistors) from the data-bus bonding *pads*, in each case. The four bytes of a 36-bit data word are grouped as $D_0 - D_8$ , $D_9 - D_{17}$ , $D_{18} - D_{26}$ , and $D_{27} - D_{35}$ . The parity of each nine-bit byte is individually checked, and the four single-bit parity indications are logically inclusive-ORed to produce the Parity-Flag output. Parity checking is initialized for odd parity at reset, but can be reprogrammed for even parity or for odd parity during operation. Control-Register bit 0 (zero) selects the parity mode, odd or even (see Table 3). All nine bits of each byte are treated alike by the parity logic. The byte parity over the nine bits is compared with the Parity Mode bit in the Control Register, to generate a byte-parity-error indication. Then, the four byte-parity-error signals are NORed together, to compute the assertive-LOW parity-flag value. #### Word-Width Selection on Port B The word width of data access on Port B is selected by the WS<sub>0</sub> and WS<sub>1</sub> control inputs. WS<sub>0</sub> and WS<sub>1</sub> both are tied HIGH for 36-bit access; they both are tied LOW for single-byte access. For double-byte access, WS<sub>0</sub> is tied HIGH and WS<sub>1</sub> is tied LOW. In the single-byte-access or double-byte-access modes, FIFO write operations on Port B essentially pack the data to form 36-bit words, as viewed from Port A. Similarly, single-byte or double-byte FIFO read operations on Port B essentially unpack 36-bit words through a series of shift operations. FIFO status flags are updated following the last access which forms a complete 36-bit transfer. Since the values for each status flag are computed by logic directly associated with one of the FIFO-memory arrays, and not by logic associated with Port B, the flag values reflect the array fullness situation in terms of complete 36-bit words, and not in terms of bytes or double bytes. However, there is no such restriction for switching from writing to reading, or from reading to writing, at Port B. As long as $t_{RWS}$ , $t_{DS}$ , and $t_{A}$ are satisfied, $R\overline{W}_{B}$ may change state after *any* single-byte or double-byte access, and not only after a full 36-bit-word access. Also, the word-width-writing feature continues to operate properly in 'loopback' mode. Note that the programmable word-width-matching feature is *only* supported for FIFO accesses. Mailbox and Data Bypass operations do *not* support word-width matching between Port A and Port B. Tables 2, 3, and 4, and Figures 4a and 4b summarize word-width selection for Port B. Table 2. Port B Word-Width Selection | WS <sub>1</sub> | WS <sub>0</sub> | PORT B DATA WIDTH | |-----------------|-----------------|-------------------| | Н | Н | 36-Bit | | Н | L | (Reserved) | | L | Н | 18-Bit | | L | L | 9-Bit | Table 3. Resource-Register Programming | RESOURCE-<br>REGISTER<br>ADDRESS | | RESOURCE-REGISTER CONTENTS | | | | | | | | | | | | |----------------------------------|-----------------|----------------------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------|------------------|-------------------------------------|------------------|-------------------------------------|-------------|-------------------------------------|--|--|--| | A <sub>2A</sub> | A <sub>1A</sub> | AQA | NORMAL FIFO OPERATION | | | | | | | | | | | | | Н | Н | D <sub>35</sub> A | | <del></del> | NOTHINAL | 0 01 | LIKITON | | D <sub>0A</sub> | | | | | Н | | | X | | | | | | | X | | | | | | | | | | | | | | | | | | | | | Н | L | | | | | MAILBO | K | | | | | | | | | | D35A | | | | | | | D0A | | | | | Н | | | X | | | | | | | X | | | | | | | | AF <sub>2</sub> , AE <sub>2</sub> , AF <sub>1</sub> , AE <sub>1</sub> FLAG OFFSETS REGISTER (36-BIT MODE) | | | | | | | | | | | | | | | D35A | D34AD <sub>27A</sub> | D <sub>26A</sub> | D25AD <sub>18A</sub> | D <sub>17A</sub> | D16A D9A | D8A | D7AD <sub>0A</sub> | | | | | Н | L | Н | Х | ĀF <sub>2</sub> Offset <sup>1</sup> | Х | ĀĒ <sub>2</sub> Offset <sup>1</sup> | X | ĀF <sub>1</sub> Offset <sup>1</sup> | Х | ĀĒ <sub>1</sub> Offset <sup>1</sup> | | | | | | | | | | | | | | | | | | | | н | L | L | D | | | CONTROL REGIST | rer (WR | ITE-ONLY) PARITY | | | | | | | | | | D35A | | | | | | D1A | Dod 2 | | | | | П | | | <b>^</b> | | | | | | X | Parity Mode <sup>2</sup> | | | | | | Н | Н | | | | 8-BIT AE1 FLA | AG OFFS | ET REGISTER | <del></del> | | | | | | | | | D <sub>35A</sub> | | | | | | D8A | D7A D <sub>0A</sub> | | | | | L | | | X | | | | | | X | AE <sub>1</sub> Offset <sup>1</sup> | | | | | | | | | | | 8-BIT AF1 FLA | G OFFS | ET REGISTER | | | | | | | | | | D <sub>35A</sub> | | | | | | D8A | D7AD <sub>0A</sub> | | | | | L | Н | L | X | | | | | | X | ĀF <sub>1</sub> Offset <sup>1</sup> | | | | | | | | | | | | | | | | | | | | | L | Н | _ | | | 8-BIT AE <sub>2</sub> FL | AG OFFS | ET REGISTER | | | | | | | L | | | D <sub>35A</sub> | | | | | | D8A | D7A D <sub>0A</sub> | | | | | L | | | λ | | | | <del></del> | | X | ĀĒ <sub>2</sub> Offset <sup>1</sup> | | | | | | | | | | | 8-BIT AF <sub>2</sub> FLA | AG OFFS | ET REGISTER | | | | | | | | | | D <sub>35A</sub> | | | | | | D8A | D7AD <sub>0A</sub> | | | | | L | L | L L | X | | | | | | X | AF <sub>2</sub> Offset <sup>1</sup> | | | | #### NOTES: - 1. All four programmable-flag-offset values are initialized to eight (8) during a reset operation. - 2. Odd parity = HIGH; even parity = LOW. The parity mode is initialized to odd during a reset operation. Table 4. Flag Definition Table <sup>1</sup> | | VALID FU | LL-WORD REA | AD CYCLES RE | VALID FULL-WORD WRITE CYCLES REMAINING | | | | | |------|----------|-------------|--------------|----------------------------------------|--------|-------|-------------|-------| | FLAG | FLAG = | = LOW | FLAG | = HIGH | FLAG : | = LOW | FLAG = HIGH | | | | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | | FF | 256 | 256 | 0 | 255 | 0 | 0 | 1 | 256 | | AF | 256-р | 256 | 0 | 255-p | 0 | р | p + 1 | 256 | | HF | 129 | 256 | 0 | 128 | 0 | 127 | 128 | 256 | | AE | 0 | q | q + 1 | 256 | 256-q | 256 | 0 | 255-q | | EF | 0 | 0 | 1 | 256 | 256 | 256 | 0 | 255 | #### NOTE: - 1. q = Programmable-Almost-Empty offset value. (Default value: q = 8.) - 2. p = Programmable-Almost-Full offset value. (Default value: p = 8.) www.DataSheet4U.com ## PORT B WORD-WIDTH SELECTION Figure 4a. 36-to-18 Funneling Through FIFO #1 Figure 4b. 36-to-9 Funneling Through FIFO #1 #### NOTES: - The heavy black borders on register segments indicate the main data path, suitable for most applications. Alternate paths feature a different ordering of bytes within a word, at Port B. - The funneling process does not change the ordering of bits within a byte. Halfwords (Figure 4a) or bytes (Figure 4b) are transferred in parallel form from Port A to Port B. - 3. The word-width setting may be changed during system operation; however, two clock intervals should be allowed for these signals to settle, before again attempting to read D<sub>08</sub> D<sub>358</sub>, and three dummy words should be passed through initially. Also, incomplete data words may occur when the word width is changed from shorter to longer, at an inappropriate point in the data block passing through the FIFO. To avoid such incomplete data words, and to achieve proper synchronization, 'dummy' partial words should be supplied to complete the final longer word. ## PORT B WORD-WIDTH SELECTION Figure 5a. 18-to-36 Defunneling Through FIFO #2 Figure 5b. 9-to-36 Defunneling Through FIFO #2 #### NOTES: - The heavy black borders on register segments indicate the only data paths used. The other byte segments of Port B do not participate in the data path during defunneling. - The defunneling process does not change the ordering of bits within a byte. Halfwords (Figure 5a) or bytes (Figure 5b) are transferred in parallel form from Port B to Port A. - 3. The word-width setting may be changed during system operation; however, two clock intervals should be allowed for these signals to settle, before again attempting to send data, and three dummy words should be passed through initially. Also, incomplete data words may occur when the word width is changed from shorter to longer, at an inappropriate point in the data block passing through the FIFO. To avoid such incomplete data words, and to achieve proper synchronization, 'dummy' partial words should be supplied to complete the final longer word. ## **TIMING DIAGRAMS** Figure 6. Reset Timing Figure 7. Data Bypass Timing Figure 8. Port A FIFO Read/Write Figure 9. Port B FIFO Read/Write Figure 10. Port A Mailbox Access Figure 11. Port B Mailbox Access Figure 12. Flag Programming Figure 13. Empty Flag Timing Figure 14. Almost-Empty Flag Timing 2 Figure 15. Full Flag Timing Figure 16. Almost-Full Flag Timing Figure 17. Half-Full Flag Timing Figure 18. FIFO #2 Retransmit 24 Figure 19. FIFO #1 Retransmit Figure 20. FIFO #1 Write and Read Operation in Near-Empty Region t<sub>FRL</sub> (First Read Latency) - The first read following an empty condition may begin no earlier than t<sub>FRL</sub> after the first write to an empty FIFO, to ensure that valid read data is retrieved. Figure 21. FIFO #2 Write and Read Operation in Near-Empty Region 5420-17 # Figure 22. FIFO #1 Read and Write Operation in Near-Full Region ## NOTES: - 1. A2A, A1A, and A0A all are held HIGH for FIFO access at Port A. $\underline{A}_{0B}$ is held HIGH for FIFO access at Port B. - 2. $\overline{OE_B}$ is held LOW. - 3. OE<sub>A</sub> is held HIGH. - 4. t<sub>FWL</sub> (First Write Latency) The first write following a full condition may begin no earlier than $t_{\text{FWL}}$ after the first read from a full FIFO, to ensure that valid write data is written. 5420-15 Figure 23. FIFO #2 Read and Write Operation in **Near-Full Region** Figure 24. Port B Double-Byte FIFO #1 Read Access for 36-to-18 Funneling Figure 25. Port B Double-Byte FIFO #2 Write Access for 18-to-36 Defunneling www.DataSheet4U.com 8180798 0016269 126 Figure 26. Port B Single-Byte FIFO #1 Read Access for 36-to-9 Funneling Figure 27. Port B Single-Byte FIFO #2 Write Access for 9-to-36 Defunneling Figure 28. Write Request/Acknowledge Handshake Figure 29. Read Request/Acknowledge Handshake ## **PACKAGE DIAGRAM** 132-pin PQFP ## **ORDERING INFORMATION**