## Features

- True dual-ported memory cells that allow simultaneous access of the same memory location
- $16 \mathrm{~K} \times 36$ organization (CY7C056V)
- $32 \mathrm{~K} \times 36$ organization (CY7C057V)
- 0.25-micron CMOS for optimum speed/power
- High-speed access: 12/15/20 ns
- Low operating power
- Active: $I_{C C}=\mathbf{2 5 0 ~ m A ~ ( t y p i c a l ) ~}$
- Standby: $\mathbf{I}_{\text {SB3 }}=10 \mu \mathrm{~A}$ (typical)
- Fully asynchronous operation
- Automatic power-down
- Expandable data bus to 72 bits or more using Master/Slave Chip Select when using more than one device


## Notes:

1. $\frac{A_{0}-A_{13}}{}$ for $16 \mathrm{~K} ; A_{0}-A_{14}$ for 32 K devices.
2. $\overline{B U S Y}$ is an output in Master mode and an input in Slave mode.

## Functional Description

The CY7C056V and CY7C057V are low-power CMOS 16K and $32 \mathrm{~K} \times 36$ dual-port static RAMs. Various arbitration schemes are included on the devices to handle situations when multiple processors access the same piece of data. Two ports are provided, permitting independent, asynchronous access for reads and writes to any location in memory. The devices can be utilized as standalone 36-bit dual-port static RAMs or multiple devices can be combined in order to function as a 72-bit or wider master/slave dual-port static RAM. An M/S pin is provided for implementing 72-bit or wider memory applications without the need for separate master and slave devices or additional discrete logic. Application areas include interprocessor/multiprocessor designs, communications status buffering, and dual-port video/graphics memory.

[^0]Each port has independent control pins: Chip Enable ( $\overline{\mathrm{CE}})^{[3]}$, Read or Write Enable (R/W), and Output Enable ( $\overline{\mathrm{OE}})$. Two flags are provided on each port (BUSY and INT). BUSY signals that the port is trying to access the same location currently being accessed by the other port. The Interrupt Flag (INT) permits communication between ports or systems by means of a mail box. The semaphores are used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphore logic is comprised of eight shared latches. Only one side can control the latch (semaphore) at any time. Control of a semaphore indicates that a shared resource is in use. An automatic Power-Down feature is controlled independently on each port by Chip Select ( $\mathrm{CE}_{0}$ and $\mathrm{CE}_{1}$ ) pins.
The CY7C056V and CY7C057V are available in 144-Pin Thin Quad Plastic Flatpack (TQFP) and 172-Ball Ball Grid Array (BGA) packages.

CY7C056V
CY7C057V

## Pin Configurations



Notes:
4. This pin is A 14 L for CY 7 C 057 V .
5. This pin is A14R for CY7C057V.

## Pin Configurations (continued)

## 172-Ball Ball Grid Array (BGA) <br> Top View

| A | 1/O32L | I/O30L | NC | vss | I/O13L | VDD | I/O11L | I/O11R | VDD | I/O13R | vss | NC | I/O30R | 1/O32R |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B | AOL | I/O33L | I/O29 | I/O17L | I/O14L | I/O12L | I/O9L | I/O9R | I/O12R | I/O14R | I/O17R | I/O29R | I/O33R | AOR |
| C | NC | A1L | I/O31L | I/O27L | NC | I/O15L | I/O10L | I/O10R | I/O15R | NC | I/O27R | 1/031R | A1R | NC |
| D | A2L | A3L | I/O35L | I/O34L | I/O28L | I/O16L | VSS | vSs | I/O16R | I/O28R | I/O34R | I/O35R | A3R | A2R |
| E | A4L | A5L | NC | $\overline{\mathrm{BOL}}$ | NC | NC |  |  | NC | NC | BM | NC | A5R | A4R |
| F | VDD | A6L | A7L | $\overline{\mathrm{B1L}}$ | NC |  |  |  |  | NC | SIZE | A7R | A6R | VDD |
| G | $\overline{\mathrm{OEL}}$ | $\overline{\text { B2L }}$ | $\overline{\text { B3L }}$ | $\overline{\mathrm{CEOL}}$ |  |  |  |  |  |  | $\overline{\mathrm{CEOR}}$ | BA | WA | $\overline{O E R}$ |
| H | VSS | $\mathrm{R} / \overline{\mathrm{W}} \mathrm{L}$ | A8L | CE1L |  |  |  |  |  |  | CE1R | A8R | $\mathrm{R} / \overline{\mathrm{W}} \mathrm{R}$ | vss |
| J | A9L | A10L | vSs | M/S | NC |  |  |  |  | NC | VDD | VDD | A10R | A9R |
| K | A11L | A12L | NC | $\overline{\text { SEML }}$ | NC | NC |  |  | NC | NC | $\overline{\text { SEMR }}$ | NC | A12R | A11R |
| L | $\overline{\text { BUSYL }}$ | A13L | $\overline{\text { INTL }}$ | 1/O26L | I/O25L | I/O19L | vss | VSS | I/O19R | I/O25R | I/O26R | $\overline{\text { INTR }}$ | A13R | $\overline{\text { BUSYR }}$ |
| M | NC | $\mathrm{NC}^{[4]}$ | 1/O22L | I/O18L | NC | I/O7L | I/O2L | I/O2R | I/O7R | NC | I/O18R | 1/O22R | $\mathrm{NC}^{[5]}$ | NC |
| N | I/O24L | 1/O20L | 1/O8L | 1/O6L | 1/05L | I/O3L | I/OOL | I/OOR | I/O3R | 1/O5R | 1/O6R | I/O8R | I/O20R | 1/O24R |
| P | I/O23L | I/O21L | NC | VSS | I/O4L | VDD | I/O1L | I/O1R | VDD | 1/O4R | VSS | NC | I/O21R | I/O23R |

## Selection Guide

|  | $\begin{aligned} & \hline \text { CY7C056V } \\ & \text { CY7C057V } \\ & -12 \end{aligned}$ | $\begin{aligned} & \text { CY7C056V } \\ & \text { CY7C057V } \\ & -15 \end{aligned}$ | $\begin{gathered} \hline \text { CY7C056V } \\ \text { CY7C057V } \\ -20 \end{gathered}$ | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Maximum Access Time | 12 | 15 | 20 | ns |
| Typical Operating Current | 250 | 240 | 230 | mA |
| Typical Standby Current for $\mathrm{I}_{\text {SB1 }}$ (Both Ports TTL Level) | 55 | 50 | 45 | mA |
| Typical Standby Current for $\mathrm{I}_{\text {SB3 }}$ (Both Ports CMOS Level) | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ | $\mu \mathrm{A}$ |

CY7C056V CY7C057V

## Pin Definitions

