## CY7C024E, CY7C0241E CY7C025E, CY7C0251E

 4K x 16/18 and 8K x 16/18 Dual-Port Static RAM with SEM, INT, BUSY
## Features

- True dual-ported memory cells that allow simultaneous reads of the same memory location
■ 4K $\times 16$ organization (CY7C024E)
■ 4K $\times 18$ organization (CY7C0241E)
- $8 \mathrm{~K} \times 16$ organization (CY7C025E)
- 8K $\times 18$ organization (CY7C0251E)
- $0.35-\mu$ complementary metal oxide semiconductor (CMOS) for optimum speed and power

■ High-speed access: 15 ns
L Low operating power: $\mathrm{I}_{\mathrm{CC}}=180 \mathrm{~mA}$ (typ), $\mathrm{I}_{\mathrm{SB} 3}=0.05 \mathrm{~mA}$ (typ)
■ Fully asynchronous operation

- Automatic power-down
- Expandable data bus to $32 / 36$ bits or more using master/slave chip select when using more than one device

■ On-chip arbitration logic
■ Semaphores included to permit software handshaking between ports

- INT flag for port-to-port communication
- Separate upper-byte and lower-byte control

■ Pin select for master or slave

- Available in Pb-free 100-pin thin quad flatpack (TQFP) package


## Functional Description

