## 18/36/72-Mbit Programmable

 2-Queue FIFOs
## Features

- Memory organization
a Industry's largest first in first out (FIFO) memory densities: 18-Mbit, 36-Mbit, 72-Mbit
$\square$ Selectable memory organization: $\times 9, \times 12, \times 16, \times 18, \times 20$, $\times 24, \times 32, \times 36$

■ Up to $100-\mathrm{MHz}$ clock operation

- Unidirectional operation

■ Independent read and write ports
$\square$ Supports simultaneous read and write operations
$\square$ Reads and writes operate on independent clocks upto a maximum clock ratio of 2 , enabling data buffering across clock domains
a Supports multiple I/O voltage standard: Low voltage complementary metal oxide semiconductor (LVCMOS) 3.3 V and 1.8 V voltage standards.
■ Output enable control for read skip operations
■ User configured two-Queue operating mode
■ Mark and retransmit: resets read pointer to user marked position

- Empty and full status flags
- Flow-through mailbox register to send data from input to output port, bypassing the FIFO sequence
■ Configure programmable flags and registers through serial or parallel modes
■ Separate serial clock (SCLK) input for serial programming
■ Master reset to clear entire FIFO
■ Joint test action group (JTAG) port provided for boundary scan function

■ Industrial temperature range: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

## Functional Description

The Cypress programmable FIFO family offers the industry's highest-density programmable FIFO memory device. It has independent read and write ports, which can be clocked up to 100 MHz . User can configure input and output bus sizes. The maximum bus size of 36 bits enables a maximum data throughput of 3.6 Gbps. The read and write ports can support multiple I/O voltage standards. The user-programmable registers enable user to configure the device operation as desired. The device also offers a simple and easy-to-use interface to reduce implementation and debugging efforts, improve time-to-market, and reduce engineering costs. This makes it an ideal memory choice for a wide range of applications including multiprocessor interfaces, video and image processing, networking and telecommunications, high-speed data acquisition, or any system that needs buffering at very high speeds across different domains.
As implied by the name, the functionality of the FIFO is such that the data is read out of the read port in the same sequence in which it was written into the write port. The data is sequentially written into the FIFO from the write port. If the writes and inputs are enabled, the data on the write port gets written into the device at the rising edge of the write clock. Enabling the reads and outputs fetches data on the read port at every rising edge of the read clock. Both reads and writes can occur simultaneously at different speeds provided the ratio of read to write clock is between 0.5 and 2. Appropriate flags are set whenever the FIFO is empty or full.
The device also supports two-Queue operation, mark and retransmit of data, and a flow-through mailbox register.
All product features and specs are common to all densities (CYF1072V, CYF1036V, and CYF1018V) unless otherwise specified. All descriptions are given assuming the device is CYF1072V operated in $\times 36$ mode. They hold good for other densities (CYF1036V, and CYF1018V) and all port sizes $\times 9$, $\times 12, \times 16, \times 18, \times 20, \times 24$ and $\times 32$ unless otherwise specified. the only difference will be in the input and output bus width.
Table 1 on page 8 shows the part of bus with valid data from $D[35: 0]$ and $Q[35: 0]$ in $\times 9, \times 12, \times 16, \times 18, \times 20, \times 24, \times 32$ and $\times 36$ modes.

## Logic Block Diagram



## Contents

Pin Diagram for CYF1XXXV ..... 4
Pin Definitions ..... 5
Architecture ..... 7
Reset Logic ..... 7
Flag Operation ..... 7
Full Flag ..... 7
Empty Flag ..... 7
Retransmit from Mark Operation ..... 7
Flow-through mailbox Register ..... 7
Selecting Word Sizes ..... 8
Data Valid Signal ..... 8
Power Up ..... 8
Read Skip Operation ..... 8
Multi-Queue Operation ..... 8
Width Expansion Configuration ..... 10
Memory Organization for Different Port Sizes ..... 11
Read/Write Clock Requirements ..... 11
JTAG operation ..... 11
Maximum Ratings ..... 13
Operating Range ..... 13
Recommended DC Operating Conditions ..... 13
Electrical Characteristics ..... 13
I/O Characteristics ..... 14
Latency Table ..... 14
Switching Characteristics ..... 15
Switching Waveforms ..... 16
Ordering Information ..... 24
Ordering Code Definitions ..... 24
Package Diagram ..... 25
Acronyms ..... 26
Document Conventions ..... 26
Units of Measure ..... 26
Document History Page ..... 27
Sales, Solutions, and Legal Information ..... 28
Worldwide Sales and Design Support ..... 28
Products ..... 28
PSoC Solutions ..... 28

## Pin Diagram for CYF1XXXV

Figure 1. 209-ball FBGA (Top View)