| Left Port | Right Port | Description |
| :---: | :---: | :---: |
| $\mathrm{A}_{0 L}-\mathrm{A}_{13 / 14 \mathrm{~L}}$ | $\mathrm{A}_{0 \mathrm{R}}-\mathrm{A}_{13 / 14 \mathrm{R}}$ | Address ( $\mathrm{A}_{0}-\mathrm{A}_{13}$ for $16 \mathrm{~K} ; \mathrm{A}_{0}-\mathrm{A}_{14}$ for 32 K devices) |
| $\overline{\mathrm{SEM}}_{\mathrm{L}}$ | $\overline{\mathrm{SEM}}_{\mathrm{R}}$ | Semaphore Enable |
| $\overline{\mathrm{CE}}_{0 \mathrm{~L}}, \mathrm{CE}_{1 \mathrm{~L}}$ | $\overline{\mathrm{CE}}_{0 \mathrm{R}}, \mathrm{CE}_{1 \mathrm{R}}$ | Chip Enable ( $\overline{\mathrm{CE}}$ is LOW when $\overline{\mathrm{CE}}_{0} \leq \mathrm{V}_{\mathrm{IL}}$ and $\mathrm{CE}_{1} \geq \mathrm{V}_{\mathrm{IH}}$ ) |
| $\overline{\mathrm{INT}}_{\mathrm{L}}$ | $\overline{\mathrm{INT}}_{\mathrm{R}}$ | Interrupt Flag |
| $\overline{\mathrm{BUSY}}_{\mathrm{L}}$ | $\overline{\mathrm{BUSY}}_{\mathrm{R}}$ | Busy Flag |
| $\mathrm{I} / \mathrm{O}_{0 \mathrm{~L}}-\mathrm{l} / \mathrm{O}_{35 \mathrm{~L}}$ | $1 / \mathrm{O}_{0 \mathrm{R}^{-1 / O_{35 R}} \text { }}$ | Data Bus Input/Output |
| $\overline{\mathrm{OE}}_{\mathrm{L}}$ | $\overline{\mathrm{OE}}_{\mathrm{R}}$ | Output Enable |
| $\mathrm{R} / \bar{W}_{\mathrm{L}}$ | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | Read/Write Enable |
| $\overline{\mathrm{B}}_{0}-\overline{\mathrm{B}}_{3}$ |  | Byte Select Inputs. Asserting these signals enables read and write operations to the corresponding bytes of the memory array. |
|  | BM, SIZE | See Bus Matching for details. |
|  | WA, BA | See Bus Matching for details. |
| M/S |  | Master or Slave Select |
| $\mathrm{V}_{\text {SS }}$ |  | Ground |
| $V_{\text {DD }}$ |  | Power |

## Maximum Ratings ${ }^{[6]}$

(Above which the useful life may be impaired. For user guidelines, not tested.)

Storage Temperature ................................. $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied............................................ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential ............... -0.5 V to +4.6 V
DC Voltage Applied to
Outputs in High Z State
........................ -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$
DC Input Voltage -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}^{[7]}$

Output Current into Outputs (LOW).............................. 20 mA
Static Discharge Voltage.......................................... >2001V
Latch-Up Current................................................... >200 mA
Operating Range

| Range | Ambient <br> Temperature | $\mathbf{V}_{\text {DD }}$ |
| :--- | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $3.3 \mathrm{~V} \pm 165 \mathrm{mV}$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $3.3 \mathrm{~V} \pm 165 \mathrm{mV}$ |

Shaded areas contain advance information.

Notes:
6. The voltage on any input or I/O pin can not exceed the power pin during power-up.
7. Pulse width < 20 ns .

## Electrical Characteristics Over the Operating Range ${ }^{[8,9]}$

| Parameter | Description |  | CY7C056V <br> CY7C057V |  |  |  |  |  |  |  |  | \# |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | -12 |  |  | -15 |  |  | -20 |  |  |  |
|  |  |  | $\dot{\Sigma}$ | $\stackrel{\dot{2}}{\stackrel{\circ}{2}}$ | $\begin{aligned} & \dot{\times} \\ & \dot{x} \end{aligned}$ | $\dot{\Sigma}$ | $\stackrel{\text { ¢ }}{\stackrel{\circ}{2}}$ | $\dot{\times}$ ® N | $\dot{\Sigma}$ | $\stackrel{\text { ¢ }}{2}$ | + |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage$\left(\mathrm{V}_{\mathrm{DD}}=\mathrm{Min} ., \mathrm{I}_{\mathrm{OH}}=-4.0 \mathrm{~mA}\right)$ |  | 2.4 |  |  | 2.4 |  |  | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage$\left(\mathrm{V}_{\mathrm{DD}}=\mathrm{Min} ., \mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA}\right)$ |  |  |  | 0.4 |  |  | 0.4 |  |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage |  | 2.0 |  |  | 2.0 |  |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Voltage |  |  |  | 0.8 |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{I}_{\mathrm{Oz}}$ | Output Leakage Current |  | -10 |  | 10 | -10 |  | 10 | -10 |  | 10 | $\mu \mathrm{A}$ |
| ICC | Operating Current ( $\mathrm{V}_{\mathrm{DD}}=$ Max., $\mathrm{l}_{\mathrm{OUT}}=0 \mathrm{~mA}$ ) Outputs Disabled | Commercial |  | 250 | 385 |  | 240 | 360 |  | 230 | 340 | mA |
|  |  | Industrial |  |  |  |  | 265 | 385 |  |  |  | mA |
| $\mathrm{I}_{\text {SB1 }}$ | Standby Current (Both Ports TTL Level and Deselected)$\mathrm{f}=\mathrm{f}_{\mathrm{MAX}}$ | Commercial |  | 55 | 75 |  | 50 | 70 |  | 45 | 65 | mA |
|  |  | Industrial |  |  |  |  | 65 | 95 |  |  |  | mA |
| ${ }^{\text {SB2 }}$ | Standby Current (One Port TTL Level and Deselected)$f=f_{\mathrm{MAX}}$ | Commercial |  | 180 | 240 |  | 175 | 230 |  | 165 | 210 | mA |
|  |  | Industrial |  |  |  |  | 190 | 255 |  |  |  | mA |
| $\mathrm{I}_{\text {SB3 }}$ | Standby Current (Both Ports CMOS Level and Deselected) $\mathrm{f}=0$ | Commercial |  | 0.01 | 1 |  | 0.01 | 1 |  | 0.01 | 1 | mA |
|  |  | Industrial |  |  |  |  | 0.01 | 1 |  |  |  | mA |
| $\mathrm{I}_{\text {SB4 }}$ | Standby Current (One Port CMOS Level and Deselected) $f=f_{\text {MAX }}{ }^{[10]}$ | Commercial |  | 160 | 210 |  | 155 | 200 |  | 145 | 180 | mA |
|  |  | Industrial |  |  |  |  | 170 | 215 |  |  |  | mA |

## Capacitance ${ }^{[11]}$

| Parameter | Description | Test Conditions | Max. | Unit |
| :--- | :--- | :--- | :--- | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$, | 10 | pF |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | $\mathrm{V}_{\mathrm{DD}}=3.3 \mathrm{~V}$ | 10 | pF |

## Notes:

