## FEATURES

- Free-running CLKA and CLKB may be asynchronous or coincident (permits simultaneous reading and writing of data on a single clock edge)
- $64 \times 36$ storage capacity FIFO buffering data from Port A to Port B
- Mailbox bypass registers in each direction
- Dynamic Port B bus sizing of 36 bits (long word), 18-bits (word), and 9 bits (byte)
- Selection of Big- or Little-Endian format for word and byte bus sizes
- Three modes of byte-order swapping on Port B
- Programmable Almost-Full and Almost-Empty flags
- Microprocessor interface control logic
- $\overline{\mathrm{FF}}, \overline{\mathrm{AF}}$ flags synchronized by CLKA
- $\overline{\mathrm{EF}}, \overline{\mathrm{AE}}$ flags synchronized by CLKB
- Passive parity checking on each Port
- Parity Generation can be selected for each Port
- Supports clock frequencies up to 67 MHz
- Fast access times of 10 ns
- Available in 132-pin quad flatpack (PQFP) or space-saving 120-pin thin quad flatpack (TQFP)
- Industrial temperature range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ is available
- Green parts available, see orderng information


## DESCRIPTION

The IDT723613 is a monolithic, high-speed, low-power, CMOS synchronous (clocked) FIFO memory which supports clock frequencies up to 67 MHz and has read-accesstimes as fastas 10 ns . The $64 \times 36$ dual-portSRAMFIFO buffers data from portA to portB. The FIFO has flags to indicate empty and full conditions, and two programmable flags, Almost-Full ( $\overline{\mathrm{AF}}$ ) and Almost-Empty $(\overline{\mathrm{AE}})$, to indicate when a selected number of words is stored in memory. FIFO data on port B can be output in 36-bit, 18-bit, and 9-bitformats with achoice of big-orLittle-Endian configurations. Three modes of byte-order swapping are possible with any bus-size selection. Communication betweeneach portcan bypass the FIFO via two 36-bit mailbox registers. Each mailbox register has

## FUNCTIONAL BLOCK DIAGRAM



## DESCRIPTION (CONTINUED)

a flag to signal when new mail has been stored. Parity is checked passively on each port and may be ignored if not desired. Parity generation can be selected for data read from each port. Two or more devices may be used in parallel to create wider data paths.
The IDT723613 is a synchronous (clocked) FIFO, meaning each port employs a synchronous interface. All data transfers through a port are gated to the LOW-to-HIGH transition of a continuous (free-running) port clock by
enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. Theenables for each portare arranged to providea simple interface between microprocessors and/orbuses with synchronous interfaces.
The Full Flag ( $\overline{\mathrm{FF}}$ ) and Almost-Full ( $\overline{\mathrm{AF}}$ ) flag of the FIFO are two-stage synchronized to the portclock (CLKA) that writes data into its array. The Empty Flag ( $\overline{\mathrm{EF}})$ and Almost-Empty ( $\overline{\mathrm{AE}})$ flag ofthe FIFO are two-stage synchronized to the port clock (CLKB) that reads data from its array
The IDT723613 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## PIN CONFIGURATIONS


2. $N C=$ No internal connection.

## PIN CONFIGURATIONS (CONTINUED)



## NOTES:

1. Electrical pin 1 in center of beveled edge.
2. NC = No internal connection.
3. Uses Yamaichi socket IC51-1324-828.

## PIN DESCRIPTION

| Symbol | Name | I/0 | Description |
| :---: | :---: | :---: | :---: |
| A0-A35 | Port A Data | I/0 | 36-bit bidirectional data port for side A. |
| $\bar{A} \bar{E}$ | Almost-Empty Flag | $\begin{gathered} 0 \\ \text { Port B } \end{gathered}$ | Programmable Almost-Empty flag synchronized to CLKB. It is LOW when Port B the number of 36 -bit words in the FIFO is less than or equal to the value in the offset register, X . |
| $\overline{\mathrm{A}} \overline{\mathrm{F}}$ | Almost-Full Flag | $\begin{gathered} \hline 0 \\ \text { Port } \mathrm{A} \end{gathered}$ | Programmable Almost-Full flag synchronized to CLKA. It is LOW when the number of 36 -bit empty location in the FIFO is less than or equal to the value in the offset register, X . |
| Bo-B35 | Port B Data | I/0 | 36 -bit bidirectional data port for side B |
| $\overline{\mathrm{B}} \mathrm{E}$ | Big-Endian Select | 1 | Selects the bytes on port B used during byte or word FIFO reads. A LOW on $\overline{\mathrm{E}}$ selects the most significant bytes on $\mathrm{B} 0-\mathrm{B} 35$ for use, and a HIGH selects the least significant bytes. |
| CLKA | Port A Clock | 1 | CLKA is a continuous clock that synchronizes all data transfers through port A and can be asynchronous or coincident to CLKB. $\overline{\mathrm{FF}}$ and $\overline{\mathrm{AF}}$ are synchronized to the LOW-to-HIGH transition of CLKA. |
| CLKB | Port B Clock | 1 | CLKB is a continuous clock that synchronizes all data transfers through port B and can be asynchronous or coincident to CLKA. Port-B byte swapping and data port sizing operations are also synchronous to the LOW-to-HIGH transition of CLKB. EF and $\overline{\text { AE }}$ are synchronized to the LOW-to-HIGH transition of CLKB. |
| C̄S̄A | Port A Chip Select | 1 | $\overline{\text { CSA }}$ must be LOW to enable a LOW-to-HIGH transition of CLKA to read or write data on port A. The A0-A 35 outputs are in the high-impedance state when $\overline{\mathrm{CS}}$ A is HIGH. |
| $\overline{\text { CS }} \overline{\mathrm{B}}$ | Port B Chip Select | 1 | $\overline{\text { CSB }}$ must be LOW to enable a LOW-to-HIGH transition of CLKB to read or write data on port B. The Bo-B35 outputs are in the high-impedance state when $\overline{\text { CSB }}$ is HIGH. |
| EF | Empty Flag | $\begin{gathered} 0 \\ \text { Port B } \end{gathered}$ | EF is synchronized to the LOW-to-HIGH transition of CLKB. When EF is LOW, the FIFO is empty, and reads from its memory are disabled. Data can be read from the FIFO to its output register when EF is HIGH. EF is forced LOW when the device is reset and is set HIGH by the second LOW-to-HIGH transition of CLKB after data is loaded into empty FIFO memory. |
| ENA | Port A Enable | 1 | ENA must be HIGH to enable a LOW-to-HIGH transition of CLKA to read or write data on port A. |
| ENB | Port B Enable | 1 | ENB must be HIGH to enable a LOW-to-HIGH transition of CLKB to read or write data on port B. |
| $\overline{\text { FF }}$ | Full Flag | $\begin{gathered} 0 \\ \text { Port A } \end{gathered}$ | $\overline{\text { FF }}$ is synchronized to the LOW-to-HIGH transition of CLKA. When FF is LOW, the FIFO is full, and writes to its memory are disabled. FF is forced LOW when the device is reset and is set HIGH by the second LOW-to-HIGH transition of CLKA after reset. |
| FS1, FS0 | Flag Offset Selects | 1 | The LOW-to-HIGH transition of RST latches the values of FSo and FS1, which loads one of four preset values into the Almost-Full flag and Almost-Empty flag offsets. |
| MBA | Port A Mailbox Select | 1 | A high level on MBA chooses a mailbox register for a port A read or write operation. When the A0-A35 outputs are active, mail 2 register data is output. |
| $\overline{\text { MBF1 }}$ | Mail 1 Register Flag | 0 | $\overline{\text { MBF1 }}$ is set LOW by a LOW-to-HIGH transition of CLKA that writes data to the mail1 register. Writes to the mail1 register are inhibited while $\overline{\text { MBF1 }}$ is set LOW. MBF1 is set HIGH by a LOW-to-HIGH transition of CLKB when a port B read is selected and both $\mathrm{SIZ1}$ and SIZO are HIGH . MBF1 is set HIGH when the device is reset. |
| $\overline{\text { MBF2 }}$ | Mail2 Register Flag | 0 | $\overline{\text { MBF2 }}$ is set LOW by a LOW-to-HIGH transition of CLKB that writes data to the mail2 register. Writes to the mail2 register are inhibited while $\overline{\text { MBF2 }}$ is set LOW. $\overline{\text { MBF2 }}$ is set HIGH by a LOW-to-HIGH transition of CLKA when a port A read is selected and MBA is HIGH. $\overline{\text { MBF2 }}$ is set HIGH when the device is reset. |
| $\begin{array}{\|l\|l\|} \hline \text { ODD } / ~ \\ \text { EVEN } \\ \hline \end{array}$ | Odd/Even Parity Select | 1 | Odd parity is checked on each port when ODD/EVEN is HIGH, and even parity is checked when ODD EVEN is LOW. ODD/EVEN also selects the type of parity generated for each port if parity generation is enabled for a read operation. |
| $\overline{\text { PEFFA }}$ | Port A Parity Error Flag | $\begin{gathered} 0 \\ \text { (Port A) } \end{gathered}$ | When any byte applied to terminals A0-A35 fails parity, PEFA is LOW. Bytes are organized as A0-A8, A9-A 17 , A18-A26, and A27-A35, with the most significant bit of each byte serving as the parity bit. The type of parity checked is determined by the state of the ODD/EVEN input. The parity trees used to check the Ao-A35 inputs are shared by the mail2 register to generate parity if parity generation is selected by PGA. Therefore, if a mail2 read with parity generation is set up by having CSA LOW, ENA HIGH, W/R्RA LOW, MBA HIGH and PGA HIGH, the PEFA flag is forced HIGH regardless of the state of the A0-A35 inputs. |
| $\overline{\text { PEFEB }}$ | Port B Parity Error Flag | $\begin{gathered} 0 \\ \text { (PortB) } \end{gathered}$ | When any valid byte applied to terminals B 0 -B35 fails parity, PEFB is LOW. Bytes are organized as $\mathrm{B} 0-\mathrm{BB}$, $\mathrm{B} 9-\mathrm{B} 17, \mathrm{~B} 18-\mathrm{B} 26$, and $\mathrm{B} 27-\mathrm{B} 35$, with the most significant bit of each byte sevving as the parity bit. A byte is valid when it is used by the bus size selected for port $B$. The type of parity checked is determined by the state of the ODD/EVEN input. The parity trees used to check the Bo-B35 inputs are shared by the mail1 register to generate parity if parity generation is selected by PGB. Therefore, if a maill read with parity generation is set up by having CSB LOW, ENB HIGH, W/RB LOW, SIZ1 and SIZO HIGH and PGB HIGH, the PEFB flag is forced HIGH regardless of the state of the Bo-B35 inputs. |