|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | $\overline{\text { FF }}$ | D0 | D1 | WQSEL0 | PORTSZ0 | PORTSZ1 | DNU | RQSEL0 | RT | Q0 | Q1 |
| B | $\overline{\mathrm{EF}}$ | D2 | D3 | DNU | DNU | PORTSZ2 | DNU | DNU | $\overline{\text { REN }}$ | Q2 | Q3 |
| C | D4 | D5 | $\overline{\text { WEN }}$ | DNU | VCC1 | DNU | VCC1 | DNU | RCLK | Q4 | Q5 |
| D | D6 | D7 | VSS | VCC1 | DNU | $\overline{\text { LD }}$ | DNU | VCC1 | VSS | Q6 | Q7 |
| E | D8 | D9 | VCC2 | VCC2 | VCCIO | VCCIO | VCCIO | VCC2 | VCC2 | Q8 | Q9 |
| F | D10 | D11 | VSS | VSS | VSS | DNU | VSS | VSS | VSS | Q10 | Q11 |
| G | D12 | D13 | VCC2 | VCC2 | VCCIO | VCC1 | VCCIO | VCC2 | VCC2 | Q12 | Q13 |
| H | D14 | D15 | VSS | VSS | VSS | VCC1 | VSS | VSS | VSS | Q14 | Q15 |
| J | D16 | D17 | VCC2 | VCC2 | VCCIO | VCC1 | VCCIO | VCC2 | VCC2 | Q16 | Q17 |
| K | DNU | DNU | WCLK | DNU | VSS | DNU | VSS | DNU | VCCIO | VCCIO | VCCIO |
| L | D18 | D19 | VCC2 | VCC2 | VCCIO | VCC1 | VCCIO | VCC2 | VCC2 | Q18 | Q19 |
| M | D20 | D21 | VSS | VSS | VSS | VCC1 | VSS | VSS | VSS | Q20 | Q21 |
| N | D22 | D23 | VCC2 | VCC2 | VCCIO | VCC1 | VCCIO | VCC2 | VCC2 | Q22 | Q23 |
| P | D24 | D25 | VSS | VSS | VSS | $\overline{\text { SPI_SEN }}$ | VSS | VSS | VSS | Q24 | Q25 |
| R | D26 | D27 | VCC2 | VCC2 | VCCIO | VCCIO | VCCIO | VCC2 | VCC2 | Q26 | Q27 |
| T | D28 | D29 | VSS | VCC1 | VCC1 | SPI_SI | VCC1 | VCC1 | VSS | Q28 | Q29 |
| U | $\overline{\text { DVal0 }}$ | DNU | D30 | D31 | DNU | DNU ${ }^{[1] ~}$ | SPI_SCLK | Vref | $\overline{\text { OE }}$ | Q30 | Q31 |
| V | DNU | DNU | D32 | D33 | DNU | $\overline{\text { MRS }}$ | MB | DNU | MARK | Q32 | Q33 |
| W | TDO | $\overline{\text { DVal1 }}$ | D34 | D35 | TDI | $\overline{\text { TRST }}$ | TMS | TCK | Vref | Q34 | Q35 |

## Note

1. This pin should be tied to $\mathrm{V}_{\mathrm{SS}}$ preferably or can be left floating to ensure normal operation.

## Pin Definitions

| Pin Name | I/O | Pin Description |
| :---: | :---: | :---: |
| D[35:0] | Input | Data inputs: Data inputs for a 36-bit bus. |
| Q[35:0] | Output | Data outputs: Data outputs for a 36-bit bus. |
| WEN | Input | Write enable: $\overline{\text { WEN }}$ enables WCLK to write data into the FIFO memory and configuration registers. |
| REN | Input | Read enable: $\overline{\text { REN }}$ enables RCLK to read data from the FIFO memory and configuration registers. |
| $\overline{\mathrm{OE}}$ | Input | Output enable: When $\overline{\mathrm{OE}}$ is LOW, FIFO data outputs are enabled; when $\overline{\mathrm{OE}}$ is HIGH, the FIFO's outputs are in High Z (high impedance) state. |
| WCLK | Input | Write clock: When enabled by $\overline{\text { WEN }}$, the rising edge of WCLK writes data into the FIFO if $\overline{\mathrm{LD}}$ is high and into the configuration registers if $\overline{\mathrm{LD}}$ is low. |
| RCLK | Input | Read clock: When enabled by $\overline{\text { REN }}$, the rising edge of RCLK reads data from the FIFO memory if $\overline{\operatorname{LD}}$ is high and from the configuration registers if $\overline{\mathrm{LD}}$ is low. |
| $\overline{\text { DVal0 }}$ | Output | Data valid for Queue-0: Active low signal indicating valid data read for Queue-0 from Q[35:0]. |
| $\overline{\text { DVal1 }}$ | Output | Data valid for Queue-1: Active low signal indicating valid data read for Queue-1 from Q[35:0]. |
| $\overline{\mathrm{EF}}$ | Output | Empty flag: When $\overline{\mathrm{EF}}$ is LOW, the Queue is empty. $\overline{\mathrm{EF}}$ is synchronized to RCLK. |
| $\overline{\mathrm{FF}}$ | Output | Full flag: When $\overline{\mathrm{FF}}$ is LOW, the Queue is full. $\overline{\mathrm{FF}}$ is synchronized to WCLK. |
| $\overline{\text { LD }}$ | Input | Load: When $\overline{\mathrm{LD}}$ is LOW, $\mathrm{D}[7: 0]$ ( $\mathrm{Q}[7: 0]$ ) are written (read) into (from) the configuration registers. When $\overline{\mathrm{LD}}$ is HIGH, D[35:0] (Q[35:0]) are written (read) into (from) the FIFO. |
| RT | Input | Retransmit: A HIGH pulse on RT resets the internal read pointer to a physical location of the FIFO which is marked by the user (using MARK pin). With every valid read cycle after retransmit, previously accessed data is read and the read pointer is incremented until it is equal to the write pointer. |
| $\overline{\mathrm{MRS}}$ | Input | Master reset: $\overline{\mathrm{MRS}}$ initializes the read and write pointers to zero and sets the output register to all zeroes. During Master Reset, the configuration registers are all set to default values and flags are reset. |
| SPI_SCLK | Input | Serial clock: A rising edge on SPI_SCLK clocks the serial data present on the SPI_SI input into the offset registers if SPI_SEN is enabled. |
| SPI_SI | Input | Serial input: Serial input when SPI_SEN is enabled. |
| $\overline{\text { SPI_SEN }}$ | Input | Serial enable: Enables serial loading of programmable flag offsets and configuration registers. |
| MARK | Input | Mark for retransmit: When this pin is asserted the current location of the read pointer is marked. Any subsequent retransmit operation resets the read pointer to this position. |
| MB | Input | Mailbox: When asserted the reads and writes happen to flow-through mailbox register. |
| WQSEL0 | Input | Write Queue select: select Queue-0 when low and Queue-1 when high. |
| RQSEL0 | Input | Read Queue select: select Queue-0 when low and Queue-1 when high. |
| TCK | Input | Test clock (TCK) pin for JTAG. |
| TRST | Input | Reset pin for JTAG. |
| TMS | Input | Test mode select (TMS) pin for JTAG. |
| TDI | Input | Test data in (TDI) pin for JTAG. |
| TDO | Output | Test data out (TDO) for JTAG. |
| PORTSZ [2:0] | Input | Port word size select: Port word width select pins (common for read and write ports). |
| $\mathrm{V}_{\mathrm{CC} 1}$ | Power Supply | Core voltage supply $1: 1.8 \mathrm{~V}$ supply voltage |
| $\mathrm{V}_{\mathrm{CC} 2}$ | Power Supply | Core voltage supply 2 : 1.5 V supply voltage |

