## FEATURES

- Pin-Compatible and Functionally Upwards-Compatible with Sharp LH5420 and LH543601, but Deeper
- Expanded Control Register that is Fully Readable as well as Writeable
- Fast Cycle Times: 18/20/25/30/35 ns
- Improved Input Setup and Flag Out Timing
- Two $512 \times 36$-bit FIFO Buffers (LH543611) or Two $1024 \times 36$-bit FIFO Buffers (LH543621)
- Full 36-bit Word Width
- Selectable 36/18/9-bit Word Width on Port B; Selection May be Changed Without Resetting the BiFIFO
- Programmable Byte-Order Reversal -'Big-Endian $\leftrightarrow$ Little-Endian Conversion'
- Independently-Synchronized ('Fully-Asynchronous') Operation of Port A and Port B
- 'Synchronous' Enable-Plus-Clock Control at Both Ports
- $\mathrm{R} / \overline{\mathrm{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
- All Flags are Independently Programmable for Either Synchronous or Asynchronous Operation
- Almost-Full Flag and Almost-Empty Flag Have Programmable Offsets
- Mailbox Registers with Synchronized Flags
- Data-Bypass Function
- Data-Retransmit Function
- Automatic Byte Parity Checking with Programmable Parity Flag Latch
- Programmable Byte Parity Generation
- Programmable Byte, Half-Word, or Full-Word Oriented Parity Operations
- 8 mA -Iol High-Drive Three-State Outputs with Built-In Series Resistor
- TTL/CMOS-Compatible I/O
- Space-Saving PQFP and TQFP Packages


## FUNCTIONAL DESCRIPTION

The LH543611 and LH543621 contain 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 512 or 1024 by 36 bits. The LH543611 and LH543621 are ideal either for wide unidirectional applications or for bidirectional data applications; component count and board area are reduced.

The LH543611 and LH543621 have 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 LH543611 and LH543621 are fully-static parts.

Conceptually, the port clocks $\mathrm{CK}_{\mathrm{A}}$ and $\mathrm{CK}_{B}$ are freerunning, periodic 'clock' waveforms, used to control other signals which are edge-sensitive. 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. Each of these flags may be independently programmed for either synchronous or asynchronous operation. Also, 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. Adata block of 512 (LH543611) or 1024 (LH543621) 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. 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 initialization 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 band widths. Subject to meeting timing requirements, the word-width selection may be changed at any time during the operation of an LH543611 or LH543621, without the need either for a reset operation or for passing dummy words through Port $B$ immediately after the
change; except that if the change is not made at a full-word boundary, at least one dummy word must be passed through Port B before any actual data words are transmitted.

A Byte Parity Check Flag at each port monitors data integrity. Control-Register bit 00 (zero) selects the parity mode, odd or even. This bit is initialized for odd data parity at reset; but it may be reprogrammed for even parity, or back again to odd parity, as desired. The parity flags may be programmed to operate either in a latched mode or in a flowthrough mode. The parity checking may be performed over 36-bit full-words, over 18-bit half-words, or over 9-bit single bytes.

Parity generation may be selected as well as parity checking, and may likewise be performed over full-words or half-words or single bytes. In any case, a parity bit of the proper mode is generated over the least-significant eight bits of a byte, and then is stored in the most-significant bit position of the byte as it passes through the LH543611/21, overwriting whatever bit was present in that bit position previously.

## PIN CONNECTIONS



Figure 1. Pin Connections for 132-Pin PQFP Package (Top View)


Figure 2. Pin Connections for 144-Pin TQFP Package (Top View)

## PIN LIST

| SIGNAL NAME | PQFP PIN NO. | TQFP PIN NO. | SIGNAL NAME | PQFP PIN NO. | TQFP PIN NO. | SIGNAL NAME | $\begin{gathered} \text { PQFP } \\ \text { PIN122 NO. } \end{gathered}$ | TQFP PIN NO. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0} \mathrm{~A}$ | 1 | 126 | $\overline{\mathrm{EF}}_{1}$ | 60 | 62 | $\mathrm{D}_{20 \mathrm{~A}}$ | 120 | 140 |
| $\mathrm{A}_{1} \mathrm{~A}$ | 2 | 125 | $\mathrm{ACK}_{\text {B }}$ | 61 | 61 | D19A | 122 | 138 |
| $\mathrm{A}_{2 \mathrm{~A}}$ | 3 | 124 | REQb | 63 | 59 | D ${ }_{18 \text { A }}$ | 123 | 137 |
| $\overline{\mathrm{OE}}_{\mathrm{A}}$ | 4 | 123 | $\mathrm{ENB}_{\text {B }}$ | 64 | 58 | $\overline{\mathrm{MBF}}_{2}$ | 124 | 136 |
| $\overline{\mathrm{FF}}_{1}$ | 6 | 121 | $\mathrm{R} / \bar{W}_{B}$ | 65 | 57 | $\overline{\mathrm{AE}}_{2}$ | 125 | 135 |
| $\overline{\mathrm{AF}}_{1}$ | 7 | 120 | $\mathrm{CK}_{\mathrm{B}}$ | 66 | 56 | $\overline{\mathrm{EF}}_{2}$ | 126 | 134 |
| $\overline{\mathrm{HF}}_{1}$ | 8 | 119 | A0B | 67 | 55 | $\mathrm{ACK}_{\mathrm{A}}$ | 127 | 133 |
| $\overline{\mathrm{PF}}_{\mathrm{A}}$ | 9 | 118 | WSo | 68 | 53 | $\mathrm{REQ}_{\mathrm{A}}$ | 129 | 131 |
| $\mathrm{D}_{17 \mathrm{~A}}$ | 10 | 117 | WS1 | 69 | 52 | ENA | 130 | 130 |
| D16A | 11 | 116 | $\overline{\mathrm{OE}}_{\mathrm{B}}$ | 70 | 51 | $\mathrm{R} / \bar{W}_{\mathrm{A}}$ | 131 | 129 |
| D15A | 12 | 115 | $\overline{\mathrm{FF}}_{2}$ | 72 | 49 | $\mathrm{CK}_{\text {A }}$ | 132 | 128 |
| $\mathrm{D}_{14 \mathrm{~A}}$ | 14 | 113 | $\overline{\mathrm{AF}}_{2}$ | 73 | 48 | VCC | 5 | 122 |
| $\mathrm{D}_{13 \mathrm{~A}}$ | 15 | 112 | $\overline{\mathrm{HF}}_{2}$ | 74 | 47 | Vsso | 13 | 114 |
| $\mathrm{D}_{12 \mathrm{~A}}$ | 16 | 111 | $\overline{\mathrm{PF}}_{\mathrm{B}}$ | 75 | 46 | VSSO |  | 109 |
| $\mathrm{D}_{11 \mathrm{~A}}$ | 17 | 110 | $\mathrm{D}_{18 \mathrm{~B}}$ | 76 | 45 | Vcco |  | 108 |
| $\mathrm{D}_{10 \mathrm{~A}}$ | 19 | 106 | D19B | 77 | 44 | V cco | 18 | 107 |
| D9A | 20 | 105 | $\mathrm{D}_{20 \mathrm{~B}}$ | 78 | 43 | V ${ }_{\text {SSO }}$ | 22 | 103 |
| $\mathrm{D}_{8 \mathrm{~A}}$ | 21 | 104 | $\mathrm{D}_{21 \mathrm{~B}}$ | 80 | 41 | Vcco | 26 | 99 |
| D7A | 23 | 102 | $\mathrm{D}_{22 \mathrm{~B}}$ | 81 | 40 | Vsso | 30 | 95 |
| $\mathrm{D}_{6} \mathrm{~A}$ | 24 | 101 | $\mathrm{D}_{23 \mathrm{~B}}$ | 82 | 39 | $V_{\text {SSO }}$ |  | 90 |
| D5A | 25 | 100 | $\mathrm{D}_{24}$ | 83 | 38 | Vsso | 38 | 86 |
| $\mathrm{D}_{4}$ | 27 | 98 | $\mathrm{D}_{25 B}$ | 85 | 34 | Vcco | 42 | 82 |
| $\mathrm{D}_{3}$ | 28 | 97 | $\mathrm{D}_{26 \mathrm{~B}}$ | 86 | 33 | $V_{\text {Sso }}$ | 46 | 78 |
| $\mathrm{D}_{2 \mathrm{~A}}$ | 29 | 96 | D27B | 87 | 32 | Vcco | 50 | 74 |
| $\mathrm{D}_{1 \mathrm{~A}}$ | 31 | 94 | D28B | 89 | 30 | Vcco |  | 73 |
| $\mathrm{D}_{0 \mathrm{~A}}$ | 32 | 93 | D29B | 90 | 29 | Vsso |  | 72 |
| $\overline{\mathrm{RS}}$ | 33 | 92 | $\mathrm{D}_{30 \mathrm{~B}}$ | 91 | 28 | $V_{\text {SSO }}$ | 55 | 67 |
| $\overline{\mathrm{RT}}_{1}$ | 34 | 91 | $\mathrm{D}_{31 \mathrm{~B}}$ | 93 | 26 | VSS | 62 | 60 |
| $\mathrm{D}_{0 \mathrm{~B}}$ | 35 | 89 | $\mathrm{D}_{32 \mathrm{~B}}$ | 94 | 25 | VSS |  | 54 |
| $\mathrm{D}_{1 \mathrm{~B}}$ | 36 | 88 | $\mathrm{D}_{33 \mathrm{~B}}$ | 95 | 24 | $V_{\text {cc }}$ | 71 | 50 |
| $\mathrm{D}_{2 \mathrm{~B}}$ | 37 | 87 | $\mathrm{D}_{34 \mathrm{~B}}$ | 97 | 22 | Vsso | 79 | 42 |
| $\mathrm{D}_{3 \mathrm{~B}}$ | 39 | 85 | $\mathrm{D}_{35 \mathrm{~B}}$ | 98 | 21 | Vsso |  | 37 |
| D4B | 40 | 84 | $\mathrm{RT}_{2}$ | 100 | 18 | V Cco |  | 36 |
| D5B | 41 | 83 | D35A | 101 | 17 | Vcco | 84 | 35 |
| D6B | 43 | 81 | $\mathrm{D}_{34}$ | 102 | 16 | Vsso | 88 | 31 |
| $\mathrm{D}_{7 \mathrm{~B}}$ | 44 | 80 | $\mathrm{D}_{33}$ | 103 | 15 | $V_{\text {cco }}$ | 92 | 27 |
| D8B | 45 | 79 | $\mathrm{D}_{32 \mathrm{~A}}$ | 105 | 13 | Vsso | 96 | 23 |
| $\mathrm{D}_{9 \mathrm{~B}}$ | 47 | 77 | $\mathrm{D}_{31 \mathrm{~A}}$ | 106 | 12 | VSS | 99 | 20 |
| D10B | 48 | 76 | $\mathrm{D}_{30 \mathrm{~A}}$ | 107 | 11 | VSSO |  | 19 |
| $\mathrm{D}_{11 \mathrm{~B}}$ | 49 | 75 | D29A | 109 | 9 | Vsso | 104 | 14 |
| $\mathrm{D}_{12 \mathrm{~B}}$ | 51 | 71 | D28A | 110 | 8 | Vcco | 108 | 10 |
| $\mathrm{D}_{13 \mathrm{~B}}$ | 52 | 70 | D27A | 111 | 7 | Vsso | 112 | 6 |
| $\mathrm{D}_{14 \mathrm{~B}}$ | 53 | 69 | $\mathrm{D}_{26 \mathrm{~A}}$ | 113 | 5 | V Cco | 116 | 2 |
| $\mathrm{D}_{15 \mathrm{~B}}$ | 54 | 68 | D25A | 114 | 4 | Vcco |  | 1 |
| D16B | 56 | 66 | D24A | 115 | 3 | Vsso |  | 144 |
| $\mathrm{D}_{17 \mathrm{~B}}$ | 57 | 65 | D23A | 117 | 143 | $V_{\text {SSO }}$ | 121 | 139 |
| $\mathrm{MBF}_{1}$ | 58 | 64 | D22A | 118 | 142 | VSS | 128 | 132 |
| $\overline{\mathrm{AE}}_{1}$ | 59 | 63 | $\mathrm{D}_{21 \mathrm{~A}}$ | 119 | 141 | VSS |  | 127 |

## NOTE:

| PINS | COMMENTS |
| :--- | :--- |
| VCC | Supply internal logic. Connected to each other. |
| VCCO | Supply output drivers only. Connected to each <br> other. |

## PINS

VSS
$V_{\text {SSO }}$

## COMMENTS

Supply internal logic. Connected to each other. Supply output drivers only. Connected to each other.


543611-3
Figure 3a. Simplified LH543611/21 Block Diagram


543611-4
Figure 3b. Detailed LH543611/21 Block Diagram

## PIN DESCRIPTIONS

| PIN | PIN TYPE ${ }^{1}$ | DESCRIPTION |
| :---: | :---: | :---: |
| GENERAL |  |  |
| $\mathrm{V}_{\text {CC }}, \mathrm{V}_{\text {SS }}$ | V | Power, Ground |
| $\overline{\mathrm{RS}}$ | 1 | Reset |
| PORT A |  |  |
| $\mathrm{CK}_{\text {A }}$ | 1 | Port A Free-Running Clock |
| $\mathrm{R} / \bar{W}_{\mathrm{A}}$ | 1 | Port A Edge-Sampled Read/Write Control |
| $\mathrm{EN}_{\mathrm{A}}$ | 1 | Port A Edge-Sampled Enable |
| A0A, $A_{1 A}, A_{2} A$ | 1 | Port A Edge-Sampled Address Pins |
| $\overline{\mathrm{OE}}_{\mathrm{A}}$ | 1 | Port A Level-Sensitive Output Enable |
| $\mathrm{REQ}_{\mathbf{A}}$ | 1 | Port A Request/Enable |
| $\overline{\mathrm{RT}}_{2}$ | 1 | FIFO \#2 Retransmit |
| $\mathrm{D}_{0 \mathrm{~A}}-\mathrm{D}_{35 \mathrm{~A}}$ | I/O/Z | Port A Bidirectional Data Bus |
| $\overline{\mathrm{FF}}_{1}$ | 0 | FIFO \#1 Full Flag (Write Boundary) |
| $\overline{\mathrm{AF}}_{1}$ | 0 | FIFO \#1 Programmable Almost-Full Flag (Write Boundary) |
| $\overline{\mathrm{HF}}_{1}$ | 0 | FIFO \#1 Half-Full Flag |
| $\overline{\mathrm{AE}}_{2}$ | 0 | FIFO \#2 Programmable Almost-Empty Flag (Read Boundary) |
| $\overline{E F}_{2}$ | 0 | FIFO \#2 Empty Flag (Read Boundary) |
| $\overline{\mathrm{MBF}}_{2}$ | 0 | New-Mail-Alert Flag for Mailbox \#2 |
| $\overline{\mathrm{PF}}_{\mathrm{A}}$ | 0 | Port A Parity Flag |
| $\mathrm{ACK}_{\text {A }}$ | 0 | Port A Acknowledge |
| PORT B |  |  |
| CKB | 1 | Port B Free-Running Clock |
| $\mathrm{R} / \bar{W}_{B}$ | 1 | Port B Edge-Sampled Read/Write Control |
| ENB | 1 | Port B Edge-Sampled Enable |
| $\mathrm{A}_{0 \mathrm{~B}}$ | 1 | Port B Edge-Sampled Address Pin |
| $\overline{\mathrm{OE}}_{\mathrm{B}}$ | 1 | Port B Level-Sensitive Output Enable |
| $\mathrm{WS}_{0}, \mathrm{WS}_{1}$ | 1 | Port B Word-Width Select |
| REQb | 1 | Port B Request/Enable |
| $\overline{\mathrm{RT}}_{1}$ | 1 | FIFO \#1 Retransmit |
| $\mathrm{D}_{0 \mathrm{~B}}-\mathrm{D}_{35 \mathrm{~B}}$ | I/O/Z | Port B Bidirectional Data Bus |
| $\overline{\mathrm{FF}}_{2}$ | 0 | FIFO \#2 Full Flag (Write Boundary) |
| $\overline{\mathrm{AF}}_{2}$ | 0 | FIFO \#2 Programmable Almost-Full Flag (Write Boundary) |
| $\overline{\mathrm{HF}}_{2}$ | 0 | FIFO \#2 Half-Full Flag |
| $\overline{\mathrm{AE}}_{1}$ | 0 | FIFO \#1 Programmable Almost-Empty Flag (Read Boundary) |
| $\overline{\mathrm{EF}}_{1}$ | 0 | FIFO \#1 Empty Flag (Read Boundary) |
| $\overline{\mathrm{MBF}}_{1}$ | 0 | New-Mail-Alert Flag for Mailbox \#1 |
| $\overline{\mathrm{PF}}_{\mathrm{B}}$ | 0 | Port B Parity Flag |
| $\mathrm{ACK}_{\mathrm{B}}$ | 0 | Port B Acknowledge |

NOTE:

1. $\mathrm{I}=$ Input, $\mathrm{O}=$ Output, $\mathrm{Z}=$ High-Impedance, $\mathrm{V}=$ Power Voltage Leve I

# ABSOLUTE MAXIMUM RATINGS ${ }^{1}$ 

| PARAMETER | RATING |
| :--- | :--- |
| Supply Voltage to $\mathrm{V}_{\text {SS }}$ Potential | -0.5 V to 7 V |
| Signal Pin Voltage to $\mathrm{V}_{\text {SS }}$ Potential ${ }^{3}$ | -0.5 V to $\mathrm{V} \mathrm{CC}+0.5 \mathrm{~V}$ |
| DC Output Current $^{2}$ | $\pm 40 \mathrm{~mA}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |
| Power Dissipation (Package Limit) | 2 Watts (Quad Flat Pack) |

## NOTES:

1. 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.
2. 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 |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{A}}$ | Temperature, Ambient | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |
| VCC | Supply Voltage | 4.5 | 5.5 | V |
| Vss | Supply Voltage | 0 | 0 | V |
| $\mathrm{~V}_{\text {IL }}$ | Logic LOW <br> Input Voltage | -0.5 | 0.8 | V |
| V IH | Logic HIGH <br> Input Voltage | 2.2 | $\mathrm{Vcc}+0.5$ | V |