## PIN DESCRIPTION (CONTINUED)

| Symbol | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| PGA | Port A Parity Generation | 1 | Parity is generated for data reads from the mail2 register when PGA is HIGH. The type of parity generated is selected by the state of the ODD/EVEN input. Bytes are organized at A0-A8, A9-A17, A18-A26, and A27-A35. The generated parity bits are output in the most significant bit of each byte. |
| PGB | Port B Parity | 1 | Parity is generated for data reads from port $B$ when PGB is HIGH. The type of parity generated is selected by the state of the ODD/EVEN input. Bytes are organized as $\mathrm{B} 0-\mathrm{B} 8, \mathrm{~B} 9-\mathrm{B} 17, \mathrm{~B} 18-\mathrm{B} 26$, and B27-B35. The generated parity bits are output in the most significant bit of each byte. |
| $\overline{\mathrm{RST}}$ | Reset | 1 | To reset the device, four LOW-to-HIGH transitions of CLKA and four LOW-to-HIGH transitions of CLKB must occur while $\overline{\mathrm{RST}}$ is LOW. This sets the $\overline{\mathrm{AF}}, \overline{\mathrm{MBF} 1}$, and $\overline{\mathrm{MBF} 2}$ flags HIGH and the $\overline{\mathrm{EF}}, \overline{\mathrm{AE}}$, and $\overline{\mathrm{FF}}$ flags LOW. The LOW-to-HIGH transition of $\overline{\text { RST }}$ latches the status of the FS1 and FSo inputs to select Almost-Full flag and Almost-Empty flag offset. |
| $\begin{aligned} & \mathrm{SIZO}, \\ & \mathrm{SIZ1} \end{aligned}$ | Port B Bus Size Selects | (Port B) | A LOW-to-HIGH transition of CLKB latches the states of SIZO, SIZ1, and $\overline{\mathrm{BE}}$, and the following LOW-to HIGH transition of CLKB implements the latched states as a port B bus size. Port B bus sizes can be long word, word, or byte. A HIGH on both SIZO and SIZ1 accesses the mailbox registers for a port B 36-bit write or read. |
| SW0, SW1 | Port B Byte Swap Selects | $\begin{gathered} \text { I } \\ \text { (Port B) } \end{gathered}$ | At the beginning of each long word FIFO read, one of four modes of byte-order swapping is selected by SW0 and SW1. The four modes are no swap, byte swap, word swap, and byte-word swap. Byte order swapping is possible with any bus-size selection. |
| W/ $\overline{\mathrm{R}} \mathrm{A}$ | Port A Write/Read Select Select | 1 | A HIGH selects a write operation and a LOW selects a read operation on port A for a LOW-to-HIGH transition of CLKA. The Ao-A35 outputs are in the high-impedance state when W/RA is HIGH. |
| W/R B | Port B Write/Read Select | I | A HIGH selects a write operation and a LOW selects a read operation on port B for a LOW-to-HIGH transition of CLKB. The Bo-B35 outputs are in the high-impedance state when W/R$B$ is HIGH. |

## ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED) ${ }^{(1)}$