The CY7C024E/CY7C0241E and CY7C025E/CY7C0251E are low-power CMOS 4K $\times 16 / 18$ and $8 \mathrm{~K} \times 16 / 18$ dual-port static RAMs. Various arbitration schemes are included on the CY7C024E/CY7C0241E and CY7C025E/CY7C0251E 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 CY7C024E/CY7C0241E and CY7C025E/CY7C0251E can be used as standalone 16 or 18-bit dual-port static RAMs or multiple devices can be combined to function as a $32-/ 36$-bit or wider master/ slave dual-port static RAM. An M/S pin is provided for implementing 32-/36-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.
Each port has independent control pins: Chip Enable ( $\overline{\mathrm{CE}})$, Read or Write Enable (R/W), and Output Enable (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 a CE pin.

The CY7C024E/CY7C0241E and CY7C025E/CY7C0251E are available in 100 -pin Pb-free TQFP.

## Selection Guide

| Parameter | $\mathbf{- 1 5}$ | $\mathbf{- 2 5}$ | $\mathbf{- 5 5}$ |
| :--- | :---: | :---: | :---: |
| Maximum access time (ns) | 15 | 25 | 55 |
| Typical operating current (mA) | 190 | 170 | 150 |
| Typical standby current for $\mathrm{I}_{\mathrm{SB} 1}(\mathrm{~mA})$ | 50 | 40 | 20 |

CY7C024E, CY7C0241E CY7C025E, CY7C0251E

## Logic Block Diagram



## Notes

1. BUSY is an output in master mode and an input in slave mode
2. $\mathrm{I} / \mathrm{O}_{0}-\mathrm{l} / \mathrm{O}_{8}$ on the CY7C0241E/CY7C0251E.
3. $1 / \mathrm{O}_{9}-1 / \mathrm{O}_{17}$ on the CY7C0241E/CY7C0251E.

CY7C024E, CY7C0241E CY7C025E, CY7C0251E

## Contents

Pin Configurations ..... 4
Pin Definitions ..... 5
Architecture ..... 6
Functional Description ..... 6
Write Operation ..... 6
Read Operation ..... 6
Interrupts ..... 6
Busy ..... 6
Master/Slave ..... 6
Semaphore Operation ..... 6
Maximum Ratings ..... 9
Operating Range ..... 9
Electrical Characteristics Over the Operating Range ..... 9
Capacitance[12] ..... 9
Switching Characteristics Over the Operating Range ..... 10
Data Retention Mode ..... 12
Timing ..... 12
Switching Waveforms ..... 12
Ordering Information (4K x16 Dual-Port SRAM) ..... 19
Ordering Information (8K x 16 Dual-Port SRAM) ..... 19
Ordering Information (4K x 18 Dual-Port SRAM) ..... 19
Ordering Information (8K x 18 Dual-Port SRAM ) ..... 19
Ordering Code Definition ..... 19
Package Diagrams ..... 21
Acronyms ..... 21
Document History Page ..... 22
Sales, Solutions, and Legal Information ..... 22
Worldwide Sales and Design Support ..... 22
Products ..... 22
PSoC Solutions ..... 22

CY7C024E, CY7C0241E CY7C025E, CY7C0251E

## Pin Configurations

Figure 1. 100-Pin TQFP (Top View)


## Notes

4. $\mathrm{A}_{12 \mathrm{~L}}$ on the CY7C025E/CY7C0251E.
5. $A_{12 R}$ on the CY7C025E/CY7C0251E.

Figure 2. 100-Pin TQFP (Top View)


Pin Definitions

| Left Port | Right Port | Description |
| :---: | :---: | :---: |
| $\overline{\mathrm{CE}}_{\mathrm{L}}$ | $\overline{\mathrm{CE}}_{\mathrm{R}}$ | Chip enable |
| $\mathrm{R} / \bar{W}_{\mathrm{L}}$ | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | Read/write enable |
| $\overline{\mathrm{OE}}_{\mathrm{L}}$ | $\overline{\mathrm{OE}}_{\mathrm{R}}$ | Output enable |
| $\mathrm{A}_{0 \mathrm{~L}}-\mathrm{A}_{11 / 12 \mathrm{~L}}$ | $\mathrm{A}_{0 \mathrm{R}}-\mathrm{A}_{11 / 12 \mathrm{R}}$ | Address |
| $\mathrm{I} / \mathrm{O}_{0 \mathrm{~L}}-\mathrm{l} / \mathrm{O}_{15 / 17 \mathrm{~L}}$ | $\mathrm{I} / \mathrm{O}_{0 \mathrm{R}}-\mathrm{l} / \mathrm{O}_{15 / 17 \mathrm{R}}$ | Data bus input/output |
| $\overline{\text { SEM }}_{\text {L }}$ | $\overline{S E M}_{R}$ | Semaphore enable |
| $\overline{\mathrm{UB}}_{\mathrm{L}}$ | $\overline{\mathrm{UB}}_{\mathrm{R}}$ | Upper byte select |
| $\overline{\mathrm{LB}}_{\mathrm{L}}$ | $\overline{\mathrm{LB}}_{\mathrm{R}}$ | Lower byte select |
| $\overline{\mathrm{INT}}_{\mathrm{L}}$ | $\overline{\mathrm{INT}}_{\mathrm{R}}$ | Interrupt flag |
| $\overline{\mathrm{BUSY}}_{\mathrm{L}}{ }^{[8]}$ | $\overline{\mathrm{BUSY}}_{\mathrm{R}}{ }^{[8]}$ | Busy flag |
| M/ $\bar{S}$ |  | Master or slave select |
| $\mathrm{V}_{\text {CC }}$ |  | Power |
| GND |  | Ground |

## Notes

6. $\mathrm{A}_{12 \mathrm{~L}}$ on the CY7C025E/CY7C0251E.
7. $\overline{A_{12 R}}$ on the CY7C025E/CY7C0251E.
8. BUSY is an output in master mode and an input in slave mode.

## Architecture

The CY7C024E/CY7C0241E and CY7C025E/CY7C0251E consist of an array of 4 K words of $16 / 18$ bits each and 8 K words of 16/18 bits each of dual-port RAM cells, I/O and address lines, and control signals ( $\overline{\mathrm{CE}}, \overline{\mathrm{OE}}, \mathrm{R} / \overline{\mathrm{W}}$ ). 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 used for port-to-port communication. Two semaphore ( $\overline{\mathrm{SEM}}$ ) control pins are used for allocating shared resources. With the M/S pin, the CY7C024E/CY7C0241E and CY7C025E/CY7C0251E can function as a master (BUSY pins are outputs) or as a slave ( $\overline{B U S Y}$ pins are inputs). The CY7C024E/CY7C0241E and CY7C025E/CY7C0251E have an automatic power-down feature controlled by $\overline{\mathrm{CE}}$. Each port is provided with its own output enable control ( $\overline{\mathrm{OE}})$, which allows data to be read from the device.

## Functional Description

## Write Operation

Data must be set up for a duration of $t_{\text {SD }}$ before the rising edge of $R / \bar{W}$ to guarantee a valid write. A write operation is controlled by either the $R / \bar{W}$ pin (see Figure 7) or the CE pin (see Figure 8). 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 is 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{C E}$ pins. Data is available $t_{A C E}$ after $\overline{C E}$ or $t_{D O E}$ after $\overline{O E}$ is asserted. If the user of the CY7C024E/CY7C0241E and CY7C025E/CY7C0251E wishes to access a semaphore flag, then the SEM pin must be asserted instead of the CE 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 (FFF for the CY7C024E/CY7C0241E, 1FFF for the CY7C025E/CY7C0251E) is the mailbox for the right port and the second-highest memory location (FFE for the CY7C024E/CY7C0241E, 1FFE for the CY7C025E/CY7C0251E) 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 $\overline{B U S Y}$ to a port prevents that port from reading its own mailbox and thus resetting the interrupt to it.

If your 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 on page 8.

## Busy

The CY7C024E/CY7C0241E and CY7C025E/CY7C0251E provide on-chip arbitration to resolve simultaneous memory location access (contention). If both ports' $\overline{\mathrm{CE}}$ s are asserted and an address match occurs within $t_{P S}$ of each other, the busy logic determines which port has access. If $t_{P S}$ is violated, one port definitely gains permission to the location, but which one is not predictable. $\overline{B U S Y}$ is asserted $t_{B L A}$ after an address match or $\mathrm{t}_{\mathrm{BLC}}$ after $\overline{\mathrm{CE}}$ is taken LOW.

## Master/Slave

A $M / \bar{S}$ pin is provided 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 allows 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 ( $\mathrm{t}_{\mathrm{BLC}}$ or $\mathrm{t}_{\mathrm{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 CY7C024E/CY7C0241E and CY7C025E/CY7C0251E 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, $\overline{\mathrm{SEM}}$ or $\overline{\mathrm{OE}}$ must be deasserted for tSOP before attempting to read the semaphore. The semaphore value is available t $_{\text {SWRD }}+$ t $_{\text {DOE }}$ after the rising edge of the semaphore write. If the left port was successful (reads a zero), it assumes control of the shared resource, otherwise (reads a one) 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 one), the left side succeeds 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 ( $\overline{C E}$ must remain HIGH during SEM LOW). AO-2 represents the semaphore address. OE and R/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 one appears at the same semaphore address on the right port. That semaphore can now only be modified by the side showing zero (the left port in this case). If the left port now relinquishes control by writing a one to the semaphore, the semaphore is set to one for both sides. However, if the right port had requested the semaphore (written a zero) while the left port had control, the right port immediately owns the semaphore as soon as the left
port releases it. Table 3 on page 8 shows sample semaphore operations.
When reading a semaphore, all 16/18 data lines 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 is definitely obtained by one side or the other, but there is no guarantee which side controls the semaphore.

Table 1. Non-Contending Read/Write

| Inputs |  |  |  |  |  | Outputs |  | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CE | R/W | OE | UB | LB | SEM | $1 / \mathrm{O}_{0}-1 / \mathrm{O}_{7}{ }^{[9]}$ | $1 / \mathrm{O}_{8}-1 / \mathrm{O}_{15}{ }^{[10]}$ |  |
| H | X | X | X | X | H | High Z | High Z | Deselected: power-down |
| X | X | X | H | H | H | High Z | High Z | Deselected: power-down |
| L | L | X | L | H | H | High Z | Data in | Write to upper byte only |
| L | L | X | H | L | H | Data in | High Z | Write to lower byte only |
| L | L | X | L | L | H | Data in | Data in | Write to both bytes |
| L | H | L | L | H | H | High Z | Data out | Read upper byte only |
| L | H | L | H | L | H | Data out | High Z | Read lower byte only |
| L | H | L | L | L | H | Data out | Data out | Read both bytes |
| X | X | H | X | X | X | High Z | High Z | Outputs disabled |
| H | H | L | X | X | L | Data out | Data out | Read data in semaphore flag |
| X | H | L | H | H | L | Data out | Data out | Read data in semaphore flag |
| H | $\ldots$ | X | X | X | L | Data in | Data in | Write $\mathrm{D}_{\text {INo }}$ into semaphore flag |
| X | $\checkmark$ | X | H | H | L | Data in | Data in | Write $\mathrm{D}_{\text {INo }}$ into semaphore flag |
| L | X | X | L | X | L |  |  | Not allowed |
| L | X | X | X | L | L |  |  | Not allowed |

[^0]Table 2. Interrupt Operation Example (Assumes $\left.\overline{\mathrm{BUSY}}_{\mathrm{L}}=\overline{\mathrm{BUSY}}_{\mathrm{R}}=\mathrm{HIGH}\right)^{[11]}$

| Function | Left Port |  |  |  |  | Right Port |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{R} / \bar{W}_{\mathrm{L}}$ | $\overline{C E}_{L}$ | $\overline{\mathrm{OE}}_{\mathrm{L}}$ | A ${ }_{\text {0L-11L }}$ | $\overline{\mathbf{I N T}}_{\mathrm{L}}$ | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | $\overline{C E}_{R}$ | $\overline{O E}_{R}$ | $\mathrm{A}_{0 \mathrm{R}-11 \mathrm{R}}$ | $\overline{\mathrm{INT}}_{\mathrm{R}}$ |
| Set right $\overline{\mathrm{NT}}_{\mathrm{R}}$ flag | L | L | X | (1)FFF | X | X | X | X | X | $L^{[12]}$ |
| Reset right $\overline{\mathrm{NT}}_{\mathrm{R}}$ flag | X | X | X | X | X | X | L | L | (1)FFF | $\mathrm{H}^{[13]}$ |
| Set left INT ${ }_{\text {L }}$ flag | X | X | X | X | $L^{[13]}$ | L | L | X | (1)FFE | X |
| Reset left $\overline{\mathrm{NT}}_{\mathrm{L}}$ flag | X | L | L | (1)FFE | $\mathrm{H}^{[12]}$ | X | X | X | X | X |

Table 3. Semaphore Operation Example

| Function | $\mathrm{I} / \mathrm{O}_{0}-\mathrm{I} / \mathrm{O}_{15 / 17}{ }_{\text {Left }}$ | $\begin{aligned} & \hline 1 / \mathrm{O}_{0}-1 / \mathrm{O}_{15 / 17} \\ & \text { Right } \end{aligned}$ | Status |
| :---: | :---: | :---: | :---: |
| No action | 1 | 1 | Semaphore-free |
| Left port writes 0 to semaphore | 0 | 1 | Left port has semaphore token |
| Right port writes 0 to semaphore | 0 | 1 | No change. Right side has no write access to 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 semaphore | 0 | 1 | Left port obtains semaphore token |
| Left port writes 1 to semaphore | 1 | 1 | Semaphore-free |
| Right port writes 0 to semaphore | 1 | 0 | Right port has semaphore token |
| Right port writes 1 to 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 |

[^1]
## Maximum Ratings

Exceeding maximum ratings may shorten the useful life of the device. User guidelines are not tested. ${ }^{[14]}$
Storage temperature $\qquad$ $-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 $\qquad$ . -0.3 V to +7.0 V
DC voltage applied to outputs in high $Z$ state $\qquad$ .. 0.5 V to +7.0 V

DC input voltage ${ }^{[15]}$ $\qquad$ -0.5 V to +7.0 V

Output current into outputs (LOW)
.20 mA
Static discharge voltage......................................... > 2001 V
(per MIL-STD-883, Method 3015)
Latch-up current ................................................... > 200 mA
Operating Range

| Range | Ambient Temperature | $\mathbf{V}_{\text {cc }}$ |
| :--- | :---: | :---: |
| Commercial | $0{ }^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ |

Electrical Characteristics Over the Operating Range

| Parameter | Description | Test Conditions |  | -15 |  |  | -25 |  |  | -55 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max | Min | Typ | Max | Min | Typ | Max |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-4.0 \mathrm{~mA}$ |  | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH voltage |  |  | 2.2 | - |  | 2.2 | - |  | 2.2 | - |  | V |
| $\mathrm{V}_{\text {IL }}$ | Input LOW voltage |  |  | -0.7 | - | 0.8 | -0.7 | - | 0.8 | -0.7 | - | 0.8 | V |
| IIX | Input leakage current | $\mathrm{GND} \leq \mathrm{V}_{\mathrm{I}} \leq \mathrm{V}_{\mathrm{CC}}$ |  | -10 | - | +10 | -10 | - | +10 | -10 | - | +10 | $\mu \mathrm{A}$ |
| I OZ | Output leakage current | Output disabled,$\mathrm{GND} \leq \mathrm{V}_{\mathrm{O}} \leq \mathrm{V}_{\mathrm{CC}}$ |  | -10 | - | +10 | -10 | - | +10 | -10 | - | +10 | $\mu \mathrm{A}$ |
| ${ }^{\text {cc }}$ | Operating current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{I}_{\mathrm{OUT}}=0 \mathrm{~mA},$ Outputs Disabled | Commercial | - | 190 | 285 | - | 170 | 250 | - | 150 | 230 | mA |
|  |  |  | Industrial | - | 215 | 305 | - | 180 | 290 | - | 180 | 290 |  |
| $\mathrm{I}_{\text {SB1 }}$ | Standby current (both ports TTL levels) | $\begin{aligned} & \overline{C E}_{L} \text { and } \overline{C E}_{R} \geq V_{I H}, \\ & f=f_{M A X}[16] \end{aligned}$ | Commercial | - | 50 | 70 | - | 40 | 60 | - | 20 | 50 | mA |
|  |  |  | Industrial | - | 65 | 95 | - | 55 | 80 | - | 55 | 80 |  |
| $\mathrm{I}_{\text {SB2 }}$ | Standby current (one port TTL level) | $\begin{aligned} & \overline{C E}_{L} \text { or } \overline{C E}_{R} \geq V_{I H}, \\ & f=f_{M A X}, \end{aligned}$ | Commercial | - | 120 | 180 | - | 100 | 150 | - | 75 | 135 | mA |
|  |  |  | Industrial | - | 135 | 205 | - | 120 | 175 | - | 120 | 175 |  |
| $\mathrm{I}_{\text {SB3 }}$ | Standby current (both ports CMOS levels) | Both Ports $\overline{\mathrm{CE}}$ and $\overline{\mathrm{CE}}_{\mathrm{R}} \geq$ $\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}, \mathrm{~V}_{\text {IN }} \geq \mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$ or $\mathrm{V}_{\text {IN }} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{[16]}$ | Commercial | - | 0.05 | 0.5 | - | 0.05 | 0.50 | - | 0.05 | 0.50 | mA |
|  |  |  | Industrial | - | 0.05 | 0.5 | - | 0.05 | 0.50 | - | 0.05 | 0.50 |  |
| $\mathrm{I}_{\text {SB4 }}$ | Standby current (both ports CMOS levels) | $\begin{aligned} & \text { One Port } \overline{C E}_{L} \text { or } \\ & \overline{C E}_{R} \geq V_{C C}-0.2 \mathrm{~V}, \\ & V_{I N} \geq V_{C C}-0.2 \mathrm{~V} \text { or } V_{I N} \leq 0.2 \mathrm{~V} \\ & \text { Active Port Outputs, } \mathrm{f}=\mathrm{f}_{\text {MAX }}[16] \end{aligned}$ | Commercial | - | 110 | 160 | - | 90 | 130 | - | 70 | 120 | mA |
|  |  |  | Industrial | - | 125 | 175 | - | 110 | 150 | - | 110 | 150 |  |

## Capacitance

| Parameter ${ }^{[17]}$ | 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}_{\text {OUT }}$ | Output capacitance | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ | 10 | pF |

[^2]CY7C024E, CY7C0241E CY7C025E, CY7C0251E

Figure 3. AC Test Loads and Waveforms


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

| Parameter | Description | -15 |  | -25 |  | -55 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Read Cycle |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {RC }}$ | Read cycle time | 15 | - | 25 | - | 55 | - | ns |
| $\mathrm{t}_{\mathrm{AA}}$ | Address to data valid | - | 15 | - | 25 | - | 55 | ns |
| $\mathrm{t}_{\text {OHA }}$ | Output hold from address change | 3 | - | 3 | - | 3 | - | ns |
| $\mathrm{t}_{\text {ACE }}{ }^{[19]}$ | $\overline{\mathrm{CE}}$ LOW to data valid | - | 15 | - | 25 | - | 55 | ns |
| $t_{\text {doe }}$ | $\overline{\mathrm{OE}}$ LOW to data valid | - | 10 | - | 13 | - | 25 | ns |
| $\mathrm{t}_{\text {LZOE }}{ }^{[20,21,22]}$ | $\overline{\mathrm{OE}}$ low to low Z | 3 | - | 3 | - | 3 | - | ns |
| $\mathrm{t}_{\text {Hzoe }}{ }^{[20,21,22]}$ | $\overline{\mathrm{OE}}$ HIGH to high Z | - | 10 | - | 15 | - | 25 | ns |
| $\mathrm{t}_{\text {LZCE }}{ }^{[20,21,22]}$ | $\overline{\text { CE LOW }}$ to low Z | 3 | - | 3 | - | 3 | - | ns |
| $\mathrm{t}_{\mathrm{HZCE}}{ }^{[20,21,22]}$ | CE HIGH to High Z | - | 10 | - | 15 | - | 25 | ns |
| $\mathrm{t}_{\mathrm{PU}}{ }^{[22]}$ | $\overline{C E}$ LOW to power-up | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\text {PD }}{ }^{[22]}$ | CE HIGH to power-down | - | 15 | - | 25 | - | 55 | ns |
| $\mathrm{t}_{\mathrm{ABE}}{ }^{\text {[19] }}$ | Byte enable access time | - | 15 | - | 25 | - | 55 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |
| ${ }^{\text {twc }}$ | Write cycle time | 15 | - | 25 | - | 55 | - | ns |
| $\mathrm{t}_{\text {SCE }}{ }^{[19]}$ | $\overline{\text { CE }}$ LOW to write end | 12 | - | 20 | - | 35 | - | ns |