NOTE:

1. Negative undershoot of 1.5 V in amplitude is permitted for up to 10 ns , once per cycle.

## DC ELECTRICAL CHARACTERISTICS (OVER OPERATING RANGE)

| Symbol | PARAMETER | TEST CONDITIONS | min | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 l | Input Leakage Current | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ To $\mathrm{V}_{\mathrm{CC}}$ | -10 | - | 10 | $\mu \mathrm{A}$ |
| ILo | I/O Leakage Current | $\overline{\mathrm{OE}} \geq \mathrm{V}_{\mathrm{H}}, 0 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ | -10 | - | 10 | $\mu \mathrm{A}$ |
| Vol | Logic LOW Output Voltage | $\mathrm{loL}=8.0 \mathrm{~mA}$ | - | - | 0.4 | V |
| V OH | Logic HIGH Output Voltage | $\mathrm{l}_{\mathrm{OH}}=-8.0 \mathrm{~mA}$ | 2.4 | - | - | V |
| Icc | Average Supply Current ${ }^{1,2}$ | Measured at $\mathrm{fcc}^{\text {c }}$ MAX | - | 180 | 280 | mA |
| Icc2 | Average Standby Supply Current ${ }^{1,3}$ | All Inputs $=\mathrm{V}_{\text {IHmin }}($ Clocks idle $)$ | - | 13 | 25 | mA |
| Icca | Power-Down Supply Current ${ }^{1}$ | All Inputs $=\mathrm{V}_{\text {cc }}-0.2 \mathrm{~V}$ (Clocks idle) | - | 0.002 | 1 | mA |
| Icca | Power-Down Supply Current ${ }^{1,3}$ | All Inputs $=\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$ <br> (Clocks running at $\mathrm{fcc}_{\mathrm{c}}=\mathrm{MAX}$ ) | - | 10 | 25 | mA |