| Symbol | Rating | Commercial | Unit |
| :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage Range | -0.5 to 7 | V |
| $\mathrm{V}^{(2)}$ | Input Voltage Range | -0.5 to Vcc +0.5 | V |
| $\mathrm{Vo}{ }^{(2)}$ | Output Voltage Range | -0.5 to Vcc +0.5 | V |
| IIK | Input Clamp Current, (VI < 0 or $\mathrm{VI}>\mathrm{VCCC}^{\prime}$ | $\pm 20$ | mA |
| Iok | Output Clamp Current, (Vo < 0 or Vo > Vcc) | $\pm 50$ | mA |
| Iout | Continuous Output Current, (Vo = 0 to Vcc) | $\pm 50$ | mA |
| Icc | Continuous Current Through Vcc or GND | $\pm 500$ | mA |
| Tstg | Storage Temperature Range | -65 to 150 | ${ }^{\circ} \mathrm{C}$ |

## NOTES:

1. Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those indicated under "Recommended Operating Conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
2. The input and output voltage ratings may be exceeded provided the input and output current ratings are observed.

## RECOMMENDED OPERATING CONDITIONS

| Symbol | Parameter | Min. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.5 | V |
| VIH | High-Level Input Voltage | 2 | - | V |
| VIL | Low-Level Input Voltage | - | 0.8 | V |
| IOH | High-Level Output Current | - | -4 | mA |
| IOL | Low-Level Output Current | - | 8 | mA |
| TA | Operating Free-Air Temperature | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

## ELECTRICAL CHARACTERISTICS OVER RECOMMENDED OPERATING FREEAIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED)

| Parameter | Test Conditions |  |  | IDT723613 Commercial \& Industrial ${ }^{(1)}$ $\mathrm{T}_{\mathrm{A}}=15,20 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Typ. ${ }^{(2)}$ | Max. |  |
| Voh | $\mathrm{Vcc}=4.5 \mathrm{~V}$, | $\mathrm{IOH}=-4 \mathrm{~mA}$ |  | 2.4 | - | - | V |
| Vol | $\mathrm{Vcc}=4.5 \mathrm{~V}$, | $\mathrm{lOL}=8 \mathrm{~mA}$ |  | - | - | 0.5 | V |
| 11 | $\mathrm{Vcc}=5.5 \mathrm{~V}$, | $\mathrm{V} \mathrm{I}=\mathrm{Vcc}$ or 0 |  | - | - | $\pm 50$ | $\mu \mathrm{A}$ |
| 102 | $\mathrm{Vcc}=5.5 \mathrm{~V}$, | $\mathrm{Vo}=\mathrm{Vcc}$ or 0 |  | - | - | $\pm 50$ | $\mu \mathrm{A}$ |
| ICC ${ }^{(3)}$ | $\mathrm{Vcc}=5.5 \mathrm{~V}$, | $10=0 \mathrm{~mA}$, | $\mathrm{VI}=\mathrm{Vcc}$ or GND | - | - | 1 | mA |
| Ci | $\mathrm{V}_{1}=0$ | $\mathrm{f}=1 \mathrm{MHz}$ |  | - | 4 | - | pF |
| Co | $\mathrm{Vo}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | - | 8 | - | pF |

## NOTES:

1. Industrial temperature range product for 20 ns is available as a standard device. All other speed grades are available by special order.
2. All typical values are at $\mathrm{Vcc}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
3. For additional ICC information, see the following page.


Figure 1. Typical Characteristics: Supply Current vs Clock Frequency

## CALCULATING POWER DISSIPATION

The ICCf current for the graph in Figure 1 was taken while simultaneously reading and writing the FIFO on the IDT723613 with CLKA and CLKB set to fs. All date inputs and data outputs change state during each clock cycle to consume the highest supply current. Data outputs were disconnected to normalize the graph to a zero-capacitance load. Once the capacitive lead per data-output channel is known, the power dissipation can be calculated with the equation below.

With ICC(f) taken from Figure 1, the maximum power dissipation (PT) of the IDT723613 may be calculated by:

$$
\text { PT }=\operatorname{VCC} \times \operatorname{ICC}(f)+\Sigma\left[C L x(\mathrm{VOH}-\mathrm{VoL})^{2} \times \mathrm{fo}\right)
$$

where:

| CL | $=$ output capacitive load |
| :--- | :--- |
| $\mathrm{f}_{0}$ | $=$ switching frequency of an output |
| VOH | $=$ output high-level voltage |
| VOL | $=$ output high-level voltage |

When no reads or writes are occurring on the IDT723613, the power dissipated by a single clock (CLKA or CLKB) input running at frequency fs is calculated by:

$$
\text { PT }=\text { Vcc x fs } x 0.29 \mathrm{~mA} / \mathrm{MHz}
$$

## AC ELECTRICAL CHARACTERISTICS OVER RECOMMENDED RANGES OF SUPPLY VOLTAGE AND OPERATING FREE-AIR TEMPERATURE

(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Industrial; $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \hline \text { Commercial } \\ \hline \text { IDT723613L15 } \end{gathered}$ |  | $\text { Com'I \& Ind' }{ }^{(1)}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | IDT723613L20 |  |  |
|  |  | Min. | Max. | Min. | Max. |  |
| fs | Clock Frequency, CLKA or CLKB | - | 66.7 | - | 50 | MHz |
| tCLK | Clock Cycle Time, CLKA or CLKB | 15 | - | 20 | - | ns |
| tCLKH | Pulse Duration, CLKA and CLKB HIGH | 6 | - | 8 | - | ns |
| tcLKL | Pulse Duration, CLKA and CLKB LOW | 6 | - | 8 | - | ns |
| tDS | Setup Time, A0-A35 before CLKA $\uparrow$ and B0-B35 before CLKB $\uparrow$ | 4 | - | 5 | - | ns |
| tens | Setup Time, $\overline{\mathrm{CSA}}, \mathrm{W} / \overline{\mathrm{R} A}, \mathrm{ENA}$, and MBA before CLKA $\uparrow ; \overline{\mathrm{CSB}}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{B}$, and ENB before CLKB $\uparrow$ | 5 | - | 5 | - | ns |
| tszs | Setup Time, SIZ0, SIZ1, and BE before CLKB $\uparrow$ | 4 | - | 5 | - | ns |
| tsws | Setup Time, SW0 and SW1 before CLKB $\uparrow$ | 5 | - | 7 | - | ns |
| tPGS | Setup Time, ODD/EVEN and PGB before CLKB $\uparrow^{(2)}$ | 4 | - | 5 | - | ns |
| tRSTS | Setup Time, $\overline{\mathrm{RST}}$ LOW before CLKA $\uparrow$ or CLKB $\uparrow^{(3)}$ | 5 | - | 6 | - | ns |
| tFSS | Setup Time, FS0 and FS1 before $\overline{\text { RST }}$ HIGH | 5 | - | 6 | - | ns |
| tDH | Hold Time, A0-A35 after CLKA $\uparrow$ and Bo-B35 after CLKB $\uparrow$ | 1 | - | 1 | - | ns |
| tenh | Hold Time, $\overline{C S A}$ W/RA, ENA and MBA after CLKA $\uparrow$; $\overline{C S B}, \mathrm{~W} / \overline{\mathrm{R} B}$, and ENB after CLKB $\uparrow$ | 1 | - | 1 | - | ns |
| tszH | Hold Time, SIZ0, SIZ1, and $\overline{\mathrm{BE}}$ after CLKB $\uparrow$ | 2 | - | 2 | - | ns |
| tsWH | Hold Time, SW0 and SW1 after CLKB $\uparrow$ | 0 | - | 0 | - | ns |
| tPGH | Hold Time, ODD/EVEN and PGB after CLKB $\uparrow^{(2)}$ | 0 | - | 0 | - | ns |
| tRSTH | Hold Time, $\overline{\text { RST }}$ LOW after CLKA $\uparrow$ or CLKB $\uparrow^{(3)}$ | 5 | - | 6 | - | ns |
| tFSH | Hold Time, FS0 and FS1 after $\overline{\text { RST }}$ HIGH | 4 | - | 4 | - | ns |
| tSKEW1 ${ }^{(4)}$ | Skew Time, between CLKA $\uparrow$ and CLKB $\uparrow$ for $\overline{\mathrm{EF}}$ and $\overline{\mathrm{FF}}$ | 8 | - | 8 | - | ns |
| tSKEW2 ${ }^{(4)}$ | Skew Time, between CLKA $\uparrow$ and CLKB $\uparrow$ for $\overline{\mathrm{AE}}$ and $\overline{\mathrm{AF}}$ | 14 | - | 16 | - | ns |

## NOTES:

1. Industrial temperature range product for 20 ns speed grade is available as a standard device. All other speed grades are available by special order.
2. Only applies for a clock edge that does a FIFO read.
3. Requirement to count the clock edge as one of at least four needed to reset a FIFO.
4. Skew time is not a timing constraint for proper device operation and is only included to illustrate the timing relationship between CLKA cycle and CLKB cycle.

## SWITCHING CHARACTERISTICS OVER RECOMMENDED RANGES OF SUPPLY VOLTAGE AND OPERATING FREE-AIR TEMPERATURE, CL = 30PF <br> (Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Industrial; $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Com |  | Com' | $\mathrm{d}^{\prime} \mathrm{I}^{(1)}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IDT723613L15 |  | IDT723613L20 |  |  |
|  |  | Min. | Max. | Min. | Max. |  |
| tA | Access Time, CLKA to A0-A35 and CLKB $\uparrow$ to B0-B35 | 2 | 10 | 2 | 12 | ns |
| twFF | Propagation Delay Time, CLKA $\uparrow$ to $\overline{\text { FF }}$ | 2 | 10 | 2 | 12 | ns |
| tREF | Propagation Delay Time, CLKB $\uparrow$ to $\overline{\mathrm{EF}}$ | 2 | 10 | 2 | 12 | ns |
| tPAE | Propagation Delay Time, CLKB $\uparrow$ to $\overline{\mathrm{AE}}$ | 2 | 10 | 2 | 12 | ns |
| tPAF | Propagation Delay Time, CLKA $\uparrow$ to $\overline{\mathrm{AF}}$ | 2 | 10 | 2 | 12 | ns |
| tPMF | Propagation Delay Time, CLKA to $\overline{\text { MBF1 }}$ LOW or MBF2 HIGH and CLKB $\uparrow$ to $\overline{\text { MBF2 }}$ LOW or $\overline{\text { MBF1 }}$ HIGH | 1 | 9 | 1 | 12 | ns |
| 巴MR | Propagation Delay Time, CLKA to $\mathrm{Bo} 0-\mathrm{B} 35^{(2)}$ and CLKB $\uparrow$ to $\mathrm{A} 0-\mathrm{A} 35^{(3)}$ | 3 | 11 | 3 | 12 | ns |
| tPPE ${ }^{(4)}$ | Propagation delay time, CLKB $\uparrow$ to $\overline{\text { PEFB }}$ | 2 | 11 | 2 | 12 | ns |
| tMDV | Propagation Delay Time, SIZ1, SIZ0 to B0-B35 valid | 1 | 11 | 1 | 11.5 | ns |
| tPDPE | Propagation Delay Time, A0-A35 valid to $\overline{\text { PEFA }}$ valid; $\mathrm{B0}-\mathrm{B} 35$ valid to $\overline{\mathrm{PEFB}}$ valid | 3 | 10 | 3 | 11 | ns |
| tPOPE | Propagation Delay Time, ODD/ $\overline{\text { EVEN }}$ to $\overline{\text { PEFA }}$ and $\overline{\text { PEFB }}$ | 3 | 11 | 3 | 12 | ns |
| tPOPB ${ }^{(5)}$ | Propagation Delay Time, ODD/EVEN to parity bits (A8, A17, $\mathrm{A} 26, \mathrm{~A} 35)$ and (B8, B17, $226, \mathrm{~B} 35)$ | 2 | 12 | 2 | 13 | ns |
| tPEPE | Propagation Delay Time, $\overline{\mathrm{CSA}}, \mathrm{ENA}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}, \mathrm{MBA}$, or PGA to $\overline{\mathrm{PEFA}}$; $\overline{\mathrm{CSB}}, \mathrm{ENB}, \mathrm{W} / \overline{\mathrm{R} B}$, SIZ1, SIZO, or PGB to $\overline{\text { PEFB }}$ | 1 | 11 | 1 | 12 | ns |
| tPEPB ${ }^{(5)}$ | Propagation Delay Time, $\overline{\mathrm{CSA}}, \mathrm{ENA}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}, \mathrm{MBA}$, or PGA to parity bits (A8, A17, A26, A35); $\overline{\mathrm{CSB}}, \mathrm{ENB}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{B}, \mathrm{SIZ1}, \mathrm{SIZ0}$, or PGB to parity bits (B8, B17, B26, B35) | 3 | 12 | 3 | 13 | ns |
| tRSF | Propagation Delay Time, $\overline{\mathrm{RST}}$ to $\overline{\mathrm{AE}}$, $\overline{\mathrm{EF}}$ LOW and $\overline{\mathrm{AF}}, \overline{\mathrm{MBF}}$, $\overline{\mathrm{MBF}}$ HIGH | 1 | 15 | 1 | 20 | ns |
| ENN | Enable Time, $\overline{\mathrm{CSA}}$ and W/RA LOW to Ao-A35 active and $\overline{\mathrm{CSB}}$ LOW and W/R$B$ HIGH to Bo-B35 active | 2 | 10 | 2 | 12 | ns |
| tols | Disable Time, $\overline{\mathrm{CSA}}$ or W/信A HIGH to Ao-A 35 at high impedance and $\overline{\mathrm{CSB}}$ HIGH or W/RB LOW to B0-B35 at high impedance | 1 | 8 | 1 | 9 | ns |