## Notes

18. 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 ${ }^{1} \mathrm{O} / \mathrm{l}_{\mathrm{OH}}$ and 30 pF load capacitance.
19. To access RAM, $\overline{C E}=L, \overline{U B}=L, \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 tSCE
20. 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 }}$.
21. Test conditions used are Load 3 .
22. This parameter is guaranteed but not tested.

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

| Parameter | Description | -15 |  | -25 |  | -55 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $\mathrm{t}_{\text {AW }}$ | Address setup to write end | 12 | - | 20 | - | 35 | - | ns |
| $\mathrm{t}_{\mathrm{HA}}$ | Address hold from write end | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\mathrm{SA}}{ }^{[23]}$ | Address setup to write start | 0 | - | 0 | - | 0 | - | ns |
| $t_{\text {PWE }}$ | Write pulse width | 12 | - | 20 | - | 35 | - | ns |
| $\mathrm{t}_{\text {SD }}$ | Data setup to write end | 10 | - | 15 | - | 20 | - | ns |
| $\mathrm{t}_{\mathrm{HD}}$ | Data hold from write end | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\text {HZWE }}{ }^{[24,25]}$ | R/W LOW to high Z | - | 10 | - | 15 | - | 25 | ns |
| $\mathrm{t}_{\text {LZWE }}{ }^{[24,25]}$ | R/్̄W HIGH to low $Z$ | 3 | - | 3 | - | 3 | - | ns |
| $\mathrm{t}_{\text {WDD }}{ }^{[26]}$ | Write pulse to data delay | - | 30 | - | 50 | - | 70 | ns |
| $\mathrm{t}_{\text {DDD }}{ }^{\text {[26] }}$ | Write data valid to read data valid | - | 25 | - | 35 | - | 45 | ns |
| Busy Timing ${ }^{[27]}$ |  |  |  |  |  |  |  |  |
| $t_{\text {bLA }}$ | $\overline{\text { BUSY }}$ LOW from Address Match | - | 15 | - | 20 | - | 45 | ns |
| $t_{\text {BHA }}$ | BUSY HIGH from Address Mismatch | - | 15 | - | 20 | - | 40 | ns |
| $t_{\text {bLC }}$ | $\overline{\text { BUSY }}$ LOW from $\overline{C E}$ LOW | - | 15 | - | 20 | - | 40 | ns |
| $\mathrm{t}_{\text {BHC }}$ | $\overline{\text { BUSY }}$ HIGH from $\overline{\text { CE }}$ HIGH | - | 15 | - | 20 | - | 35 | ns |
| $\mathrm{t}_{\text {PS }}$ | Port Setup for Priority | 5 | - | 5 | - | 5 | - | ns |
| ${ }^{\text {t }}$ WB | R/్̄W HIGH after $\overline{\text { BUSY }}$ (Slave) | 0 | - | 0 | - | 0 | - | ns |
| ${ }^{\text {t }}$ WH | R/̄W HIGH after BUSY HIGH (Slave) | 13 | - | 20 | - | 40 | - | ns |
| $\mathrm{t}_{\text {BDD }}{ }^{[28]}$ | $\overline{\text { BUSY }}$ HIGH to Data Valid | - | Note 28 |  | Note 28 |  | Note 28 | ns |
| Interrupt Timing ${ }^{[27]}$ |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {INS }}$ | $\overline{\text { INT Set Time }}$ | - | 15 | - | 20 | - | 30 | ns |
| $\mathrm{t}_{\text {INR }}$ | $\overline{\text { INT Reset Time }}$ | - | 15 | - | 20 | - | 30 | ns |
| Semaphore Timing |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {SOP }}$ | SEM Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\mathrm{SEM}})$ | 10 | - | 12 | - | 20 | - | ns |
| ${ }^{\text {tswRD }}$ | SEM Flag Write to Read Time | 5 | - | 10 | - | 15 | - | ns |
| ${ }^{\text {t }}$ SPS | SEM Flag Contention Window | 5 | - | 10 | - | 15 | - | ns |
| $t_{\text {SAA }}$ | SEM Address Access Time | - | 15 |  | 25 | - | 55 | ns |