## NOTES:

 outputs open (for Icc: $\mathrm{C}_{\mathrm{L}}=0 \mathrm{pF}$ ); and, for $\mathrm{Icc}^{\mathrm{cc}}$ and $\mathrm{I}_{\mathrm{Cc}} 4$, operating at minimum cycle times.
2. I $\mathrm{I}_{\mathrm{CC}}$ (MAX.) using $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}=5.5 \mathrm{~V}$ and 'worst case' data pattern. I ICC (TYP.) using $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and 'average' data pattern.
3. Icc2 (TYP.) and $\operatorname{Icc4}$ (TYP.) using $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

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

## CAPACITANCE ${ }^{1,2}$

## PARAMETER

$\mathrm{C}_{\mathrm{IN}}$ (Input Capacitance)
Cout (Output Capacitance)

Figure 5

## NOTES:

1. Sample tested only.
2. Capacitances are maximum values at $25^{\circ} \mathrm{C}$, measured at 1.0 MHz , with $\mathrm{V}_{\mathbb{I N}}=0 \mathrm{~V}$.

AC ELECTRICAL CHARACTERISTICS ${ }^{1}\left(\mathrm{VCC}=5 \mathrm{~V} \pm+10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| SYMBOL | DESCRIPTION | -18 |  | -20 |  | -25 |  | -30 |  | -35 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{f}_{\mathrm{Cc}}$ | Clock Cycle Frequency | - | 55 | - | 50 | - | 40 | - | 33 | - | 28.5 | MHz |
| tcc | Clock Cycle Time | 18 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock HIGH Time | 7 | - | 8 | - | 10 | - | 12 | - | 15 | - | ns |
| tcL | Clock LOW Time | 7 | - | 8 | - | 10 | - | 12 | - | 15 | - | ns |
| tds | Data Setup Time | 7.5 | - | 7.5 | - | 9 | - | 10 | - | 12 | - | ns |
| tD | Data Hold Time | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | ns |
| tes | Enable Setup Time | 5.5 | - | 5.5 | - | 7.5 | - | 8.5 | - | 10.5 | - | ns |
| teh | Enable Hold Time | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | ns |
| trws | Read/Write Setup Time | 5.5 | - | 5.5 | - | 7.5 | - | 8.5 | - | 10.5 | - | ns |
| trwh | Read/Write Hold Time | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | ns |
| tras | Request Setup Time | 5.5 | - | 5.5 | - | 7.5 | - | 8.5 | - | 10.5 | - | ns |
| trah | Request Hold Time | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | ns |
| $\mathrm{t}_{\text {AS }}$ | Address Setup Time ${ }^{2}$ | 7.5 | - | 7.5 | - | 9 | - | 10 | - | 12 | - | ns |
| $\mathrm{t}_{\mathrm{AH}}$ | Address Hold Time ${ }^{2}$ | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | ns |
| twSs | Width Select Setup Time | 5.5 | - | 5.5 | - | 7.5 | - | 8.5 | - | 10.5 | - | ns |
| twSH | Width Select Hold Time ${ }^{3}$ | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | 0.5 | - | ns |
| $t_{\text {A }}$ | Data Output Access Time | - | 13 | - | 13.8 | - | 16 | - | 20 | - | 25 | ns |
| tack | Acknowledge Access Time | - | 9.5 | - | 9.5 | - | 13 | - | 16 | - | 18 | ns |
| toh | Output Hold Time | 4 | - | 4 | - | 4 | - | 4 | - | 4 | - | ns |
| tzx | Output Enable Time, $\overline{\mathrm{OE}}$ LOW to $D_{0}-D_{35}$ Low-Z ${ }^{3}$ | 1.5 | - | 1.5 | - | 2 | - | 3 | - | 3 | - | ns |
| txz | Output Disable Time, $\overline{\mathrm{OE}}$ HIGH to $D_{0}-D_{35}$ High-Z ${ }^{3}$ | - | 9 | - | 9 | - | 12 | - | 15 | - | 20 | ns |
| tef | Clock to $\overline{\mathrm{EF}}$ Flag Valid | - | 14 | - | 14.5 | - | 19 | - | 22 | - | 27 | ns |
| tFF | Clock to $\overline{\text { FF }}$ Flag Valid | - | 14 | - | 14.5 | - | 19 | - | 22 | - | 27 | ns |
| thF | Clock to $\overline{\mathrm{HF}}$ Flag Valid | - | 14 | - | 14.5 | - | 19 | - | 22 | - | 27 | ns |
| $t_{\text {AE }}$ | Clock to $\overline{\mathrm{AE}}$ Flag Valid | - | 14.5 | - | 15 | - | 19 | - | 22 | - | 27 | ns |
| $t_{\text {AF }}$ | Clock to $\overline{\mathrm{AF}}$ Flag Valid | - | 14.5 | - | 15 | - | 19 | - | 22 | - | 27 | ns |
| tMBF | Clock to $\overline{\text { MBF }}$ Flag Valid | - | 10 | - | 10 | - | 13 | - | 18 | - | 23 | ns |
| tPF | Data to Parity Flag Valid ${ }^{4}$ | - | 14 | - | 14 | - | 17 | - | 20 | - | 25 | ns |
| trs | Reset/Retransmit Pulse Width ${ }^{5}$ | 18 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| $t_{\text {RSS }}$ | Reset/Retransmit Setup Time ${ }^{6}$ | 15 | - | 16 | - | 20 | - | 25 | - | 30 | - | ns |
| trse | Reset/Retransmit Hold Time ${ }^{6}$ | 7.2 | - | 8 | - | 10 | - | 15 | - | 20 | - | ns |
| $\mathrm{t}_{\text {RF }}$ | Reset LOW to Flag Valid | - | 21 | - | 21 | - | 25 | - | 30 | - | 35 | ns |
| tFRL | First Read Latency ${ }^{7}$ | 18 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tfwL | First Write Latency ${ }^{8}$ | 18 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| $t_{B S}$ | Bypass Data Setup | 8.5 | - | 8.5 | - | 10 | - | 13 | - | 15 | - | ns |
| $t_{B H}$ | Bypass Data Hold | 2 | - | 2 | - | 3 | - | 4 | - | 5 | - | ns |
| tBA | Bypass Data Access | - | 15.5 | - | 16 | - | 18 | - | 23 | - | 28 | ns |
| tskew1 | Skew Time Read-to-Write Clock | 14 | - | 14.5 | - | 19 | - | 22 | - | 27 | - | ns |
| tskew2 | Skew Time Write-to-Read Clock | 14 | - | 14.5 | - | 19 | - | 22 | - | 27 | - | ns |

## NOTES

1. Timing measurements performed at 'AC Test Condition' levels.
2. tas, tar address setup times and hold times need only be satisfied at clock edges which occur while the corresponding enables are being asserted.
3. Values are guaranteed by design; not currently production tested.
4. Measured with Parity Flag operating in flowthrough mode.
5. When $\mathrm{CK}_{A}$ or $\mathrm{CK}_{B}$ is enabled; $\mathrm{t}_{\mathrm{RS}}=\mathrm{t}_{\mathrm{RSS}}+\mathrm{t}_{\mathrm{CH}}+\mathrm{t}_{\mathrm{RSH}}$.
6. trss and/or trsh 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.
7. tFRL is the minimum first-write-to-first-read delay, following an empty condition, which is required to assure valid read data.
8. tFwL is the minimum first-read-to-first-write delay, following a full condition, which is required to assure successful writing of data.

## OPERATIONAL DESCRIPTION

## Reset

The device is reset whenever the asynchronous Reset $(\overline{\mathrm{RS}})$ input is taken LOW, and at least one rising edge and one falling edge of both $\mathrm{CK}_{\mathrm{A}}$ and $C K_{B}$ occur while $\overline{\mathrm{RS}}$ is LOW. A reset operation is required after power-up, before the first write operation may occur. The LH543611/21 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{\mathrm{AE}}_{1} / \overline{\mathrm{AE}}_{2}$ flags get asserted within eight locations of an empty condition, and the $\overline{\mathrm{AF}}_{1} / \overline{\mathrm{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{\mathrm{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 the $\mathrm{R} \bar{W}_{A}$ control input, which does not get overridden by the 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-regis-ter-select inputs, $\mathrm{A}_{0 \mathrm{~A}}, \mathrm{~A}_{1 \mathrm{~A}}$, and $\mathrm{A}_{2 \mathrm{~A}}$, which select between FIFO access, mailbox-register access, control-register access, and programmable flag-offset-value-register access. Port $B$ has a single address input, $A_{0 B}$, 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 CK ${ }_{B}$ ). Resource-register select-input address definitions are summarized in Table 1.

## Table 1. Resource-Register Addresses

| $A_{2 A}$ | $\mathbf{A}_{1 A}$ | $A_{0 A}$ | RESOURCE |
| :---: | :---: | :---: | :--- |
| PORT A |  |  |  |

## Control Register

The eighteen Control-Register bits govern the synchronization mode of the fullness-status flags at each port, the choice of odd or even parity at both ports, the enabling of parity generation for data flow at each port, the optional latching behavior of the parity-error flags at each port, and the selection of a full-word or half-word or single-byte field for parity checking. A reset operation initializes the LH543611/21 Control Register for LH5420/LH543601-compatible operation, but it may be reprogrammed at will at any time during LH543611/21 operation.

## 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 ( $\mathrm{CK}_{\mathrm{A}}$ or $\mathrm{CK}_{\mathrm{B}}$ ) whenever: the appropriate enable ( $\mathrm{EN} \mathrm{N}_{\mathrm{A}}$ or $\mathrm{EN}_{\mathrm{B}}$ ) is held HIGH; the appropriate request ( $\mathrm{REQ}_{A}$ or REQB) is held HIGH; the appropriate Read/Write control $\left(R / \bar{W}_{A}\right.$ or $\left.R \bar{W}_{B}\right)$ is held LOW; the FIFO address is selected for the address inputs ( $\mathrm{A}_{2 \mathrm{~A}}-\mathrm{A}_{0 \mathrm{~A}}$ or $\mathrm{A}_{0 B}$ ); 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 ( $D_{0 A}-D_{35 A}$ or $\mathrm{D}_{0 \mathrm{~B}}-\mathrm{D}_{35 \mathrm{~B}}$ ).

Normally, the appropriate Output Enable signal ( $\overline{\mathrm{OE}}_{\mathrm{A}}$ or $\overline{\mathrm{OE}}_{\mathrm{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

## OPERATIONAL DESCRIPTION (cont'd)

which otherwise would be permissible for that speed grade of LH543611/21.

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{\mathrm{FF}}=\mathrm{HIGH}$ ). The first write operation should begin no earlier than a First Write Latency (trwl) after the first read operation from a full FIFO, to ensure that correct read data are retrieved. (See Figures 33 and 34.)

## FIFO Read

PortA reads from FIFO \#2, and PortB reads from FIFO \#1. A read operation is initiated on the rising edge of a clock ( $\mathrm{CK}_{\mathrm{A}}$ or $\mathrm{CK}_{\mathrm{B}}$ ) whenever: the appropriate enable ( $\mathrm{EN} \mathrm{N}_{\mathrm{A}}$ or $\mathrm{EN} \mathrm{N}_{\mathrm{B}}$ ) is held HIGH; the appropriate request ( $R_{A} Q_{A}$ or $R_{B}$ ) is held HIGH; the appropriate Read/Write control ( $\mathrm{R} \bar{W}_{A}$ or $\mathrm{R} \bar{W}_{B}$ ) is held HIGH; the FIFO address is selected for the address inputs ( $\mathrm{A}_{2 \mathrm{~A}}-\mathrm{A}_{0 \mathrm{~A}}$ or $\mathrm{A}_{0 B}$ ); and the prescribed setup times and hold times are observed for all of these signals. Read data becomes valid on the data-bus pins ( $\mathrm{D}_{0 \mathrm{~A}}-\mathrm{D}_{35 \mathrm{~A}}$ or $D_{0 B}-D_{35 B}$ ) by a time $t_{A}$ after the rising clock ( $C K_{A}$ or $\mathrm{CK}_{\mathrm{B}}$ ) edge, provided that the data outputs are enabled.
$\overline{\mathrm{OE}}_{\mathrm{A}}$ and $\overline{\mathrm{OE}}_{\mathrm{B}}$ 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 ( $\overline{\mathrm{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. (See Figures 31 and 32.)

## Dedicated FIFO Status Flags

Six dedicated FIFO status flags are included for Full ( $\overline{\mathrm{FF}}_{1}$ and $\overline{\mathrm{FF}}_{2}$ ), Half-Full ( $\mathrm{HF}_{1}$ and $\mathrm{HF}_{2}$ ), and Empty ( $\overline{\mathrm{EF}}_{1}$ and $\mathrm{EF}_{2}$ ). $\mathrm{FF}_{1}, \mathrm{HF}_{1}$, and $\mathrm{EF}_{1}$ indicate the status of FIFO \#1; and $\mathrm{FF}_{2}, \mathrm{HF}_{2}$, and $\mathrm{EF}_{2}$ indicate the status of FIFO \#2.

A Full Flag is asserted following the first subsequent rising clock edge for a write operation which fills the FIFO. A Full Flag is deasserted following the first subsequent falling clock edge for a read operation to a full FIFO. A Half-Full Flag is updated following the first subsequent rising clock edge of a read or write operation to a FIFO which changes its 'half-full' status. An Empty Flag is asserted following the first subsequent rising clock edge for a read operation which 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{\mathrm{AF}}_{1}$ and $\overline{\mathrm{AF}}_{2}$ ), and two for AlmostEmpty ( $\overline{\mathrm{AE}}_{1}$ and $\overline{\mathrm{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 first subsequent rising clock edge after a write operation which has partially filled the FIFO up to the 'almost-full' offset point. An Almost-Full Flag is deasserted following the first subsequent falling clock edge after a read operation which has partially emptied the FIFO down past the 'almost-full' offset point. An Almost-Empty Flag is asserted following the first subsequent rising clock edge after a read operation which has partially emptied the FIFO down to the 'almost-empty' offset point. An Almost-Empty Flag is deasserted following the first subsequent falling clock edge after a write operation which has partially filled the FIFO up past the 'almost-empty' offset point.

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 nine-bit (LH543611) or ten-bit (LH543621) status words. Tables 3a and 3b illustrate the data format for flag-programming words. Note that when all four offsets are set simultaneously in an LH543621, the settings are limited to magnitudes expressible in nine bits; for larger offset values, the individual setting option must be used. (See Figure 3b.)

Also, Tables 4 a and 4 b define the meaning of each of the five flags, both the dedicated flags and the programmable flags, for the LH543611 and LH543621 respectively.

NOTE: 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 ( $E N_{A}$ or ENB) HIGH. That is, writing to Mailbox Register \#1, or reading from Mailbox Register \#2, is synchronized to $\mathrm{CK}_{\mathrm{A}}$; and writing to MailboxRegister \#2, or reading from Mailbox Register \#1, is synchronized to CK $_{B}$.

The $\mathrm{R} / \overline{\mathrm{W}}_{\mathrm{A} / \mathrm{B}}$ and $\overline{\mathrm{OE}}_{\mathrm{A} / \mathrm{B}}$ pins control the direction and availability of mailbox-register accesses. Each mailbox register has its own New-Mail-Alert Flag $\left(\overline{\mathrm{MBF}}_{1}\right.$ and

## OPERATIONAL DESCRIPTION (cont'd)

$\overline{\mathrm{MBF}}_{2}$ ), 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

A synchronous request-acknowledge handshake feature is provided for each port, to perform boundary synchronization between asynchronously-operated ports. The use of this feature is optional. When it is used, the Request input (REQAB) is sampled at a rising clock edge. With REQAB HIGH, R/WAB determines whether a FIFO read operation or a FIFO write operation is being requested. The Acknowledge output ( $A C K_{A / B}$ ) is updated during the following clock cycle(s). ACK ${ }_{A / B}$ meets the setup and hold time requirements of the Enable input ( $E N_{A}$ or $E N_{B}$ ). Therefore, $A C K_{A / 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 $A^{\prime} K_{A / B}$ signifies that REQAB was asserted. However, ACK $A_{A B}$ does not depend logically on $\mathrm{EN}_{\mathrm{ABB}}$; and thus the assertion of $\mathrm{ACK}_{\mathrm{A} / \mathrm{B}}$ does not prove that a FIFO write access or a FIFO read access actually took place. While $R^{2} Q_{A B}$ and $E N_{A / B}$ are being held HIGH, ACK ${ }_{A / B}$ may be considered as a synchronous, predictive boundary flag. That is, ACKAB acts as a synchronized predictor of the Almost-Full Flag AF for write operations, or as a synchronized predictor of the AlmostEmpty Flag $\overline{\mathrm{AE}}$ for read operations.

Outside the 'almost-full' region and the 'almost-empty' region, ACK $_{A B}$ remains continuously HIGH whenever REQA/B is held continuously HIGH. Withinthe 'almost-full' region or the 'almost-empty' region, ACK $A B$ occurs only on every third cycle, 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 $A C K_{A / B}$ is received.

The 'almost-full region' is defined as 'thatregion, where the Almost-Full Flag is being asserted'; and the 'almostempty region' as 'that region, where the Almost-Empty Flag is being asserted.' Thus, the extent of these 'almost' regions depends on how the systemhas programmed the offset values for the Almost-Full Flags and the AlmostEmpty 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, ACK $_{\text {A/B }}$ is not asserted in response to REQAB.

If the REQ/ACK handshake is not used, then the REQAB input may be used as a second enable input, at a possible minor loss in maximum operating speed. In this case, the $A C K_{A / 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 that port to function at all - for FIFO, mailbox, or databypass operation.

## 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 512 or 1024 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{\mathrm{RT}}_{1}$ pin LOW. FIFO\#2 retransmit is initiated by strobing the $\overline{\mathrm{RT}}_{2}$ pin LOW. Read and write operations to a FIFO should be stopped while the corresponding Retransmit signal is being asserted.

## Parity Checking

The Parity Check Flags, $\overline{\mathrm{PF}}_{\mathrm{A}}$ and $\overline{\mathrm{PF}}_{\mathrm{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. Thus, $\overline{\mathrm{PF}}_{\mathrm{A}}$ and $\overline{\mathrm{PF}}_{\mathrm{B}}$ provide parity-error indications for whatever 36 -bit words are present at Port A and Port B respectively, regardless of whether those words originated within the LH543611/21 or in the external system.

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 ORed and inverted to produce the Parity-Flag output.

If the Parity Policy bit (Control-Register bit 09) is HIGH, then parity at Port B will be computed over the field defined by the Word-Width Selection control inputs WS $0_{0}$ and $\mathrm{WS}_{1}$, and then may be for full-words, for half-words, or for single bytes. Otherwise, parity will be computed over full-words regardless of the setting of $\mathrm{WS}_{0}$ and $\mathrm{WS}_{1}$.

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 00 (zero) selects the parity mode, odd or even. (See Tables 3, 5, and 6, and Figure 10.)

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-parityerror signals are NORed together, to compute the asser-tive-LOW parity-flag value. This value may pass through to the output pin on a flowthrough basis, or it may be latched, according to the setting of the Control-Register latching bit for that port (bit 02 or bit 11). (See Figure 6 for an example of parity checking.)

## Parity Generation

Unlike parity checking, parity generation at a port operates only when it is explicitly invoked by setting the corresponding Control-Register bit for that port (bit 01 or bit 10) HIGH. The presumed division of words into bytes still remains the same as for parity checking. However, it is no longer true that all nine bits of each byte are treated alike; now, the most-significant bit of each byte is explicitly designated as the parity bit for that byte. The parity-generation process records a new value into that bit position for each byte passing through the port. (See Figure 6 for an example of parity generation.)

Ifthe Parity Policy bit (Control Register bit 09), is HIGH, parity at Port B will be generated for full-words, for halfwords, or for single bytes according to the setting of the Word-Width Selection control inputs $\mathrm{WS}_{0}$ and $\mathrm{WS}_{1}$. Otherwise, parity will be generated for full-words regardless of the setting of $\mathrm{WS}_{0}$ and $\mathrm{WS}_{1}$.

The parity bits generated may be even or odd, according to the setting of Control-Register bit 00, which is the same bit that governs their interpretation during parity checking.

## Word-Width Selection and Byte-Order Reversal on Port B

The word width of data access on Port B is selected by the $W S_{0}$ and $W_{1}$ control inputs. $\mathrm{WS}_{0}$ and $\mathrm{WS}_{1}$ both are tied HIGH for 36 -bit access; they both are tied LOW for single-byte access. For double-byte access, $\mathrm{WS}_{1}$ is tied LOW; WS $0_{0}$ is tied HIGH for straight-through transmission of 36-bit words, or tied LOW for on-the-fly byte-order reversal of the four bytes in the word ('big-endian $\leftrightarrow$ little-endian conversion'). (See Table 2a and 2b.)

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, singlebyte 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 two 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_{R W s}, t_{D S}$, 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, $\mathrm{WS}_{0}$ and $\mathrm{WS}_{1}$ may be changed between fullwords during FIFO operation, without the need for any reset operation, or for passing any dummy words on through in advance of real data. If such a change is made other than at a full-word boundary, however, at least one dummy word should be used.

Also, the word-width-matching 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 a$ and 2 b and Figures 7,8 , and 9 , summarize word-width selection for Port B.

Table 2a. Port B Word-Width Selection

| wS $_{1}$ | ws $_{0}$ | PORT B DATA WIDTH |
| :---: | :---: | :---: |
| H | H | 36-Bit |
| H | L | 36-Bit with <br> Byte-Order Reversal |
| L | H | 18-Bit |
| L | L | 9-Bit |


| PARITY CHECKING |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{D}_{\text {A }} 35$ |  |  | $\mathrm{D}_{\mathrm{A} / \mathrm{B}} 0$ |  |
| Output word: | 100111100 | 000111100 | 100111000 | 000111000 |
| Odd parity: | Parity of Bytes = 0110; (1 = Byte Parity Error) $\overline{\mathrm{PF}}=\mathrm{L}$ |  |  |  |
| Even parity: | Parity of Bytes = 1001; (1 = Byte Parity Error) $\overline{\mathrm{PF}}=\mathrm{L}$ |  |  |  |
| PARITY GENERATION |  |  |  |  |
| Input word: | 100111100 | 000111100 | 100111000 | 000111000 |
| Output, odd parity: | 100111100 | 100111100 | 000111000 | 000111000 |
| Output, even parity: | 000111100 | 000111100 | 100111000 | 100111000 |

Figure 6. Example of Parity Checking and Generation

Table 2b. Bus Funneling/Defunneling *

| DA[35:0] |  |  |  |  |  | $\begin{gathered} \text { WS }=3(\mathrm{HH}) \\ \mathrm{DB}[35: 0] \end{gathered}$ |  |  |  | $\begin{gathered} \text { WS }=2(\mathrm{HL}) \\ \mathrm{DB}[35: 0] \end{gathered}$ |  |  |  | WS = 1 (LH) |  |  |  | WS = 0 (LL) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | DB[35:18] | DB[17:0] |  | DB[35:9] |  |  | DB[8:0] |
| 0 | B3 | B2 | B1 | B0 | 0 |  |  |  |  | B3 | B2 | B1 | B0 | B0 | B1 | B2 | B3 | B3 | B2 | B1 | B0 | B3 | B2 | B1 | B0 |
| 1 | B7 | B6 | B5 | B4 | 1 | B7 | B6 | B5 | B4 |  |  |  |  | B4 | B5 | B6 | B7 | B1 | B0 | B3 | B2 | B0 | B3 | B2 | B1 |
|  |  |  |  |  | 2 |  |  |  |  |  |  |  |  | B7 | B6 | B5 | B4 | B1 | B0 | B3 | B2 |
|  |  |  |  |  | 3 |  |  |  |  |  |  |  |  | B5 | B4 | B7 | B6 | B2 | B1 | B0 | B3 |
|  |  |  |  |  | 4 |  |  |  |  |  |  |  |  |  |  |  |  | B7 | B6 | B5 | B4 |

* NOTE: B0, B1, . . ., represent data bytes.


Figure 7. Example of 36-to-36 Byte Order Reversal

## PORT B WORD-WIDTH SELECTION



Figure 8a. 36-to-18 Funneling Through FIFO \#1


Figure 8b. 36-to-9 Funneling Through FIFO \#1

## NOTES:

1. 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.
2. The funneling process does not change the ordering of bits within a byte. Halfwords (Figure 8a) or bytes (Figure 8b) 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 Dob - D35B. 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.

## PORT B WORD-WIDTH SELECTION



Figure 9a. 18-to-36 Defunneling Through FIFO \#2


Figure 9b. 9-to-36 Defunneling Through FIFO \#2

## NOTES:

1. 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.
2. The defunneling process does not change the ordering of bits within a byte. Halfwords (Figure 9a) or bytes (Figure 9b) 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. 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.

Table 3a. LH543611 Resource-Register Programming
RESOURCE-
REGISTER
ADDRESS

RESOURCE-REGISTER CONTENTS
$A_{2 A} \quad A_{1 A} \quad A_{0 A}$
NORMAL FIFO OPERATION

|  |  |  | $D_{35 A}$ |
| :---: | :---: | :---: | :---: |
| $H$ | $H$ | $\mathrm{X} \ldots$ | $D_{0 A}$ |
|  |  | $\ldots X$ |  |

MAILBOX
$\mathrm{D}_{35 \mathrm{~A}} \quad \mathrm{D}_{0 \mathrm{~A}}$
H H
L X...
...X
$\overline{\mathbf{A F}}_{2}, \overline{\mathbf{A E}}_{2}, \overline{\mathrm{AF}}_{1}, \overline{\mathrm{AE}}_{1}$ FLAG REGISTER (36-BIT MODE)

| H | L | H | $\overline{\mathbf{A F}}_{2}, \overline{\mathbf{A E}}_{2}, \overline{\mathbf{A F}}_{1}, \overline{\mathrm{AE}}_{1}$ FLAG REGISTER (36-BIT MODE) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}} \ldots \mathrm{D}_{27 \mathrm{~A}}$ | $\mathrm{D}_{26 \mathrm{~A}} \ldots \mathrm{D}_{18 \mathrm{~A}}$ | $\mathrm{D}_{17 \mathrm{~A}} \ldots . . \mathrm{D}_{9 \mathrm{~A}}$ | $\mathrm{D}_{8 \mathrm{~A}} \ldots . \mathrm{D}_{0 \mathrm{~A}}$ |
|  |  |  | $\overline{\mathrm{AF}}_{2}$ Offset ${ }^{1}$ | $\overline{\mathrm{AE}}_{2}$ Offset ${ }^{1}$ | $\overline{\mathrm{AF}}_{1}$ Offset ${ }^{1}$ | $\overline{\mathrm{AE}}_{1}$ Offset ${ }^{1}$ |


| H | L | L | CONTROL REGISTER: FLAG SYNCHRONIZATION, PARITY CONFIGURATION |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}}$ | D18A | D17A | D9A | $\mathrm{D}_{8 \mathrm{~A}}$ | $\mathrm{D}_{1 \mathrm{~A}}$ | $\mathrm{D}_{0 \mathrm{~A}}$ |
|  |  |  | X... | ...X | Po |  | P | Control ${ }^{3}$ | PM ${ }^{2}$ |
| L | H | H | 9-BIT $\overline{\mathrm{AE}}_{1}$ FLAG OFFSET REGISTER |  |  |  |  |  |  |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}}$ |  |  |  | $\mathrm{D}_{9 \mathrm{~A}}$ | $\mathrm{D}_{8 \mathrm{~A}} \ldots \mathrm{D}_{0 \mathrm{~A}}$ |  |
|  |  |  | X... |  |  |  | ...X | $\overline{\mathrm{AE}}_{1}$ Offset |  |
| L | H | L | 9-BIT $\overline{\mathrm{AF}}_{1}$ FLAG OFFSET REGISTER |  |  |  |  |  |  |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}}$ |  |  |  | D9A | $\mathrm{D}_{8 \mathrm{~A}} \ldots . . \mathrm{D}_{0} \mathrm{~A}$ |  |
|  |  |  | X... |  |  |  | ..X | $\overline{\mathrm{AF}}_{1}$ Offset |  |
| L | L | H | 9-BIT $\overline{\mathrm{AE}}_{2}$ FLAG OFFSET REGISTER |  |  |  |  |  |  |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}}$ |  |  |  | D9A | $\mathrm{D}_{8 \mathrm{~A}} \ldots . . \mathrm{D}_{0 \mathrm{~A}}$ |  |
|  |  |  | X... |  |  |  | ...X | $\overline{\mathrm{AE}}_{2}$ Offset |  |
|  |  | 9-BIT $\overline{\text { AF }}_{2}$ FLAG OFFSET REGISTER |  |  |  |  |  |  |  |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}}$ |  |  |  | $\mathrm{D}_{9 \mathrm{~A}}$ | $\mathrm{D}_{8 \mathrm{~A}} \ldots \mathrm{D}_{0 \mathrm{~A}}$ |  |
| L | L | L | X... |  |  |  | ...X | $\overline{\mathrm{AF}}_{2}$ Offset |  |
| NOTES: |  |  |  |  |  |  |  |  |  |
| 1. All four programmable-flag-offset values are initialized to eight (8) during a reset operation. <br> 2. Parity Mode: Odd parity = HIGH; even parity = LOW. The parity mode is initialized to odd during a reset operation. <br> 3. See Tables 5 and 6 and Figure 10 for the detailed format of the Control Register word. |  |  |  |  |  |  |  |  |  |

Table 3b. LH543621 Resource-Register Programming
RESOURCE-
REGISTER

## ADDRESS

## RESOURCE-REGISTER CONTENTS

$\begin{array}{lll}A_{2 A} & A_{1 A} & A_{0 A}\end{array}$
NORMAL FIFO OPERATION

| H | H | H | $\mathrm{D}_{35 \mathrm{~A}}$ |  | $\mathrm{D}_{0 \mathrm{~A}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | X... |  | $\ldots \mathrm{X}$ |
|  |  | MAILBOX |  |  |  |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}}$ |  | $\mathrm{D}_{0 \mathrm{~A}}$ |
| H | H | L | X |  |  |


| H | L | H | $\overline{\mathbf{A F}}_{2}, \overline{\mathbf{A E}}_{2}, \overline{\mathrm{AF}}_{1}, \overline{\mathrm{AE}}_{1}$ FLAG REGISTER (36-BIT MODE) ${ }^{4}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}} \ldots \mathrm{D}_{27 \mathrm{~A}}$ | $\mathrm{D}_{26 \mathrm{~A}} \ldots \mathrm{D}_{18 \mathrm{~A}}$ | $\mathrm{D}_{17 \mathrm{~A}} \ldots . . \mathrm{D}_{9 \mathrm{~A}}$ | $\mathrm{D}_{8 \mathrm{~A}} \ldots \mathrm{D}_{0 \mathrm{~A}}$ |  |
|  |  |  | $\overline{\mathrm{AF}}_{2}$ Offset ${ }^{1}$ | $\overline{\mathrm{AE}}_{2}$ Offset ${ }^{1}$ | $\overline{\mathrm{AF}}_{1}$ Offset ${ }^{1}$ | $\overline{\mathrm{AE}}_{1}$ Offset ${ }^{1}$ |  |
|  |  |  | CONTROL REGISTER: FLAG SYNCHRONIZATION, PARITY CONFIGURATION |  |  |  |  |
|  |  |  | $\mathrm{D}_{35 \mathrm{~A}}$ | D18A | D17A D9A | D8A DiA | DoA |
| H | L | L | X... | ...X | Port B Control ${ }^{3}$ | Port A Control ${ }^{3}$ | PM ${ }^{2}$ |