## NOTES:

1. Industrial temperature range product for 20 ns speed grade is available as a standard device. All other speed grades are available by special order.
2. Writing data to the mail1 register when the Bo-B35 outputs are active and SIZ1 and SIZO are HIGH.
3. Writing data to the mail2 register when the A0-A35 outputs are active.
4. Only applies when a new port-B bus size is implemented by the rising CLKB edge.
5. Only applies when reading data from a mail register.

## FUNCTIONAL DESCRIPTION

## RESET ( $\overline{\operatorname{RST}})$

The IDT723613is resetbytaking the Reset( $\overline{\operatorname{RST}}$ ) inputLOWforatleastfour port A Clock (CLKA) and four portB Clock (CLKB) LOW-to-HIGH transitions. The Reset input can switch asynchronously to the clocks. A device reset initializes the internal read and write pointers ofthe FIFO and forces the Full Flag (嚴) LOW, the Empty Flag ( $\overline{\mathrm{EF}}$ ) LOW, the Almost-Empty flag ( $\overline{\mathrm{AE}})$ LOW, and the Almost-Full flag ( $\overline{\mathrm{AF}}$ ) HIGH. A resetalsoforces the Mailbox Flags ( $\overline{\mathrm{MBF} 1}$, MBF2) HIGH. Attera reset, FF is setHIGHaftertwo LOW-to-HIGH transitions ofCLKA. The device mustbe resetafter powerup before data is written to its memory.
ALOW-to-HIGHtransition onthe $\overline{R S T}$ inputloadsthe Almost-Full and AlmostEmpty Offsetregister (X) with the value selected by the FlagSelect(FSO,FS1) inputs. The values that can be loaded into the register are shown in Table 1.

## FIFO WRITE/READ OPERATION

The state of the portA data (A0-A35) outputs is controlled by the port-A Chip Select( $\overline{\mathrm{CSA}}$ ) and the port-AWrite/Read select( $W / \bar{R} A$ ). The A 0 -A 35 outputs are in the high-impedance state when either $\overline{\text { SSA }}$ or W/RA is HIGH. The A0-A35 outputs are active when both $\overline{C S A}$ and $W / \bar{R} A$ are LOW.