[^3]CY7C024E, CY7C0241E CY7C025E, CY7C0251E

## Data Retention Mode

The CY7C024E/CY7C0241E is designed with battery backup in mind. Data retention voltage and supply current are guaranteed over temperature. The following rules insure data retention:

1. Chip enable ( $\overline{\mathrm{CE}})$ must be held HIGH during data retention, within $\mathrm{V}_{\mathrm{CC}}$ to $\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$.
2. $\overline{\mathrm{CE}}$ must be kept between $\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$ and $70 \%$ of $\mathrm{V}_{\mathrm{CC}}$ during the power up and power down transitions.
3. The RAM can begin operation $>t_{\mathrm{RC}}$ after $\mathrm{V}_{\mathrm{CC}}$ reaches the minimum operating voltage ( 4.5 V ).

## Data Retention Timing



| Parameter | Test Conditions ${ }^{[29]}$ | Max | Unit |
| :---: | :---: | :---: | :---: |
| $\mathrm{ICC}_{\text {DR1 }}$ | At VCC $\mathrm{DR}=2 \mathrm{~V}$ | 1.5 | mA |

Note
29. $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\text {in }}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{CC}}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$. This parameter is guaranteed but not tested.

## Switching Waveforms

Figure 4. Read Cycle No. 1 (Either Port Address Access) ${ }^{[30,31,32]}$