Table 4a. LH543611 Flag Definition Table
VALID READ CYCLES REMAINING

| FLAG | VALID READ CYCLES REMAINING |  |  |  | VALID WRITE CYCLES REMAINING |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FLAG = LOW |  | FLAG $=$ HIGH |  | FLAG = LOW |  | FLAG $=$ HIGH |  |
|  | MIN | max | MIN | max | min | max | MIN | MAX |
| $\overline{\text { FF }}$ | 512 | 512 | 0 | 511 | 0 | 0 | 1 | 512 |
| $\overline{\mathrm{AF}}$ | 512-p | 512 | 0 | 511-p | 0 | p | $p+1$ | 512 |
| $\overline{\mathrm{HF}}$ | 257 | 512 | 0 | 256 | 0 | 255 | 256 | 512 |
| $\overline{\mathrm{AE}}$ | 0 | q | q + 1 | 512 | 512-q | 512 | 0 | 511-q |
| EF | 0 | 0 | 1 | 512 | 512 | 512 | 0 | 511 |

NOTE:
$q=$ Programmable-Almost-Empty Offset value. (Default value: $q=8$.)
$p=$ Programmable-Almost-Full Offset value. (Default value: $p=8$.)

Table 4b. LH543621 Flag Definition Table

| FLAG | VALID READ CYCLES REMAINING |  |  |  | VALID WRITE CYCLES REMAINING |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FLAG = LOW |  | FLAG $=\mathrm{HIGH}$ |  | FLAG = Low |  | FLAG $=\mathrm{HIGH}$ |  |
|  | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| $\overline{\text { FF }}$ | 1024 | 1024 | 0 | 1023 | 0 | 0 | 1 | 1024 |
| $\overline{\mathrm{AF}}$ | 1024-p | 1024 | 0 | 1023-p | 0 | p | $p+1$ | 1024 |
| $\overline{\mathrm{HF}}$ | 513 | 1024 | 0 | 512 | 0 | 511 | 512 | 1024 |
| $\overline{\mathrm{AE}}$ | 0 | q | $q+1$ | 1024 | 1024-q | 1024 | 0 | 1023-q |
| EF | 0 | 0 | 1 | 1024 | 1024 | 1024 | 0 | 1023 |