Pin Definitions (continued)

| Pin Name | I/O |  |
| :--- | :---: | :--- |
| $V_{\text {CCIO }}$ | Power <br> Supply | Supply for I/Os. |
| Vref | Input <br> Reference | Reference voltage: Reference voltage (regardless of I/O standard used) |
| $V_{\text {SS }}$ | Ground | Ground |
| DNU | - | Do not use: These pins need to be left floating. |

## Architecture

The CYF1072V, CYF1036V, and CYF1018V are of memory arrays of $72-\mathrm{Mbit}, 36-\mathrm{Mbit}$, and $18-\mathrm{Mbit}$ respectively. The memory organization is user configurable and word sizes can be selected as $\times 9, \times 12, \times 16, \times 18, \times 20, \times 24, \times 32$, or $\times 36$. The logic blocks to implement FIFO functionality and the associated features are built around these memory arrays.
The input and output data buses have a maximum width of 36 bits configurable through PORTSZ[2:0]. The input data bus goes to an input register and the data flow from the input register to the memory is controlled by the write logic block. The inputs to the write logic block are WCLK, WEN and WQSELO. When the writes are enabled through $\overline{\mathrm{WEN}}$, the data on the input bus is written into the memory array at the rising edge of WCLK. This also increments the write pointer. WQSELO selects the Queue for write operation.
Similarly, the output register is connected to the data output bus. Transfer of contents from the memory to the output register is controlled by the read control logic. The inputs to the read control logic include RCLK, REN, $\overline{O E}$, RQSELO, RT and MARK. When reads are enabled by REN and outputs are enabled through $\overline{O E}$, the data from the memory pointed by the read pointer is transferred to the output data bus at the rising edge of RCLK along with active low $\overline{\text { Dval0 }}$ or $\overline{\text { Dval1 }}$ based on the Queue number selected using RQSELO. If the outputs are disabled through $\overline{O E}$ but the reads enabled, the outputs are in high impedance state, but internally the read pointer is incremented. The MARK signal is used to 'mark' the location from which data is retransmitted when requested.
During write operation, the number of writes performed is always a even number (i.e., minimum write burst length is two and number of writes always a multiple of two), whereas during read operation, the number of reads performed can be even or odd (i.e., minimum read burst length is one).

By default, the FIFO is accessed as a single Queue device. It is possible to divide the whole memory space into 2 equal sized array, and each array can be independently accessed as an independent FIFO. This is like having two independent Queues inside the FIFO instead of entire memory space acting as single Queue FIFO. User can configure the number of Queues by setting the value of DO of configuration register 3(refer Table 3 on page 9). Table 2 on page 8 shows the value to be set in D0 of configuration register 3 to configure the device in single-Queue or two-Queue mode.

## Reset Logic

The Master Reset ( $\overline{\mathrm{MRS}}$ ) initializes the read and write pointers to zero, sets the output registers to all zeros and sets the status of the flags to $\overline{\mathrm{FF}}$ deasserted and $\overline{\mathrm{EF}}$ asserted. $\overline{\mathrm{MRS}}$ also resets the configuration register and the mark address to their default values. MRS affects all the Queues in the FIFO. A $\overline{M R S}$ is required after power up before accessing the FIFO. After MRS, a minimum latency of 1024 clocks is necessary before the first access. The word size is configured through pins; values of the three PORTSZ pins are latched during rising edge of MRS. After MRS, the device is configured in single Queue mode by default.

## Flag Operation

This device provides two flag pins to indicate the condition of the FIFO contents.

## Full Flag

The Full Flag ( $\overline{\mathrm{FF}}$ ) goes LOW when the device is full. All write operations are ignored whenever $\overline{\mathrm{FF}}$ is LOW regardless of the state of WEN. FF is synchronized to WCLK, that is, it is exclusively updated by each rising edge of WCLK. In 2Q mode, $\overline{F F}$ indicates the status of the Queue selected by WQSELO.The worst case assertion latency for Full Flag is four. As the user cannot know that the FIFO is full for four clock cycles, it is possible that user continues writing data during this time. In this case, the four data word written will be stored to prevent data loss and these words have to be read back in order for full flag to get de-asserted. The minimum number of reads required to de-assert full-flag is two and the maximum number of reads required to de-assert full flag is six. The assertion and de-assertion of full flag with associated latencies is explained in Latency Table on page 14.

## Empty Flag

The Empty Flag ( $\overline{\mathrm{EF}}$ ) goes LOW when the device is empty. Read operations are ignored whenever $\overline{\mathrm{EF}}$ is LOW, regardless of the state of REN. $\overline{\mathrm{EF}}$ is synchronized to RCLK, i.e., it is exclusively updated by each rising edge of RCLK. In 2Q mode, $\overline{E F}$ indicates the status of the Queue selected by RQSELO. The assertion and de-assertion of empty flag with associated latencies is explained in Latency Table on page 14.

## Retransmit from Mark Operation

The retransmit feature is useful for transferring packets of data repeatedly. It enables the receipt of data to be acknowledged by the receiver and retransmitted if necessary. The retransmit feature is used when the number of writes equal to or less than the depth of the FIFO has occurred - and at least one word has been read since the last reset cycle. A HIGH pulse on RT resets the internal read pointer to a physical location of the FIFO that is marked by the user (using the MARK pin). In 2-Queue mode the MARK and RT signals are validated with RQSELO, i.e., Mark or Retransmit function will be performed for the Queue that is selected by RQSELO. With every valid read cycle after retransmit, previously accessed data is read and the read pointer is incremented until it is equal to the write pointer. Flags are governed by the relative locations of the read and write pointers and are updated during a retransmit cycle. Data written to FIFO after activation of RT are also transmitted. The full depth of the FIFO can be repeatedly retransmitted. To mark a location, the Mark pin is asserted when reading that particular location.