Figure 5. Read Cycle No. 2 (Either Port $\overline{\mathrm{CE}} / \overline{\mathrm{OE}}$ Access) ${ }^{[30,33,34]}$


Figure 6. Read Cycle No. 3 (Either Port) ${ }^{[30,32,33,33,34]}$


## Notes

30. R/W is HIGH for read cycles.
31. Device is continuously selected $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ and $\overline{\mathrm{UB}}$ or $\overline{\mathrm{LB}}=\mathrm{V}_{\mathrm{IL}}$. This waveform cannot be used for semaphore reads
32. $\overline{O E}=V_{\text {IL }}$.
33. Address valid prior to or coincident with $\overline{C E}$ transition LOW
34. To access RAM, $\overline{C E}=V_{I L}, \overline{\mathrm{UB}}$ or $\overline{\mathrm{LB}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{SEM}}=\mathrm{V}_{\mathrm{IH}}$. To access semaphore, $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}, \overline{\mathrm{SEM}}=\mathrm{V}_{\mathrm{IL}}$.

CY7C024E, CY7C0241E CY7C025E, CY7C0251E

Switching Waveforms (continued)
Figure 7. Write Cycle No. 1: R/W Controlled Timing ${ }^{[35,36,37,38]}$


Figure 8. Write Cycle No. 2: $\overline{\mathrm{CE}}$ Controlled Timing ${ }^{[35,36,37,43]}$