NOTE:
$q=$ Programmable-Almost-Empty Offset value. (Default value: $q=8$. .)
$p=$ Programmable-Almost-Full Offset value. (Default value: $p=8$. )

Table 5. Control-Register Format

| PORT | COMMAND REGISTER BITS | CODE | VALUE AFTER RESET | FLAG AFFECTED, IF ANY | DESCRIPTION | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A, B | 00 | L | H | $\overline{\mathrm{PF}}_{\mathrm{A}}, \overline{\mathrm{PF}}_{\mathrm{B}}$ | EVEN parity in effect. | A correct 9-bit byte has an even number of ones. |
|  |  | H |  |  | ODD parity in effect. | A correct 9-bit byte has an odd number of ones. |
| A | 01 | L | L | - | Disable Port A parity generation. | No overwriting of parity bits. |
|  |  | H |  |  | Enable Port A parity generation. | Parity bit over eight least-significant bits of each byte is overwritten into the most-significant bit of that byte. |
|  | 02 | L | L | $\overline{\mathrm{PF}}_{\mathrm{A}}$ | Port A parity-error flag operates 'flowthrough.' | $\overline{\mathrm{PF}}_{\mathrm{A}}$ is subject to transient glitches while data bus is changing. |
|  |  | H |  |  | Port A parity-error flag is latched by CKA. | $\overline{\mathrm{PF}}_{\mathrm{A}}$ is subject to transient glitches while data bus is changing. |
|  | 03 | L | L | $\overline{\mathrm{EF}} 2$ | Set by $\uparrow \mathrm{CK}_{\mathrm{A}}$, reset by $\uparrow \mathrm{CK}_{\mathrm{B}}$. | Asynchronous flag clocking. |
|  |  | H |  |  | Set and reset by $\uparrow \mathrm{CK}_{A}$. | Synchronous flag clocking. |
|  | 04 | L | L | $\overline{\mathrm{AE}}_{2}$ | Set by $\uparrow \mathrm{CK}_{\mathrm{A}}$, reset by $\uparrow \mathrm{CK}_{\mathrm{B}}$. | Asynchronous flag clocking. |
|  |  | H |  |  | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{B}}$. | Synchronous flag clocking. |
|  | 05, 06 | LL | LL | $\overline{\mathrm{HF}}_{1}$ | Set by $\uparrow \mathrm{CK}_{\mathrm{A}}$, reset by $\uparrow \mathrm{CK}_{\mathrm{B}}$. | Asynchronous flag clocking. |
|  |  | LH |  |  | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{B}}$. | Synchronous flag clocking by Port B clock. |
|  |  | HL, HH |  |  | Set and reset by $\uparrow$ CKA. | Synchronous flag clocking by Port A clock. |
|  | 07 | L | L | $\overline{\mathrm{AF}}_{1}$ | Set by $\uparrow \mathrm{CK}_{\mathrm{A}}$, reset by $\uparrow$ CK $\mathrm{K}_{\text {B }}$. | Asynchronous flag clocking. |
|  |  | H |  |  | Set and reset by $\uparrow$ CKA. | Synchronous flag clocking. |
|  | 08 | L | L | $\overline{\mathrm{FF}}_{1}$ | Set by $\uparrow \mathrm{CK}_{\mathrm{A}}$, reset by $\uparrow \mathrm{CK}_{\mathrm{B}}$. | Asynchronous flag clocking. |
|  |  | H |  |  | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{A}}$. | Synchronous flag clocking. |
| B | 09 | L | L | $\overline{\mathrm{PF}}_{\mathrm{B}}$ | Parity check computed over all four bytes of each word. | Full-word parity-error indication regardless of $\mathrm{WS}_{1}-\mathrm{WS}_{0}$ setting. |
|  |  | H |  |  | Parity check computed over halfword or single-byte according to $\mathrm{WS}_{1}-\mathrm{WS} 0$ setting. | Full-word, half word, or single-byte parity-error indication according to $\mathrm{WS}_{1}-\mathrm{WS}_{0}$ setting. |
|  | 10 | L | L | - | Disable Port B parity generation. | No overwriting of parity bits. |
|  |  | H |  |  | Enable Port B parity generation. | Parity bit over eight least-significant bits of each byte is overwritten into the most-significant bit of that byte. |
|  | 11 | L | L | $\overline{\mathrm{PF}}_{\mathrm{B}}$ | Port B parity-error flag operates 'flowthrough'. | $\overline{\mathrm{PF}}_{\mathrm{B}}$ is subject to transient glitches while data bus is changing. |
|  |  | H |  |  | Port B parity-error flag is latched by $\mathrm{CK}_{\mathrm{B}}$. | $\overline{\mathrm{PF}}_{\mathrm{B}}$ remains steady until its value should change. |
|  | 12 | L | L | $\overline{\mathrm{EF}}_{1}$ | Set by $\uparrow$ CKB, reset by $\uparrow \mathrm{CK}_{\mathrm{A}}$. | Asynchronous flag clocking. |
|  |  | H |  |  | Set and reset by $\uparrow$ CKB. | Synchronous flag clocking. |
|  | 13 | L | L | $\overline{\mathrm{AE}}_{1}$ | Set by $\uparrow \mathrm{CK}_{\mathrm{B}}$, reset by $\uparrow \mathrm{CK}_{\mathrm{A}}$. | Asynchronous flag clocking. |
|  |  | H |  |  | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{A}}$. | Synchronous flag clocking. |
|  | 14, 15 | LL | LL | $\overline{\mathrm{HF}}_{2}$ | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{A}}$. | Asynchronous flag clocking. |
|  |  | LH |  |  | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{A}}$. | Synchronous flag clocking by Port A clock. |
|  |  | HL, HH |  |  | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{A}}$. | Synchronous flag clocking by Port B clock. |