## Flow-through mailbox Register

This feature transfers data from input to output directly by bypassing the FIFO sequence. When MB signal is asserted the data present in $\mathrm{D}[35: 0$ ] will be available at Q [35:0] after two WCLK cycles. Normal read and write operations are not allowed during flow-through mailbox operation. Before starting Flow-through mailbox operation FIFO read should be completed to make data valid ( $\overline{\mathrm{DVaIO} / \overline{\mathrm{DVal1}}) \text { high in order to avoid data loss }}$ from FIFO. The width of flow-through mailbox register always corresponds to port size.

## Selecting Word Sizes

The word sizes are configured based on the logic levels on the PORTSZ pins during the master reset (MRS) cycle only (latched on low to high edge). The port size cannot be changed during normal mode of operation and these pins are ignored. Table 1. explains the pins of $\mathrm{D}[35: 0$ ] and $\mathrm{Q}[35: 0]$ that will have valid data in modes where the word size is less than $\times 36$. If word size is less than $\times 36$, the unused output pins are tri-stated by the device and unused input pins will be ignored by the internal logic. The pins with valid data input $\mathrm{D}[\mathrm{N}: 0]$ and output $\mathrm{Q}[\mathrm{N}: 0]$ is given in Table 1.

## Data Valid Signal

Data valid ( $\overline{\mathrm{Dval0}}, \overline{\mathrm{Dval1}})$ are active low signals provided for easy capture of output data. When a read operation is performed, the $\overline{\mathrm{DValO}} / \overline{\mathrm{DVal} 1}$ signal goes low along with output data indicating
valid data on $Q$ bus for either Queue-0 or Queue-1. This helps to capture the data without keeping track of REN and RQSELO to data output latency. These signals also help to capture the output data when write and read operations are performed continuously at different frequencies by indicating when valid data is read out at the output port Q [35:0].

## Power Up

The device becomes functional after $\mathrm{V}_{\mathrm{CC} 1}, \mathrm{~V}_{\mathrm{CC} 2}, \mathrm{~V}_{\mathrm{CCIO}}$, and Vref attain minimum stable voltage required as given in Recommended DC Operating Conditions on page 13. The device can be accessed $t_{P u}$ time after these supplies attain the minimum required level
(see Switching Characteristics on page 15). There is no power sequencing requirement for the device.

Table 1. Word Size Selection

| PORTSZ[2:0] | Word Size | Active input data pins D[X:0] | Active output data pins Q[X:0] |
| :---: | :---: | :---: | :---: |
| 000 | $\times 9$ | $\mathrm{D}[8: 0]$ | $\mathrm{Q}[8: 0]$ |
| 001 | $\times 12$ | $\mathrm{D}[11: 0]$ | $\mathrm{Q}[11: 0]$ |
| 010 | $\times 16$ | $\mathrm{D}[15: 0]$ | $\mathrm{Q}[15: 0]$ |
| 011 | $\times 18$ | $\mathrm{D}[17: 0]$ | $\mathrm{Q}[17: 0]$ |
| 100 | $\times 20$ | $\mathrm{D}[19: 0]$ | $\mathrm{Q}[19: 0]$ |
| 101 | $\times 24$ | $\mathrm{D}[23: 0]$ | $\mathrm{Q}[23: 0]$ |
| 110 | $\times 32$ | $\mathrm{D}[31: 0]$ | $\mathrm{Q}[31: 0]$ |
| 111 | $\times 36$ | $\mathrm{D}[35: 0]$ | $\mathrm{Q}[35: 0]$ |

Table 2. Multi-Queue Configuration

| operating mode | RQSELO/WQSELO | Queue Number Selected |
| :---: | :---: | :---: |
| 1Q mode <br> register $0 \times 3[0]=0$ | 0 | 0 |
|  | 1 | invalid |
| 2Q mode | 0 | 0 |
| register $0 \times 3[0]=1$ |  |  |

## Read Skip Operation

As mentioned in Architecture on page 7, during a read operation, if the outputs are disabled by having the OE high, the read data does not appear on the output bus; however, the read pointer is incremented.

## Multi-Queue Operation

In general, the entire memory space is accessed as a First In First Out (FIFO) order for the write and read operation. In this case, the entire memory space is called a single Queue. For example, for 72 M device, the entire memory space is available as a single Queue FIFO operation.

In multi Queue mode, the entire memory space is divided into equal sized memory array and each individual memory array can be accessed as an independent FIFO based on additional control signals. These independent memory arrays are called as Queues. For example, when 72M device, is configured into two Queue mode, the entire memory space of 72 M is divided into two 36M memory array called as Queue-0 and Queue-1. These Queues can be accessed independently as a FIFO by selecting the Queue select signals WQSELO and RQSELO. In this way, two Queues can be created for a given device where data can be stored independently and read out independently.

Table 3. Configuration Registers

| ADDR | Configuration Register | Default | Bit [7] | Bit [6] | Bit [5] | Bit [4] | Bit [3] | Bit [2] | Bit [1] | Bit [0] |
| :---: | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $0 \times 1$ | Reserved | $0 \times 00$ | X | X | X | X | X | X | X | X |
| $0 \times 2$ | Reserved | $0 \times 00$ | X | X | X | X | X | X | X | X |
| $0 \times 3$ | Number of Queues | $0 \times 00$ | X | X | X | X | X | X | X | D |
| $0 \times 4$ | Reserved | $0 \times 7 \mathrm{~F}$ | X | X | X | X | X | X | X | X |
| $0 \times 5$ | Reserved | $0 \times 00$ | X | X | X | X | X | X | X | X |
| $0 \times 6$ | Reserved | $0 \times 00$ | X | X | X | X | X | X | X | X |
| $0 \times 7$ | Reserved | $0 \times 7 \mathrm{~F}$ | X | X | X | X | X | X | X | X |
| $0 \times 8$ | Reserved | $0 \times 00$ | X | X | X | X | X | X | X | X |
| $0 \times 9$ | Reserved | $0 \times 00$ | X | X | X | X | X | X | X | X |
| 0xA | Fast CLK Bit Register | $1 X X X X X X X b$ | Fast | X | X | X | X | X | X | X |
|  |  |  | CLK bit |  |  |  |  |  |  |  |