8. Cross Levels are $\mathrm{V}_{\mathrm{DD}}-0.2 \mathrm{~V} \leq \mathrm{V}_{7} \leq 0.2 \mathrm{~V}$.
9. Deselection for a port occurs if $\overline{C E}_{0}$ is HIGH or if $\mathrm{CE}_{1}$ is LOW.
10. $f_{\text {MAX }}=1 / t_{R C}=$ All inputs cycling at $f=1 / t_{R C}$ (except Output Enable). $f=0$ means no address or control lines change. This applies only to inputs at CMOS level standby $\mathrm{I}_{\mathrm{SB} 3}$.
11. Tested initially and after any design or process changes that may affect these parameters.

CY7C056V CY7C057V

## AC Test Load and Waveforms



(b) Load Derating Curve

Notes:
12. External AC Test Load Capacitance $=10$ pF
13. (Internal I/O pad Capacitance $=10 \mathrm{pF})+$ AC Test Load.

## Switching Characteristics Over the Operating Range ${ }^{[14]}$

| Parameter | Description | $\begin{aligned} & \text { CY7C056V } \\ & \text { Vy7C057v } \end{aligned}$ |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | -12 |  | -15 |  | -20 |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {RC }}$ | Read Cycle Time | 12 |  | 15 |  | 20 |  | ns |
| $\mathrm{t}_{\mathrm{AA}}$ | Address to Data Valid |  | 12 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\text {OHA }}$ | Output Hold From Address Change | 3 |  | 3 |  | 3 |  | ns |
| $\mathrm{t}_{\mathrm{ACE}}{ }^{[3,15]}$ | $\overline{\mathrm{CE}}$ LOW to Data Valid |  | 12 |  | 15 |  | 20 | ns |
| $t_{\text {doe }}$ | $\overline{\mathrm{OE}}$ LOW to Data Valid |  | 8 |  | 10 |  | 12 | ns |
| $\mathrm{t}_{\text {LZoE }}{ }^{[3,16,17,18]}$ | $\overline{\mathrm{OE}}$ Low to Low Z | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {HZOE }}{ }^{[3,16,17,18]}$ | $\overline{\text { OE HIGH to High Z }}$ |  | 10 |  | 10 |  | 12 | ns |
| $\mathrm{t}_{\text {LZCE }}{ }^{[3,14,17,18]}$ | $\overline{\text { CE LOW to Low } Z}$ | 3 |  | 3 |  | 3 |  | ns |
| $\mathrm{t}_{\text {HZCE }}{ }^{[3,16,17,18]}$ | $\overline{\text { CE }}$ HIGH to High Z |  | 10 |  | 10 |  | 12 | ns |
| t LZBE | Byte Enable to Low Z | 3 |  | 3 |  | 3 |  | ns |
| $\mathrm{t}_{\text {HZBE }}$ | Byte Enable to High Z |  | 10 |  | 10 |  | 12 | ns |
| $\mathrm{t}_{\mathrm{PU}}{ }^{[3,18]}$ | CE LOW to Power-Up | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {PD }}{ }^{[3,18]}$ | $\overline{\mathrm{CE}}$ HIGH to Power-Down |  | 12 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\text {ABE }}{ }^{[15]}$ | Byte Enable Access Time |  | 12 |  | 15 |  | 20 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {Wc }}$ | Write Cycle Time | 12 |  | 15 |  | 20 |  | ns |
| $\mathrm{t}_{\text {SCE }}{ }^{[3,15]}$ | $\overline{\mathrm{CE}}$ LOW to Write End | 10 |  | 12 |  | 15 |  | ns |
| $\mathrm{t}_{\text {AW }}$ | Address Valid to Write End | 10 |  | 12 |  | 15 |  | ns |
| $\mathrm{t}_{\mathrm{HA}}$ | Address Hold From Write End | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{SA}}{ }^{[15]}$ | Address Set-Up to Write Start | 0 |  | 0 |  | 0 |  | ns |
| tPWE | Write Pulse Width | 10 |  | 12 |  | 15 |  | ns |
| $\mathrm{t}_{\text {SD }}$ | Data Set-Up to Write End | 10 |  | 10 |  | 15 |  | ns |
| $\mathrm{t}_{\mathrm{HD}}$ | Data Hold From Write End | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{HZWE}}{ }^{[17,18]}$ | R/W̄ LOW to High Z |  | 10 |  | 10 |  | 12 | ns |
| $\mathrm{t}_{\text {LZWE }}{ }^{[17,18]}$ | R/W̄ HIGH to Low Z | 3 |  | 3 |  | 3 |  | ns |
| $\mathrm{t}_{\text {WDD }}{ }^{\text {[19] }}$ | Write Pulse to Data Delay |  | 25 |  | 30 |  | 45 | ns |
| $\mathrm{t}_{\text {DDD }}{ }^{\text {[19] }}$ | Write Data Valid to Read Data Valid |  | 20 |  | 25 |  | 30 | ns |
| Busy Timing ${ }^{[20]}$ |  |  |  |  |  |  |  |  |
| $t_{\text {BLA }}$ | $\overline{\text { BUSY }}$ LOW from Address Match |  | 12 |  | 15 |  | 20 | ns |
| $t_{\text {BHA }}$ | $\overline{\text { BUSY }}$ HIGH from Address Mismatch |  | 12 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\text {BLC }}$ | $\overline{B U S Y}$ LOW from $\overline{C E}$ LOW |  | 12 |  | 15 |  | 20 | ns |

Notes:
14. Test conditions assume signal transition time of 3 ns or less, timing reference levels of 1.5 V , input pulse levels of 0 to 3.0 V , and output loading of the specified $\mathrm{I}_{\mathrm{OI}} / \mathrm{I}_{\mathrm{OH}}$ and $10-\mathrm{pF}$ load capacitance.
15. To access RAM, $\overline{C E}=L$ and $\overline{S E M}=H$. To access semaphore, $\overline{C E}=H$ and $\overline{S E M}=L$. Either condition must be valid for the entire $t_{S C E}$ time.
16. At any given temperature and voltage condition for any given device, $t_{\text {HZCE }}$ is less than $t_{\text {LZCE }}$ and $t_{\text {Hzoe }}$ is less than $t_{\text {Lzoe }}$.
17. Test conditions used are Load 2.
18. This parameter is guaranteed by design, but it is not production tested. For information on port-to-port delay through RAM cells from writing port to reading port, refer to Read Timing with Busy waveform.
19. For information on port-to-port delay through RAM cells from writing port to reading port, refer to Read Timing with Busy waveform.
20. Test conditions used are Load 1.

Switching Characteristics Over the Operating Range ${ }^{[14]}$ (continued)