Data is loaded into the FIFO from the A0-A35 inputs on a LOW-to-HIGH transition of CLKA when $\overline{C S A}$ is LOW, W/ $\bar{R} A$ is HIGH, ENA is HIGH, MBA is LOW, and FFA is HIGH (see Table 2).
The state of the portBdata (Bo-B35) outputs is controlled by the port BChip Select( (CSB) and the portBWrite/Read select(W/RBB). The B0-B35 outputs are in the high-impedance state when either $\overline{C S B}$ or W/RB is HIGH. The Bo-B35 outputs are active when both $\overline{C S B}$ and $W / \bar{R} B$ are LOW. Data is read from the FIFO to the Bo-B35 outputs by aLOW-to-HIGH transition of CLKB when $\overline{\text { CSB }}$

## TABLE 1 - FLAG PROGRAMMING

| FS1 | FS0 | RST | Almost-Full and <br> Almost-Empty Flag <br> Offset Register (X) |
| :---: | :---: | :---: | :---: |
| $H$ | $H$ | $\uparrow$ | 16 |
| $H$ | $L$ | $\uparrow$ | 12 |
| $L$ | $H$ | $\uparrow$ | 8 |
| $L$ | $L$ | $\uparrow$ | 4 |

is LOW, W/ $\overline{\mathrm{RB}}$ is LOW, ENB is HIGH, $\overline{\mathrm{EFB}}$ is HIGH, and either SIZO or SIZ1 is LOW (see Table 3).

The setup and hold-time constraintstothe portclocks forthe portChipSelects ( $\overline{\mathrm{CSA}}, \overline{\mathrm{CSB}}$ ) and Write/Read selects ( $\mathrm{W} / \overline{\mathrm{R}} \mathrm{A}, \mathrm{W} / \overline{\mathrm{R} B}$ ) are only forenabling write and read operations and are notrelated to high-impedance control of the data outputs. If a portenable is LOWduring a clock cycle, the port'sChipSelectand Write/Read selectcan change states during the setup and hold time window of the cycle.

## SYNCHRONIZED FIFO FLAGS

Each FIFO flagis synchronized to its portclock throughtwo flip-flop stages. This is done to improve the flags' reliability by reducing the probability of metastable events on their outputs when CLKA and CLKB operate asynchronously to one another. $\overline{\mathrm{FF}}$ and $\overline{\mathrm{AF}}$ are synchronized to CLKA. $\overline{\mathrm{EF}}$ and $\overline{\mathrm{AE}}$ are synchronized to CLKB. Table 4 shows the relationship of each portflag to the level of FIFOfill.

## EMPTY FLAG (EF)

The FIFO Empty Flagis synchronized to the portclock thatreads data from its array (CLKB). When the EF is HIGH, new data can be readtothe FIFO output register. When the EF is LOW, the FIFO is empty and attempted FIFO reads are ignored. When reading the FIFO with a byte or word size on port B, EF is set LOW when the fourth byte or second word of the last long word is read.

The FIFO read pointer is incremented each time a new word is clocked to itsoutputregister. Thestatemachinethatcontrolsthe $\overline{\mathrm{EF}}$ monitors awrite-pointer and read-pointer comparator that indicates when the FIFO SRAM status is empty, empty+1, or empty+2. A word written to the FIFO can be read to the FIFO output register in a minimum of three port B clock (CLKB) cycles. Therefore, an $\overline{\mathrm{EF}}$ is LOW if a word in memory is the next data to be sent to the FIFO outputregister and two CLKB cycles have notelapsed since the time the word was written. The $\overline{\mathrm{EF}}$ of the FIFO is setHIGH by the second LOW-to-HIGH transition ofCLKB, and the new dataword canbe read tothe FIFO outputregister in the following cycle.

ALOW-to-HIGH transition onCLKB begins the firstsynchronization cycle of a write if the clock transition occurs at time tSKEW1 or greater after the write. Otherwise, the subsequent CLKB cycle can be the first synchronization cycle (see Figure 10).

## FULL FLAG (FF)

TheFIFO Full Flagis synchronized tothe portclock that writes datato its array

TABLE 2 - PORT A ENABLE FUNCTION TABLE

| $\overline{\text { CSA }}$ | W/R्RA | ENA | MBA | CLKA | A0-A35 Outputs | Port Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | In high-impedance state | None |
| L | H | L | X | X | In high-impedance state | None |
| L | H | H | L | $\uparrow$ | In high-impedance state | FIFO write |
| L | H | H | H | $\uparrow$ | In high impedance state | Mail1 write |
| L | L | L | L | X | Active, mail2 register | None |
| L | L | H | L | $\uparrow$ | Active, mail2 register | None |
| L | L | L | H | X | Active, mail2 register | None |
| L | L | H | H | $\uparrow$ | Active, mail2 register | Mail2 read (set $\overline{\text { MBF2 HIGH) }}$ |

TABLE 3 - PORT B ENABLE FUNCTION TABLE

| $\overline{\text { CSB }}$ | W/R̄B | ENB | SIZ1, SIZ0 | CLKB | B0-B35 Outputs | Port Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | In high-impedance state | None |
| L | H | L | X | X | In high-impedance state | None |
| L | H | H | One, both LOW | $\uparrow$ | In high-impedance state | None |
| L | H | H | Both HIGH | $\uparrow$ | In high-impedance state | Mail2 write |
| L | L | L | One, both LOW | X | Active, FIFO output register | None |
| L | L | H | One, both LOW | $\uparrow$ | Active, FIFO output register | FIFO read |
| L | L | L | Both HIGH | X | Active, mail1 register | None |
| L | L | H | Both HIGH | $\uparrow$ | Active mail1 register | Mail1 read (set $\overline{\text { MBF1 }} \mathrm{HIGH}$ ) |

(CLKA). When the $\overline{F F}$ is HIGH, a SRAM location is free to receive new data. Nomemory locations are free when the FF is LOW and attempted writes to the FIFO are ignored.
Each time a word is written to the FIFO, its write-pointeris incremented. The state machine that controls the $\overline{F F}$ monitors a write-pointer and read-pointer comparator that indicates when the FIFO SRAM status is full, full-1, or full-2. Fromthetime aword is readfrom the FIFO, its previous memory locationis ready to be writtenina minimum ofthreeCLKA cycles. Therefore, aFF is LOW ifless than two CLKA cycles have elapsed since the nextmemory write location has been read. The secondLOW-to-HIGH transition onthe FF synchronizing clock after the read sets the FF HIGH and data can be written in the following clock cycle.
ALOW-to-HIGHtransition onCLKA begins the firstsynchronization cycle of a read if the clock transition occurs at time tSKEW1 or greater after the read. Otherwise, the subsequent clock cycle can be the first synchronization cycle (see Figure 11).

## ALMOST-EMPTYFLAG ( $\overline{\mathrm{AE}})$

The FIFO Almost-Emptyflagissynchronized tothe portclock thatreads data fromits array (CLKB). The state machine that controls the $\overline{\text { AE flag monitors a }}$ write-pointerand read-pointercomparator thatindicates whenthe FIFOSRAM statusisalmost-empty, almost-empty+1, oralmost-empty+2. Thealmost-empty state is defined by the value ofthe Almost-Full and Almost-Empty Offsetregister (X). This register is loaded with one offour presetvalues during a device reset (see resetabove). The $\overline{A E}$ flag is LOW when the FIFO contains X orless long words in memory and is HIGH when the FIFO contains ( $\mathrm{X}+1$ ) or more long words.
TwoLOW-to-HIGH transitions onthe portBClock (CLKB) are required after aFIFO write for the $\overline{A E}$ flag to reflect the new level offill. Therefore, the $\overline{A E}$ flag ofaFIFO containing $(X+1)$ ormore long words remains LOWiftwo CLKB cycles

## TABLE 4 - FIFO FLAG OPERATION

| Number of 36-Bit Words in the $\mathrm{FIFO}^{(1)}$ | Synchronized to CLKB |  | Synchronized to CLKA |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{E}} \overline{\mathrm{F}}$ | $\overline{\mathrm{AE}}$ | $\overline{\mathrm{A}} \overline{\mathrm{F}}$ | $\overline{\mathrm{F}} \overline{\mathrm{F}}$ |
| 0 | L | L | H | H |
| 1 to $X$ | H | L | H | H |
| $(\mathrm{X}+1)$ to $[64-(\mathrm{X}+1)]$ | H | H | H | H |
| $(64-X)$ to 63 | H | H | L | H |
| 64 | H | H | L | L |