[^4]CY7C024E, CY7C0241E CY7C025E, CY7C0251E

Switching Waveforms (continued)
Figure 9. Semaphore Read After Write Timing, Either Side ${ }^{[44]}$


Figure 10. Timing Diagram of Semaphore Contention ${ }^{[45,46,47]}$


[^5]Switching Waveforms (continued)


Figure 12. Write Timing with Busy Input (M/ $\overline{\mathbf{S}}=$ LOW)


Note
48. $\overline{C E}_{L}=\overline{C E}_{R}=$ LOW .

CY7C024E, CY7C0241E CY7C025E, CY7C0251E

Switching Waveforms (continued)
Figure 13. Busy Timing Diagram No. 1 ( $\overline{C E}$ Arbitration) ${ }^{[49]}$


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


Right Address Valid First:


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

CY7C024E, CY7C0241E CY7C025E, CY7C0251E

Switching Waveforms (continued)
Figure 15. Interrupt Timing Diagrams



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


Left Side Clears $\mathrm{INT}_{\mathrm{L}}$ :

## Notes

50. $\mathrm{t}_{\mathrm{HA}}$ depends on which enable pin ( $\overline{\mathrm{CE}}_{L}$ or $\mathrm{R} \bar{W}_{L}$ ) is deasserted first
51. $\mathrm{t}_{\mathrm{INS}}$ or $\mathrm{t}_{\mathrm{INR}}$ depends on which enable pin $\left(\overline{\mathrm{CE}}_{\mathrm{L}}\right.$ or $\left.\mathrm{R} \bar{W}_{\mathrm{L}}\right)$ is asserted last.