Table 5. Control-Register Format (cont'd)

| PORT | COMMAND REGISTER BITS | CODE | VALUE AFTER RESET | FLAG AFFECTED, IF ANY | DESCRIPTION | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B | 16 | L | L | $\overline{\mathrm{AF}}_{2}$ | Set by $\uparrow \mathrm{CK}_{\mathrm{B}}$, reset by $\uparrow \mathrm{CK}_{\mathrm{A}}$. | Asynchronous flag clocking. |
|  |  | H |  |  | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{B}}$. | Synchronous flag clocking. |
|  | 17 | L | L | $\overline{\mathrm{FF}} 2$ | Set by $\uparrow \mathrm{CK}_{\mathrm{B}}$, reset by $\uparrow \mathrm{CK}_{\text {A }}$. | Asynchronous flag clocking. |
|  |  | H |  |  | Set and reset by $\uparrow \mathrm{CK}_{\mathrm{B}}$. | Synchronous flag clocking. |

Table 6. Controllable Functions

| TYPE | DESCRIPTION | CONTROL-REGISTER BIT |  |
| :---: | :---: | :---: | :---: |
|  |  | PORT A | PORT B |
| Parity | Even/Odd | $0{ }^{1}$ | $0{ }^{1}$ |
|  | Policy for 9/18-Bit Word-Width Selection | - | 9 |
|  | Generation: Enable/Disable | 1 | 10 |
|  | Flag Behavior: Latched/Flowthrough | 2 | 11 |
| Flag Synchronization | $\overline{\text { EF Synchronous/Asynchronous }}$ | 3 | 12 |
|  | $\overline{\mathrm{AE}}$ Synchronous/Asynchronous | 4 | 13 |
|  |  | 5-6 | 14-15 |
|  | $\overline{\text { AF }}$ Synchronous/Asynchronous | 7 | 16 |
|  | $\overline{\text { FF }}$ Synchronous/Asynchronous | 8 | 17 |