NOTE:

1. X is the value in the Almost-Empty flag and Almost-Full flag Offset register.
have notelapsed since the write thatilled the memory to the $(X+1)$ level. The $\overline{\text { AEflagis setHIGHbythe second CLKBLOW-to-HIGHtransition afterthe FIFO }}$ write that fills memory to the $(X+1)$ level. ALOW-to-HIGH transition of CLKB begins the firstsynchronization cycle ifitoccurs attimetSKEW2 orgreater after thewrite thatillls the FIFO to (X+1)longwords. Otherwise, the subsequentCLKB cycle can be the first synchronization cycle (see Figure 12).

## ALMOST FULL FLAG ( $\overline{\mathrm{AF}})$

The FIFO Almost-Full flagis synchronized to the port clock that writes data toits array (CLKA). The state machine that controls an $\overline{\text { AF flag monitors a write- }}$ pointerand read-pointercomparator thatindicateswhenthe FIFOSRAM status is almost-full, almost-full-1, oralmost-full-2. The almost-full state is defined by the value ofthe Almost-Full and Almost-Empty Offsetregister ( X ). This register is loaded with one offour presetvalues during a device reset(see resetabove). The $\overline{\text { AF }}$ flag is LOW when the FIFO contains ( $64-\mathrm{X}$ ) or more long words in memory and is HIGH when the FIFO contains $[64-(\mathrm{X}+1)$ ] or less long words.
TwoLOW-to-HIGH transitions on the portAClock (CLKA) are required after aFIFO read for the $\overline{A F}$ flag to reflect the new level offill. Therefore, the $\overline{\mathrm{AF}}$ flag of FIFO containing $[64-(X+1)]$ orless words remains LOWiftwo CLKA cycles have not elapsed since the read that reduced the number of long words in memory to [64-(X+1)]. The $\overline{\mathrm{AF}}$ flag is setHIGH by the second CLKALOW-toHIGH transition after the FIFO read that reduces the number of long words in memory to $[64-(\mathrm{X}+1)]$. A LOW-to-HIGH transition on CLKA begins the first synchronization cycle ifit occurs at time tSKEW2 or greater after the read that reduces the number of long words in memory to [64-( $\mathrm{X}+1)]$. Otherwise, the subsequentCLKA cycle can be the firstsynchronization cycle (see Figure 13).

## MAILBOX REGISTERS

Two 36-bit bypass registers (mail1, mail2) are on the IDT723613 to pass command and control information between portA and port B withoutputting it in queue.ALOW-to-HIGH transition on CLKA writes A0-A35 data to the mail1 register when a port A write is selected by $\overline{C S A}, W / \overline{R A}$, and ENA (with MBA HIGH). ALOW-to-HIGH transition on CLKB writes Bo-B35 data to the mail2 registerwhen aportB write is selected by $\overline{C S B}, W / \bar{R} B$, and $E N B$ (and both SIZO and SIZ1 are HIGH). Writing datato a mail register sets its corresponding flag ( $\overline{\text { MBF1 }}$ or $\overline{\text { MBF2 }}$ ) LOW. Attempted writes to a mail register are ignored while its mail flagisLOW.
When the port Bdata (B0-B35) outputs are active, the dataon the bus comes from the FIFO outputregisterwhen eitherone or both SIZ1 and SIZO are LOW and from the mail1 register when both SIZ1 and SIZO are HIGH. The Mail1 Register Flag ( $\overline{\text { MBF1 }}$ ) is set HIGH by a rising CLKB edge when a port B read is selected by $\overline{\mathrm{CSB}}, \mathrm{W} / \overline{\mathrm{R} B}$, and ENB, (and both SIZ1 and SIZO HIGH). The Mail2 Register Flag (MBF2) is set HIGH by a rising CLKA edge when a port A read is selected by $\overline{C S A}, W / \bar{R} A$, and ENA (with MBA HIGH). The data in a mail register remains intactafteritis read and changes only when new data is
written to the register.

## DYNAMIC BUS SIZING

The port B bus can be configured in a 36-bit long word, 18-bit word, or 9bitbyteformatfor data read from theFIFO. Word-and byte-size bus selections canutilize the mostsignificant bytes of the bus(Big-Endian) orleastsignificant bytes of the bus (Little-Endian). PortB bus-size can be changed dynamically and synchronous to CLKB to communicate with peripherals of various bus widths.

The levels applied to the port B bus-size select(SIZO, SIZ1) inputs and the Big-Endian select( $\overline{\mathrm{BE}}$ )inputare stored oneachCLKBLOW-to-HIGHtransition. The stored portB bus-size selection is implemented by the nextrising edgeon CLKB according to Figure 2.

Only 36-bit long-word data is written to or read from the FIFO memory on the IDT723613. Bus-matching operations are done after data is read from the FIFO RAM. Port B bus sizing does not apply to mail register operations.

## BUS-MATCHING FIFO READS

Data is read from the FIFO RAM in 36-bit long-word increments. If a longword bus-size is implemented, theentirelongwordimmediately shiftstotheFIFO output register upon a read. If byte or word size is implemented on portB, only the first one or two bytes appear on the selected portion of the FIFO output register, with the rest ofthe long word stored in auxiliary registers. In this case, subsequentFIFO reads with the same bus-size implementation outputthe rest of the long word to the FIFO output register in the order shown by Figure 2.

Each FIFO read with a new bus-size implementation automatically unloads datafrom the FIFORAMto its outputregister and auxiliary registers. Therefore, implementing a new portB bus-size and performing aFIFO read before all bytes or words stored in the auxiliary registers have been read results in a loss of the unread data in these registers.

When reading data from FIFO in byte or word format, the unused Bo-B35 outputs remain inactive but static, with the unused FIFO output register bits holding the last data value to decrease power consumption.

## BYTE SWAPPING

The byte-order arrangement of data read from the FIFO can be changed synchronous to the rising edge ofCLKB. Byte-order swapping is notavailable for mail registerdata. Four modes ofbyte-order swapping (including no swap) can be done with any data port size selection. The order of the bytes are rearranged within the long word, but the bit order within the bytes remains constant.

Byte arrangement is chosen by the portB Swap select(SW0, SW1) inputs on a CLKB rising edge that reads a new long word from the FIFO. The byte orderchosen on the firstbyte orfirstword of anewlong word read from the FIFO is maintained until theentirelong word is transferred, regardless of the SW0 and SW1 states during subsequent reads. Figure 4 is an example of the byte-order swapping available for long word reads. Performing a byte swap and bus-size simultaneously for a FIFO read first rearranges the bytes as shown in Figure 4, then outputs the bytes as shown in Figure 2.

## PORT-B MAIL REGISTER ACCESS

In addition to selecting port B bus sizes for FIFO reads, the portB bus Size select(SIZO, SIZ1) inputs also access the mail registers. When both SIZO and SIZ1 are HIGH, the mail1 register is accessed for a port B long-word read and the mail2 register is accessed for a port Blong-word write. The mail register is accessed immediately and any bus-sizing operation that can be underway is unaffected by the mail registeraccess. After the mail registeraccess is complete, the previousFIFO access can resume inthenextCLKBcycle. Thelogic diagram
in Figure 3 shows the previous bus-size selection is preserved when the mail registers are accessed from portB. A portB bus-size is implemented on each rising CLKB edge according to the states of SIZO_Q, SIZ1_Q, and $\overline{B E} \_Q$.