| Parameter | Description | CY7C056V <br> CY7C057V |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | -12 |  | -15 |  | -20 |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Busy Timing ${ }^{[20]}$ |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{BHC}}$ | $\overline{\text { BUSY }}$ HIGH from $\overline{\text { CE }}$ HIGH |  | 12 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\mathrm{PS}}$ | Port Set-Up for Priority | 5 |  | 5 |  | 5 |  | ns |
| $\mathrm{t}_{\mathrm{WB}}$ | R/్̄W LOW after $\overline{\text { BUSY }}$ (Slave) | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {WH }}$ | R/V/ HIGH after $\overline{\text { BUSY }}$ HIGH (Slave) | 11 |  | 13 |  | 15 |  | ns |
| $\mathrm{t}_{\text {BDD }}{ }^{[21]}$ | $\overline{\text { BUSY }}$ HIGH to Data Valid |  | 12 |  | 15 |  | 20 | ns |
| Interrupt Timing ${ }^{[20]}$ |  |  |  |  |  |  |  |  |
| tins | $\overline{\mathrm{INT}}$ Set Time |  | 12 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\text {INR }}$ | $\overline{\text { INT Reset Time }}$ |  | 12 |  | 15 |  | 20 | ns |
| Semaphore Timing |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {SOP }}$ | SEM Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\mathrm{SEM}})$ | 10 |  | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\text {SWRD }}$ | SEM Flag Write to Read Time | 5 |  | 5 |  | 5 |  | ns |
| $\mathrm{t}_{\text {SPS }}$ | SEM Flag Contention Window | 5 |  | 5 |  | 5 |  | ns |
| $t_{\text {SAA }}$ | SEM Address Access Time |  | 12 |  | 15 |  | 20 | ns |

## Data Retention Mode

The CY7C056V and CY7C057V are designed with battery backup in mind. Data retention voltage and supply current are guaranteed over temperature. The following rules ensure data retention:

1. Chip Enable ( $\overline{\mathrm{CE}})^{[3]}$ must be held HIGH during data retention, within $V_{D D}$ to $V_{D D}-0.2 \mathrm{~V}$.
2. $\overline{C E}$ must be kept between $\mathrm{V}_{\mathrm{DD}}-0.2 \mathrm{~V}$ and $70 \%$ of $\mathrm{V}_{\mathrm{DD}}$ during the power-up and power-down transitions.
3. The RAM can begin operation $>t_{R C}$ after $V_{D D}$ reaches the minimum operating voltage ( 3.15 volts).

## Timing



| Parameter | Test Conditions ${ }^{[22]}$ | Max. | Unit |
| :--- | :--- | :---: | :---: |
| $\mathrm{ICC}_{\mathrm{DR} 1}$ | $@ \mathrm{VDD}_{\mathrm{DR}}=2 \mathrm{~V}$ | 50 | $\mu \mathrm{~A}$ |

Notes:
21. $t_{B D D}$ is a calculated parameter and is the greater of $t_{W D D}-t_{P W E}$ (actual) or $t_{D D D}-t_{S D}$ (actual).
22. $C E=V_{D D}, V_{\text {in }}=V_{S S}$ to $V_{D D}, T_{A}=25^{\circ} \mathrm{C}$. This parameter is guaranteed but not tested.

## Switching Waveforms

Read Cycle No. 1 (Either Port Address Access) ${ }^{[23, ~ 24, ~ 25] ~}$


Read Cycle No. 2 (Either Port $\overline{\mathrm{CE}} / \overline{\mathrm{OE}}$ Access) ${ }^{[23,26,27]}$


Read Cycle No. 3 (Either Port) ${ }^{[23, ~ 25, ~ 26, ~ 27] ~}$


## Notes:

23. R/W is HIGH for read cycles.
24. Device is continuously selected. $\overline{C E}_{0}=V_{I L}, C E_{1}=V_{I H}$, and $\bar{B}_{0}, \bar{B}_{1}, \bar{B}_{2}, \bar{B}_{3}, W A, B A$ are valid. This waveform cannot be used for semaphore reads.
25. $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$.
26. Address valid prior to or coinciding with $\overline{\mathrm{CE}}_{0}$ transition LOW and $\mathrm{CE}_{1}$ transition HIGH
27. To access $R A M, \overline{C E}_{0}=V_{L}, C E_{1}=V_{I H}, \bar{B}_{0}, \bar{B}_{1}, \bar{B}_{2}, \bar{B}_{3}, W A, B A$ are valid, and $\overline{S E M}=V_{I H}$. To access semaphore, $\overline{C E}_{0}=V_{I H}, C E_{1}=V_{I L}$ and $\overline{S E M}=V_{I L}$ or $\overline{C E} \overline{S E}_{0}$ and $\mathrm{SEM}=\mathrm{V}_{I L}$, and $\mathrm{CE}_{1}=\mathrm{B}_{0}=\mathrm{B}_{1}=\mathrm{B}_{2}=\mathrm{B}_{3},=\mathrm{V}_{I H}$.

## Switching Waveforms (continued)

Write Cycle No. 1: R/W Controlled Timing ${ }^{[28, ~ 29, ~ 30, ~ 31] ~}$


Write Cycle No. 2: $\overline{\text { CE }}$ Controlled Timing ${ }^{[28, ~ 29, ~ 30, ~ 36] ~}$


## Notes:

28. R/W must be HIGH during all address transitions.
29. A write occurs during the overlap ( $t_{S C E}$ or $t_{P W E}$ ) of $C E_{0}=V_{\| L}$ and $C E_{1}=V_{1 H}$ or $S E M=V_{I L}$ and $B_{0-3} \mathrm{LOW}$.
30. $\mathrm{t}_{\mathrm{HA}}$ is measured from the earlier of $\mathrm{CE}_{0} / C_{E_{1}}$ or $\mathrm{R} / \overline{\mathrm{W}}$ or ( $\overline{\mathrm{SEM}}$ or R/W) going HIGH at the end of Write Cycle.
31. If OE is LOW during a $R / \bar{W}$ controlled write cycle, the write pulse width must be the larger of $t_{P W E}$ or ( $t_{H Z W E}+t_{S D}$ ) to allow the I/O drivers to turn off and data to be placed on the bus for the required $\mathrm{t}_{\text {SD }}$. If OE is HIGH during an R/W controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified $t_{\text {PWE }}$.
32. To access RAM, $\overline{C E}_{0}=V_{I L}, C E_{1}=\overline{S E M}=V_{I H}$.
33. To access byte $\bar{B}_{B}, \frac{\overline{C E}_{0}}{C}=V_{\text {IL }}, \frac{\bar{B}_{0}}{B_{0}}=V_{I L}, C E_{1}=\overline{S E M}=V_{I H}$.

To access byte $\bar{B}_{1}, C_{C}=V_{I L}, B_{1}=V_{I L}, C E_{1}=S E M=V_{I H}$.
To access byte $B_{2}, C E_{0}=V_{I L}, B_{2}=V_{I L}, C E_{1}=S E M=V_{I H}$.
To access byte $\bar{B}_{3}, \overline{C E}_{0}=V_{I L}, \bar{B}_{3}=V_{I L}, \mathrm{CE}_{1}=\mathrm{SEM}=V_{I H}$.
34. Transition is measured $\pm 150 \mathrm{mV}$ from steady state with a $5-\mathrm{pF}$ load (including scope and jig). This parameter is sampled and not $100 \%$ tested.
35. During this period, the I/O pins are in the output state, and input signals must not be applied.
36. If the $\overline{C E}_{0}$ LOW and $\mathrm{CE}_{1}$ HIGH or $\overline{\text { SEM }}$ LOW transition occurs simultaneously with or after the R/W LOW transition, the outputs remain in the high-impedance state.