NOTE:

1. LH5420/LH543601 also have this Control-Register function. The same Control-Register bit, bit 00, controls both Port A and Port B functionality.


Figure 10. LH5420/LH543601 and LH543611/21
Control-Register Formats

## TIMING DIAGRAMS



NOTES:

1. $\overline{R S}$ overrides all other input signals, except for $R \bar{W}_{A}, E N_{A}$, and $R E Q_{A}$. It operates asynchronously. $\stackrel{\mathrm{RS}}{\mathrm{FR}}{ }_{1}$, and $\overline{\mathrm{FR}}_{2}$ operates whether or not $E N_{\mathrm{A}}$ and/or $\mathrm{EN}_{\mathrm{B}}$ are asserted. At least one rising edge and one falling edge of both $\mathrm{CK}_{\mathrm{A}}$ and $\mathrm{CK}_{\mathrm{B}}$ must occur while RS is being asserted (is LOW), with timing as defined by $\mathrm{t}_{\text {RSs }}$ and $\mathrm{t}_{\text {RSH }}$.
2. Otherwise, $\mathrm{t}_{\text {RSS }}, \mathrm{t}_{\text {RSH }}$ need not be met unless the rising edge of $\mathrm{CK}_{A}$ and/or $\mathrm{CK}_{B}$ occurs while that clock is enabled.
3. The parity-check even/odd selection (Control Register bit 00 ) is initialized to odd byte parity at reset (HIGH). All other Control Register bits are initialized LOW. $\mathrm{FR}_{1}$ and $\mathrm{FR}_{2}$ do not alter the configuration, flags reflect the absence of data.
4. The $\overline{A E}$ and $\overline{\mathrm{AF}}$ flag offsets are initialized to eight locations from the boundary at reset controlled by $\overline{\mathrm{RS}}$.

Figure 11. Reset Timing

## TIMING DIAGRAMS (cont'd)



## NOTES:

1. $t_{R S S}, t_{R S H}$ need not be met unless the rising edge of $\mathrm{CK}_{A}$ or $\mathrm{CK}_{B}$ occurs while that clock is enabled.
2. Port $A$ is considered the master port for bypass operation. Thus, $\mathrm{CK}_{\mathrm{A}}, \mathrm{R} / \bar{W}_{\mathrm{A}}, E N_{A}$, and $R E Q_{A}$ control the transmission of data between ports at reset.

Figure 12. Data Bypass Timing

## TIMING DIAGRAMS (cont'd)



Figure 13. Port A FIFO Read/Write

## TIMING DIAGRAMS (cont'd)



Figure 14. Port B FIFO Read/Write

## TIMING DIAGRAMS (cont'd)



## NOTES:

1. Both edges of $\overline{\mathrm{MBF}}_{2}$ are synchronized to the Port $A$ clock, $\mathrm{CK}_{\mathrm{A}}$.
2. Both edges of $\mathrm{MBF}_{1}$ are synchronized to the Port B clock, $\mathrm{CK}_{\mathrm{B}}$.
3. There is a maximum of two $\mathrm{CK}_{\mathrm{B}}$ clock cycles of synchronization latency before $\overline{\mathrm{MBF}}_{1}$ is asserted to indicate valid new mailbox data.
4. The status of mailbox flags does not prevent mailbox read or write operations.

Figure 15. Port A Mailbox Access

## TIMING DIAGRAMS (cont'd)



NOTES:

1. Both edges of $\overline{\mathrm{MBF}}_{2}$ are synchronized to the Port A clock, $\mathrm{CK}_{\mathrm{A}}$.
2. Both edges of $\overline{\mathrm{MBF}}_{1}$ are synchronized to the Port $B$ clock, $\mathrm{CK}_{\mathrm{B}}$.
3. There is a maximum of two $\mathrm{CK}_{\mathrm{A}}$ clock cycles of synchronization latency before $\overline{\mathrm{MBF}}_{2}$ is asserted to indicate valid new mailbox data.
4. The status of mailbox flags does not prevent mailbox read or write operations.

Figure 16. Port B Mailbox Access

## TIMING DIAGRAMS (cont'd)



Figure 17. Flag Programming

## TIMING DIAGRAMS (cont'd)



Figure 18. Empty Flag Timing, When Asynchronous

## TIMING DIAGRAMS (cont'd)



Figure 19. Empty Flag Timing, When Synchronous

## TIMING DIAGRAMS (cont'd)



## NOTES:

1. $A_{2 A}, A_{1 A}$, and $A_{0 A}$ all are held HIGH for FIFO access at Port $A$.
$A_{O B}$ is held HIGH for FIFO access at Port B.
2. Parameters without parentheses apply to FIFO \#2 operation. Parameters with parentheses apply to FIFO \#1 operation.
3. Assertion of the Almost-Empty Flags is controlled by rising clock edges; whereas, deassertion of the Almost-Empty Flags is controlled by falling clock edges.

Figure 20. Almost-Empty Flag Timing, When Asynchronous

## TIMING DIAGRAMS (cont'd)



Figure 21. Almost-Empty Flag Timing, When Synchronous

## TIMING DIAGRAMS (cont'd)



## NOTES:

1. $A_{2 A}, A_{1 A}$, and $A_{0 A}$ all are held HIGH for FIFO access at Port A.
$A_{0 B}$ is held HIGH for FIFO access at Port B.
2. Parameters without parentheses apply to FIFO \#1 operation.

