CY7C0837AV, CY7C0830AV CY7C0831AV, CY7C0832AV CY7C0832BV, CY7C0833AV FLEx18™ 3.3V 64K/128K x 36 and 128K/256K x 18 Synchronous Dual-Port RAM ### **Features** - True Dual-Ported Memory Cells that Allow Simultaneous Access of the Same Memory Location - Synchronous Pipelined Operation - Family of 512 Kbit, 1 Mbit, 2 Mbit, 4 Mbit, and 9 Mbit 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 - 144-Ball FBGA (13 mm × 13 mm) (1.0 mm pitch) - 120 TQFP (14 mm x 14 mm x 1.4 mm) - Pb-Free Packages Available - 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 **Table 1. Product Selection Guide** # Functional Description The FLEx18™ family includes 5 The FLEx18™ family includes 512 Kbit, 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 setup 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 increments 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 $\overline{\text{CE0}}$ or LOW on CE1 for one clock cycle powers 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 CY7C0833AV device in this family has limited features. See Address Counter and Mask Register Operations [16] on page 6 for details. | Density | 512 Kbit<br>(32K x 18) | 1 Mbit<br>(64K x 18) | 2 Mbit<br>(128K x 18) | 4 N<br>(256K | 9 Mbit<br>(512K x 18) | | |---------------------------------------------|------------------------|----------------------|-----------------------|----------------------|-----------------------|------------| | Part Number | CY7C0837AV | CY7C0830AV | CY7C0831AV | CY7C0832AV | CY7C0832BV [1] | CY7C0833AV | | Maximum Speed (MHz) | 167 | 167 | 167 | 167 | 133 | 133 | | Maximum Access Time -<br>Clock to Data (ns) | 4.0 | 4.0 | 4.0 | 4.0 | 4.4 | 4.7 | | Typical Operating<br>Current (mA) | 225 | 225 | 225 | 225 | 225 | 270 | | Package | 144 FBGA | 120 TQFP<br>144 FBGA | 120 TQFP<br>144 FBGA | 120 TQFP<br>144 FBGA | 120 TQFP | 144 FBGA | Note <sup>1.</sup> CY7C0832AV and CY7C0832BV are functionally identical. # Logic Block Diagram [2] #### Note CY7C0837AV has 15 address bits, CY7C0830AV has 16 address bits, CY7C0831AV has 17 address bits, CY7C0832AV/CY7C0832BV has 18 address bits and CY7C0833AV has 19 address bits. # **Pin Configurations** ### Figure 1. 144-Ball BGA (Top View) ### CY7C0837AV / CY7C0830AV / CY7C0831AV / CY7C0832AV / CY7C0833AV | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | |---|-------------------------|-------------------------|-------------------------------------|-------------------|-------------------------|---------------------------|---------------------------|-------------------------|-------------------|---------------------------------|-------------------------|-------------------------| | A | DQ17 <sub>L</sub> | DQ16 <sub>L</sub> | DQ14 <sub>L</sub> | DQ12 <sub>L</sub> | DQ10 <sub>L</sub> | DQ9 <sub>L</sub> | DQ9 <sub>R</sub> | DQ10 <sub>R</sub> | DQ12 <sub>R</sub> | DQ14 <sub>R</sub> | DQ16 <sub>R</sub> | DQ17 <sub>R</sub> | | В | A0 <sub>L</sub> | A1 <sub>L</sub> | DQ15 <sub>L</sub> | DQ13 <sub>L</sub> | DQ11 <sub>L</sub> | MRST | NC | DQ11 <sub>R</sub> | DQ13 <sub>R</sub> | DQ15 <sub>R</sub> | A1 <sub>R</sub> | A0 <sub>R</sub> | | С | A2 <sub>L</sub> | A3 <sub>L</sub> | CE1 <sub>L</sub><br>[7] | ĪNT <sub>L</sub> | CNTINT <sub>L</sub> [9] | ADS <sub>L</sub><br>[8] | ADS <sub>R</sub><br>[8] | CNTINT <sub>R</sub> [9] | ĪNT <sub>R</sub> | CE1 <sub>R</sub><br>[7] | A3 <sub>R</sub> | A2 <sub>R</sub> | | D | A4 <sub>L</sub> | A5 <sub>L</sub> | CE <sub>0</sub> <sub>L</sub><br>[8] | NC | VDD | VDD | VDD | VDD | NC | CE <sub>0<sub>R</sub> [8]</sub> | A5 <sub>R</sub> | A4 <sub>R</sub> | | E | A6 <sub>L</sub> | A7 <sub>L</sub> | ⊟B1 <sub>L</sub> | NC | VDD | VSS | VSS | VDD | NC | B1 <sub>R</sub> | A7 <sub>R</sub> | A6 <sub>R</sub> | | F | A8 <sub>L</sub> | A9 <sub>L</sub> | C <sub>L</sub> | NC | VSS | VSS | VSS | VSS | NC | C <sub>R</sub> | A9 <sub>R</sub> | A8 <sub>R</sub> | | G | A10 <sub>L</sub> | A11 <sub>L</sub> | B0 <sub>L</sub> | NC | VSS | VSS | VSS | VSS | NC | B0 <sub>R</sub> | A11 <sub>R</sub> | A10 <sub>R</sub> | | н | A12 <sub>L</sub> | A13 <sub>L</sub> | ŌĒL | NC | VDD | VSS | VSS | VDD | NC | ŌĒ <sub>R</sub> | A13 <sub>R</sub> | A12 <sub>R</sub> | | J | A14 <sub>L</sub> | A15 <sub>L</sub><br>[3] | $R\overline{W}_L$ | NC | VDD | VDD | VDD | VDD | NC | $R\overline{W}_R$ | A15 <sub>R</sub><br>[3] | A14 <sub>R</sub> | | К | A16 <sub>L</sub><br>[4] | A17 <sub>L</sub><br>[5] | CNT/MSK <sub>L</sub><br>[7] | TDO | CNTRST <sub>L</sub> [7] | тск | TMS | CNTRST <sub>R</sub> [7] | TDI | CNT/MSK <sub>R</sub> [7] | A17 <sub>R</sub><br>[5] | A16 <sub>R</sub><br>[4] | | L | A18 <sub>L</sub><br>[6] | NC | DQ6 <sub>L</sub> | DQ4 <sub>L</sub> | DQ2 <sub>L</sub> | CNTEN <sub>L</sub><br>[8] | CNTEN <sub>R</sub><br>[8] | DQ2 <sub>R</sub> | DQ4 <sub>R</sub> | DQ6 <sub>R</sub> | NC | A18 <sub>R</sub><br>[6] | | M | DQ8 <sub>L</sub> | DQ7 <sub>L</sub> | DQ5 <sub>L</sub> | DQ3 <sub>L</sub> | DQ1 <sub>L</sub> | DQ0 <sub>L</sub> | DQ0 <sub>R</sub> | DQ1 <sub>R</sub> | DQ3 <sub>R</sub> | DQ5 <sub>R</sub> | DQ7 <sub>R</sub> | DQ8 <sub>R</sub> | #### Notes - 3. Leave this ball unconnected for CY7C0837AV. - Leave this ball unconnected for CY7C0837AV and CY7C0830AV. - Leave this ball unconnected for CY7C0837AV, CY7C0830AV and CY7C0831AV. Leave this ball unconnected for CY7C0837AV, CY7C0830AV, CY7C0831AV, and CY7C0832AV. - 7. These balls are not applicable for CY7C0833AV device. They must be tied to VDD. - These balls are not applicable for CY7C0833AV device. They must be tied to VSS. - 9. These balls are not applicable for CY7C0833AV device. They must not be connected. # **Pin Configurations** Figure 2. 120-Pin Thin Quad Flat Pack (TQFP) (Top View) CY7C0830AV / CY7C0831AV / CY7C0832AV / CY7C0832BV ## Notes 10. Leave this pin unconnected for CY7C0830AV. 11. Leave this pin unconnected for CY7C0830AV and CY7C0831AV. # **Pin Definitions** | Left Port | Right Port | Description | | | | | | |--------------------------------------------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | A <sub>0L</sub> -A <sub>18L</sub> <sup>[2]</sup> | A <sub>0R</sub> -A <sub>18R</sub> <sup>[2]</sup> | Address Inputs. | | | | | | | ADS <sub>L</sub> <sup>[8]</sup> | ADS <sub>R</sub> <sup>[8]</sup> | Address Strobe Input. Used as an address qualifier. This signal should be asserted LOW for the part using the externally supplied address on the address pins and for loading this address into the burst address counter. | | | | | | | CE0 <sub>L</sub> [8] | CE0 <sub>R</sub> <sup>[8]</sup> | Active LOW Chip Enable Input. | | | | | | | CE1 <sub>L</sub> <sup>[7]</sup> | CE1 <sub>R</sub> <sup>[7]</sup> | Active HIGH Chip Enable Input. | | | | | | | CLK <sub>L</sub> | CLK <sub>R</sub> | Clock Signal. Maximum clock input rate is f <sub>MAX</sub> . | | | | | | | CNTEN <sub>L</sub> <sup>[8]</sup> | CNTEN <sub>R</sub> <sup>[8]</sup> | <b>Counter Enable Input</b> . Asserting this signal LOW increments the burst <u>address counter of</u> its respective port on each rising edge of CLK. The increment is disabled if ADS or CNTRST are asserted LOW. | | | | | | | CNTRST <sub>L</sub> <sup>[7]</sup> | CNTRST <sub>R</sub> <sup>[7]</sup> | Counter Reset Input. Asserting this signal LOW resets to zero the unmasked portion of the burst address counter of its respective port. CNTRST is not disabled by asserting ADS or CNTEN. | | | | | | | CNT/MSK <sub>L</sub> <sup>[7]</sup> | CNT/MSK <sub>R</sub> <sup>[7]</sup> | Address Counter Mask Register Enable Input. Asserting this signal LOW enables access to the mask register. When tied HIGH, the mask register is not accessible and the address counter operations are enabled based on the status of the counter control signals. | | | | | | | DQ <sub>0L</sub> -DQ <sub>17L</sub> | DQ <sub>0R</sub> -DQ <sub>17R</sub> | Data Bus Input/Output. | | | | | | | OEL | OE <sub>R</sub> | Output Enable Input. This asynchronous signal must be asserted LOW to enable the DQ data pins during Read operations. | | | | | | | ĪNTL | ĪNTR | <b>Mailbox Interrupt Flag Output</b> . The mailbox permits comm <u>unic</u> ations between ports. The upper two memory locations are used for message passing. INT <sub>L</sub> 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. | | | | | | | CNTINT <sub>L</sub> <sup>[9]</sup> | CNTINT <sub>R</sub> <sup>[9]</sup> | <b>Counter Interrupt Output</b> . This pin is asserted LOW when the unmasked portion of the counter is incremented to all '1s.' | | | | | | | R/W <sub>L</sub> | R/W <sub>R</sub> | Read/Write Enable Input. Assert this pin LOW to write to, or HIGH to Read from the dual port memory array. | | | | | | | $\overline{B}_{0L}$ – $\overline{B}_{1L}$ | B <sub>0R</sub> -B <sub>1R</sub> | <b>Byte Select Inputs</b> . Asserting these signals enables Read and Write operations to the corresponding bytes of the memory array. | | | | | | | N | IRST | Master Reset Input. MRST is an asynchronous input signal and affects both ports. Assertir MRST LOW performs all of the reset functions as described in the text. A MRST operation i required at power up. | | | | | | | - | TMS | JTAG Test Mode Select Input. It controls the advance of JTAG TAP state machine. State machine transitions occur on the rising edge of TCK. | | | | | | | | TDI | JTAG Test Data Input. Data on the TDI input is shifted serially into selected registers. | | | | | | | - | TCK | JTAG Test Clock Input. | | | | | | | | TDO | 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. | | | | | | | | V <sub>SS</sub> | Ground Inputs. | | | | | | | , | $V_{DD}$ | Power Inputs. | | | | | | # **Byte Select Operation** | Control Pin | Effect | | | | | | |------------------|---------------------------------|--|--|--|--|--| | $\overline{B}_0$ | DQ <sub>0-8</sub> Byte Control | | | | | | | B <sub>1</sub> | DQ <sub>9-17</sub> Byte Control | | | | | | #### **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. An MRST initializes the internal burst counters to zero, and the counter mask registers to all ones (completely unmasked). MRST also forces the Mailbox Interrupt (INT) flags and the Counter Interrupt (CNTINT) flags HIGH. 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 2 shows the interrupt operation for both ports of CY7C0833AV. The highest memory location, 7FFFF is the mailbox for the right port and 7FFFE is the mailbox for the left port. Table 2 shows that to set the INT<sub>R</sub> flag, a Write operation by the left port to address 7FFFF asserts INT<sub>R</sub> LOW. At least one byte has to be active for a Write to generate an interrupt. A valid Read of the 7FFF location by the right port resets $\overline{\text{INT}}_{\text{R}}$ HIGH. At least one byte must be active 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-through mode (that is, it follows the clock edge of the writing port). Also, the flag is reset in a flow-through mode (that is, 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 [16] This section describes the features only apply to 512 Kbit,1 Mbit, 2 Mbit, and 4 Mbit devices. It does not apply to 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. The **counter register** contains the address used to access the RAM array. It is changed only by the <u>Counter Load</u>, 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 on page 8). It always contains the value last loaded into the counter register, and is changed only by the Counter Load, and by the MRST instructions. Table 3 on page 7 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 on page 7 (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 (CEO and CE1). Counter enable (CNTEN) inputs are provided to stall the operation of the address input and use 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 increments on each LOW to HIGH transition of that port's clock signal. This reads and writes one word from and to each successive address location until CNTEN s deasserted. The counter can address the entire memory array, and loops back to the start. Counter reset (CNTRST) is used to reset the unmasked portion of the burst counter to I/Os. A counter-mask register is used to control the counter wrap. Table 2. Interrupt Operation Example [2, 12, 13, 14, 15, 17] | FUNCTION | | LEFT | PORT | | RIGHT PORT | | | | | | | |-----------------------------------|------------------|------|-----------------------------------|------------------|------------------|-----|-----------------------------------|------------------|--|--|--| | | R/W <sub>L</sub> | CEL | A <sub>0L</sub> -A <sub>18L</sub> | INT <sub>L</sub> | R/W <sub>R</sub> | CER | A <sub>0R</sub> -A <sub>18R</sub> | INT <sub>R</sub> | | | | | Set Right INT <sub>R</sub> Flag | L | L | 3FFFF | Х | Х | Х | Х | L | | | | | Reset Right INT <sub>R</sub> Flag | Х | Х | Х | Х | Н | L | 3FFFF | Н | | | | | Set Left INT <sub>L</sub> Flag | Х | Х | Х | L | L | L | 3FFFE | Х | | | | | Reset Left INT <sub>L</sub> Flag | Н | L | 3FFFE | Н | Х | Х | Х | Х | | | | | Set Right INT <sub>R</sub> Flag | L | L | 3FFFF | Х | Х | Х | Х | L | | | | #### Note<u>s</u> - 12. $\overline{\text{CE}}$ is internal signal. $\overline{\text{CE}}$ = LOW if $\overline{\text{CE}}_0$ = LOW and $\overline{\text{CE}}_1$ = HIGH. For a single Read operation, $\overline{\text{CE}}$ only needs to be asserted once at the rising edge of the CLK and $\overline{\text{can}}$ be deasserted after that. Data is out after the following CLK edge and is three-stated after the next CLK edge. - 13. OE is "Don't Care" for mailbox operation. - 14. At least one of $\overline{\text{BE0}}$ , $\overline{\text{BE1}}$ must be LOW. - 15. A18x is a NC for CY7C0832AV/CY7C0832BV, therefore the Interrupt Addresses are 3FFFF and 3FFFE. A18x and A17x are NC for CY7C0831AV, therefore the Interrupt addresses are 1FFFF and 1FFFE; A18x, A17x and A16x are NC for CY7C0830AV, therefore the Interrupt Addresses are FFFF and FFFE; A18x, A17x, A16x and A15x are NC for CY7C0837AV, therefore the Interrupt Addresses are 7FFF and 7FFE. - 16. This section describes the CY7C0832AV/CY7C0832BV, CY7C0831AV, CY7C0830AV and CY7C0837AV having 18, 17, 16 and 15 address bits. - 17. "X" = "Don't Care," "H" = HIGH, "L" = LOW. ### **Counter Reset Operation** All unmasked bits of the counter are reset to '0.' All masked bits remain unchanged. The mirror register is loaded with the value of the burst counter. A Mask Reset followed by a Counter Reset resets the counter and mirror registers to 00000, as does 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** When 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 wraps 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 returns the counter register to its initial value, which was stored in the mirror register. The counter address <u>can instead be forced</u> to loop to 00000 by externally connecting CNTINT to CNTRST.<sup>[19]</sup> An increment that results in one or more of the unmasked bits of the counter being '0' deasserts the counter interrupt flag. The example in Figure 4 on page 10 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 after the counter is configured for increment operation. The counter address starts at address 8h. The counter increments its internal address value until it reaches the mask register value of 3Fh. The counter <u>wraps around</u> the memory block to location 8h at the next count. <u>CNTINT</u> 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. ### **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 de-asserted 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 is 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) are three-stated. Figure 3 on page 9 shows a block diagram of the operation. Table 3. Address Counter and Counter-Mask Register Control Operation (Any Port) [17, 18] | CLK | MRST | CNT/MSK | CNTRST | ADS | CNTEN | Operation | Description | |-----|------|---------|--------|-----|-------|-------------------|----------------------------------------------------------------------| | Х | L | Х | Х | Х | Х | Master Reset | Reset address counter to all 0s and mask register to all 1s. | | 7 | Н | Н | L | Х | Х | 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 | #### Notes Document #: 38-06059 Rev. \*S Page 7 of 28 <sup>18.</sup> Counter operation and mask register operation is independent of chip enables. <sup>19.</sup> CNTINT and CNTRST specs are guaranteed by design to operate properly at speed grade operating frequency when tied together. CY7C0837AV, CY7C0830AV CY7C0831AV, CY7C0832AV CY7C0832BV, CY7C0833AV #### 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 is valid $t_{CM2}$ after the next rising edge of the <u>port</u>'s clock. If mask readback occurs while the port is enabled (CE0 LOW and CE1 HIGH), the data lines (DQs) is three-stated. Figure 3 on page 9 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 3. Counter, Mask, and Mirror Logic Block Diagram [1] Figure 4. Programmable Counter-Mask Register Operation [2, 20] # IEEE 1149.1 Serial Boundary Scan (JTAG) [21] 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 <u>devices</u>, and may be performed while the device is operating. An <u>MRST</u> 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 outputs the next bit in the chain twice. For example, if the value expected from the chain is 1010101, the device outputs a 11010101. This extra bit causes 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 CY7C0833AV have two DIEs. Each DIE contain 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 DIE are connected serially to form the scan chain of the CY7C0833AV as shown in Figure 5 on page 11. TMS and TCK are connected in parallel to each DIE to drive all TAP controllers in unison. In many cases, each DIE is 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 FLEx18 family is typically connected to multiple DIEs. For connectivity testing with the EXTEST instruction, it is desirable to check the internal connections between DIEs and the external connections to the package. This is 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 is found in the Cypress application note *Using JTAG Boundary Scan For System in a Package (SIP) Dual-Port SRAMs*. #### Notes 20. The "X" in this diagram represents the counter upper bits 21. Boundary scan is IEEE 1149.1-compatible. See Performing a Pause/Restart on page 10 for deviation from strict 1149.1 compliance Figure 5. Scan Chain for 9 Mb 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 CY7C0832AV/CY7C0832BV | | | C091h | Defines Cypress part number for CY7C0831AV | | | C093h | Defines Cypress part number for CY7C0830AV | | | C094h | Defines Cypress part number for CY7C0837AV. | | 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 Registers Sizes | Register Name | Bit Size | |----------------|-------------------| | Instruction | 4 | | Bypass | 1 | | Identification | 32 | | Boundary Scan | n <sup>[22]</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 22. See details in the device BSDL file. # CY7C0837AV, CY7C0830AV CY7C0831AV, CY7C0832AV CY7C0832BV, CY7C0833AV # **Maximum Ratings** Exceeding maximum ratings<sup>[23]</sup> may impair the useful life of the device. These user guidelines are 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_{DD} + 0.5V^{[24]}$ | 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>DD</sub> | |------------|------------------------|-----------------| | Commercial | 0°C to +70°C | 3.3V±165 mV | | Industrial | -40°C to +85°C | 3.3V±165 mV | # **Electrical Characteristics** Over the Operating Range | Parameter | Description | | | -167 | | -133 | | | -100 | | | Unit | |----------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------|------|-----|------|-----|-----|------|-----|-----|------| | Parameter | Description | Description | | | Max | Min | Тур | Max | Min | Тур | Max | Unit | | V <sub>OH</sub> | Output HIGH Voltage (V <sub>DD</sub> = Min., I <sub>C</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>O</sub> | <sub>L</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, 7 | TMS, MRST | -10 | | 10 | -10 | | 10 | -10 | | 10 | μА | | I <sub>IX2</sub> | Input Leakage Current TDI, TMS, MI | RST | -0.1 | | 1.0 | -0.1 | | 1.0 | -0.1 | | 1.0 | mΑ | | I <sub>CC</sub> | Operating Current for (V <sub>DD</sub> = Max., I <sub>OUT</sub> = 0 mA), Outputs Disabled | CY7C0837AV<br>CY7C0830AV<br>CY7C0831AV<br>CY7C0832AV<br>CY7C0832BV | | 225 | 300 | | 225 | 300 | | | | mA | | | | CY7C0833AV | | | | | 270 | 400 | | 200 | 310 | mA | | I <sub>SB1</sub> <sup>[25]</sup> | Standby Current (Both Ports TTL Let $\overline{CE}_L$ and $\overline{CE}_R \ge V_{IH}$ , $f = f_{MAX}$ | vel) | | 90 | 115 | | 90 | 115 | | 90 | 115 | mA | | I <sub>SB2</sub> <sup>[25]</sup> | $\frac{Sta}{CE_L} \frac{C}{CE_R} \geq V_{IH}, f = f_{MAX}$ | el) | | 160 | 210 | | 160 | 210 | | 160 | 210 | mA | | I <sub>SB3</sub> <sup>[25]</sup> | Standby Current (Both Ports CMOS Level)<br>$\overline{CE}_{I}$ and $\overline{CE}_{R} \ge V_{DD} - 0.2V$ , $f = 0$ | | | 55 | 75 | | 55 | 75 | | 55 | 75 | mA | | I <sub>SB4</sub> <sup>[25]</sup> | Standby Current (One Port CMOS Level)<br>$CE_L \mid CE_R \ge V_{IH}, f = f_{MAX}$ | | | 160 | 210 | | 160 | 210 | | 160 | 210 | mA | | I <sub>SB5</sub> | Operating Current (V <sub>DD</sub> = Max, I <sub>OUT</sub> = 0 mA, f = 0) Outputs Disabled | CY7C0833AV | | | | | 70 | 100 | | 70 | 100 | mA | # Capacitance | Part Number [26] | Parameter | Description | Test Conditions | Max | Unit | |-----------------------------------------------------------|------------------|--------------------|--------------------------------------|-----|------| | CY7C0837AV/CY7C0830AV/CY7C0831AV<br>CY7C0832AV/CY7C0832BV | C <sub>IN</sub> | Input Capacitance | $T_A = 25^{\circ}C$ ,<br>f = 1 MHz, | 13 | pF | | | C <sub>OUT</sub> | Output Capacitance | - V <sub>DD</sub> = 3.3V | 10 | pF | | CY7C0833AV | C <sub>IN</sub> | Input Capacitance | | 22 | pF | | | C <sub>OUT</sub> | Output Capacitance | ] | 20 | pF | ## Notes - 23. The voltage on any input or I/O pin can not exceed the power pin during power up. - 25. I<sub>SB1</sub>, I<sub>SB2</sub>, I<sub>SB3</sub> and I<sub>SB4</sub> are not applicable for CY7C0833AV because it can not be powered down by using chip enable pins. 26. C<sub>OUT</sub> also references C<sub>I/O</sub>. Figure 6. AC Test Load and Waveforms # **Switching Characteristics** Over the Operating Range | | | -1 | 67 | | -1 | 33 | | -1 | -100 | | |--------------------------------|-----------------------------|------------------------------------------------------|---------|--------------------------------------------------------------------|-----|------------|-----|------------|------|------| | Parameter | Description | CY7C0837AV<br>CY7C0830AV<br>CY7C0831AV<br>CY7C0832AV | | CY7C0837AV<br>CY7C0830AV<br>CY7C0831AV<br>CY7C0832AV<br>CY7C0832BV | | CY7C0833AV | | CY7C0833AV | | Unit | | | | Min | Min Max | | Max | Min | Max | Min | Max | | | 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>[27]</sup> | Clock Rise Time | | 2.0 | | 2.0 | | 2.0 | | 3.0 | ns | | t <sub>F</sub> <sup>[27]</sup> | Clock Fall Time | | 2.0 | | 2.0 | | 2.0 | | 3.0 | ns | | $t_{SA}$ | Address Setup 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 Setup 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 Setup 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 Setup 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 Setup 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 Setup 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 Setup 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 Setup 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 Setup Time | 2.3 | | 2.5 | | NA | | NA | | ns | #### Note 27. Except JTAG signals ( $t_r$ and $t_f$ < 10 ns [max.]). # **Switching Characteristics** (continued) Over the Operating Range | | | -1 | 67 | | -1 | 33 | | -1 | 00 | | |-------------------------------------|------------------------------------------------------|------------------------------------------------------|-------------|--------------------------------------------------------------------|------|------------|------|------------|------|------| | Parameter | Description | CY7C0837AV<br>CY7C0830AV<br>CY7C0831AV<br>CY7C0832AV | | CY7C0837AV<br>CY7C0830AV<br>CY7C0831AV<br>CY7C0832AV<br>CY7C0832BV | | CY7C0833AV | | CY7C0833AV | | Unit | | | | Min | Max | Min | Max | Min | Max | Min | Max | | | 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> <sup>[28,29]</sup> | OE to Low Z | 0 | | 0 | | | | | | ns | | t <sub>OHZ</sub> <sup>[28,29]</sup> | OE to High Z | 0 | 4.0 | 0 | 4.4 | | 4.7 | | 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 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> [28,29] | Clock HIGH to Output High Z | 0 | 4.0 | 0 | 4.4 | | 4.7 | | 5.0 | ns | | t <sub>CKLZ</sub> [28, 29] | 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 | 7.0 | | 7.5 | | 7.5 | | 10 | | ns | | t <sub>RS</sub> | Master Reset Setup Time | 6.0 | 6.0 6.0 6.0 | | 8.5 | | ns | | | | | t <sub>RSR</sub> | Master Reset Recovery Time | 6.0 | 6.0 7.5 7.5 | | | 10 | | ns | | | | t <sub>RSF</sub> | Master Reset to Outputs Inactive | | 10.0 | | 10.0 | | 10.0 | | 10.0 | ns | | trscntint | Master Reset to Counter Interrupt Flag<br>Reset Time | | 10.0 | | 10.0 | | NA | | NA | ns | <sup>28.</sup> This parameter is guaranteed by design, but is not production tested. 29. Test conditions used are Load 2. # **JTAG Timing and Switching Waveforms** | Parameter | Description | CY7C0831AV | CY7C0837AV/CY7C0830AV<br>CY7C0831AV/CY7C0832AV<br>CY7C0832BV/CY7C0833AV | | | | |-------------------|---------------------------------------|------------|-------------------------------------------------------------------------|-----|--|--| | | | Min | Max | | | | | 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 Setup to TCK Clock Rise | 10 | | ns | | | | t <sub>TMSH</sub> | TMS Hold After TCK Clock Rise | 10 | | ns | | | | t <sub>TDIS</sub> | TDI Setup 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 | | | Figure 7. JTAG Switching Waveform # Switching Waveforms #### Figure 8. Master Reset Figure 9. Read Cycle [12, 30, 31, 32, 33] - Notes 30. OE is asynchronously controlled; all other inputs (excluding MRST and JTAG) are synchronous to the rising clock edge. 31. ADS = CNTEN = LOW, and MRST = CNTRST = CNT/MSK = HIGH. 32. The output is disabled (high-impedance state) by CE = V<sub>IH</sub> following the next rising edge of the clock. 33. Addresses need not be accessed sequentially because 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. Figure 11. Read-to-Write-to-Read ( $\overline{OE} = LOW$ )<sup>[33, 36, 37, 38, 39]</sup> #### Notes - 34. 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(B1) - = ADDRESS<sub>(B2)</sub> 35. ADS = $\overline{\text{CNTEN}}$ = $\overline{\text{BE0}}$ $\overline{\text{BE1}}$ = $\overline{\text{OE}}$ = LOW; $\overline{\text{MRST}}$ = $\overline{\text{CNTRST}}$ = $\overline{\text{CNTRST}}$ = $\overline{\text{CNT/MSK}}$ = HIGH. - 36. Output state (HIGH, LOW, or high-impedance) is determined by the previous cycle control signals. - 37. During "No Operation," data in memory at the selected address may be corrupted and should be rewritten to ensure data integrity. 38. $\overline{CE_0} = \overline{DE} = \overline{BE0} \overline{BE1} = LOW$ ; $\overline{CE_1} = \overline{RW} = \overline{CNTRST} = \overline{MRST} = HIGH$ . 39. $\overline{CE_0} = \overline{BE0} \overline{BE1} = R/\overline{W} = LOW$ ; $\overline{CE_1} = \overline{CNTRST} = \overline{MRST} = CNT/\overline{MSK} = HIGH$ . When $R/\overline{W}$ first switches low, because $\overline{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. Figure 12. Read-to-Write-to-Read ( $\overline{\text{OE}}$ Controlled)[33, 36, 38, 39] Figure 13. Read with Address Counter Advance<sup>[38]</sup> Figure 14. Write with Address Counter Advance<sup>[39]</sup> Figure 15. Counter Reset<sup>[40, 41]</sup> #### Notes - 40. $\overline{CE}_0 = \overline{BE0} \overline{BE1} = LOW$ ; $CE_1 = \overline{MRST} = CNT/\overline{MSK} = HIGH$ . - 41. No dead cycle exists during counter reset. A Read or Write cycle may be coincidental with the counter reset. - 42. Retransmit happens if the counter remains in increment mode after it wraps to initially loaded value. Figure 16. Readback State of Address Counter or Mask Register<sup>[43, 44, 45, 46]</sup> <sup>43.</sup> $\overline{CE}_0 = \overline{OE} = \overline{BE0} - \overline{BE1} = LOW$ ; $CE_1 = R/\overline{W} = \overline{CNTRST} = \overline{MRST} = HIGH$ . <sup>44.</sup> Address in output mode. Host must not be driving address bus after t<sub>CKLZ</sub> in next clock cycle. 45. Address in input mode. Host can drive address bus after t<sub>CKLZ</sub> in next clock cycle. 46. 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. Figure 17. Left\_Port (L\_Port) Write to Right\_Port (R\_Port) Read<sup>[47, 48, 49]</sup> Notes $<sup>47.\</sup>overline{CE}_0 = \overline{OE} = \overline{ADS} = \overline{CNTEN} = \overline{BE0} - \overline{BE1} = LOW; CE_1 = \overline{CNTRST} = \overline{MRST} = CNT/\overline{MSK} = HIGH.$ <sup>48.</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 is Read out. 49. If t<sub>CCS</sub> < minimum specified value, then R\_Port is 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 is 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. Figure 18. Counter Interrupt and Retransmit [15, 42, 50, 51, 52, 53] Notes 50. $\overline{CE_0} = \overline{OE} = \overline{BE0} - \overline{BE1} = LOW$ ; $CE_1 = R\overline{W} = \overline{CNTRST} = \overline{MRST} = HIGH$ . 51. $\overline{CNTINT}$ is always driven. 52. $\overline{CNTINT}$ goes LOW when the unmasked portion of the address counter is incremented to the maximum value. Figure 19. MailBox Interrupt Timing [54, 55, 56, 57, 58] Table 7. Read/Write and Enable Operation (Any Port) $^{[2,\ 17,\ 59,\ 60,\ 61]}$ | | | = | | - | | | |----|-----|-----------------|-----------------|-----|------------------------------------|------------------| | | | Inputs | | | Outputs | Operation | | OE | CLK | CE <sub>0</sub> | CE <sub>1</sub> | R/W | DQ <sub>0</sub> – DQ <sub>17</sub> | - Operation | | Х | | Н | Х | Х | High-Z | Deselected | | Х | | Х | L | Х | High-Z | Deselected | | Х | | L | Н | L | D <sub>IN</sub> | Write | | L | | L | Н | Н | D <sub>OUT</sub> | Read | | Н | Х | L | Н | Х | High-Z | Outputs Disabled | <sup>54.</sup> $\overline{CE}_0 = \overline{OE} = \overline{ADS} = \overline{CNTEN} = LOW; CE_1 = \overline{CNTRST} = \overline{MRST} = CNT/\overline{MSK} = HIGH.$ 55. Address "7FFFF" is the mailbox location for R\_Port of the 9Mb device. <sup>56.</sup> L\_Port is configured for Write operation, and R\_Port is configured for Read operation. 57. At least one byte enable (BE0 – BE1) is required to be active during interrupt operations. <sup>58.</sup> 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. <sup>59.</sup> OE is an asynchronous input signal. <sup>60.</sup> When $\overline{CE}$ changes state, deselection and Read happen after one cycle of latency. 61. $\overline{CE}_0 = \overline{OE} = LOW$ ; $\overline{CE}_1 = R\overline{W} = HIGH$ . # **Ordering Information** # $512K \times 18$ (9M) 3.3V Synchronous CY7C0833AV Dual-Port SRAM | Speed<br>(MHz) | Ordering Code | Package<br>Diagram | Package Type | Operating Range | |----------------|-------------------|--------------------|--------------------------------------------------------|-----------------| | 133 | CY7C0833AV-133BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0833AV-133BBI | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Industrial | | 100 | CY7C0833AV-100BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0833AV-100BBI | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Industrial | # 256K x 18 (4M) 3.3V Synchronous CY7C0832AV/CY7C0832BV Dual-Port SRAM | Speed<br>(MHz) | Ordering Code | Package<br>Diagram | Package Type | Operating<br>Range | |----------------|-------------------|--------------------|----------------------------------------------------------|--------------------| | 167 | CY7C0832AV-167BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0832AV-167AC | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | | | | CY7C0832AV-167AXC | | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) (Pb-Free) | | | 133 | CY7C0832AV-133BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0832AV-133AC | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | | | | CY7C0832AV-133AXC | | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) (Pb-Free) | | | | CY7C0832AV-133BBI | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Industrial | | | CY7C0832BV-133AI | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | | | | CY7C0832AV-133AXI | | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) (Pb-Free) | | # 128K × 18 (2M) 3.3V Synchronous CY7C0831AV Dual-Port SRAM | Speed (MHz) | Ordering Code | Package<br>Diagram | Package Type | Operating<br>Range | |-------------|--------------------|--------------------|------------------------------------------------------------------|--------------------| | 167 | CY7C0831AV-167BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0831AV-167AC | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | | | | CY7C0831AV-167AXC | | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) (Pb-Free) | | | 133 | CY7C0831AV-133BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0831AV-133BBXC | | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch (Pb-Free) | | | | CY7C0831AV-133AC | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | | | | CY7C0831AV-133AXC | | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) (Pb-Free) | | | | CY7C0831AV-133BBI | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Industrial | | | CY7C0831AV-133BBXI | | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch (Pb-Free) | | | | CY7C0831AV-133AI | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | | | | CY7C0831AV-133AXI | | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) (Pb-Free) | | # 64K × 18 (1M) 3.3V Synchronous CY7C0830AV Dual-Port SRAM | Speed (MHz) | Ordering Code | Package<br>Diagram | Package Type | Operating Range | |-------------|-------------------|--------------------|--------------------------------------------------------|-----------------| | 167 | CY7C0830AV-167BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0830AV-167AC | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | | | 133 | CY7C0830AV-133BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0830AV-133AC | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | 7 | | | CY7C0830AV-133BBI | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Industrial | | | CY7C0830AV-133AI | 51-85100 | 120-Pin Thin Quad Flat Pack (14 x 14 x 1.4 mm) | | # **Ordering Information** # 32K × 18 (512K) 3.3V Synchronous CY7C0837AV Dual-Port SRAM | Speed (MHz) | Ordering Code | Package<br>Diagram | Package Type | Operating Range | |-------------|-------------------|--------------------|--------------------------------------------------------|-----------------| | 167 | CY7C0837AV-167BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | 133 | CY7C0837AV-133BBC | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Commercial | | | CY7C0837AV-133BBI | 51-85141 | 144-Ball Grid Array (13 x 13 x 1.6 mm) with 1 mm pitch | Industrial | # **Package Diagrams** Figure 20. 144-Ball FBGA (13 x 13 x 1.6 mm) (51-85141) 51-85141-\*B # **Package Diagrams** Figure 21. 120-Pin Thin Quad Flatpack (14 x 14 x 1.4 mm) (51-85100) # **Document History Page** Document Title: CY7C0837AV/CY7C0830AV/CY7C0831AV/CY7C0832AV/CY7C0832BV/CY7C0833AV, FLEx18™ 3.3V 64K/128K x 36 and 128K/256K x 18 Synchronous Dual-Port RAM | Rev. | ECN No. | Orig. of<br>Change | Submission<br>Date | Description of Change | |------|---------|--------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ** | 111473 | DSG | 11/27/01 | Change from Spec number: 38-01056 to 38-06059 | | *A | 111942 | JFU | 12/21/01 | Updated capacitance values Updated switching parameters and IsB3 Updated "Read-to-Write-to-Read (OE Controlled)" waveform Revised static discharge voltage Revised footnote regarding IsB3 | | *B | 113741 | KRE | 04/02/02 | Updated Isb values Updated ESD voltage Corrected 0853 pins L3 and L12 | | *C | 114704 | KRE | 04/24/02 | Added discussion of Pause/Restart for JTAG boundary scan | | *D | 115336 | KRE | 07/01/02 | Revised speed offerings for all densities | | *E | 122307 | RBI | 12/27/02 | Power up requirements added to Maximum Ratings Information | | *F | 123636 | KRE | 1/27/03 | Revise tcd2, tOE, tOHZ, tCKHZ, tCKLZ for the CY7C0853V to 4.7 ns | | *G | 126053 | SPN | 08/11/03 | Separated out 4M and 9M data sheets Updated Isb and Icc values | | *H | 129443 | RAZ | 11/03/03 | Updated Isb and Icc values | | * | 231993 | YDT | See ECN | Removed "A particular port can write to a certain location while another port reading that location." from Functional Description. | | *J | 231813 | WWZ | See ECN | Removed x36 devices (CY7C0852/CY7C0851) from this datasheet. Added 0.5M, 1M and 9M x18 devices to it. Changed title to FLEx18 3.3V 32K/64K/128K/256K/512K x18 Synchronous Dual-Port RAM. Changed datasheet to accommodate the removals and additions. Removed general JTAG description. Updated JTAG ID codes for all devices. Added 144FBGA package for all devices. Updated selection guide table and moved to the fror page. Updated block diagram to reflect x18 configuration. Added preliminary status back due to the addition of the new devices. | | *K | 311054 | RYQ | See ECN | Minor Change: Correct the revision indicated on the footer. | | *L | 329111 | SPN | See ECN | Updated Marketing part numbers<br>Updated tRSF | | *M | 330561 | RUY | See ECN | Added Byte Select Operation Table | | *N | 375198 | YDT | See ECN | Removed Preliminary status Added I <sub>SB5</sub> Changed t <sub>RSCNTINT</sub> to 10ns | | *O | 391525 | SPN | See ECN | Updated Counter reset section to reflect what is loaded into the mirror regist | | *P | 414109 | LIJ | See ECN | Corrected Ordering Codes for 0831 devices in the 133 Mhz speed bin. Added CY7C0833AV-133BBI. | | *Q | 461113 | YDT | SEE ECN | Changed VDDIO to VDD (typo) Added lead(Pb)-free parts Corrected typo in DC table | | *R | 2544945 | VKN/AESA | 07/29/08 | Updated Template. Updated ordering information | | *S | 2668478 | VKN/PYRS | 02/04/09 | Added CY7C0832BV part Added footnote #1 Updated Ordering information table | CY7C0837AV, CY7C0830AV CY7C0831AV, CY7C0832AV CY7C0832BV, CY7C0833AV # 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.com/sales. | P | r | ٦, | h | C | te | |---|---|----|---|---|----| | | | | | | | PSoC psoc.cypress.com Clocks & Buffers clocks.cypress.com Wireless wireless.cypress.com Memories memory.cypress.com Image Sensors image.cypress.com #### **PSoC Solutions** General psoc.cypress.com/solutions Low Power/Low Voltage psoc.cypress.com/low-power Precision Analog psoc.cypress.com/precision-analog LCD Drive psoc.cypress.com/lcd-drive CAN 2.0b psoc.cypress.com/can USB psoc.cypress.com/usb © Cypress Semiconductor Corporation, 2001-2009. The information contained herein is subject to change without notice. Cypress Semiconductor Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in a Cypress product. Nor does it convey or imply any license under patent or other rights. Cypress products are not warranted nor intended to be used for medical, life support, life saving, critical control or safety applications, unless pursuant to an express written agreement with Cypress. Furthermore, Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress products in life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges. Any Source Code (software and/or firmware) is owned by Cypress Semiconductor Corporation (Cypress) and is protected by and subject to worldwide patent protection (United States and foreign), United States copyright laws and international treaty provisions. Cypress hereby grants to licensee a personal, non-exclusive, non-transferable license to copy, use, modify, create derivative works of, and compile the Cypress Source Code and derivative works for the sole purpose of creating custom software and or firmware in support of licensee product to be used only in conjunction with a Cypress integrated circuit as specified in the applicable agreement. Any reproduction, modification, translation, compilation, or representation of this Source Code except as specified above is prohibited without the express written permission of Cypress. Disclaimer: CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Cypress reserves the right to make changes without further notice to the materials described herein. Cypress does not assume any liability arising out of the application or use of any product or circuit described herein. Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress' product in a life-support systems application implies that the manufacturer 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. Document #: 38-06059 Rev. \*S Revised March 03, 2009 Page 28 of 28