## Switching Waveforms (continued)

## Semaphore Read After Write Timing, Either Side ${ }^{[37]}$



Timing Diagram of Semaphore Contention ${ }^{[38,39,40]}$


## Notes:

37. $\overline{C E}_{0}=$ HIGH and $\mathrm{CE}_{1}=$ LOW for the duration of the above timing (both write and read cycle).
38. $I / O_{O R}=I / O_{0 L}=$ LOW (request semaphore); $\overline{C E}_{0 R}=\overline{C E}_{0 L}=\mathrm{HIGH}$ and $\mathrm{CE}_{1 R}=C E_{1 L}=L O W$.
39. Semaphores are reset (available to both ports) at cycle start.
40. If $\mathrm{t}_{\text {SPS }}$ is violated, the semaphore will definitely be obtained by one side or the other, but which side will get the semaphore is unpredictable.

CY7C056V
CY7C057V

## Switching Waveforms (continued)

Timing Diagram of Write with $\overline{\text { BUSY }}(\mathbf{M} / \overline{\mathrm{S}}=\mathrm{HIGH})^{[41]}$


Write Timing with Busy Input (M/S = LOW)


Note:
41. $\overline{C E}_{0 L}=\overline{C E}_{0 R}=$ LOW; $C E_{1 L}=C E_{1 R}=\mathrm{HIGH}$.

## Switching Waveforms (continued)

Busy Timing Diagram No. 1 ( $\overline{\text { CE }}$ Arbitration) ${ }^{[42]}$
$\mathrm{CE}_{\mathrm{L}}$ Valid First:

$\overline{\mathrm{CE}}_{\mathrm{R}}$ Valid First:


Busy Timing Diagram No. 2 (Address Arbitration) ${ }^{[42]}$ Left Address Valid First:


Right Address Valid First:


## Note:

42. If $t_{P S}$ is violated, the busy signal will be asserted on one side or the other, but there is no guarantee to which side $\overline{B U S Y}$ will be asserted.

## Switching Waveforms (continued)

Interrupt Timing Diagrams


Right Side Sets $\overline{\mathrm{INT}}_{\mathrm{L}}$ :


Notes:
43. $\mathrm{t}_{\mathrm{HA}}$ depends on which enable pin $\left(\overline{\mathrm{CE}}_{0 \mathrm{~L}} / \mathrm{CE}_{11}\right.$ or $\left.\mathrm{R} / \bar{W}_{\mathrm{L}}\right)$ is deasserted first.
44. $\mathrm{t}_{\text {INS }}$ or $\mathrm{t}_{\mathrm{INR}}$ depends on which enable pin $\left(\overline{\mathrm{CE}}_{0 \mathrm{~L}} / \mathrm{CE}_{1 L}\right.$ or $\left.\mathrm{R} / \overline{\mathrm{W}}_{\mathrm{L}}\right)$ is asserted last.

## Architecture