Parameters with parentheses apply to FIFO \#2 operation.
3. Assertion of the Full Flags is controlled by rising clock edges; whereas, deassertion of the Full Flags is controlled by falling clock edges.

Figure 22. Full Flag Timing, When Asynchronous

## TIMING DIAGRAMS (cont'd)



Figure 23. Full Flag Timing, When Synchronous

## TIMING DIAGRAMS (cont'd)



NOTES:

1. $A_{2 A}, A_{1 A}$, and $A_{0 A}$ all are held HIGH for FIFO access at Port $A$. $A_{0 B}$ is held HIGH for FIFO access at Port B.
2. Parameters without parentheses apply to FIFO \#1 operation. Parameters with parentheses apply to FIFO \#2 operation.
3. Assertion of the Almost-Full Flags is controlled by rising clock edges; whereas, deassertion of the Almost-Full Flags is controlled by falling clock edges.

Figure 24. Almost-Full Flag Timing, When Asynchronous

TIMING DIAGRAMS (cont'd)


Figure 25. Almost-Full Flag Timing, When Synchronous

## TIMING DIAGRAMS (cont'd)



## NOTES:

1. $A_{2 A}, A_{1 A}$, and $A_{0 A}$ all are held HIGH for FIFO access at Port $A$.
$A_{0 B}$ is held HIGH for FIFO access at Port B.
2. Parameters without parentheses apply to FIFO \#1 operation Parameters with parentheses apply to FIFO \#2 operation.
3. Both assertion and deassertion of the Half-Full Flags are controlled entirely by rising clock edges, rather than by falling clock edges.

Figure 26. Half-Full Flag Timing, When Asynchronous

## TIMING DIAGRAMS (cont'd)



Figure 27. Half-Full Flag Timing, When Synchronized to a Port Clock Doing Reading

## TIMING DIAGRAMS (cont'd)



Figure 28. Half-Full Flag Timing, When Synchronized to a Port Clock Doing Writing

TIMING DIAGRAMS (cont'd)


NOTES:

1. $t_{R S S}$ and $t_{R S H}$ need not be met unless a rising edge of $\mathrm{CK}_{A}$ or $\mathrm{CK}_{\mathrm{B}}$ occurs while that clock is enabled.
2. $\mathrm{t}_{\mathrm{RSs}}$ is the time needed to deassert $\overline{\mathrm{RT}}_{2}$ before returning to a normal FIFO cycle.
3. $\mathrm{t}_{\mathrm{RSH}}$ is the time needed before asserting $\mathrm{RT}_{2}$ after a normal FIFO cycle.
4. Read and write operations to FIFO \#2 should be disabled while $\overline{\mathrm{RT}}_{2}$ is being asserted.

Figure 29. FIFO \#2 Retransmit

## TIMING DIAGRAMS (cont'd)



NOTES:

1. $t_{\text {RSS }}$ and $t_{\text {RSH }}$ need not be met unless a rising edge of $\mathrm{CK}_{A}$ or $\mathrm{CK}_{B}$ occurs while that clock is enabled.
2. $\mathrm{t}_{\mathrm{RSS}}$ is the time needed to deassert $\overline{\mathrm{RT}}_{1}$ before returning to a normal FIFO cycle.
3. $\mathrm{t}_{\mathrm{RSH}}$ is the time needed before asserting $\overline{\mathrm{RT}}_{1}$ after a normal FIFO cycle.
4. Read and write operations to FIFO \#1 should be disabled while $\overline{R T}_{1}$ is being asserted.

Figure 30. FIFO \#1 Retransmit

## TIMING DIAGRAMS (cont'd)



NOTES:

1. $A_{2 A}, A_{1 A}, A_{0 A}$, and $A_{0 B}$ are all held HIGH for FIFO access.
2. $\overline{O E}_{A}$ is held HIGH.
3. $\overline{O E}_{B}$ is held LOW.
4. $\mathrm{t}_{\text {FRL }}$ (First Read Latency) - The first read following an empty condition may begin no earlier than $t_{\text {FRL }}$ after the first write to an empty FIFO, to ensure that valid read data is retrieved.

Figure 31. FIFO \#1 Write and Read Operation in Near-Empty Region

## TIMING DIAGRAMS (cont'd)



## NOTES:

1. $A_{2 A}, A_{1 A}, A_{0 A}$, and $A_{0 B}$ are all held HIGH for FIFO access.
2. $\overline{O E}_{B}$ is held HIGH.
3. $\overline{\mathrm{OE}}_{\mathrm{A}}$ is held LOW.
4. $\mathrm{t}_{\text {FRL }}$ (First Read Latency) - The first read following an empty condition
may begin no earlier than $t_{\text {FRL }}$ after the first write to an empty FIFO,
to ensure that valid read data is retrieved.
Figure 32. FIFO \#2 Write and Read Operation in Near-Empty Region

## TIMING DIAGRAMS (cont'd)



## NOTES:

1. $A_{2 A}, A_{1 A}$, and $A_{0 A}$ all are held HIGH for FIFO access at Port A.
$A_{0 B}$ is held HIGH for FIFO access at Port B.
2. $\mathrm{OE}_{\mathrm{A}}$ is held HIGH.
3. $\mathrm{OE}_{\mathrm{B}}$ is held LOW.
4. $\mathrm{t}_{\text {FWL }}$ (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.

Figure 33. FIFO \#1 Read and Write Operation in Near-Full Region

## TIMING DIAGRAMS (cont'd)



NOTES:

1. $A_{2 A}, A_{1 A}$, and $A_{0 A}$ all are held HIGH for FIFO access at Port $A$.
$A_{0 B}$ is held HIGH for FIFO access at Port B.
2. $\overline{O E}_{B}$ is held HIGH .
3. $\mathrm{OE}_{\mathrm{A}}$ is held LOW.
4. $\mathrm{t}_{\text {FWL }}$ (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.

Figure 34. FIFO \#2 Read and Write Operation in Near-Full Region

## TIMING DIAGRAMS (cont'd)



## NOTES:

1. $\mathrm{A}_{0 B}$ is held HIGH for FIFO access.
2. $\mathrm{OE}_{\mathrm{B}}$ is held LOW.
3. $\mathrm{WS}_{0}$ is held HIGH and $\mathrm{WS}_{1}$ is held LOW for double-byte access.
4. Data-access time $\mathrm{t}_{\mathrm{A}}$, after the rising edge of $\mathrm{CK}_{\mathrm{B}}$, shown for the first read cycle, applies similarly for all subsequent read cycles.

Figure 35. Port B Double-Byte FIFO \#1 Read Access for 36-to-18 Funneling

TIMING DIAGRAMS (cont'd)


NOTES:

1. $\mathrm{A}_{0 B}$ is held HIGH for FIFO access.
2. $\overline{\mathrm{OE}}_{\mathrm{B}}$ is held HIGH.
3. $\mathrm{WS}_{0}$ is held HIGH and $\mathrm{WS}_{1}$ is held LOW for double-byte access.
4. Data-setup time $t_{D S}$ and data-hold time $t_{D H}$, before and after the rising edge of $\mathrm{CK}_{\mathrm{B}}$, shown for the first write cycle, apply similarly for all subsequent write cycles.

Figure 36. Port B Double-Byte FIFO \#2 Write Access for 18-to-36 Defunneling

TIMING DIAGRAMS (cont'd)


NOTES:

1. $A_{0 B}$ is held HIGH for FIFO access.
2. $\mathrm{OE}_{B}$ is held LOW.
3. $\mathrm{WS}_{0}$ and $\mathrm{WS}_{1}$ both are held LOW for single-byte access.
4. Data-access time $\mathrm{t}_{\mathrm{A}}$, after the rising edge of $\mathrm{CK}_{\mathrm{B}}$, shown for the first read cycle, applies similarly for all subsequent read cycles.

Figure 37. Port B Single-Byte FIFO \#1 Read Access for 36-to-9 Funneling

TIMING DIAGRAMS (cont'd)


NOTES:

1. $\mathrm{A}_{0 B}$ is held HIGH for FIFO access.
2. $\mathrm{OE}_{\mathrm{B}}$ is held HIGH.
3. $\mathrm{WS}_{0}$ and $\mathrm{WS}_{1}$ both are held LOW for single-byte access.
4. Data-setup time $\mathrm{t}_{\mathrm{DS}}$ and data-hold time $\mathrm{t}_{\mathrm{DH}}$, before and after the rising edge of $\mathrm{CK}_{\mathrm{B}}$, shown for the first write cycle, apply similarly for all subsequent write cycles.

Figure 38. Port B Single-Byte FIFO \#2 Write Access for

## TIMING DIAGRAMS (cont'd)



Figure 39. Write Request/Acknowledge Handshake

## TIMING DIAGRAMS (cont'd)



Figure 40. Read Request/Acknowledge Handshake

TIMING DIAGRAMS (cont'd)


NOTE: During retransmit, $\mathrm{WS}_{1}$ and $\mathrm{WS}_{0}$ must be stable throughout entire clock cycle.
Figure 41. Changing Port B Word-Width Selection During Operation

## TIMING DIAGRAMS (cont'd)



Figure 42. Parity Generation

## PACKAGE DIAGRAMS



## 132-pin PQFP



144-pin TQFP

## ORDERING INFORMATION



## NOTE:

For PQFP-to-PGA conversion for through-hole board designs, SHARP recommends QFP-to-PGA adaptors from ISI (Interconnect Systems Inc.) ISI makes three models that can map the LH543611/21 132-pin PQFP to a $13 \times 13$ PGA ( 100 mil); mode \#A 13225-1® map to a SHARP specific 120-pin PGA. For more information, contact SHARP or ISI directly at P.O. Box 1089, Simi Valley, CA 93062, Tel: (805) 581-5626.