## PARITY CHECKING

The port A data inputs (A0-A35) and port $B$ data inputs (B0-B35) each have four parity trees to check the parity of incoming (or outgoing) data. Aparity failure on one or more bytes of the port A data bus is reported by a low level on the port A Parity Error Flag ( $\overline{\mathrm{PEFA}}$ ). A parity failure on one or more bytes of the port $B$ data inputs that are valid for the bus-size implementation is reported by alow level on the portB Parity Error Flag ( $\overline{\text { PEFB }})$. Odd or Even parity checking can be selected, and the Parity Error Flags can be ignored if this feature is not desired.

Parity status is checked on each inputbus according to the level of the Odd/ Even parity (ODD/EVEN) selectinput. A parityerrorononeormore valid bytes of a port is reported by a LOW level on the corresponding portParity Error Flag ( $\overline{\mathrm{PEFA}}, \overline{\mathrm{PEFB}}$ ) output. PortA bytes are arranged as A0-A8, A9-A17, A18-A26, and $\mathrm{A} 27-\mathrm{A} 35$, and port B bytes are arranged as $\mathrm{B} 0-\mathrm{B} 8, \mathrm{~B} 9-\mathrm{B} 17, \mathrm{~B} 18-\mathrm{B} 26$, and B27-B35, and its valid bytes are those used in a port $B$ bus size implementation. When Odd/Even parity is selected, a port Parity Error Flag ( $\overline{\text { PEFA }}, \overline{\text { PEFB }}$ ) is LOW if any byte on the port has an odd/even number of LOW levels applied toitsbits.

The four parity trees used to check the A0-A35 inputs are shared by the mail2 register when parity generation is selected for port-A reads (PGA = HIGH). When a port A read from the mail2 register with parity generation is selected with $\overline{C S A} L O W, ~ E N A ~ H I G H, ~ W / R A R O W, ~ M B A ~ H I G H, ~ a n d ~ P G A ~ H I G H, ~ t h e ~ p o r t A ~$ Parity Error Flag ( $\overline{\mathrm{PEFA}}$ ) is held HIGH regardless of the levels applied to the A0-A35 inputs. Likewise, the parity trees used to check the B0-B35 inputs are shared by the mail1 register when parity generation is selected for portB reads (PGB=HIGH). When a portB readfrom the mail1 register with parity generation is selected with $\overline{C S B}$ LOW, ENBHIGH,W/R$B$ LOW, bothSIZO and SIZ1 HIGH, and PGB HIGH, the port B Parity Error Flag ( $\overline{\mathrm{PEFB}})$ is held HIGH regardless of the levels applied to the B0-B35 inputs.

## PARITY GENERATION

A HIGH level on the port A Parity Generate select (PGA) or port B Parity Generate select(PGB) enables the IDT723613 to generate parity bits for port reads from a FIFO or mailbox register. Port A bytes are arranged as A0-A8, A9-A17, A18-A26, and A27-A35, with the most significant bit of each byte used as the parity bit. Port B bytes are arranged as B0-B8, B9-B17, B18-B26, and B27-B35, with the mostsignificant bit of each byte used as the parity bit. A write to a FIFO or mail register stores the levels applied to all nine inputs of a byte regardless of the state of the Parity Generate select(PGA, PGB) inputs. When data is read from a port with parity generation selected, the lower eight bits of each byte are used to generate a parity bit according to the level on the ODD/ $\overline{\text { EVEN }}$ select. The generated parity bits are substituted for the levels originally written to the most significant bits of each byte as the word is read to the data outputs.

Parity bits for FIFO data are generated after the data is read from SRAM and before the data is written to the outputregister. Therefore, the portA Parity Generate select(PGA) and Odd/Even parity select(ODD/EVEN) have setup and hold time constraints to the port A Clock (CLKA) and the port B Parity Generate select (PGB) and ODD/EVEN select have setup and hold time constraints to the port B Clock (CLKB). These timing constraints only apply for arising clock edge used to read anewlong word to the FIFO output register.

The circuit used to generate parity for the mail1 data is shared by the portB bus(B0-B35) to check parity and the circuitused to generate parity for the mail2 data is shared by the port A bus (A0-A35) to check parity. The shared parity

trees of a portare used to generate parity bits for the data in a mail registerwhen the port Chip Select ( $\overline{\mathrm{CSA}}, \overline{\mathrm{CSB}}$ ) is LOW, Enable (ENA, ENB) is HIGH, and Write/Read select(W/RA, W/RB) inputisLOW, the mail registerisselected (MBA HIGH for port A; both SIZ0 and SIZ1 are HIGH for port B), and port Parity Generate select(PGA, PGB) is HIGH. Generating parity for mail register data does not change the contents of the register.


Figure 3. Logic Diagram for SIZ0, SIZ1, and BE Register

| SW1 | SW0 |
| :---: | :---: |
| L | L |


(a) NO SWAP

(b) BYTE SWAP

(c) WORD SWAP

(d) BYTE-WORD SWAP

Figure 4. Byte Swapping for FIFO Reads (Long-Word Size Example)


Figure 5. Device Reset Loading the $X$ Register with the Value of Eight


NOTE:

1. Written to the FIFO.

Figure 6. FIFO Write Cycle Timing


NOTES:

1. $\mathrm{SIZO}=\mathrm{HIGH}$ and $\mathrm{SIZ1}=$ HIGH selects the mail1 register for output on Bo-B35.
2. Data read from FIFO1.

## DATA SWAP TABLE FOR FIFO LONG-WORD READS

| FIFO Data Write |  |  |  | Swap Mode |  | FIF0 Data Read |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 | SW1 | SW0 | B35-B27 | B26-B18 | B17-B9 | B8-B0 |
| A | B | C | D | L | L | A | B | C | D |
| A | B | C | D | L | H | D | C | B | A |
| A | B | C | D | H | L | C | D | A | B |
| A | B | C | D | H | H | B | A | D | C |

Figure 7. FIFO Long-Word Read Cycle Timing


NOTES:

1. $\mathrm{SIZO}=\mathrm{HIGH}$ and $\mathrm{SIZ1}=\mathrm{HIGH}$ selects the mail1 register for output on Bo-B35.
2. Unused word Bo-B17 or $\mathrm{B} 18-\mathrm{B} 35$ holds last FIFO1 output register data for word-size reads.

## DATA SWAP TABLE FOR FIFO WORD READS

| FIFO Data Write |  |  |  | Swap Mode |  | Read No. | FIFO Data Read |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Big-Endian | Little-Endian |  |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 |  |  | SW1 | SW0 | B35-B27 | B26-B18 | B17-B9 | B8-B0 |
| A | B | C | D | L | L |  | $\begin{aligned} & \hline 1 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{A} \\ & \mathrm{C} \end{aligned}$ | $\begin{aligned} & \hline B \\ & D \end{aligned}$ | $\begin{aligned} & \hline \mathrm{C} \\ & \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \hline D \\ & B \end{aligned}$ |
| A | B | C | D | L | H |  | 1 | $\begin{aligned} & D \\ & \text { B } \end{aligned}$ | $\begin{aligned} & \text { C } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { B } \\ & \text { D } \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { C } \end{aligned}$ |
| A | B | C | D | H | L | 1 | c | $\begin{aligned} & D \\ & B \end{aligned}$ | $\begin{aligned} & \mathrm{A} \\ & \mathrm{C} \end{aligned}$ | $\begin{aligned} & \text { B } \\ & \text { D } \end{aligned}$ |
| A | B | C | D | H | H | 1 2 | B | A | D | C |