The CY7C056V and CY7C057V consist of an array of 16 K and 32 K words of 36 bits each of dual-port RAM cells, I/O and address lines, and control signals ( $\left.\mathrm{CE}_{0} / \mathrm{CE}_{1}, \overline{\mathrm{OE}}, \mathrm{R} / \overline{\mathrm{W}}\right)$. These control pins permit independent access for reads or writes to any location in memory. To handle simultaneous writes/reads to the same location, a BUSY pin is provided on each port. Two Interrupt (INT) pins can be utilized for port-to-port communication. Two Semaphore (SEM) control pins are used for allocating shared resources. With the M/S pin, the devices can function as a master ( $\overline{B U S Y}$ pins are outputs) or as a slave (BUSY pins are inputs). The devices also have an automatic power-down feature controlled by $\mathrm{CE}_{0} / \mathrm{CE}_{1}$. Each port is provided with its own Output Enable control ( (ОE), which allows data to be read from the device.

## Functional Description

## Write Operation

Data must be set up for a duration of $t_{S D}$ before the rising edge of $R / \bar{W}$ in order to guarantee a valid write. A write operation is controlled by either the R/W pin (see Write Cycle No. 1 waveform) or the $\overline{\mathrm{CE}}_{0}$ and $\mathrm{CE}_{1}$ pins (see Write Cycle No. 2 waveform). Required inputs for non-contention operations are summarized in Table 1.
If a location is being written to by one port and the opposite port attempts to read that location, a port-to-port flowthrough delay must occur before the data is read on the output; otherwise the data read is not deterministic. Data will be valid on the port $t_{D D D}$ after the data is presented on the other port.

## Read Operation

When reading the device, the user must assert both the $\overline{\mathrm{OE}}$ and $\overline{\mathrm{CE}^{[3]}}$ pins. Data will be available $t_{\text {ACE }}$ after $\overline{\mathrm{CE}}$ or $\mathrm{t}_{\mathrm{DOE}}$ after OE is asserted. If the user wishes to access a semaphore flag, then the $\overline{\text { SEM }}$ pin must be asserted instead of the $\overline{\mathrm{CE}}{ }^{[3]}$ pin, and $\overline{\mathrm{OE}}$ must also be asserted.

## Interrupts

The upper two memory locations may be used for message passing. The highest memory location (3FFF for the CY7C056V, 7FFF for the CY7C057V) is the mailbox for the right port and the second-highest memory location (3FFE for the CY7C056V, 7FFE for the CY7C057V) is the mailbox for the left port. When one port writes to the other port's mailbox, an interrupt is generated to the owner. The interrupt is reset when the owner reads the contents of the mailbox. The message is user defined.
Each port can read the other port's mailbox without resetting the interrupt. The active state of the busy signal (to a port) prevents the port from setting the interrupt to the winning port. Also, an active busy to a port prevents that port from reading its own mailbox and, thus, resetting the interrupt to it.
If an application does not require message passing, do not connect the interrupt pin to the processor's interrupt request input pin.
The operation of the interrupts and their interaction with Busy are summarized in Table 2.

## Busy

The CY7C056V and CY7C057V provide on-chip arbitration to resolve simultaneous memory location access (contention). If
both ports' Chip Enables ${ }^{[3]}$ are asserted and an address match occurs within $t_{P S}$ of each other, the busy logic will determine which port has access. If $t_{p s}$ is violated, one port will definitely gain permission to the location, but it is not predictable which port will get that permission. BUSY will be asserted $\mathrm{t}_{\text {BLA }}$ after an address match or $t_{B L C}$ after CE is taken LOW.

## Master/Slave

A M/ $\bar{S}$ pin is provided in order to expand the word width by configuring the device as either a master or a slave. The BUSY output of the master is connected to the $\overline{B U S Y}$ input of the slave. This will allow the device to interface to a master device with no external components. Writing to slave devices must be delayed until after the BUSY input has settled ( $t_{\text {BLC }}$ or $\mathrm{t}_{\text {BLA }}$ ), otherwise, the slave chip may begin a write_cycle during a contention situation. When tied HIGH, the M/S pin allows the device to be used as a master and, therefore, the BUSY line is an output. $\overline{B U S Y}$ can then be used to send the arbitration outcome to a slave.

## Semaphore Operation

The CY7C056V and CY7C057V provide eight semaphore latches, which are separate from the dual-port memory locations. Semaphores are used to reserve resources that are shared between the two ports. The state of the semaphore indicates that a resource is in use. For example, if the left port wants to request a given resource, it sets a latch by writing a zero to a semaphore location. The left port then verifies its success in setting the latch by reading it. After writing to the semaphore, SEM or OE must be deasserted for tsop before attempting to read the semaphore. The semaphore value will be available $t_{\text {SWRD }}+t_{\text {DOE }}$ after the rising edge of the semaphore write. If the left port was successful (reads a 0), it assumes control of the shared resource, otherwise (reads a 1) it assumes the right port has control and continues to poll the semaphore. When the right side has relinquished control of the semaphore (by writing a 1 ), the left side will succeed in gaining control of the semaphore. If the left side no longer requires the semaphore, a one is written to cancel its request.
Semaphores are accessed by asserting $\overline{\text { SEM }}$ LOW. The $\overline{\text { SEM }}$ pin functions as a chip select for the semaphore latches. For normal semaphore access, $\overline{\mathrm{CE}}^{[3]}$ must remain HIGH during $\overline{\text { SEM }}$ LOW. A $\overline{\mathrm{CE}}$ active semaphore access is also available. The semaphore may be accessed through the right port with $\overline{\mathrm{CE}}_{0 \mathrm{R}} / \mathrm{CE}_{1 \mathrm{R}}$ active by asserting the Bus Match Select (BM) pin LOW and asserting the Bus Size Select (SIZE) pin HIGH. The semaphore may be accessed through the left port with $\overline{C E}_{0 L} / \mathrm{CE}_{1 \mathrm{~L}}$ active by asserting all $\overline{\mathrm{B}}_{0-3}$ Byte Select pins HIGH. $\mathrm{A}_{0-2}$ represents the semaphore address. $\overline{\mathrm{OE}}$ and $\mathrm{R} / \overline{\mathrm{W}}$ are used in the same manner as a normal memory access. When writing or reading a semaphore, the other address pins have no effect.
When writing to the semaphore, only $\mathrm{I} / \mathrm{O}_{0}$ is used. If a zero is written to the left port of an available semaphore, a 1 will appear at the same semaphore address on the right port. That semaphore can now only be modified by the port showing 0 (the left port in this case). If the left port now relinquishes control by writing a 1 to the semaphore, the semaphore will be set to 1 for both ports. However, if the right port had requested the semaphore (written a 0 ) while the left port had control, the right port would immediately own the semaphore as soon as the left port released it. Table 3 shows sample semaphore operations.

Table 1. Non-Contending Read/Write ${ }^{[3]}$

| Inputs |  |  |  |  | Outputs | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CE}}$ | R/W | $\overline{\mathrm{OE}}$ | $\bar{B}_{0}, \bar{B}_{1}, \bar{B}_{2}, \bar{B}_{3}$ | $\overline{\text { SEM }}$ | $\mathrm{I} / \mathrm{O}_{0}-1 / \mathrm{O}_{35}$ |  |
| H | X | X | X | H | High Z | Deselected: Power-Down |
| X | X | X | All H | H | High Z | Deselected: Power-Down |
| L | L | X | H/L | H | Data In and High Z | Write to Selected Bytes Only |
| L | L | X | All L | H | Data In | Write to All Bytes |
| L | H | L | H/L | H | Data Out and High Z | Read Selected Bytes Only |
| L | H | L | All L | H | Data Out | Read All Bytes |
| X | X | H | X | X | High Z | Outputs Disabled |
| H | H | L | X | L | Data Out | Read Data in Semaphore Flag |
| X | H | L | All H | L | Data Out | Read Data in Semaphore Flag |
| H | - | X | X | L | Data In | Write $\mathrm{D}_{\text {INO }}$ into Semaphore Flag |
| X | - | X | All H | L | Data In | Write $\mathrm{D}_{\text {INO }}$ into Semaphore Flag |
| L | X | X | Any L | L |  | Not Allowed |

Table 2. Interrupt Operation Example (assumes $\left.\overline{\mathrm{BUSY}}_{\mathrm{L}}=\overline{\mathrm{BUSY}}_{\mathrm{R}}=\mathrm{HIGH}\right)^{[3,45]}$

|  | Left Port |  |  |  |  | Right Port |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Function | $\mathrm{R} / \overline{\mathbf{W}}_{\mathrm{L}}$ | $\overline{C E}_{L}$ | $\overline{\mathrm{OE}}_{\mathrm{L}}$ | A0L-13L | $\overline{\mathbf{I N T}}_{\text {L }}$ | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | $\overline{\mathrm{CE}}_{\mathrm{R}}$ | $\overline{\mathrm{OE}}_{\mathrm{R}}$ | A0R-13R | $\overline{\mathbf{I N T}}_{\text {R }}$ |
| Set Right $\overline{\mathrm{NT}}_{\mathrm{R}}$ Flag | L | L | X | 3FFF | X | X | X | X | X | $L^{[47]}$ |
| Reset Right $\mathrm{INT}_{\mathrm{R}}$ Flag | X | X | X | X | X | X | L | L | 3FFF | $\mathrm{H}^{[46]}$ |
| Set Left $\overline{\mathrm{NT}}_{\mathrm{L}}$ Flag | X | X | X | X | $L^{[46]}$ | L | L | X | 3FFE | X |
| Reset Left INT ${ }_{\text {L }}$ Flag | X | L | L | 3FFE | $\mathrm{H}^{[47]}$ | X | X | X | X | X |

Table 3. Semaphore Operation Example

| Function | $\mathbf{I / \mathbf { O } _ { \mathbf { 0 } } - \mathbf { l / \mathbf { O } _ { \mathbf { 8 } } } \mathbf { \text { Left } }}$ | $\mathbf{I / \mathbf { O } _ { \mathbf { 0 } } - \mathbf { I / } \mathbf { O } _ { \mathbf { 8 } } \text { Right }}$ |  |
| :--- | :---: | :---: | :--- |
| No Action | 1 | 1 | Status |
| Left Port Writes 0 to Semaphore | 0 | 1 | Left Port Has Semaphore Token |
| Right Port Writes 0 to <br> Semaphore | 0 | 1 | No Change. Right Side Has No Write Access to <br> Semaphore |
| Left Port Writes 1 to Semaphore | 1 | 0 | Right Port Obtains Semaphore Token |
| Left Port Writes 0 to Semaphore | 1 | 0 | No Change. Left Port Has No Write Access to Semaphore |
| Right Port Writes 1 to <br> Semaphore | 0 | 1 | Left Port Obtains Semaphore Token |
| Left Port Writes 1 to Semaphore | 1 | 1 | Semaphore Free |
| Right Port Writes 0 to <br> Semaphore | 1 | 0 | Right Port Has Semaphore Token |
| Right Port Writes 1 to <br> Semaphore | 1 | 1 | Semaphore Free |
| Left Port Writes 0 to Semaphore | 0 | 1 | Left Port Has Semaphore Token |
| Left Port Writes 1 to Semaphore | 1 | 1 | Semaphore Free |