Table 4. Writing and Reading Configuration Registers in Parallel Mode

| SPI_SEN | $\overline{\text { LD }}$ | WEN | REN | WCLK | RCLK | SPI_SCLK | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 1 | $\uparrow$ First rising edge because both LD and WEN are low | X | X | Parallel write to first register |
| 1 | 0 | 0 | 1 | $\uparrow$ Second rising edge | X | X | Parallel write to second register |
| 1 | 0 | 0 | 1 | $\uparrow$ Third rising edge | X | X | Parallel write to third register |
| 1 | 0 | 0 | 1 | $\uparrow$ Fourth rising edge | X | X | Parallel write to fourth register |
| 1 | 0 | 0 | 1 | - | X | X | - |
| 1 | 0 | 0 | 1 | $\bullet$ | X | X | - |
| 1 | 0 | 0 | 1 | $\bullet$ | X | X | $\bullet$ |
| 1 | 0 | 0 | 1 | $\uparrow$ Tenth rising edge | X | X | Parallel write to tenth register |
| 1 | 0 | 0 | 1 | $\uparrow$ Eleventh rising edge | X | X | Parallel write to first register (roll back) |
| 1 | 0 | 1 | 0 | X | $\uparrow$ First rising edge since both $\overline{\text { LD }}$ and REN are low | X | Parallel read from first register |
| 1 | 0 | 1 | 0 | X | $\uparrow$ Second rising edge | X | Parallel read from second register |
| 1 | 0 | 1 | 0 | X | $\uparrow$ Third rising edge | X | Parallel read from third register |
| 1 | 0 | 1 | 0 | X | $\uparrow$ Fourth rising edge | X | Parallel read from fourth register |
| 1 | 0 | 1 | 0 | X | - | X | - |
| 1 | 0 | 1 | 0 | X | - | X | $\bullet$ |
| 1 | 0 | 1 | 0 | X | $\bullet$ | X | $\bullet$ |
| 1 | 0 | 1 | 0 | X | $\uparrow$ Tenth rising edge | X | Parallel read from tenth register |
| 1 | 0 | 1 | 0 | X | $\uparrow$ Eleventh rising edge | X | Parallel read from first register (roll back) |
| 1 | X | 1 | 1 | X | X | X | No operation |

Table 4. Writing and Reading Configuration Registers in Parallel Mode (continued)

| $\overline{\text { SPI_SEN }}$ | $\overline{\text { LD }}$ | $\overline{\text { WEN }}$ | $\overline{\text { REN }}$ | WCLK | RCLK | SPI_SCLK | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | 1 | 0 | X | $\uparrow$ Rising edge | X | X | Write to FIFO memory |
| X | 1 | X | 0 | X | $\uparrow$ Rising edge | X | Read from FIFO memory |
| 0 | 0 | X | 1 | X | X | X | Illegal operation |

Table 5. Writing into Configuration Registers in Serial Mode

| $\overline{\text { SPI_SEN }}$ | $\overline{\text { LD }}$ | $\overline{\text { WEN }}$ | $\overline{\text { REN }}$ | WCLK | RCLK | SCLK | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | X | X | X | X | $\uparrow$ Rising edge | Each rising of the SCLK clocks <br> in one bit from the SI (Serial In). <br> Any of the 10 registers can be <br> addressed and written to, <br> following the SPI protocol. |
| X | 1 | 0 | X | $\uparrow$ Rising edge | X | X | Parallel write to FIFO memory. |
| X | 1 | X | 0 | X | $\uparrow$ Rising edge | X | Parallel read from FIFO <br> memory. |
| 1 | 0 | 1 | 1 | X | X | X | This corresponds to parallel <br> mode (refer to Table 4). |

Figure 2. Serial WRITE to Configuration Register


## Width Expansion Configuration

The width of CYF1072V can be expanded to provide word widths greater than 36 bits. During width expansion mode, all control line inputs are common and all flags are available. Empty (Full) flags are created by ANDing the Empty (Full) flags of every FIFO.

This technique avoids reading data from or writing data to the FIFO that is "staggered" by one clock cycle due to the variations in skew between RCLK and WCLK. Figure 3 on page 11 demonstrates a 72 bit-word width by using two 36 -bit word CYF1072Vs.

Figure 3. Using Two CYF1072V for Width Expansion


## Memory Organization for Different Port Sizes

The 72-Mbit memory has different organization for different port sizes. Table 6 shows the depth of the FIFO for all port sizes.
Note that for all port sizes, four to eight locations are not available for writing the data and are used to safeguard against false synchronization of empty and full flags.
Table 6. Word Size Selection

| PORTSZ[2:0] | Word Size | FIFO Depth | Memory Size |
| :---: | :---: | :---: | :---: |
| 000 | $\times 9$ | 8 Meg | 72 Mbit |
| 001 | $\times 12$ | 4 Meg | 48 Mbit |
| 010 | $\times 16$ | 4 Meg | 64 Mbit |
| 011 | $\times 18$ | 4 Meg | 72 Mbit |
| 100 | $\times 20$ | 2 Meg | 40 Mbit |
| 101 | $\times 24$ | 2 Meg | 48 Mbit |
| 110 | $\times 32$ | 2 Meg | 64 Mbit |
| 111 | $\times 36$ | 2 Meg | 72 Mbit |

The memory size mentioned is when the device is configured in single-Queue mode.

## Read/Write Clock Requirements

The read and write clocks must satisfy the following requirements:

Both read (RCLK) and write (WCLK) clocks should be free-running.
■ The clock frequency for both clocks should be between the minimum and maximum range given in Switching Characteristics on page 15.