CY7C024E, CY7C0241E CY7C025E, CY7C0251E

## Ordering Information (4K x16 Dual-Port SRAM)

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :---: |
| 15 | CY7C024E-15AXC | A100 | $100-$ Pin Pb-free TQFP | Commercial |
| 25 | CY7C024E-25AXC | A100 | $100-P i n$ Pb-free TQFP | Commercial |
|  | CY7C024E-25AXI | A100 | $100-$ Pin Pb-free TQFP | Industrial |
| 55 | CY7C024E-55AXC | A100 | $100-P i n$ Pb-free TQFP | Commercial |

## Ordering Information (8K x 16 Dual-Port SRAM)

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :---: |
| 25 | CY7C025E-25AXC | A100 | $100-$ Pin Pb-free TQFP | Commercial |
|  | CY7C025E-25AXI | A100 | $100-$ Pin Pb-free TQFP | Industrial |
| 55 | CY7C025E-55AXC | A100 | $100-$ Pin Pb-free TQFP | Commercial |

## Ordering Information (4K x 18 Dual-Port SRAM)

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :---: |
| 15 | CY7C0241E-15AXC | A100 | $100-$ Pin Pb-free TQFP | Commercial |
|  | CY7C0241E-15AXI | A100 | $100-$ Pin Pb-free TQFP | Industrial |
| 25 | CY7C0241E-25AXC | A100 | $100-P i n ~ P b-f r e e ~ T Q F P ~$ | Commercial |

## Ordering Information (8K x 18 Dual-Port SRAM )

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :---: |
| 15 | CY7C0251E-15AXC | A100 | 100-Pin Pb-free TQFP | Commercial |

Ordering Code Definition


## Package Diagrams

Figure 16. 100-Pin Pb-free Thin Quad Flat Pack (TQFP) A100


## Acronyms

| Acronym | Description |
| :--- | :--- |
| CMOS | Complementary metal oxide semiconductor |
| $\overline{C E}$ | Chip enable |
| $\overline{O E}$ | Output enable |
| RAM | Random access memory |
| TQFP | Thin quad plastic flatpack |

## Document History Page

| Document Title: CY7C024E, CY7C0241E, CY7C025E, CY7C0251E, 4K x 16/18 and 8K x 16/18 Dual-Port Static RAM with SEM, INT, BUSY <br> Document Number: 001-62932 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Rev. | ECN No. | Orig. of Change | Submission Date | Description of Change |
| ** | 2975554 | RAME | 07/09/2010 | New Datasheet |
| *A | 3056347 | ADMU | 10/28/2010 | Updated "Selection Guide" on page 1: <br> For speed bin -25: Typical Operating current(mA) changed from 180 to 170, Typical standby current for ISB1 (mA) changed from 45 to 40 <br> For speed bin -55: Typical Operating current(mA) changed from 180 to 150, Typical standby current for ISB1 (mA) changed from 45 to 20 <br> Updated "Electrical Characteristics Over the Operating Range" on page 9: <br> The values for the speed bins -25 and -55 have been put into separate columns. The values for Commercial parts have been modified for the following parameters: (no degradation of spec) <br> Operating Current ICC: "180(typ) / 275(max)" changed to "170(typ) / 250(max) for speed bin -25" and "150(typ) / 230(max) for speed bin -55" <br> Standby Current ISB1 (both ports TTL levels): "45(typ) / 65(max)" changed to "40(typ) / 60(max) for speed bin -25", and "20(typ) / 50(max) for speed bin -55" Standby Current ISB2 (one port TTL level) : "110(typ) / 160(max)" changed to "100(typ) / 150(max) for speed bin -25", and "75(typ) / 135(max) for speed bin -55" Standby Current ISB4 (both ports CMOS Levels) : "100(typ) / 140(max)" changed to "90(typ) / 130(max) for speed bin -25", and "70(typ) / 120(max) for speed bin -55" <br> Updated "Ordering Information (4K x 18 Dual-Port SRAM)" on page 19: Removed part CY7C0241E - 55AXI from ordering information. |