## Notes:

45. $A_{0 \perp-14 ।}$ and $A_{0 R-14 R}$, 7FFF/7FFE for the CY7C057V.
46. If $\overline{B U S Y}_{R}=L$, then no change.
47. If $\overline{B U S Y}_{L}=L$, then no change.

CY7C056V
CY7C057V

## Right Port Configuration ${ }^{[48, ~ 49, ~ 50] ~}$

| BM | SIZE | Configuration | $\mathrm{I} / \mathrm{O}$ Pins Used |
| :---: | :---: | :---: | :---: |
| 0 | 0 | $\mathrm{x} 36($ Standard $)$ | $\mathrm{I} / \mathrm{O}_{0-35}$ |
| 0 | 1 | $\mathrm{x} 36(\overline{\mathrm{CE}}$ Active $\overline{\text { SEM }}$ Mode $)$ | $\mathrm{I} / \mathrm{O}_{0-35}$ |
| 1 | 0 | x 18 | $\mathrm{I} / \mathrm{O}_{0-17}$ |
| 1 | 1 | x 9 | $\mathrm{I} / \mathrm{O}_{0-8}$ |

## Right Port Operation

| Configuration | WA | BA | Data Accessed ${ }^{[51]}$ | I/O Pins Used |
| :---: | :---: | :---: | :---: | :---: |
| x36 | X | X | $\mathrm{DQ}_{0-35}$ | $1 / \mathrm{O}_{0-35}$ |
| x18 | 0 | X | $\mathrm{DQ}_{0-17}$ | $\mathrm{l} / \mathrm{O}_{0-17}$ |
| x18 | 1 | X | $\mathrm{DQ}_{18-35}$ | $\mathrm{l} / \mathrm{O}_{0-17}$ |
| x9 | 0 | 0 | $\mathrm{DQ}_{0-8}$ | $1 / \mathrm{O}_{0-8}$ |
| x9 | 0 | 1 | $\mathrm{DQ}_{9-17}$ | $1 / \mathrm{O}_{0-8}$ |
| x9 | 1 | 0 | $\mathrm{DQ}_{18-26}$ | $1 / \mathrm{O}_{0-8}$ |
| x9 | 1 | 1 | $\mathrm{DQ}_{27-35}$ | $\mathrm{I} / \mathrm{O}_{0-8}$ |

## Left Port Operation

| Control Pin | Effect |
| :---: | :---: |
| $\overline{\mathrm{B} 0}$ | $\mathrm{I} / \mathrm{O}_{0-8}$ Byte Control |
| $\overline{\mathrm{B} 1}$ | $\mathrm{I} / \mathrm{O}_{9-17}$ Byte Control |
| $\overline{\mathrm{B} 2}$ | $\mathrm{I} / \mathrm{O}_{18-26}$ Byte Control |
| $\overline{\mathrm{B} 3}$ | $\mathrm{I} / \mathrm{O}_{27-35}$ Byte Control |

When reading a semaphore, data lines 0 through 8 output the semaphore value. The read value is latched in an output register to prevent the semaphore from changing state during a write from the other port. If both ports attempt to access the semaphore within $t_{\text {SPS }}$ of each other, the semaphore will definitely be obtained by one side or the other, but there is no guarantee which side will control the semaphore.
When reading a semaphore, data lines 0 through 8 output the semaphore value. The read value is latched in an output register to prevent the semaphore from changing state during a write from the other port. If both ports attempt to access the semaphore within $\mathrm{t}_{\text {SPS }}$ of each other, the semaphore will definitely be obtained by one side or the other, but there is no guarantee which side will control the semaphore.
When reading a semaphore, data lines 0 through 8 output the semaphore value. The read value is latched in an output register to prevent the semaphore from changing state during a write from the other port. If both ports attempt to access the semaphore within $\mathrm{t}_{\text {SPS }}$ of each other, the semaphore will definitely be obtained by one side or the other, but there is no guarantee which side will control the semaphore.

## Bus Match Operation

The right port of the CY7C057V 32Kx36 dual-port SRAM can be configured in a 36 -bit long-word, 18-bit word, or 9-bit byte format for data $\mathrm{I} / \mathrm{O}$. The data lines are divided into four lanes, each consisting of 9 bits (byte-size data lines).


The Bus Match Select (BM) pin works with Bus Size Select (SIZE) to select bus width (long-word, word, or byte) for the
right port of the dual-port device. The data sequencing (SIZE) to select bus width (long-word, word, or byte) for the
right port of the dual-port device. The data sequencing arrangement is selected using the Word Address (WA) and Byte Address (BA) input pins. A logic " 0 " applied to both the Bus Match Select (BM) pin and to the Bus Size Select (SIZE)

## Notes:

48. BM and SIZE must be configured one clock cycle before operation is guaranteed. 49. In x36 mode WA and BA pins are "Don't Care."
49. In $\times 18$ mode BA pin is a "Don't Care."
50. DQ represents data output of the chip.

CY7C056V CY7C057V
pin will select long-word (36-bit) operation. A logic " 1 " level applied to the Bus Match Select (BM) pin will enable either byte or word bus width operation on the right port I/Os depending on the logic level applied to the SIZE pin. The level of Bus Match Select (BM) must be static throughout device operation.
Normally, the Bus Size Select (SIZE) pin would have no standard-cycle application when BM = LOW and the device is in long-word (36-bit) operation. A "special" mode has been added however to disable ALL right port I/Os while the chip is active. This I/O disable mode is implemented when SIZE is forced to a logic " 1 " while BM is at a logic " 0 ". It allows the bus-matched port to support a chip enable "Don't Care" semaphore read/write access similar to that provided on the left port of the device when all Byte Select ( $\mathrm{B}_{0-3}$ ) control inputs are deselected.

The Bus Size Select (SIZE) pin selects either a byte or word data arrangement on the right port when the Bus Match Select (BM) pin is HIGH. A logic " 1 " on the SIZE pin when the BM pin is HIGH selects a byte bus (9-bit) data arrangement). A logic " 0 " on the SIZE pin when the BM pin is HIGH selects a word bus (18-bit) data arrangement. The level of the Bus Size Select (SIZE) must also be static throughout normal device operation.

## Long-Word (36-bit) Operation

Bus Match Select (BM) and Bus Size Select (SIZE) set to a logic "0" will enable standard cycle long-word (36-bit) operation. In this mode, the right port's I/O operates essentially in an identical fashion as does the left port of the dual-port SRAM. However no Byte Select control is available. All 36 bits of the long-word are shifted into and out of the right port's I/O buffer stages. All read and write timing parameters may be identical with respect to the two data ports. When the right port is configured for a long-word size, Word Address (WA), and Byte Address (BA) pins have no application and their inputs are "Don't Care" ${ }^{[52]}$ for the external user.