- The ratio of RCLK to WCLK must be in the range of 0.5 to 2 .

The device uses internal PLL to achieve high performance. Whenever there is change in the frequency of the clock, the device takes $t_{\text {PLL }}$ time to synchronize with the input clock. (see Switching Characteristics on page 15). The PLL requires re-synchronization when there is change in the frequency of either WCLK or RCLK or when master reset is asserted.
For proper FIFO operation, the device must determine which of the input clocks - RCLK or WCLK - is faster. This is evaluated by using counters after the MRS cycle. The device uses two 10-bit counters inside (one running on RCLK and other on WCLK), which count 1,024 cycles of read and write clock after MRS. The clock of the counter which reaches its terminal count first is used as master clock inside the FIFO.

When there is change in the relative frequency of RCLK and WCLK during normal operation of FIFO, user can specify it by using "Fast CLK bit" in the configuration register (0xA).
" 1 " - indicates $\mathrm{f}_{\text {req }}$ (WCLK) $>\mathrm{f}_{\text {req }}$ (RCLK)
" 0 " - indicates $\mathrm{f}_{\text {req }}($ WCLK $)<\mathrm{f}_{\text {req }}$ (RCLK)
The result of counter evaluated frequency is available in this register bit. User can override the counter evaluated frequency for faster clock by changing this bit.
Whenever there is a change in this bit value, user must wait $t_{\text {PLL }}$ time before issuing the next read or write to FIFO.

## JTAG operation

CYF1072V has two devices connected internally in a JTAG chain as shown in Figure 4 on page 12.

Figure 4. JTAG Operation


Table 7 shows the IR register length and device ID.

Table 7. JTAG IDCODES

|  | IR Register length | Device ID (HEX) | Bypass register length |
| :--- | :---: | :---: | :---: |
| Device-1 | 3 | "Ignore" | 1 |
| Device-2 | 8 | 1E3261CF | 1 |

For boundary scan, device-1 should be in bypass mode.
Table 8 and Table 9 shows the JTAG instruction set for devices 1 and 2.

Table 8. JTAG Instructions

| Device-1 | Opcode (Binary) |
| :---: | :---: |
| BYPASS | 111 |

Table 9. JTAG Instructions

| Device-2 | Opcode (HEX) |
| :--- | :---: |
| EXTEST | 00 |
| HIGHZ | 07 |
| SAMPLE/PRELOAD | 01 |
| BYPASS | FF |
| IDCODE | $0 F$ |

## Maximum Ratings

Exceeding maximum ratings may impair the useful life of the device. These user guidelines are not tested.
Storage temperature (without bias) ........ $-65^{\circ} \mathrm{C}$ to $+150{ }^{\circ} \mathrm{C}$
Ambient temperature with power applied $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Core supply voltage $1\left(\mathrm{~V}_{\mathrm{CC} 1}\right)$ to ground potential -0.3 V to 2.5 V
Core supply voltage $2\left(\mathrm{~V}_{\mathrm{CC} 2}\right)$ to ground potential -0.3 V to 1.65 V Latch-up current $\qquad$ $>100 \mathrm{~mA}$

I/O port supply voltage $\left(\mathrm{V}_{\mathrm{CCIO}}\right)$...................... -0.3 V to 3.7 V
Voltage applied to I/O pins ........................... -0.3 V to 3.75 V
Output current into outputs (LOW) ............................. 20 mA
Static discharge voltage
(per MIL-STD-883, Method 3015) ......................... > 2001 V

Operating Range

| Range | Ambient Temperature |
| :--- | :---: |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

## Recommended DC Operating Conditions

| Parameter ${ }^{[2]}$ | Description | Min | Typ | Max | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC} 1}$ | Core supply voltage 1 | 1.70 | 1.80 | 1.90 | V |
| $\mathrm{~V}_{\mathrm{CC} 2}$ | Core supply voltage 2 | 1.425 | 1.5 | 1.575 | V |
| $\mathrm{~V}_{\text {REF }}$ | Reference voltage (irrespective of I/O standard used) | 0.7 | 0.75 | 0.8 | V |
| $\mathrm{~V}_{\mathrm{CCIO}}$ | I/O supply voltage, read and write banks. | LVCMOS33 | 3.00 | 3.30 | 3.60 |
| nyyyyy |  | LVCMOS18 | 1.70 | 1.8 | 1.90 |

## Electrical Characteristics

| Parameter | Description | Conditions | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{cc}}$ | Active current | $\mathrm{V}_{\mathrm{CC} 1}=\mathrm{V}_{\text {CC1MAX }}$ | - | - | 300 | mA |
|  |  | $\mathrm{V}_{\mathrm{CC} 2}=\mathrm{V}_{\mathrm{CC} 2 \mathrm{MAX}}$, <br> All I/O switching, 100 MHz | - | - | 500 | mA |
|  |  | $\mathrm{V}_{\text {CCIO }}=\mathrm{V}_{\text {CCIOMAX }}$ <br> (All outputs disabled) | - | - | 100 | mA |
| $I_{1}$ | Input pin leakage current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CCIOmax }}$ to 0 V | -15 | - | 15 | $\mu \mathrm{A}$ |
| $\mathrm{l}_{\mathrm{OZ}}$ | I/O pin leakage current | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {CCIOmax }}$ to 0 V | -15 | - | 15 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\mathrm{P}}$ | Capacitance for TMS and TCK | - | - | - | 16 | pF |
| $\mathrm{C}_{\text {PIO }}$ | Capacitance for all I/Os apart from TMS and TCK | - | - | - | 8 | pF |

[^0]
## I/O Characteristics