Figure 8. FIFO Word Read-Cycle Timing


NOTES:

1. SIZ0 $=$ HIGH and SIZ1 $=$ HIGH selects the mail1 register for output on Bo-B35.
2. Unused bytes hold last FIFO output register data for byte-size reads.

DATA SWAP TABLE FOR FIFO BYTE READS

| FIFO Data Write |  |  |  | Swap Mode |  | Read No. | FIFO Data Read |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Big- | Little- |  |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 |  |  | SW1 | SW0 | B35-B27 | B8-B0 |
| A | B | C | D | L | L |  | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \hline \text { A } \\ & \text { B } \\ & \text { C } \\ & \text { D } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{D} \\ & \mathrm{C} \\ & \mathrm{~B} \\ & \mathrm{~A} \\ & \hline \end{aligned}$ |
| A | B | C | D | L | H | 1 2 3 4 | $\begin{aligned} & \text { D } \\ & \text { C } \\ & \text { B } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { B } \\ & \text { C } \\ & \text { D } \end{aligned}$ |
| A | B | C | D | H | L | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \text { C } \\ & \text { D } \\ & \text { A } \\ & \text { B } \end{aligned}$ | $\begin{aligned} & \text { B } \\ & \text { A } \\ & \text { D } \\ & \text { C } \end{aligned}$ |
| A | B | C | D | H | H | 1 2 3 4 | $\begin{aligned} & \text { B } \\ & \text { A } \\ & \text { D } \\ & C \end{aligned}$ | $\begin{aligned} & \text { C } \\ & \text { D } \\ & \text { A } \\ & \text { B } \end{aligned}$ |

Figure 9. FIFO Byte Read-Cycle Timing


## NOTES:

1. tsKEW1 is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{\mathrm{EF}}$ to transition HIGH in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tsKEw1, then the transition of EF HIGH may occur one CLKB cycle later than shown
2. Port B size of long word is selected for the FIFO read by SIZ1 = LOW, SIZO = LOW. If port-B size is word or byte, $\overline{\mathrm{EF}}$ is set LOW by the last word or byte read from the FIFO, respectively.

Figure 10. $\overline{E F}$ Flag Timing and First Data Read when the FIFO is Empty


NOTES:
3145 drw11

1. tskEw1 is the minimum time between a rising CLKB edge and a rising CLKA edge for $\overline{E F}$ to transition HIGH in the next CLKA cycle. If the time between the rising CLKB edge and rising CLKA edge is less than tskEw1, then the transition of EF HIGH may occur one CLKA cycle later than shown.
2. Port B size of long word is selected for the FIFO read by SIZ1 = LOW, SIZO = LOW. If port B size is word or byte, tskEW1 is referenced from the rising CLKB edge that reads the last word or byte of the long word, respectively.

Figure 11. $\overline{\text { FF }}$ Flag Timing and First Available Write when the FIFO is Full


## NOTES:

1. tskEwz is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{\mathrm{AE}}$ to transition HIGH in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tskEw, then AE may transition HIGH one CLKB cycle later than shown.
2. FIFO write $(\overline{\mathrm{CSA}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}=\mathrm{HIGH}, \mathrm{MBA}=\mathrm{LOW})$, FIFO read $(\overline{\mathrm{CSB}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R} B}=\mathrm{LOW}, \mathrm{MBB}=\mathrm{LOW})$.
3. Port B size of long word is selected for the FIFO read by SIZ1 = LOW, SIZO = LOW. If port B size is word or byte, tskEW is referenced to the last word or byte of the long word, respectively.

Figure 12. Timing for $\overline{A E}$ when the FIFO is Almost-Empty


## NOTES:

1. tskew2 is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{\mathrm{AF}}$ to transition HIGH in the next CLKA cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tSKEW2, then $\overline{\mathrm{AF}}$ may transition HIGH one CLKB cycle later than shown.
2. FIFO write $(\overline{\mathrm{CSA}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}=\mathrm{HIGH}, \mathrm{MBA}=\mathrm{LOW})$, FIFO read $(\overline{\mathrm{CSB}}=\mathrm{LOW}, \mathrm{W} / \overline{\mathrm{R} B}=\mathrm{LOW}, \mathrm{MBB}=\mathrm{LOW})$.
3. Port-B size of long word is selected for FIFO read by SIZ1 = LOW, SIZO = LOW. If port B size is word or byte, tskEW2 is referenced from the last word or byte read of the long word, respectively.

Figure 13. Timing for $\overline{\boldsymbol{A F}}$ when the FIFO is Almost Full


NOTE:

1. Port-B parity generation off $(P G B=L O W)$.

Figure 14. Timing for Mail1 Register and $\overline{\text { MBF1 }}$ Flag


NOTE:

1. Port-A parity generation off (PGA = LOW).

Figure 15. Timing for Mail2 Register and $\overline{\text { MBF2 }}$ Flag


NOTE:

1. $\overline{C S A}=$ LOW and ENA $=$ HIGH.

Figure 16. ODD/EVEN, W/RA, MBA, and PGA to $\overline{\text { EEFA }}$ Timing


NOTE:

1. $\overline{\mathrm{CSB}}=\mathrm{LOW}$ and $\mathrm{ENB}=\mathrm{HIGH}$.

Figure 17. ODD/EVEN, W/RB, SIZ1, SIZO, and PGB to $\overline{P E F B}$ Timing


Figure 18. Parity Generation Timing when Reading from the Mail2 Register


Figure 19. Parity Generation Timing when Reading from the Mail1 Register

## PARAMETER MEASUREMENT INFORMATION



VOLTAGE WAVEFORMS
ENABLE AND DISABLE TIMES


VOLTAGE WAVEFORMS
PROPAGATION DELAY TIMES

Figure 20. Load Circuit and Voltage Waveforms

## ORDERING INFORMATION



NOTES:

1. Industrial temperature range product for 20 ns speed grade is available as a standard device. All other speed grades are available by special order.
2. Green parts are available. For specific speeds and packages contact your sales office.

## DATASHEET DOCUMENT HISTORY

pgs. 1, 6, 8, 9, 24 and 26.
pgs. 1, 2, 3 and 26.
pg. 26.
PDN\# FS-10-04 issued. See IDT.com for PDN specifics.
10/21/2013
Datasheetchanged to ObsoleteStatus.

# IMPORTANT NOTICE AND DISCLAIMER 

RENESAS ELECTRONICS CORPORATION AND ITS SUBSIDIARIES ("RENESAS") PROVIDES TECHNICAL SPECIFICATIONS AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT OF THIRD-PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for developers who are designing with Renesas products. You are solely responsible for (1) selecting the appropriate products for your application, (2) designing, validating, and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, or other requirements. These resources are subject to change without notice. Renesas grants you permission to use these resources only to develop an application that uses Renesas products. Other reproduction or use of these resources is strictly prohibited. No license is granted to any other Renesas intellectual property or to any third-party intellectual property. Renesas disclaims responsibility for, and you will fully indemnify Renesas and its representatives against, any claims, damages, costs, losses, or liabilities arising from your use of these resources. Renesas' products are provided only subject to Renesas' Terms and Conditions of Sale or other applicable terms agreed to in writing. No use of any Renesas resources expands or otherwise alters any applicable warranties or warranty disclaimers for these products.

## Corporate Headquarters

TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan
www.renesas.com

## Contact Information

For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit www.renesas.com/contact-us/.

## Trademarks

Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners.