## Word (18-bit) Operation

Word (18-bit) bus sizing operation is enabled when Bus Match Select (BM) is set to a logic " 1 " and the Bus SIze Select (SIZE) pin is set to a logic " 0 ." In this mode, 18 bits of data are ported through $\mathrm{I} / \mathrm{O}_{0 \mathrm{R}-17 \mathrm{R}}$. The level applied to the Word Address (WA) pin during word bus size operation determines whether the most-significant or least-significant data bits are ported through the I/O $\mathrm{O}_{0 \mathrm{R}-17 \mathrm{R}}$ pins in an Upper Word/Lower Word select fashion (note that when the right port is configured for word size operation, the Byte Address pin has no application and its input is "Don't Care" ${ }^{[52]}$ ).
Device operation is accomplished by treating the WA pin as an additional address input and using standard cycle address and data setup/hold times. When transferring data in word (18-bit) bus match format, the unused $1 / \mathrm{O}_{18 \mathrm{R}-35 \mathrm{R}}$ pins are three-stated.

## Byte (9-bit) Operation

Byte (9-bit) bus sizing operation is enabled when Bus Match Select (BM) is set to a logic " 1 " and the Bus Size Select (SIZE) pin is set to a logic "1." In this mode, data is ported through $\mathrm{I} / \mathrm{O}_{0 \mathrm{R}-8 \mathrm{R}}$ in four groups of 9-bit bytes. A particular 9-bit byte group is selected according to the levels applied to the Word Address (WA) and Byte Address (BA) input pins.

| I/Os | Rank | WA | BA |
| :---: | :---: | :---: | :---: |
| $\mathrm{I} / \mathrm{O}_{27 \mathrm{R}-35 \mathrm{R}}$ | Upper-MSB | 1 | 1 |
| $\mathrm{I} / \mathrm{O}_{18 \mathrm{R}-26 \mathrm{R}}$ | Lower-MSB | 1 | 0 |
| $\mathrm{I} / \mathrm{O}_{9 R-17 \mathrm{R}}$ | Upper-MSB | 0 | 1 |
| $\mathrm{I} / \mathrm{O}_{0 \mathrm{R}-8 \mathrm{R}}$ | Lower-MSB | 0 | 0 |

Device operation is accomplished by treating the Word Address (WA) pin and the Byte Address (BA) pins as additional address inputs having standard cycle address and data set-up/hold times. When transferring data in byte (9-bit) bus match format, the unused I/O $\mathrm{O}_{9 R-35 R}$ pins are three-stated.

[^1]
## Ordering Information

| Speed <br> (ns) | Ordering Code | Package <br> Name | Operating <br> Range |  |
| :---: | :--- | :---: | :--- | :--- |
| 12 | CY7C056V-12AC | A144 | 144-Pin Thin Quad Flat Pack | Commercial |
|  | CY7C056V-12AXC | A144 | 144-Pin Pb-Free Thin Quad Flat Pack |  |
|  | CY7C056V-12BBC | BB172 | 172-Ball Ball Grid Array (BGA) |  |
|  | CY7C056V-15AC | A144 | 144-Pin Thin Quad Flat Pack |  |
|  | CY7C056V-15AXC | A144 | 144-Pin Pb-Free Thin Quad Flat Pack |  |
|  | CY7C056V-15BBC | BB172 | 172-Ball Ball Grid Array (BGA) |  |
| 20 | CY7C056V-20AC | A144 | 144-Pin Thin Quad Flat Pack | Commercial |
|  | CY7C056V-20BBC | BB172 | 172-Ball Ball Grid Array (BGA) |  |


| Speed <br> (ns) | Ordering Code | Package <br> Name | Operating <br> Range |  |
| :---: | :--- | :---: | :--- | :--- |
| 12 | CY7C057V-12AC | A144 | 144-Pin Thin Quad Flat Pack | Commercial |
|  | CY7C057V-12AXC | A144 | 144-Pin Pb-Free Thin Quad Flat Pack |  |
|  | CY7C057V-12BBC | BB172 | 172-Ball Ball Grid Array (BGA) |  |
|  | CY7C057V-15AC | A144 | 144-Pin Thin Quad Flat Pack | Commercial |
|  | CY7C057V-15AXC | A144 | 144-Pin Pb-Free Thin Quad Flat Pack |  |
|  | CY7C057V-15AI | A144 | 144-Pin Thin Quad Flat Pack | Industrial |
|  | CY7C057V-15AXI | A144 | 144-Pin Pb-Free Thin Quad Flat Pack |  |
|  | CY7C057V-15BBC | BB172 | 172-Ball Ball Grid Array (BGA) | Commercial |
|  | CY7C057V-15BBI | BB172 | 172-Ball Ball Grid Array (BGA) | Industrial |
| 20 | CY7C057V-20AC | A144 | 144-Pin Thin Quad Flat Pack | Commercial |
|  | CY7C057V-20BBC | BB172 | 172-Ball Ball Grid Array (BGA) |  |

## Package Diagrams

144-Pin Plastic Thin Quad Flat Pack (TQFP) A144
144-Pin Pb-Free Plastic Thin Quad Flat Pack (TQFP) A144


DETAIL A 51-85047-*A

Package Diagrams (continued)
172-Ball FBGA (15 x $15 \times 1.25 \mathrm{~mm}$ ) BB172


FLEx36 is a trademark of Cypress Semiconductor Corporation. All products and company names mentioned in this document may be the trademarks of their respective holders.

CY7C056V
CY7C057V

## Document History Page

Document Title: CY7C056V/CY7C057V 3.3V 16K/32K x 36 FLEx36 ${ }^{\text {TM }}$ Asynchronous Dual-Port Static RAM
Document Number: 38-06055

| REV. | ECN NO. | Issue <br> Date | Orig. of <br> Change | Description of Change |
| :---: | :---: | :---: | :---: | :--- |
| ${ }^{* *}$ | 110214 | $12 / 16 / 01$ | SZV | Change from Spec number: 38-00742 to 38-06055 |
| ${ }^{*} \mathrm{~A}$ | 122305 | $12 / 27 / 02$ | RBI | Power up requirements added to Maximum Ratings Information |
| ${ }^{*} \mathrm{~B}$ | 393770 | See ECN | YIM | Added Pb-Free Logo <br> Added Pb-Free parts to ordering information: <br> CY7C056V-12AXC, CY7C056V-15AXC, CY7C057V-12AXC, <br> CY7C057V-15AXC, CY7CO57V-15AXI |


[^0]:    Note:
    3. $\overline{\mathrm{CE}}$ is LOW when $\overline{\mathrm{CE}}_{0} \leq \mathrm{V}_{\mathrm{IL}}$ and $\mathrm{CE}_{1} \geq \mathrm{V}_{\mathrm{IH}}$

[^1]:    Note:
    52. Even though a logic level applied to a "Don't Care" input will not change the logical operation of the dual-port, inputs that are temporarily a "Don't Care" (along with unused inputs) must not be allowed to float. They must be forced either HIGH or LOW.