| I/O standard | Nominal I/O <br> supply <br> voltage | Input Voltage (V) |  | Output voltage (V) |  | Output Current (mA) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathbf{V}_{\mathbf{I H}(\mathbf{m i n})}$ | $\mathbf{V}_{\mathbf{O L}}(\mathbf{m a x})$ | $\mathbf{V}_{\mathbf{O H}}(\mathbf{m i n})$ | $\mathbf{I}_{\mathbf{O L}(\mathbf{m a x})}$ | $\mathbf{I}_{\mathbf{O H}}(\mathbf{m a x})$ |  |
| LVCMOS33 | 3.3 V | 0.80 | 2.20 | 0.45 | 2.40 | 24 | 24 |
| LVCMOS18 | 1.8 V | $30 \% \mathrm{~V}_{\mathrm{CCIO}}$ | $65 \% \mathrm{~V}_{\mathrm{CCIO}}$ | 0.45 | $\mathrm{~V}_{\mathrm{CCIO}}-0.45$ | 16 | 16 |

## Latency Table

| Latency Parameter | Number of cycles | Details |
| :---: | :---: | :---: |
| L/ $\overline{\text { FF_ASSERT }}$ | $\begin{aligned} & \operatorname{Min}=0 \\ & \operatorname{Max}=4 \end{aligned}$ | Last data write to $\overline{\mathrm{FF}}$ going low |
| L-EF_ASSERT | 0 | Last data read to $\overline{\mathrm{EF}}$ going low |
| LRQSEL_CHANGE | 1 | Minimum RCLK cycles before RQSEL0 can change |
| LWQSEL_CHANGE | 2 | Minimum WCLK cycles before WQSELO can change |
| $\mathrm{L}_{\text {MAILBOX }}$ | 2 | Latency from write port to read port when MB = 1 (w.r.t WCLK) |
| L $\overline{\text { REN_TO_DATA }}$ | 4 | Latency when $\overline{\text { REN }}$ is asserted low to first data output from FIFO |
| L- $\overline{\text { REN_TO_CONFIG }}$ | 4 | Latency when $\overline{R E N}$ is asserted along with $\overline{\mathrm{LD}}$ to first data read from configuration registers |
| L- ${ }_{\text {FF_DEASSERT }}$ | 7 | Read to $\overline{\mathrm{FF}}$ going high |
| L ${ }_{\text {RT_TO_REN }}$ | 9 | RT 5th cycle to REN going low for read |
| LRT_TO_DATA | $\begin{aligned} & \operatorname{Min}=20 \\ & \operatorname{Max}=23 \end{aligned}$ | RT 5th cycle to valid data on Q[35:0] |
| $\mathrm{L}_{\text {IN }}$ | $\begin{aligned} & \hline \operatorname{Min}=8 \\ & \operatorname{Max}=29 \end{aligned}$ | Initial latency for data read after FIFO goes empty during simultaneous read/write |
| L-EF_DEASSERT | $\begin{aligned} & \operatorname{Min}=6 \\ & \operatorname{Max}=27 \end{aligned}$ | Write to EF going high |

Figure 5. AC Test Load Conditions

(c) All Input Pulses

## Switching Characteristics

Over the operating Range

| Parameter | Description |  | -100 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |
| $\mathrm{t}_{\mathrm{PU}}$ | Power-up time after all supplies reach minimum value |  | - | 2 | ms |
| $\mathrm{t}_{\text {S }}$ | Clock cycle frequency | 3.3 V LVCMOS | 24 | 100 | MHz |
| $\mathrm{t}_{\text {S }}$ | Clock cycle frequency | 1.8 V LVCMOS | 24 | 100 | MHz |
| $\mathrm{t}_{\mathrm{A}}$ | Data access time |  | - | 10 | ns |
| $\mathrm{t}_{\text {CLK }}$ | Clock cycle time |  | 10 | 41.67 | ns |
| t ${ }_{\text {CLKH }}$ | Clock high time |  | 4.5 | - | ns |
| $\mathrm{t}_{\text {CLKL }}$ | Clock low time |  | 4.5 | - | ns |
| $\mathrm{t}_{\mathrm{DS}}$ | Data setup time |  | 3 | - | ns |
| $\mathrm{t}_{\mathrm{DH}}$ | Data hold time |  | 3 | - | ns |
| $\mathrm{t}_{\text {QS }}$ | RQSEL0 and WQSEL0 setup time |  | 3 | - | ns |
| $\mathrm{t}_{\text {QH }}$ | RQSEL0 and WQSELO hold time |  | 3 | - | ns |
| $\mathrm{t}_{\text {ENS }}$ | Enable setup time |  | 3 | - | ns |
| $\mathrm{t}_{\text {ENH }}$ | Enable hold time |  | 3 | - | ns |
| tens_SI | Setup time for SPI_SI and SPI_SEN pin |  | 5 | - | ns |
| tenh_S | Hold time for SPI_SI and SPI_SEN pin |  | 5 | - | ns |
| tratE_SPI | Frequency of SPI_SCLK |  | - | 25 | MHz |
| $\mathrm{t}_{\text {RS }}$ | Reset pulse width |  | 100 | - | ns |
| $\mathrm{t}_{\text {PZS }}$ | Port size select to MRS setup time |  | 25 | - | ns |
| $\mathrm{t}_{\text {PZH }}$ | MRS to port size select hold time |  | 25 | - | ns |
| $\mathrm{t}_{\text {RSF }}$ | Reset to flag output time |  | - | 50 | ns |
| trRT | Retransmit pulse width |  | 5 | - | RCLK cycles |
| $\mathrm{t}_{\text {OLZ }}$ | Output enable to output in Low Z |  | 4 | 15 | ns |
| $\mathrm{t}_{\mathrm{OE}}$ | Output enable to output valid |  | - | 15 | ns |
| $\mathrm{t}_{\mathrm{OHz}}$ | Output enable to output in High Z |  | - | 15 | ns |
| $\mathrm{t}_{\text {WFF }}$ | Write clock to FF |  | - | 9 | ns |
| $\mathrm{t}_{\text {REF }}$ | Read clock to EF |  | - | 9 | ns |
| $\mathrm{t}_{\text {PLL }}$ | Time required to synchronize PLL |  | - | 1024 | cycles |
| trate_JTAG | JTAG TCK cycle time |  | 100 | - | ns |
| $\mathrm{t}_{\text {S_JTAG }}$ | Setup time for JTAG TMS, TDI |  | 8 | - | ns |
| $\mathrm{t}_{\text {H_JTAG }}$ | Hold time for JTAG TMS,TDI |  | 8 | - | ns |
| ${ }^{\text {t }}$ O_JTAG | JTAG TCK low to TDO valid |  | - | 20 | ns |

