# FLEx18™ 3.3V 64K/128K/256K/512K x 18 Synchronous Dual-Port RAM #### **Features** - True dual-ported memory cells that allow simultaneous access of the same memory location - Synchronous pipelined operation - Organization of 1 Mbit, 2 Mbits, 4 Mbits and 9 Mbits devices - · Pipelined output mode allows fast operation - 0.18-micron CMOS for optimum speed and power - High-speed clock to data access - · 3.3V low power - Active as low as 225 mA (typ) - Standby as low as 55 mA (typ) - Mailbox function for message passing - · Global master reset - · Separate byte enables on both ports - Commercial and industrial temperature ranges - IEEE 1149.1-compatible JTAG boundary scan - 256-ball FBGA (1 mm pitch) - Counter wrap-around control - Internal mask register controls counter wrap-around - Counter-interrupt flags to indicate wrap-around - Memory block retransmit operation - Counter readback on address lines - · Mask register readback on address lines - Dual Chip Enables on both ports for easy depth expansion - · Seamless migration to next-generation dual-port family ### **Functional Description** The FLEx18™ family includes 1-Mbit, 2-Mbit, 4-Mbit and 9-Mbit pipelined, synchronous, true dual-port static RAMs that are high-speed, low-power 3.3V CMOS. Two ports are provided, permitting independent, simultaneous access to any location in memory. The result of writing to the same location by more than one port at the same time is undefined. Registers on control, address, and data lines allow for minimal set-up and hold time. During a Read operation, data is registered for decreased cycle time. Each port contains a burst counter on the input address register. After externally loading the counter with the initial address, the counter will increment the address internally (more details to follow). The internal Write pulse width is independent of the duration of the R/W input signal. The internal Write pulse is self-timed to allow the shortest possible cycle times. A HIGH on CEO or LOW on CE1 for one clock cycle will power down the internal circuitry to reduce the static power consumption. One cycle with chip enables asserted is required to reactivate the outputs. Additional features include: readback of burst-counter internal address value on address lines, counter-mask registers to control the counter wrap-around, counter interrupt (CNTINT) flags, readback of mask register value on address lines, retransmit functionality, interrupt flags for message passing, JTAG for boundary scan, and asynchronous Master Reset (MRST). The CYD09S18V device in this family has limited features. Please see Address Counter and Mask Register Operations on page 5 for details. #### **Seamless Migration to Next Generation Dual Port Family** Cypress offers a migration path for all devices in this family to the next-generation devices in the Dual-Port family with a compatible footprint. Please contact Cypress Sales for more details. **Table 1. Product Selection Guide** | Density | 1 Mbit<br>(64K x 18) | 2 Mbit<br>(128K x 18) | 4 Mbit<br>(256K x 18) | 9 Mbit<br>(512K x 18) | |---------------------------------------|----------------------------|----------------------------|----------------------------|----------------------------| | Part Number | CYD01S18V | CYD02S18V | CYD04S18V | CYD09S18V | | Max. Speed (MHz) | 167 | 167 | 167 | 133 | | Max. Access Time – Clock to Data (ns) | 4.0 | 4.0 | 4.0 | 4.7 | | Typical operating current (mA) | 225 | 225 | 225 | 270 | | Package | 256FBGA<br>(17 mm x 17 mm) | 256FBGA<br>(17 mm x 17 mm) | 256FBGA<br>(17 mm x 17 mm) | 256FBGA<br>(17 mm x 17 mm) | #### Note: 1. CYD01S18V has 16 address bits, CYD02S18V has 17 address bits, CY04S18V has 18 address bits and CYD09S18V has 19 address bits. ## **Pin Configurations** # 256-ball BGA Top View CYD01S18V/CYD02S18V CYD04S18V/CYD09S18V | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | |---|-------------------------|-------------------------|---------------------------------|--------------------------------|--------------------------------|------------------------------|---------------------------|-------------------|-------------------|---------------------------|---------------------------|--------------------------------|-----------------------------|---------------------------------|-------------------------|-------------------------| | Α | NC | NC | NC | DQ17 <sub>L</sub> | DQ16 <sub>L</sub> | DQ13 <sub>L</sub> | DQ12 <sub>L</sub> | DQ9 <sub>L</sub> | DQ9 <sub>R</sub> | DQ12 <sub>R</sub> | DQ13 <sub>R</sub> | DQ16 <sub>R</sub> | DQ17 <sub>R</sub> | NC | NC | NC | | В | NC | NC | NC | NC | DQ15 <sub>L</sub> | DQ14 <sub>L</sub> | DQ11 <sub>L</sub> | DQ10 <sub>L</sub> | DQ10 <sub>R</sub> | DQ11 <sub>R</sub> | DQ14 <sub>R</sub> | DQ15 <sub>R</sub> | NC | NC | NC | NC | | С | NC | NC | RET <sub>L</sub> [2,3] | ĪNT <sub>L</sub> | NC<br>[2,5] | NC<br>[2,5] | REV <sub>L</sub><br>[2,4] | TRST<br>[2,5] | MRST | NC<br>[2,5] | NC<br>[2,5] | NC<br>[2,5] | <del>INT</del> <sub>R</sub> | RET <sub>R</sub> [2,3] | NC | NC | | D | A0 <sub>L</sub> | A1 <sub>L</sub> | WRP <sub>L</sub> [2,3] | VREF <sub>L</sub><br>[2,4] | FTSEL <sub>L</sub> [2,3] | LowSPD <sub>L</sub><br>[2,4] | VSS | VTTL | VTTL | VSS | LowSPD <sub>R</sub> [2,4] | FTSEL <sub>R</sub> [2,3] | VREF <sub>R</sub> [2,4] | WRP <sub>R</sub> [2,3] | A1 <sub>R</sub> | A0 <sub>R</sub> | | E | A2 <sub>L</sub> | A3 <sub>L</sub> | CE0 <sub>L</sub> [10] | CE1 <sub>L</sub> [9] | VDDIOL | VDDIOL | VDDIOL | VCORE | VCORE | VDDIO <sub>R</sub> | VDDIO <sub>R</sub> | VDDIO <sub>R</sub> | CE1 <sub>R</sub> [9] | CE0 <sub>R</sub> [10] | A3 <sub>R</sub> | A2 <sub>R</sub> | | F | A4 <sub>L</sub> | A5 <sub>L</sub> | CNTINT <sub>L</sub> [11] | NC | VDDIOL | VSS | VSS | VSS | VSS | VSS | VSS | VDDIO <sub>R</sub> | NC | CNTINT <sub>R</sub> [11] | A5 <sub>R</sub> | A4 <sub>R</sub> | | G | A6 <sub>L</sub> | A7 <sub>L</sub> | BUSY <sub>L</sub> [2,5] | NC | REV <sub>L</sub><br>[2,3] | VSS | VSS | VSS | VSS | VSS | VSS | VDDIO <sub>R</sub> | NC | BUSY <sub>R</sub> [2,5] | A7 <sub>R</sub> | A6 <sub>R</sub> | | н | A8 <sub>L</sub> | A9 <sub>L</sub> | C <sub>L</sub> | VTTL | VCORE | VSS | VSS | VSS | VSS | VSS | VSS | VCORE | VTTL | C <sub>R</sub> | A9 <sub>R</sub> | A8 <sub>R</sub> | | J | A10 <sub>L</sub> | A11 <sub>L</sub> | VSS | PortSTD1 <sub>L</sub><br>[2,4] | VCORE | VSS | VSS | VSS | VSS | VSS | VSS | VCORE | PortSTD1 <sub>R</sub> [2,4] | VSS | A11 <sub>R</sub> | A10 <sub>R</sub> | | κ | A12 <sub>L</sub> | A13 <sub>L</sub> | ŌĒL | BE1 <sub>L</sub> | VDDIOL | VSS | VSS | VSS | VSS | VSS | VSS | VDDIO <sub>R</sub> | BE1 <sub>R</sub> | ŌE <sub>R</sub> | A13 <sub>R</sub> | A12 <sub>R</sub> | | L | A14 <sub>L</sub> | A15 <sub>L</sub> | ADS <sub>L</sub> | BE0 <sub>L</sub> | VDDIOL | VSS | VSS | VSS | VSS | VSS | VSS | VDDIO <sub>R</sub> | BE0 <sub>R</sub> | ADS <sub>R</sub> | A15 <sub>R</sub> | A14 <sub>R</sub> | | М | A16 <sub>L</sub><br>[6] | A17 <sub>L</sub><br>[7] | $R\overline{W}_L$ | REV <sub>L</sub><br>[2,4] | VDDIOL | VDDIOL | VDDIOL | VCORE | VCORE | VDDIO <sub>R</sub> | VDDIO <sub>R</sub> | VDDIO <sub>R</sub> | REV <sub>R</sub><br>[2,4] | $R\overline{W}_R$ | A17 <sub>R</sub><br>[7] | A16 <sub>R</sub><br>[6] | | N | A18 <sub>L</sub><br>[8] | NC | CNT/<br>MSK <sub>L</sub><br>[9] | VREF <sub>L</sub><br>[2,4] | PortSTD0 <sub>L</sub><br>[2,4] | READY <sub>L</sub><br>[2,5] | REV <sub>L</sub><br>[2,3] | VTTL | VTTL | REV <sub>R</sub><br>[2,3] | READY <sub>R</sub> [2,5] | PortSTD0 <sub>R</sub><br>[2,4] | VREF <sub>R</sub> [2,4] | CNT/<br>MSK <sub>R</sub><br>[9] | NC | A18 <sub>R</sub><br>[8] | | Р | NC | NC | CNTEN <sub>L</sub><br>[10] | CNTRST <sub>L</sub><br>[9] | NC<br>[2,5] | NC<br>[2,5] | TCK | TMS | TDO | TDI | NC<br>[2,5] | NC<br>[2,5] | CNTRST <sub>R</sub> [9] | CNTEN <sub>R</sub> [10] | NC | NC | | R | NC | NC | NC | NC | DQ6 <sub>L</sub> | DQ5 <sub>L</sub> | DQ2 <sub>L</sub> | DQ1 <sub>L</sub> | DQ1 <sub>R</sub> | DQ2 <sub>R</sub> | DQ5 <sub>R</sub> | DQ6 <sub>R</sub> | NC | NC | NC | NC | | Т | NC | NC | NC | DQ8 <sub>L</sub> | DQ7 <sub>L</sub> | DQ4 <sub>L</sub> | DQ3 <sub>L</sub> | DQ0 <sub>L</sub> | DQ0 <sub>R</sub> | DQ3 <sub>R</sub> | DQ4 <sub>R</sub> | DQ7 <sub>R</sub> | DQ8 <sub>R</sub> | NC | NC | NC | - 2. This ball will represent a next generation FLEx18-E Dual-Port feature. For more information about this feature, contact Cypress Sales. - 3. Connect this ball to VDDIO. For more information about this next generation FLEx18-E Dual-Port feature contact Cypress Sales. - 4. Connect this ball to VSS. For more information about this next generation FLEx18-E Dual-Port feature, contact Cypress Sales. - 5. Leave this ball unconnected. For more information about this feature, contact Cypress Sales. - 6. Leave this ball unconnected for a 64K x 18. - Leave this ball unconnected for a 128K x 18 and 64K x 18. Leave this ball unconnected for a 256K x 18, 128K x 18 and 64K x 18. These balls are not applicable for CYD09S18V device. They need to be tied to VDDIO. These balls are not applicable for CYD09S18V device. They need to be tied to VSS. These balls are not applicable for CYD09S18V device. They need to be no connected. ## **Pin Definitions** | Left Port | Right Port | Description | | | | | |--------------------------------------------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | A <sub>0L</sub> -A <sub>18L</sub> | A <sub>0R</sub> -A <sub>18R</sub> | Address Inputs. | | | | | | BE <sub>0L</sub> -BE <sub>1L</sub> | BE <sub>0R</sub> –BE <sub>1R</sub> | <b>Byte Enable Inputs</b> . Asserting these signals enables Read and Write operations to the corresponding bytes of the memory array. | | | | | | BUSY <sub>L</sub> [2,5] | BUSY <sub>R</sub> <sup>[2,5]</sup> | Port Busy Output. When the collision is detected, a BUSY is asserted. | | | | | | C <sub>L</sub> | C <sub>R</sub> | Input Clock Signal. | | | | | | CE0 <sub>L</sub> [10] | CE0 <sub>R</sub> <sup>[10]</sup> | Active Low Chip Enable Input. | | | | | | CE1 <sub>L</sub> <sup>[9]</sup> | CE1 <sub>R</sub> <sup>[9]</sup> | Active High Chip Enable Input. | | | | | | DQ <sub>0L</sub> -DQ <sub>17L</sub> | DQ <sub>0R</sub> -DQ <sub>17R</sub> | Data Bus Input/Output. | | | | | | ŌE <sub>L</sub> | <del>OE</del> <sub>R</sub> | Output Enable Input. This asynchronous signal must be asserted LOW to enable the DQ data pins during Read operations. | | | | | | ĪNT <sub>L</sub> | ĪNT <sub>R</sub> | <b>Mailbox Interrupt Flag Output</b> . The mailbox permits communications between ports. The upper two memory locations can be used for message passing. $INT_L$ is asserted LOW when the right port writes to the mailbox location of the left port, and vice versa. An interrupt to a port is deasserted HIGH when it reads the contents of its mailbox. | | | | | | LowSPD <sub>L</sub> <sup>[2,4]</sup> | LowSPD <sub>R</sub> <sup>[2,4]</sup> | <b>Port Low Speed Select Input</b> . When operating at less than 100 MHz, the LowSPD disables the port DLL. | | | | | | PORTSTD[1:0] <sub>L</sub> <sup>[2,4]</sup> | PORTSTD[1:0] <sub>R</sub> <sup>[2,4]</sup> | Port Address/Control/Data I/O Standard Select Input. | | | | | | R/W <sub>L</sub> | R/W <sub>R</sub> | <b>Read/Write Enable Input</b> . Assert this pin LOW to write to, or HIGH to read from the dual-port memory array. | | | | | | READY <sub>L</sub> <sup>[2,5]</sup> | READY <sub>R</sub> <sup>[2,5]</sup> | <b>Port Ready Output</b> . This signal will be asserted when a port is ready for normal operation. | | | | | | CNT/MSK <sub>L</sub> [9] | CNT/MSK <sub>R</sub> <sup>[9]</sup> | Port Counter/Mask Select Input. Counter control input. | | | | | | ADS <sub>L</sub> <sup>[10]</sup> | ADS <sub>R</sub> <sup>[10]</sup> | Port Counter Address Load Strobe Input. Counter control input. | | | | | | CNTEN <sub>L</sub> <sup>[10]</sup> | CNTEN <sub>R</sub> <sup>[10]</sup> | Port Counter Enable Input. Counter control input. | | | | | | CNTRST <sub>L</sub> <sup>[9]</sup> | CNTRST <sub>R</sub> <sup>[9]</sup> | Port Counter Reset Input. Counter control input. | | | | | | CNTINT <sub>L</sub> <sup>[11]</sup> | CNTINT <sub>R</sub> <sup>[11]</sup> | <b>Port Counter Interrupt Output</b> . This pin is asserted LOW when the unmasked portion of the counter is incremented to all "1s". | | | | | | WRP <sub>L</sub> <sup>[2,3]</sup> | WRP <sub>R</sub> <sup>[2,3]</sup> | <b>Port Counter Wrap Input</b> . After the burst counter reaches the maximum count, if WRP is low, the unmasked counter bits will be set to 0. If high, the counter will be loaded with the value stored in the mirror register. | | | | | | RET <sub>L</sub> [2,3] | RET <sub>R</sub> <sup>[2,3]</sup> | Port Counter Retransmit Input. Counter control input. | | | | | | FTSEL <sub>L</sub> [2,3] | FTSEL <sub>R</sub> <sup>[2,3]</sup> | Flow-Through Mode Select Input. | | | | | | VREF <sub>L</sub> <sup>[2,4]</sup> | VREF <sub>R</sub> <sup>[2,4]</sup> | Port External High-Speed IO Reference Input. | | | | | | VDDIO <sub>L</sub> | VDDIO <sub>R</sub> | Port IO Power Supply. | | | | | | $REV_{L[2,4]}$ | $REV_{R[2,4]}$ | Reserved pins for future features. | | | | | | MF | RST | Master Reset Input. MRST is an asynchronous input signal and affects both ports. A master reset operation is required at power-up. | | | | | | TRS | T <sup>[2,5]</sup> | JTAG Reset Input. | | | | | | TN | <b>MS</b> | <b>JTAG Test Mode Select Input</b> . It controls the advance of JTAG TAP state machine. State machine transitions occur on the rising edge of TCK. | | | | | | T | DI | JTAG Test Data Input. Data on the TDI input will be shifted serially into selected registers. | | | | | | ТС | CK | JTAG Test Clock Input. | | | | | | TE | 00 | JTAG Test Data Output. TDO transitions occur on the falling edge of TCK. TDO is normally three-stated except when captured data is shifted out of the JTAG TAP. | | | | | ### Pin Definitions (continued) | Left Port | Right Port | Description | | | | | | |-----------------|------------|---------------------|--|--|--|--|--| | | 'ss | Ground Inputs. | | | | | | | V <sub>CO</sub> | [12]<br>RE | Core Power Supply. | | | | | | | V | TTL | LVTTL Power Supply. | | | | | | #### Master Reset The FLEx18 family devices undergo a complete reset by taking its MRST input LOW. The MRST input can switch asynchronously to the clocks. The MRST initializes the internal burst counters to zero, and the counter mask registers to all ones (completely unmasked). The MRST also forces the Mailbox Interrupt (INT) flags and the Counter Interrupt (CNTINT) flags HIGH. The MRST must be performed on the FLEx18 family devices after power-up. #### Mailbox Interrupts The upper two memory locations may be used for message passing and permit communications between ports. Table shows the interrupt operation for both ports of CYD09S18V. The highest memory location, 7FFFF is the mailbox for the right port and 7FFFE is the mailbox for the left port. Table shows that in order to set the $\overline{INT}_R$ flag, a Write operation by the left port to address 7FFFF will assert $\overline{\text{INT}}_{R}$ LOW. At least one byte has to be active for a Write to generate an interrupt. A valid Read of the 7FFFF location by the right port will reset INT<sub>R</sub> HIGH. At least one byte has to be active in order for a Read to reset the interrupt. When one port Writes to the other port's mailbox, the INT of the port that the mailbox belongs to is asserted LOW. The INT is reset when the owner (port) of the mailbox Reads the contents of the mailbox. The interrupt flag is set in a flow-thru mode (i.e., it follows the clock edge of the writing port). Also, the flag is reset in a flow-thru mode (i.e., it follows the clock edge of the reading port). Each port can read the other port's mailbox without resetting the interrupt. And each port can write to its own mailbox without setting the interrupt. If an application does not require message passing, INT pins should be left open. ## **Address Counter and Mask Register Operations** This section describes the features only apply to 1-Mbit, 2-Mbit, and 4-Mbit devices. It does not apply to a 9-Mbit device. Each port of these devices has a programmable burst address counter. The burst counter contains three registers: a counter register, a mask register, and a mirror register. [17] The **counter register** contains the address used to access the RAM array. It is changed only by the Counter Load, Increment, Counter Reset, and by master reset (MRST) operations. The mask register value affects the Increment and Counter Reset operations by preventing the corresponding bits of the counter register from changing. It also affects the counter interrupt output (CNTINT). The mask register is changed only by the Mask Load and Mask Reset operations, and by the MRST. The mask register defines the counting range of the counter register. It divides the counter register into two regions: zero or more "0s" in the most significant bits define the masked region, one or more "1s" in the least significant bits define the unmasked region. Bit 0 may also be "0," masking the least significant counter bit and causing the counter to increment by two instead of one. The mirror register is used to reload the counter register on increment operations (see "retransmit," below). It always contains the value last loaded into the counter register, and is changed only by the Counter Load, and Counter Reset operations, and by the MRST. Table 3 summarizes the operation of these registers and the required input control signals. The MRST control signal is asynchronous. All the other control signals in Table 3 (CNT/MSK, CNTRST, ADS, CNTEN) are synchronized to the port's CLK. All these counter and mask operations are independent of the port's chip enable inputs (CE0 and CE1). Table 2. Interrupt Operation Example [1, 13, 14, 15, 16] | | | Left Port | | | | | Right Port | | | | | | |-----------------------------------|------------------|-----------|---------------------|------------------|------------------|-----|---------------------|------------------|--|--|--|--| | Function | R/W <sub>L</sub> | CEL | A <sub>0L-18L</sub> | INT <sub>L</sub> | R/W <sub>R</sub> | CER | A <sub>0R-18R</sub> | INT <sub>R</sub> | | | | | | Set Right INT <sub>R</sub> Flag | L | L | 7FFFF | Х | Х | Х | Х | L | | | | | | Reset Right INT <sub>R</sub> Flag | Х | Х | Х | Х | Н | L | 7FFFF | Н | | | | | | Set Left INT <sub>L</sub> Flag | Х | Х | Х | L | L | L | 7FFFE | Х | | | | | | Reset Left INT <sub>L</sub> Flag | Н | L | 7FFFE | Н | Х | Х | X | Х | | | | | #### Notes: - 12. This family of Dual-Ports does not use V<sub>CORE</sub>, and these pins are internally NC. The next generation Dual-Port family, the FLEx18-E™, will use V<sub>CORE</sub> of 1.5V or 1.8V. Please contact local Cypress FAE for more information. 13. CE is internal signal. CE = LOW if CE<sub>0</sub> = LOW and CE<sub>1</sub> = HIGH. For a single Read operation, CE only needs to be asserted once at the rising edge of the CLK and can be deasserted after that. Data will be out after the following CLK edge and will be three-stated after the next CLK edge. - 14. OE is "Don't Care" for mailbox operation. - 15. At least one of BEO, BE1 must be LOW. - 16. A18x is a NC for CYD04S18V, therefore the Interrupt Addresses are 3FFFF and 3FFFE. A18x and A17x are NC for CYD02S18V, therefore the Interrupt addresses are 1FFFF and 1FFFE; A18x, A17x and A16x are NC for CYD01S18V, therefore the Interrupt Addresses are FFFF and FFFÉ. - 17. This section describes the CYD04S18V, CYD02S18V, CYD01S18V 18, 17, and 16 address bits. Table 3. Address Counter and Counter-Mask Register Control Operation (Any Port) [18, 19] | CLK | MRST | CNT/MSK | CNTRST | ADS | CNTEN | Operation | Description | |-----|------|---------|--------|-----|-------|-------------------|----------------------------------------------------------------------| | Х | L | Х | Χ | Х | Х | Master Reset | Reset address counter to all 0s and mask register to all 1s. | | | Н | Н | L | X | Х | Counter Reset | Reset counter unmasked portion to all 0s. | | | Η | Н | Н | L | L | Counter Load | Load counter with external address value presented on address lines. | | | Н | Н | Н | L | Н | Counter Readback | Read out counter internal value on address lines. | | | Н | Н | Н | Н | L | Counter Increment | Internally increment address counter value. | | | Η | Н | Н | Н | Н | Counter Hold | Constantly hold the address value for multiple clock cycles. | | | Н | L | L | Х | Х | Mask Reset | Reset mask register to all 1s. | | | Н | L | Н | L | L | Mask Load | Load mask register with value presented on the address lines. | | | Н | L | Н | L | Н | Mask Readback | Read out mask register value on address lines. | | | Н | L | Н | Н | Х | Reserved | Operation undefined | Counter enable (CNTEN) inputs are provided to stall the operation of the address input and utilize the internal address generated by the internal counter for fast, interleaved memory applications. A port's burst counter is loaded when the port's address strobe (ADS) and CNTEN signals are LOW. When the port's CNTEN is asserted and the ADS is deasserted, the address counter will increment on each LOW to HIGH transition of that port's clock signal. This will Read/Write one word from/into each successive address location until CNTEN is deasserted. The counter can address the entire memory array, and will loop back to the start. Counter reset (CNTRST) is used to reset the unmasked portion of the burst counter to 0s. A counter-mask register is used to control the counter wrap. #### **Counter Reset Operation** All unmasked bits of the counter and mirror registers are reset to "0." All masked bits remain unchanged. A Mask Reset followed by a Counter Reset will reset the counter and mirror registers to 00000, as will master reset (MRST). #### **Counter Load Operation** The address counter and mirror registers are both loaded with the address value presented at the address lines. ## **Counter Increment Operation** Once the address counter register is initially loaded with an external address, the counter can internally increment the address value, potentially addressing the entire memory array. Only the unmasked bits of the counter register are incremented. The corresponding bit in the mask register must be a "1" for a counter bit to change. The counter register is incremented by 1 if the least significant bit is unmasked, and by 2 if it is masked. If all unmasked bits are "1," the next increment will wrap the counter back to the initially loaded value. If an Increment results in all the unmasked bits of the counter being "1s," a counter interrupt flag (CNTINT) is asserted. The next Increment will return the counter register to its initial value, which was stored in the mirror register. The counter address can instead be forced to loop to 00000 by externally connecting CNTINT to CNTRST. [20] An increment that results in one or more of the unmasked bits of the counter being "0" will deassert the counter interrupt flag. The example in Figure 2 shows the counter mask register loaded with a mask value of 0003Fh unmasking the first 6 bits with bit "0" as the LSB and bit "16" as the MSB. The maximum value the mask register can be loaded with is 3FFFFh. Setting the mask register to this value allows the counter to access the entire memory space. The address counter is then loaded with an initial value of 8h. The base address bits (in this case, the 6th address through the 16th address) are loaded with an address value but do not increment once the counter is configured for increment operation. The counter address will start at address 8h. The counter will increment its internal address value till it reaches the mask register value of 3Fh. The counter wraps around the memory block to location 8h at the next count. CNTINT is issued when the counter reaches its maximum value. #### **Counter Hold Operation** The value of all three registers can be constantly maintained unchanged for an unlimited number of clock cycles. Such operation is useful in applications where wait states are needed, or when address is available a few cycles ahead of data in a shared bus interface. - 18. "X" = "Don't Care," "H" = HIGH, "L" = LOW. - 19. Counter operation and mask register operation is independent of chip enables. - 20. CNTINT and CNTRST specs are guaranteed by design to operate properly at speed grade operating frequency when tied together. #### **Counter Interrupt** The counter interrupt (CNTINT) is asserted LOW when an increment operation results in the unmasked portion of the counter register being all "1s." It is deasserted HIGH when an Increment operation results in any other value. It is also deasserted by Counter Reset, Counter Load, Mask Reset and Mask Load operations, and by MRST. #### **Counter Readback Operation** The internal value of the counter register can be read out on the address lines. Readback is pipelined; the address will be valid $t_{CA2}$ after the next rising edge of the port's clock. If address readback occurs while the port is enabled (CE0 LOW and CE1 HIGH), the data lines (DQs) will be three-stated. Figure 1 shows a block diagram of the operation. #### Retransmit Retransmit is a feature that allows the Read of a block of memory more than once without the need to reload the initial address. This eliminates the need for external logic to store and route data. It also reduces the complexity of the system design and saves board space. An internal "mirror register" is used to store the initially loaded address counter value. When the counter unmasked portion reaches its maximum value set by the mask register, it wraps back to the initial value stored in this "mirror register." If the counter is continuously configured in increment mode, it increments again to its maximum value and wraps back to the value initially stored into the "mirror register." Thus, the repeated access of the same data is allowed without the need for any external logic. #### **Mask Reset Operation** The mask register is reset to all "1s," which unmasks every bit of the counter. Master reset (MRST) also resets the mask register to all "1s." #### **Mask Load Operation** The mask register is loaded with the address value presented at the address lines. Not all values permit correct increment operations. Permitted values are of the form $2^n - 1$ or $2^n - 2$ . From the most significant bit to the least significant bit, permitted values have zero or more "0s," one or more "1s," or one "0." Thus 3FFFF, 003FE, and 00001 are permitted values, but 3F0FF, 003FC, and 00000 are not. #### Mask Readback Operation The internal value of the mask register can be read out on the address lines. Readback is pipelined; the address will be valid $t_{CM2}$ after the next rising edge of the port's clock. If mask readback occurs while the port is enabled (CE0 LOW and CE1 HIGH), the data lines (DQs) will be three-stated. Figure 1 shows a block diagram of the operation. #### Counting by Two When the least significant bit of the mask register is "0," the counter increments by two. This may be used to connect the x18 devices as a 36-bit single port SRAM in which the counter of one port counts even addresses and the counter of the other port counts odd addresses. This even-odd address scheme stores one half of the 36-bit data in even memory locations, and the other half in odd memory locations. Figure 1. Counter, Mask, and Mirror Logic Block Diagram<sup>[1]</sup> Figure 2. Programmable Counter-Mask Register Operation<sup>[1, 21]</sup> ## IEEE 1149.1 Serial Boundary Scan (JTAG)[22] The FLEx18 family devices incorporate an IEEE 1149.1 serial boundary scan test access port (TAP). The TAP controller functions in a manner that does not conflict with the operation of other devices using 1149.1-compliant TAPs. The TAP operates using JEDEC-standard 3.3V I/O logic levels. It is composed of three input connections and one output connection required by the test logic defined by the standard. ### **Performing a TAP Reset** A reset is performed by forcing TMS HIGH ( $V_{DD}$ ) for five rising edges of TCK. This reset does not affect the operation of the devices, and may be performed while the device is operating. An $\overline{MRST}$ must be performed on the devices after power-up. #### Performing a Pause/Restart When a SHIFT-DR PAUSE-DR SHIFT-DR is performed the scan chain will output the next bit in the chain twice. For example, if the value expected from the chain is 1010101, the device will output a 11010101. This extra bit will cause some testers to report an erroneous failure for the devices in a scan test. Therefore the tester should be configured to never enter the PAUSE-DR state. #### **Boundary Scan Hierarchy for 9-Mbit Device** Internally, the CYD09S18V have two DIEs. Each DIE contains all the circuitry required to support boundary scan testing. The circuitry includes the TAP, TAP controller, instruction register, and data registers. The circuity and operation of the DIE boundary scan are described in detail below. The scan chain of each DIEs are connected serially to form the scan chain of the CYD09S18V as shown in *Figure 3*. TMS and TCK are connected in parallel to each DIE to drive all TAP controllers in unison. In many cases, each DIE will be supplied with the same instruction. In other cases, it might be useful to supply different instructions to each DIE. One example would be testing the device ID of one DIE while bypassing the others. Each pin of the FLEx18 9-Mb device is typically connected to two DIEs. For connectivity testing with the EXTEST instruction, it is desirable to check the internal connections between DIEs as well as the external connections to the package. This can be accomplished by merging the netlist of the devices with the netlist of the user's circuit board. To facilitate boundary scan testing of the devices, Cypress provides the BSDL file for each DIE, the internal netlist of the device, and a description of the device scan chain. The user can use these materials to easily integrate the devices into the board's boundary scan environment. Further information can be found in the Cypress application note *Using JTAG Boundary Scan For System In a Package (SIP) Dual-Port SRAMs*. #### Notes: - 21. The "X" in this diagram represents the counter upper bits. - 22. Boundary scan is IEEE 1149.1-compatible. See "Performing a Pause/Restart" for deviation from strict 1149.1 compliance. Figure 3. Scan Chain for 9-Mbit Device **Table 4. Identification Register Definitions** | Instruction Field | Value | Description | |---------------------------|-------------------------------------------|--------------------------------------------------------------| | Revision Number (31:28) | 0h | Reserved for version number. | | Cypress Device ID (27:12) | C090h | Defines Cypress part number for CYD04S18V and CYD09S18V DIE | | | Defines Cypress part number for CYD02S18V | | | | C093h | Defines Cypress part number for CYD01S18V | | Cypress JEDEC ID (11:1) | 034h | Allows unique identification of the DP family device vendor. | | ID Register Presence (0) | 1 | Indicates the presence of an ID register. | Table 5. Scan Register Sizes | Register Name | Bit Size | |----------------|-------------------| | Instruction | 4 | | Bypass | 1 | | Identification | 32 | | Boundary Scan | n <sup>[23]</sup> | **Table 6. Instruction Identification Codes** | Instruction | Code | Description | |----------------|-----------------|-------------------------------------------------------------------------------------| | EXTEST | 0000 | Captures the Input/Output ring contents. Places the BSR between the TDI and TDO. | | BYPASS | 1111 | Places the BYR between TDI and TDO. | | IDCODE | 1011 | Loads the IDR with the vendor ID code and places the register between TDI and TDO. | | HIGHZ | 0111 | Places BYR between TDI and TDO. Forces all device output drivers to a High-Z state. | | CLAMP | 0100 | Controls boundary to 1/0. Places BYR between TDI and TDO. | | SAMPLE/PRELOAD | 1000 | Captures the input/output ring contents. Places BSR between TDI and TDO. | | NBSRST | 1100 | Resets the non-boundary scan logic. Places BYR between TDI and TDO. | | RESERVED | All other codes | Other combinations are reserved. Do not use other than the above. | #### Note: 23. See details in the device BSDL file. ## Maximum Ratings<sup>[24]</sup> (Above which the useful life may be impaired. For user guidelines, not tested.) Storage Temperature ...... -65°C to +150°C Ambient Temperature with Power Applied......-55°C to +125°C Supply Voltage to Ground Potential ..... -0.5V to +4.6V DC Voltage Applied to Outputs in High-Z State.....-0.5V to V<sub>DD</sub> +0.5V DC Input Voltage.....-0.5V to V<sub>DD</sub> + 0.5V<sup>[25]</sup> | Output Current into Outputs (LOW) | 20 mA | |-----------------------------------|---------| | Static Discharge Voltage | > 2000V | | (JEDEC JESD22-A114-2000B) | | | Latch-up Current> | 200 mA | ## **Operating Range** | Range | Ambient<br>Temperature | V <sub>DDIO/VTTL</sub> | V <sub>CORE</sub> <sup>[12]</sup> | |------------|------------------------|------------------------|-----------------------------------| | Commercial | 0°C to +70°C | 3.3V±165 mV | 1.8V±100 mV | | Industrial | –40°C to +85°C | 3.3V±165 mV | 1.8V±100 mV | ## **Electrical Characteristics** Over the Operating Range | | | | | -167 | | | -133 | | -100 | | | | |-----------------------------------|-----------------------------------------------------------------------------------------------------|-------------------------------------|------|------|------|------|------|------|------|------|------|------| | Parameter | Description | | Min. | Тур. | Max. | Min. | Тур. | Max. | Min. | Тур. | Max. | Unit | | V <sub>OH</sub> | Output HIGH Voltage (V <sub>DD</sub> = Min., I <sub>0</sub> | <sub>OH</sub> = -4.0 mA) | 2.4 | | | 2.4 | | | 2.4 | | | V | | V <sub>OL</sub> | Output LOW Voltage (V <sub>DD</sub> = Min., I <sub>d</sub> | <sub>OL</sub> = +4.0 mA) | | | 0.4 | | | 0.4 | | | 0.4 | V | | V <sub>IH</sub> | Input HIGH Voltage | | 2.0 | | | 2.0 | | | 2.0 | | | V | | V <sub>IL</sub> | Input LOW Voltage | | | | 0.8 | | | 0.8 | | | 0.8 | V | | I <sub>OZ</sub> | Output Leakage Current | | -10 | | 10 | -10 | | 10 | -10 | | 10 | μА | | I <sub>IX1</sub> | Input Leakage Current Except TDI, | , TMS, MRST | -10 | | 10 | -10 | | 10 | -10 | | 10 | μА | | I <sub>IX2</sub> | Input Leakage Current TDI, TMS, | MRST | -1.0 | | 0.1 | -1.0 | | 0.1 | -1.0 | | 0.1 | mA | | Icc | $(V_{DD} = Max., I_{OUT} = 0 mA),$ | CYD01S18V<br>CYD02S18V<br>CYD04S18V | | 225 | 300 | | 225 | 300 | | | | mA | | | | CYD09S18V | | | | | 270 | 400 | | 200 | 310 | mA | | I <sub>SB1</sub> <sup>[26]</sup> | Standby Current (Both Ports TTL L<br>$CE_L$ and $CE_R \ge V_{IH}$ , $f = f_{MAX}$ | _evel) | | 90 | 115 | | 90 | 115 | | | | mA | | I <sub>SB2</sub> <sup>[26]</sup> | Standby Current (One Port TTL Le $CE_L \mid CE_R \ge V_{IH}$ , $f = f_{MAX}$ | evel) | | 160 | 210 | | 160 | 210 | | | | mA | | I <sub>SB3</sub> <sup>[26]</sup> | Standby Current (Both Ports CMO $\overline{CE}_L$ and $\overline{CE}_R \ge V_{DD} - 0.2V$ , $f = 0$ | S Level) | | 55 | 75 | | 55 | 75 | | | | mA | | I <sub>SB4</sub> <sup>[26]</sup> | Standby Current (One Port CMOS Level) $CE_L \mid CE_R \ge V_{IH}, f = f_{MAX}$ | | | 160 | 210 | | 160 | 210 | | | | mA | | I <sub>SB5</sub> | Operating Current (VDDIO = Max, lout=0mA,f=0) Outputs Disabled | CYD09S18V | | | | | | 75 | | | 75 | mA | | I <sub>CORE</sub> <sup>[12]</sup> | Core Operating Current for $(V_{DD} = I_{OUT} = 0 \text{ mA})$ , Outputs Disabled | : Max., | | 0 | 0 | | 0 | 0 | | 0 | 0 | mA | ## Capacitance<sup>[27]</sup> | Part Number | Parameter | Description | Test Conditions | Max. | Unit | |------------------------|------------------|--------------------|-----------------------------|------|------| | CYD01S18V | C <sub>IN</sub> | Input Capacitance | $T_A = 25$ °C, $f = 1$ MHz, | 13 | pF | | CYD02S18V<br>CYD04S18V | C <sub>OUT</sub> | Output Capacitance | $V_{DD} = 3.3V$ | 10 | pF | | CYD09S18V | C <sub>IN</sub> | Input Capacitance | | 22 | pF | | | C <sub>OUT</sub> | Output Capacitance | 7 | 20 | pF | #### Notes: 24. The voltage on any input or I/O pin can not exceed the power pin during power-up. 25. Pulse width < 20 ns. 26. $I_{SB1}$ , $I_{SB2}$ , $I_{SB3}$ and $I_{SB4}$ are not applicable for CYD09S18V because it can not be powered down by using chip enable pins. 27. $C_{OUT}$ also references $C_{I/O}$ ## **AC Test Load and Waveforms** (a) Normal Load (Load 1) (b) Three-state Delay (Load 2) # Switching Characteristics Over the Operating Range | | | -1 | -167 | | | -133 | | | -100 | | | |--------------------------------|-----------------------------|------|-------------------------------------|------|-------------------------|-----------|------|-----------|------|------|--| | | | CYD0 | CYD01S18V<br>CYD02S18V<br>CYD04S18V | | 1S18V<br>2S18V<br>4S18V | CYD09S18V | | CYD09S18V | | | | | Parameter | Description | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | | f <sub>MAX2</sub> | Maximum Operating Frequency | | 167 | | 133 | | 133 | | 100 | MHz | | | t <sub>CYC2</sub> | Clock Cycle Time | 6.0 | | 7.5 | | 7.5 | | 10 | | ns | | | t <sub>CH2</sub> | Clock HIGH Time | 2.7 | | 3.0 | | 3.0 | | 4.0 | | ns | | | t <sub>CL2</sub> | Clock LOW Time | 2.7 | | 3.0 | | 3.0 | | 4.0 | | ns | | | t <sub>R</sub> <sup>[28]</sup> | Clock Rise Time | | 2.0 | | 2.0 | | 2.0 | | 3.0 | ns | | | t <sub>F</sub> <sup>[28]</sup> | Clock Fall Time | | 2.0 | | 2.0 | | 2.0 | | 3.0 | ns | | | t <sub>SA</sub> | Address Set-up Time | 2.3 | | 2.5 | | 2.5 | | 3.0 | | ns | | | t <sub>HA</sub> | Address Hold Time | 0.6 | | 0.6 | | 0.6 | | 0.6 | | ns | | | t <sub>SB</sub> | Byte Select Set-up Time | 2.3 | | 2.5 | | 2.5 | | 3.0 | | ns | | | t <sub>HB</sub> | Byte Select Hold Time | 0.6 | | 0.6 | | 0.6 | | 0.6 | | ns | | | t <sub>SC</sub> | Chip Enable Set-up Time | 2.3 | | 2.5 | | NA | | NA | | ns | | | t <sub>HC</sub> | Chip Enable Hold Time | 0.6 | | 0.6 | | NA | | NA | | ns | | | t <sub>SW</sub> | R/W Set-up Time | 2.3 | | 2.5 | | 2.5 | | 3.0 | | ns | | | t <sub>HW</sub> | R/W Hold Time | 0.6 | | 0.6 | | 0.6 | | 0.6 | | ns | | | t <sub>SD</sub> | Input Data Set-up Time | 2.3 | | 2.5 | | 2.5 | | 3.0 | | ns | | | t <sub>HD</sub> | Input Data Hold Time | 0.6 | | 0.6 | | 0.6 | | 0.6 | | ns | | | t <sub>SAD</sub> | ADS Set-up Time | 2.3 | | 2.5 | | NA | | NA | | ns | | | t <sub>HAD</sub> | ADS Hold Time | 0.6 | | 0.6 | | NA | | NA | | ns | | | t <sub>SCN</sub> | CNTEN Set-up Time | 2.3 | | 2.5 | | NA | | NA | | ns | | | t <sub>HCN</sub> | CNTEN Hold Time | 0.6 | | 0.6 | | NA | | NA | | ns | | | t <sub>SRST</sub> | CNTRST Set-up Time | 2.3 | | 2.5 | | NA | | NA | | ns | | | t <sub>HRST</sub> | CNTRST Hold Time | 0.6 | | 0.6 | | NA | | NA | | ns | | | t <sub>SCM</sub> | CNT/MSK Set-up Time | 2.3 | | 2.5 | | NA | | NA | | ns | | | t <sub>HCM</sub> | CNT/MSK Hold Time | 0.6 | | 0.6 | | NA | | NA | | ns | | | t <sub>OE</sub> | Output Enable to Data Valid | | 4.0 | | 4.4 | | 4.7 | | 5.0 | ns | | | t <sub>OLZ</sub> [29, 30] | OE to Low Z | 0 | | 0 | | 0 | | 0 | | ns | | <sup>29.</sup> This parameter is guaranteed by design, but it is not production tested. <sup>30.</sup> Test conditions used are Load 2. ## **Switching Characteristics** Over the Operating Range (continued) | | | -1 | 67 | | -13 | 33 | | -1 | | | | |---------------------------------------|------------------------------------------------------------------|-------------------------------------|------|-------------------------------------|------|-----------|------|-----------|------|--------|--| | | | CYD01S18V<br>CYD02S18V<br>CYD04S18V | | CYD01S18V<br>CYD02S18V<br>CYD04S18V | | CYD09S18V | | CYD09S18V | | | | | Parameter | Description | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | | t <sub>OHZ</sub> [29, 30] | OE to High Z | 0 | 4.0 | 0 | 4.4 | 0 | 4.7 | 0 | 5.0 | ns | | | t <sub>CD2</sub> | Clock to Data Valid | | 4.0 | | 4.4 | | 4.7 | | 5.0 | ns | | | t <sub>CA2</sub> | Clock to Counter Address Valid | | 4.0 | | 4.4 | | NA | | NA | ns | | | t <sub>CM2</sub> | Clock to Mask Register Readback<br>Valid | | 4.0 | | 4.4 | | NA | | NA | ns | | | t <sub>DC</sub> | Data Output Hold After Clock HIGH | 1.0 | | 1.0 | | 1.0 | | 1.0 | | ns | | | t <sub>CKHZ</sub> [29,30] | Clock HIGH to Output High Z | 0 | 4.0 | 0 | 4.4 | 0 | 4.7 | 0 | 5.0 | ns | | | t <sub>CKLZ</sub> <sup>[29, 30]</sup> | Clock HIGH to Output Low Z | 1.0 | 4.0 | 1.0 | 4.4 | 1.0 | 4.7 | 1.0 | 5.0 | ns | | | t <sub>SINT</sub> | Clock to INT Set Time | 0.5 | 6.7 | 0.5 | 7.5 | 0.5 | 7.5 | 0.5 | 10 | ns | | | t <sub>RINT</sub> | Clock to INT Reset Time | 0.5 | 6.7 | 0.5 | 7.5 | 0.5 | 7.5 | 0.5 | 10 | ns | | | t <sub>SCINT</sub> | Clock to CNTINT Set Time | 0.5 | 5.0 | 0.5 | 5.7 | NA | NA | NA | NA | ns | | | t <sub>RCINT</sub> | Clock to CNTINT Reset time | 0.5 | 5.0 | 0.5 | 5.7 | NA | NA | NA | NA | ns | | | Port to Por | t Delays | | | | | | | | | | | | t <sub>CCS</sub> | Clock to Clock Skew | 5.2 | | 6.0 | | 6.0 | | 8.0 | | ns | | | Master Res | set Timing | | | | | | | | _ | _ | | | t <sub>RS</sub> | Master Reset Pulse Width | 5.0 | | 5.0 | | 5.0 | | 5.0 | | cycles | | | t <sub>RS</sub> | Master Reset Set-up Time | 6.0 | | 6.0 | | 6.0 | | 8.5 | | ns | | | t <sub>RSR</sub> | Master Reset Recovery Time | 5.0 | | 5.0 | | 5.0 | | 5.0 | | cycles | | | t <sub>RSF</sub> | Master Reset to Outputs Inactive | | 10.0 | | 10.0 | | 10.0 | | 10.0 | ns | | | t <sub>RSINT</sub> | Master Reset to Counter and Mailbox<br>Interrupt Flag Reset Time | | 10.0 | | 10.0 | | NA | | NA | ns | | ## **JTAG Timing and Switching Waveforms** | | | CYD01S18V/CYD02S18V<br>CYD04S18V/CYD09S18V | | | |-------------------|---------------------------------------|--------------------------------------------|------|------| | Parameter | Description | Min. | Max. | Unit | | f <sub>JTAG</sub> | Maximum JTAG TAP Controller Frequency | | 10 | MHz | | t <sub>TCYC</sub> | TCK Clock Cycle Time | 100 | | ns | | t <sub>TH</sub> | TCK Clock HIGH Time | 40 | | ns | | t <sub>TL</sub> | TCK Clock LOW Time | 40 | | ns | | t <sub>TMSS</sub> | TMS Set-up to TCK Clock Rise | 10 | | ns | | t <sub>TMSH</sub> | TMS Hold After TCK Clock Rise | 10 | | ns | | t <sub>TDIS</sub> | TDI Set-up to TCK Clock Rise | 10 | | ns | | t <sub>TDIH</sub> | TDI Hold After TCK Clock Rise | 10 | | ns | | t <sub>TDOV</sub> | TCK Clock LOW to TDO Valid | | 30 | ns | | t <sub>TDOX</sub> | TCK Clock LOW to TDO Invalid | 0 | | ns | ## **Switching Waveforms** Read Cycle<sup>[13, 31, 32, 33, 34]</sup> - Notes: 31. OE is asynchronously controlled; all other inputs (excluding MRST and JTAG) are synchronous to the rising clock edge. 32. ADS = CNTEN = LOW, and MRST = CNTRST = CNT/MSK = HIGH. 33. The output is disabled (high-impedance state) by CE = V<sub>IH</sub> following the next rising edge of the clock. 34. Addresses do not have to be accessed sequentially since ADS = CNTEN = V<sub>IL</sub> with CNT/MSK = V<sub>IH</sub> constantly loads the address on the rising edge of the CLK. Numbers are for reference only Numbers are for reference only. Bank Select Read<sup>[35, 36]</sup> # Read-to-Write-to-Read ( $\overline{\text{OE}} = \text{LOW}$ )[34, 37, 38, 39, 40] #### Notes: - 35. In this depth-expansion example, B1 represents Bank #1 and B2 is Bank #2; each bank consists of one Cypress FLEx18 device from this data sheet. ADDRESS<sub>(B1)</sub> = ADDRESS<sub>(B2)</sub>. - 36. ADS = CNTEN= BEO BE1 = OE = LOW; MRST = CNTRST = CNT/MSK = HIGH. - 37. Output state (HIGH, LOW, or high-impedance) is determined by the previous cycle control signals. - 38. <u>During "No Operation,"</u> data in memory at the selected address may be corrupted and should be rewritten to ensure data integrity. 39. <u>CE<sub>0</sub> = OE = BEO BE1 = LOW; CE<sub>1</sub> = R/W = CNTRST = MRST = HIGH.</u> 40. <u>CE<sub>0</sub> = BEO BE1 = R/W = LOW; CE<sub>1</sub> = CNTRST = MRST = CNT/MSK = HIGH. When R/W first switches low, since OE = LOW, the Write operation cannot be completed (labelled as no operation). One clock cycle is required to three-state the I/O for the Write operation on the next rising edge of CLK.</u> # Read-to-Write-to-Read (OE Controlled)[34, 37, 39, 40] ## Read with Address Counter Advance<sup>[39]</sup> ## Write with Address Counter Advance [40] Counter Reset<sup>[41, 42]</sup> Notes: 41. CE<sub>0</sub> = BE0 - BE1 = LOW; CE<sub>1</sub> = MRST = CNT/MSK = HIGH. 42. No dead cycle exists during counter reset. A Read or Write cycle may be coincidental with the counter reset. 43. Retransmit happens if the counter remains in increment mode after it wraps to initially loaded value. Readback State of Address Counter or Mask Register<sup>[44, 45, 46, 47]</sup> - Notes: 44. $\overline{CE}_0 = \overline{OE} = \overline{BE0} \overline{BE1} = LOW$ ; $CE_1 = R/\overline{W} = \overline{CNTRST} = \overline{MRST} = HIGH$ . 45. Address in output mode. Host must not be driving address bus after t<sub>CKLZ</sub> in next clock cycle. - 46. Address in input mode. Host can drive address bus after t<sub>CKHZ</sub>. 47. An \* is the internal value of the address counter (or the mask register depending on the CNT/MSK level) being Read out on the address lines. Left\_Port (L\_Port) Write to Right\_Port (R\_Port) Read<sup>[48, 49, 50]</sup> #### Notes: <sup>48.</sup> $\overline{CE}_0 = \overline{OE} = \overline{ADS} = \overline{CNTEN} = \overline{BE0} - \overline{BE1} = LOW$ ; $CE_1 = \overline{CNTRST} = \overline{MRST} = \overline{CNT/MSK} = HIGH$ . <sup>49.</sup> This timing is valid when one port is writing, and other port is reading the same location at the same time. If t<sub>CCS</sub> is violated, indeterminate data will be Read out. 50. If t<sub>CCS</sub> < minimum specified value, then R\_Port will Read the most recent data (written by L\_Port) only (2 \* t<sub>CYC2</sub> + t<sub>CD2</sub>) after the rising edge of R\_Port's clock. If t<sub>CCS</sub> ≥ minimum specified value, then R\_Port will Read the most recent data (written by L\_Port) (t<sub>CYC2</sub> + t<sub>CD2</sub>) after the rising edge of R\_Port's clock. Counter Interrupt and Retransmit $^{[16,\ 43,\ 51,\ 52,\ 53,\ 54]}$ 54. The mask register assumed to have the value of 3FFFFh. Notes: 51. $\overline{CE_0} = \overline{OE} = \overline{BE0} - \overline{BE1} = LOW$ ; $CE_1 = R/\overline{W} = \overline{CNTRST} = \overline{MRST} = HIGH$ . 52. $\overline{CNTINT}$ is always driven. 53. $\overline{CNTINT}$ goes LOW when the unmasked portion of the address counter is incremented to the maximum value. MailBox Interrupt Timing<sup>[55, 56, 57, 58, 59]</sup> Table 7. Read/Write and Enable Operation (Any Port) $^{[1,\ 18,\ 60,\ 61,\ 62]}$ | | | Inputs | | | Outputs | | |----|-----|-----------------|-----------------|-----|------------------------------------|------------------| | OE | CLK | CE <sub>0</sub> | CE <sub>1</sub> | R/W | DQ <sub>0</sub> – DQ <sub>17</sub> | Operation | | Х | 7 | Н | Х | Х | High-Z | Deselected | | Х | | Х | L | Х | High-Z | Deselected | | Х | 7 | L | Н | L | D <sub>IN</sub> | Write | | L | 7 | L | Н | Н | D <sub>OUT</sub> | Read | | Н | Х | L | Н | X | High-Z | Outputs Disabled | - 55. $\overline{CE}_0 = \overline{OE} = \overline{ADS} = \overline{CNTEN} = LOW; CE_1 = \overline{CNTRST} = \overline{MRST} = CNT/\overline{MSK} = HIGH.$ - 56. Address "7FFFF" is the mailbox location for R\_Port of the 9Mb device. - 57. L\_Port is configured for Write operation, and R\_Port is configured for Read operation. 58. At least one byte enable (BE0 BE1) is required to be active during interrupt operations. - 59. Interrupt flag is set with respect to the rising edge of the Write clock, and is reset with respect to the rising edge of the Read clock. - 60. $\overline{\text{OE}}$ is an asynchronous input signal. 61. When $\overline{\text{CE}}$ changes state, deselection and Read happen after one cycle of latency. 62. $\overline{\text{CE}}_0 = \overline{\text{OE}} = \text{LOW}$ ; $\overline{\text{CE}}_1 = \overline{\text{R/W}} = \text{HIGH}$ . ## **Ordering Information** ### 512K × 18 (9Mb) 3.3V Synchronous CYD09S18V Dual-Port SRAM | Speed<br>(MHz) | Ordering Code | Package<br>Name | Package Type | Operating<br>Range | |----------------|------------------|-----------------|-----------------------------------------------------------|--------------------| | 133 | CYD09S18V-133BBC | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Commercial | | 100 | CYD09S18V-100BBC | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Commercial | | | CYD09S18V-100BBI | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Industrial | ## 256K x 18 (4Mb) 3.3V Synchronous CYD04S36V Dual-Port SRAM | Speed<br>(MHz) | Ordering Code | Package<br>Name | Package Type | Operating<br>Range | |----------------|------------------|-----------------|-----------------------------------------------------------|--------------------| | 167 | CYD04S18V-167BBC | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Commercial | | 133 | CYD04S18V-133BBC | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Commercial | | | CYD04S18V-133BBI | BB256 | 256-ball Grid Array 17 mm x 17 mm with 1.0 mm pitch (BGA) | Industrial | ### 128K x 18 (2Mb) 3.3V Synchronous CYD02S18V Dual-Port SRAM | Speed<br>(MHz) | Ordering Code | Package<br>Name | Package Type | Operating<br>Range | |----------------|------------------|-----------------|-----------------------------------------------------------|--------------------| | 167 | CYD02S18V-167BBC | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Commercial | | 133 | CYD02S18V-133BBC | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Commercial | | | CYD02S18V-133BBI | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Industrial | ## 64K x 18 (1Mb) 3.3V Synchronous CYD01S18V Dual-Port SRAM | Speed<br>(MHz) | Ordering Code | Package<br>Name | Package Type | Operating<br>Range | |----------------|------------------|-----------------|-----------------------------------------------------------|--------------------| | 167 | CYD01S18V-167BBC | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Commercial | | 133 | CYD01S18V-133BBC | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Commercial | | | CYD01S18V-133BBI | BB256 | 256-ball Grid Array 17 mm × 17 mm with 1.0 mm pitch (BGA) | Industrial | ## **Package Diagram** #### 256-Ball FBGA (17 x 17 mm) BB256 FLEx18 and FLEx18-E are trademarks of Cypress Semiconductor Corporation. All products and company names mentioned in this document may be the trademarks of their respective holders. ## **Document History Page** Document Title: CYD01S18V/CYD02S18V/CYD04S18V/CYD09S18V FLEx18™ 3.3V 64K/128K/256K/512K x 18 Synchronous Dual-Port RAM Document Number: 38-06077 | REV. | ECN NO. | Issue Date | Orig. of<br>Change | Description of Change | |------|---------|------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ** | 259671 | See ECN | WWZ | New data sheet | | *A | 289711 | See ECN | YDT | Change Pinout D10 from NC to VSS Changed tRSCNTINT to tRSINT Added tRSINT to the master reset timing diagram Added I <sub>SB5</sub> and changed I <sub>IX2</sub> | | *B | 327354 | See ECN | AEQ | Change Pinout C10 from REV <sub>R</sub> [2,4] to NC[2,5]<br>Change Pinout G5 from VDDIO <sub>L</sub> to REV <sub>L</sub> [2,3] | | *C | 365320 | See ECN | YDT | Added note for V <sub>CORE</sub><br>Removed preliminary status |