## Sales, Solutions, and Legal Information

## Worldwide Sales and Design Support

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

## Products

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

[^6]
[^0]:    Notes
    9. $\mathrm{I} / \mathrm{O}_{0}-\mathrm{l} / \mathrm{O}_{8}$ on the CY7C0241E/CY7C0251E.
    10. $\mathrm{I} / \mathrm{O}_{9}-\mathrm{I} / \mathrm{O}_{17}$ on the CY7C0241E/CY7C0251E.

[^1]:    Notes
    11. $\mathrm{A}_{0 \mathrm{~L}-12 \mathrm{~L}}$ and $\mathrm{A}_{0 R-12 R}$, 1FFF/1FFE for the CY7C025E/CY7C0251E.
    12. If $\overline{\operatorname{BUSY}}_{L}=L$, then no change.
    13. $\overline{\operatorname{BUSY}}_{\mathrm{R}}=\mathrm{L}$, then no change.If

[^2]:    Notes
    14. The voltage on any input or I/O pin cannot exceed the power pin during power-up.
    15. Pulse width < 20 ns .
    16. $f_{\text {MAX }}=1 / \mathrm{t}_{\mathrm{RC}}=$ All inputs cycling at $\mathrm{f}=1 / \mathrm{t}_{\mathrm{RC}}$ (except output enable). $\mathrm{f}=0$ means no address or control lines change. This applies only to inputs at CMOS level standby ${ }^{\text {SBB3 }}$.
    17. Tested initialiy and after any design or process changes that may affect these parameters.

[^3]:    Notes
    23. To access RAM, $\overline{C E}=L, \overline{U B}=L, \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_{\text {SCE }}$ time.
    24. Test conditions used are Load 3.
    25. This parameter is guaranteed but not tested.
    26. For information on port-to-port delay through RAM cells from writing port to reading port, refer to Figure 11 on page 16.
    27. Test conditions used are Load 2.
    28. $t_{B D D}$ is a calculated parameter and is the greater of $t_{\text {WDD }}-t_{\text {PWE }}$ (actual) or $t_{D D D}-t_{S D}$ (actual).

[^4]:    Notes
    35. R/W must be HIGH during all address transitions.
    36. A write occurs during the overlap ( $t_{S C E}$ or $t_{P W E}$ ) of a LOW $\overline{C E}$ or $\overline{S E M}$ and a LOW $\overline{U B}$ or $\overline{L B}$.
    37. $\mathrm{t}_{\mathrm{HA}}$ is measured from the earlier of CE or RM or (SEM or R/W) going HIGH at the end of write cycle.
    38. If $\overline{O E}$ 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}_{\mathrm{SD}}$. If $\overline{\mathrm{OE}}$ is HIGH during an $\mathrm{R} \overline{\mathrm{W}}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified tPWE.
    39. To access RAM, $\overline{C E}=\mathrm{V}_{\mathrm{H}}, \overline{\mathrm{SEM}}=\mathrm{V}_{\mathrm{H}}$.
    40. To access upper byte, $C E=V_{\text {世, }}, U B=V_{4}$, $\mathrm{SEM}=\mathrm{V}_{\mathrm{IH}}$.

    To access lower byte, $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{LB}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{SEM}=\mathrm{V}_{\mathrm{IH}}$.
    41. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is sampled and not $100 \%$ tested.
    42. During this period, the I/O pins are in the output state, and input signals must not be applied.
    43. If the CE or SEM LOW transition occurs simultaneously with or after the R/W LOW transition, the outputs remain in the high impedance state.

[^5]:    Notes
    44. CE = HIGH for the duration of the above timing (both write and read cycle).
    45. $\mathrm{I} / \mathrm{O}_{0 \mathrm{R}}=\mathrm{I} / \mathrm{O}_{0 \mathrm{~L}}=$ LOW (request semaphore); $\overline{\mathrm{CE}}_{\mathrm{R}}=\overline{\mathrm{CE}}_{\mathrm{L}}=\mathrm{HIGH}$.
    46. Semaphores are reset (available to both ports) at cycle start.
    47. If $t_{\text {SPS }}$ is violated, the semaphore is definitely obtained by one side or the other, but which side gets the semaphore is unpredictable.

[^6]:     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