## Switching Waveforms

Figure 6. Write Cycle Timing


Figure 7. Read Cycle Timing


Figure 8. Reset Timing


Switching Waveforms (continued)
Figure 9. $\overline{\text { MRS }}$ to PORTSZ [2:0]


Figure 10. Flow-through mailbox Operation


Switching Waveforms (continued)
Figure 11. Configuration Register Write


Figure 12. Configuration Register Read


Figure 13. WQSEL to $\overline{\mathrm{FF}}$


Switching Waveforms (continued)
Figure 14. RQSELO to $\overline{E F}$


Figure 15. Write to Empty Flag De-assertion


Switching Waveforms (continued)
Figure 16. Read to Empty Flag Assertion


Figure 17. Full Flag Assertion


Switching Waveforms (continued)
Figure 18. Full Flag De-assertion


Figure 19. Switching between Queues - Write


Switching Waveforms (continued)
Figure 20. Switching between Queues - Read


Figure 21. Simultaneous Write \& Read QUE - 0


Switching Waveforms (continued)
Figure 22. Mark


Figure 23. Retransmit


## Ordering Information

| $\begin{aligned} & \text { Speed } \\ & \text { (MHz) } \end{aligned}$ | Ordering Code | Package Diagram | Package Type | Operating Range |
| :---: | :---: | :---: | :---: | :---: |
| 100 | CYF1018V33L-100BGXI | 51-85167 | 209-ball fine-pitch ball grid array (FBGA) ( $14 \times 22 \times 1.76 \mathrm{~mm}$ ) | Industrial |
|  | CYF1036V33L-100BGXI |  |  |  |
|  | CYF1072V33L-100BGXI |  |  |  |
|  | CYF1018V18L-100BGXI |  |  |  |
|  | CYF1036V18L-100BGXI |  |  |  |
|  | CYF1072V18L-100BGXI |  |  |  |

## Ordering Code Definitions



## Package Diagram

Figure 24. 209-ball FBGA ( $14 \times 22 \times 1.76 \mathrm{~mm}$ ) BB209A, $51-85167$


## Acronyms

| Acronym | Description |
| :--- | :--- |
| $\overline{\mathrm{EF}}$ | empty flag |
| $\overline{\mathrm{FF}}$ | full flag |
| FIFO | first in first out |
| I/O | input/output |
| FBGA | fine-pitch ball grid array |
| JTAG | joint test action group |
| LVCMOS | low voltage complementary metal oxide <br> semiconductor |
| MB | mailbox |
| $\overline{\text { MRS }}$ | master reset |
| $\overline{\text { OE }}$ | output enable |
| RCLK | read clock |
| $\overline{\text { REN }}$ | read enable |
| RQSELO | read queue select |
| SCLK | serial clock |
| TDI | test data in |
| TDO | test data out |
| TCK | test clock |
| TMS | test mode select |
| WCLK | write clock |
| WEN | write enable |
| WQSEL0 | write queue select |
| QUE-0 | queue number 0 |
| QUE-1 | queue number 1 |

## Document Conventions

## Units of Measure

| Symbol | Unit of Measure |
| :--- | :--- |
| ${ }^{\circ} \mathrm{C}$ | degree Celsius |
| MHz | megahertz |
| $\mu \mathrm{A}$ | microampere |
| mA | milliampere |
| mm | millimeter |
| ms | millisecond |
| ns | nanosecond |
| $\Omega$ | ohm |
| pF | picofarad |
| V | volt |
| W | watt |
|  |  |

## Document History Page

| Document Title: CYF1018V/CYF1036V/CYF1072V, 18/36/72-Mbit Programmable 2-Queue FIFOs <br> Document Number: 001-68321 |  |  |  |  |
| :---: | :---: | :---: | :---: | :--- |
| Rev. | ECN No. | Orig. of <br> Change | Submission <br> Date | Description of Change |
| ${ }^{* *}$ | 3209860 | SIVS | $03 / 30 / 2011$ | New data sheet |
| ${ }^{*} \mathrm{~A}$ | 3353401 | AJU | $08 / 26 / 2011$ | Updated Package Diagram. |
| *B | 3387127 | AJU | $09 / 28 / 2011$ | Updated Pin Diagram for CYF1XXXV (Added Note 1 and referred the same <br> note in DNU in ball U6). <br> Updated Multi-Queue Operation (Updated Table 4 (WCLK column in first row)). <br> Updated Recommended DC Operating Conditions (Added Note 2 and referred <br> the same note in Parameter column). <br> Updated Switching Waveforms (Removed the numbers in Figure 10, <br> Figure 14, Figure 16, and Figure 20). |

CYF1036V
CYF1072V

## Sales, Solutions, and Legal Information

## Worldwide Sales and Design Support

Cypress maintains a worldwide network of offices, solution centers, manufacturer's representatives, and distributors. To find the office closest to you, visit us at Cypress Locations.

## Products

| Automotive | cypress.com/go/automotive |
| :--- | ---: |
| Clocks \& Buffers | cypress.com/go/clocks <br> cypress.com/go/interface |
| Interface | cypress.com/go/powerpsoc <br> Lighting \& Power Control <br> cypress.com/go/plc |
| Memory | cypress.com/go/memory |
| Optical \& Image Sensing | cypress.com/go/image |
| PSoC | cypress.com/go/psoc |
| Touch Sensing | cypress.com/go/touch |
| USB Controllers | cypress.com/go/USB |
| Wireless/RF | cypress.com/go/wireless |




 application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges.



 the express written permission of Cypress.



 assumes all risk of such use and in doing so indemnifies Cypress against all charges.

Use may be limited by and subject to the applicable Cypress software license agreement.


[^0]:    Note
    2. Device operation guaranteed for a supply rate $>1 \mathrm{~V} / \mu \mathrm{s}$.

