# 32K/64K x 16/18 Dual-Port Static RAM ### **Features** - True Dual-Ported memory cells which allow simultaneous access of the same memory location - 32K x 16 organization (CY7C027) - 64K x 16 organization (CY7C028) - 32K x 18 organization (CY7C037) - 64K x 18 organization (CY7C038) - 0.35-micron CMOS for optimum speed/power - High-speed access: 12<sup>[1]</sup>/15/20 ns - · Low operating power - Active: I<sub>CC</sub> = 180 mA (typical) Standby: I<sub>SB3</sub> = 0.05 mA (typical) - · 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 flags for port-to-port communication - · Separate upper-byte and lower-byte control - Dual Chip Enables - · Pin select for Master or Slave - Commercial and industrial temperature ranges - · Available in 100-pin TQFP - · Pb-Free packages available ### Notes: - See page 6 for Load Conditions. - 2. $I/O_8 I/O_{15}$ for x16 devices; $I/O_9 I/O_{17}$ for x18 devices. - 3. $I/O_0-I/O_7$ for x16 devices; $I/O_0-I/O_8$ for x18 devices. - 4. A<sub>0</sub>-A<sub>14</sub> for 32K; A<sub>0</sub>-A<sub>15</sub> for 64K devices. - 5. BUSY is an output in master mode and an input in slave mode. # **Functional Description** The CY7C027/028 and CY7C037/038 are low-power CMOS 32K, 64K x 16/18 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 16/18-bit dual-port static RAMs or multiple devices can be combined in order 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. $\underline{\text{Eac}}\text{h}$ port has independent control pins: dual chip enables $(\underline{\text{CE}}_0$ and $\text{CE}_1)$ , 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 the chip enable pins. The CY7C027/028 and CY7C037/038 are available in 100-pin Thin Quad Plastic Flatpack (TQFP) packages. # **Pin Configurations** ## 100-Pin TQFP (Top View) ### Note: 6. This pin is NC for CY7C027. # Pin Configurations (continued) # 100-Pin TQFP (Top View) ### **Selection Guide** | | CY7C027/028<br>CY7C037/038<br>-12 <sup>[1]</sup> | CY7C027/028<br>CY7C037/038<br>-15 | CY7C027/028<br>CY7C037/038<br>-20 | Unit | |----------------------------------------------------------------------|--------------------------------------------------|-----------------------------------|-----------------------------------|------| | Maximum Access Time | 12 | 15 | 20 | ns | | Typical Operating Current | 195 | 190 | 180 | mA | | Typical Standby Current for I <sub>SB1</sub> (Both ports TTL level) | 55 | 50 | 45 | mA | | Typical Standby Current for I <sub>SB3</sub> (Both ports CMOS level) | 0.05 | 0.05 | 0.05 | mA | ### Note: 7. This pin is NC for CY7C037. ### **Pin Definitions** | Left Port | Right Port | Description | |---------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | CE <sub>0L</sub> , CE <sub>1L</sub> | CE <sub>0R</sub> , CE <sub>1R</sub> | Chip Enable ( $\overline{CE}$ is LOW when $\overline{CE}_0 \le V_{IL}$ and $CE_1 \ge V_{IH}$ ) | | $R/\overline{W}_L$ | R/W <sub>R</sub> | Read/Write Enable | | ŌĒL | <del>OE</del> <sub>R</sub> | Output Enable | | A <sub>0L</sub> -A <sub>15L</sub> | A <sub>0R</sub> -A <sub>15R</sub> | Address (A <sub>0</sub> –A <sub>14</sub> for 32K; A <sub>0</sub> –A <sub>15</sub> for 64K devices) | | I/O <sub>0L</sub> –I/O <sub>17L</sub> | I/O <sub>0R</sub> –I/O <sub>17R</sub> | Data Bus Input/Output (I/O <sub>0</sub> –I/O <sub>15</sub> for x16 devices; I/O <sub>0</sub> –I/O <sub>17</sub> for x18) | | SEM <sub>L</sub> | SEMR | Semaphore Enable | | UB <sub>L</sub> | UB <sub>R</sub> | Upper Byte Select (I/O <sub>8</sub> –I/O <sub>15</sub> for x16 devices; I/O <sub>9</sub> –I/O <sub>17</sub> for x18 devices) | | <u>IB</u> ∟ | LB <sub>R</sub> | Lower Byte Select (I/O <sub>0</sub> –I/O <sub>7</sub> for x16 devices; I/O <sub>0</sub> –I/O <sub>8</sub> for x18 devices) | | INT <sub>L</sub> | INT <sub>R</sub> | Interrupt Flag | | BUSYL | BUSY <sub>R</sub> | Busy Flag | | M/S | | Master or Slave Select | | V <sub>CC</sub> | | Power | | GND | | Ground | | NC | | No Connect | # Maximum Ratings<sup>[8]</sup> (Above which the useful life may be impaired. For user guidelines, not tested.) Storage Temperature ......-65°C to +150°C Ambient Temperature with Power Applied......–55°C to +125°C Supply Voltage to Ground Potential ..... -0.3V to +7.0V DC Voltage Applied to Outputs in High Z State ......-0.5V to +7.0DC | Output Current into Outputs (LOW) | 20 mA | |-----------------------------------|---------| | Static Discharge Voltage | >1100V | | Latch-Up Current | >200 mA | # **Operating Range** | Range | Ambient<br>Temperature | V <sub>CC</sub> | |----------------------------|------------------------|-----------------| | Commercial | 0°C to +70°C | 5V ± 10% | | Industrial <sup>[10]</sup> | –40°C to +85°C | 5V ± 10% | ### Notes: - 8. The Voltage on any input or I/O pin cannot exceed the power pin during power-up. 9. Pulse width < 20 ns. - 10. Industrial parts are available in CY7C028 and CY7C038 only. # **Electrical Characteristics** Over the Operating Range | | | | | | | | 7C027/<br>7C037/ | | | | | | |------------------|-------------------------------------------------------------------------------------------|------------------------|------|---------------------------|------|------|------------------|------|------|------|------|------| | | | | | <b>-12</b> <sup>[1]</sup> | | | -15 | | -20 | | | | | Symbol | Parameter | | Min. | Тур. | Max. | Min. | Тур. | Max. | Min. | Тур. | Max. | Unit | | V <sub>OH</sub> | Output HIGH Voltage (V <sub>CC</sub> = N<br>= -4.0 mA) | Min., I <sub>OH</sub> | 2.4 | | | 2.4 | | | 2.4 | | | V | | V <sub>OL</sub> | Output LOW Voltage (V <sub>CC</sub> = N<br>= +4.0 mA) | /lin., l <sub>OH</sub> | | | 0.4 | | | 0.4 | | | 0.4 | V | | $V_{IH}$ | Input HIGH Voltage | | 2.2 | | | 2.2 | | | 2.2 | | | 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>CC</sub> | Operating Current | Com'l. | | 195 | 325 | | 190 | 280 | | 180 | 265 | mA | | | (V <sub>CC</sub> =Max, I <sub>OUT</sub> =0 mA)<br>Outputs Disabled | Ind. <sup>[10]</sup> | | | | | | | | 305 | 290 | mA | | I <sub>SB1</sub> | Standby Current (Both Ports | Com'l. | | 55 | 75 | | 50 | 70 | | 45 | 65 | mA | | | $TTL Level) \overline{CE}_L \& \overline{CE}_R \ge V_{IH},$<br>$f = f_{MAX}$ | Ind. <sup>[10]</sup> | | | | | | | | 60 | 80 | mA | | I <sub>SB2</sub> | Standby Current (One Port | Com'l. | | 125 | 205 | | 120 | 180 | | 110 | 160 | mA | | | TTL Level) $CE_L \mid CE_R \ge V_{IH}$ , $f = f_{MAX}$ | Ind. <sup>[10]</sup> | | | | | | | | 125 | 175 | mA | | I <sub>SB3</sub> | Standby Current (Both Ports C | | | 0.05 | 0.5 | | 0.05 | 0.5 | | 0.05 | 0.5 | mA | | | CMOS Level) $CE_L \& CE_R \ge V_{CC} - 0.2V$ , $f = 0$ | Ind. <sup>[10]</sup> | | | | | | | | 0.05 | 0.5 | mA | | I <sub>SB4</sub> | Standby Current (One Port | Com'l. | | 115 | 185 | | 110 | 160 | | 100 | 140 | mA | | | CMOS Level) $\overline{CE}_L \mid \overline{CE}_R \ge V_{IH}$ , f = f <sub>MAX</sub> [11] | Ind. <sup>[10]</sup> | | | | | | | | 115 | 155 | mA | # Capacitance<sup>[12]</sup> | Parameter | Description | Test Conditions | Max. | Unit | |------------------|--------------------|-----------------------------------|------|------| | C <sub>IN</sub> | Input Capacitance | T <sub>A</sub> = 25°C, f = 1 MHz, | 10 | pF | | C <sub>OUT</sub> | Output Capacitance | $V_{CC} = 5.0V$ | 10 | pF | ### Note: <sup>11.</sup> f<sub>MAX</sub> = 1/t<sub>RC</sub> = All inputs cycling at f = 1/t<sub>RC</sub> (except output enable). f = 0 means no address or control lines change. This applies only to inputs at CMOS level standby I<sub>SB3</sub> # **AC Test Loads and Waveforms** (a) Normal Load (Load 1) (b) Thévenin Equivalent (Load 1) (c) Three-State Delay (Load 2) (Used for $t_{CKLZ}$ , $t_{OLZ}$ , & $t_{OHZ}$ including scope and jig) ### ALL INPUTPULSES # AC Test Loads (Applicable to -12 only)[13] 12. Tested initially and after any design or process changes that may affect these parameters. 13. Test Conditions: C = 0 pF. # Switching Characteristics Over the Operating Range<sup>[14]</sup> | Parameter Description Parameter Description Min. Max. Min. Max. Min. Min | | | | | CY7C | 027/028<br>037/038 | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------------------------------|------|-------------------------|------|--------------------|------|------|------| | READ CYCLE | | | -1 | <b>2</b> <sup>[1]</sup> | | 15 | -2 | 20 | | | I <sub>EC</sub> Read Cycle Time 12 15 20 ns I <sub>AA</sub> Address to Data Valid 12 15 20 ns I <sub>OHA</sub> Output Hold From Address Change 3 3 3 ns I <sub>OCE</sub> <sup>[15]</sup> CE LOW to Data Valid 12 15 20 ns I <sub>OCE</sub> <sup>[16]</sup> OE LOW to Data Valid 8 10 12 ns I <sub>OCE</sub> <sup>[16]</sup> OE LOW to Low Z 3 3 3 ns I <sub>COC</sub> <sup>[16]</sup> 17, 18] OE HIGH to High Z 10 10 12 ns I <sub>LOCE</sub> <sup>[16]</sup> 17, 18] OE LOW to Low Z 3 3 3 3 ns I <sub>LOCE</sub> <sup>[16]</sup> 17, 18] OE LOW to Low Z 3 3 3 3 ns I <sub>LOCE</sub> <sup>[16]</sup> CE LOW to Coverup 0 0 0 0 ns I <sub>LOCE</sub> <sup>[18]</sup> CE LOW to Power-Down 12 15 20 ns I <sub>LOC</sub> <sup>[18]</sup> Byte Enable Access Time 12 15 | Parameter | Description | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | LAA | READ CYCLE | | | | | | | | | | total Output Hold From Address Change 3 3 3 ns tacc[fis] Œ LOW to Data Valid 12 15 20 ns tooc Œ LOW to Data Valid 8 10 12 ns tacce [16,17,18] Œ LOW to Low Z 3 3 3 ns tacce [16,17,18] Œ HiGH to High Z 10 10 10 12 ns tacce [16,17,18] Œ LOW to Low Z 3 3 3 3 ns tacce [16,17,18] Œ LOW to Low Z 3 3 3 3 ns tacce [16,17,18] Œ LOW to Low Z 3 3 3 3 ns tacce [16,17,18] Œ LOW to Power-Up 0 0 0 0 ns tacce [16] Œ LOW to Power-Up 0 0 0 0 ns tage [16] Byte Enable Access Time 12 15 20 ns tace [16] Write Cycle Time 12 15 20 | t <sub>RC</sub> | Read Cycle Time | 12 | | 15 | | 20 | | ns | | Loce <sup>115</sup> CE LOW to Data Valid 12 15 20 ns tool OE LOW to Data Valid 8 10 12 ns t_Loce <sup>116, 17, 18]</sup> OE LOW to Low Z 3 3 3 3 ns t_Loce <sup>116, 17, 18]</sup> OE LOW to Low Z 3 3 3 3 ns t_Loce <sup>116, 17, 18]</sup> OE LOW to Low Z 3 3 3 3 ns t_Loce <sup>116, 17, 18]</sup> OE LOW to Low Z 3 3 3 3 ns t_Loce <sup>116, 17, 18]</sup> OE LOW to Power-Up 0 0 0 0 ns t_Loce <sup>118, 17, 18]</sup> OE HIGH to Power-Down 12 15 20 ns tp0 <sup>118]</sup> OE HIGH to Power-Down 12 15 20 ns tp0 <sup>118</sup> OF ELOW to Write End 12 15 20 ns tsce <sup>115</sup> Byte Enable Access Time 12 15 20 ns tsce <sup>115</sup> Byte Enable Access Time 12 15 20 ns tsce <sup>115</sup> Byte Enable Access Time 12 15 20 ns< | t <sub>AA</sub> | Address to Data Valid | | 12 | | 15 | | 20 | ns | | tool ÖE LOW to Data Valid 8 10 12 ns t_zooe <sup>[16, 17, 18]</sup> ÖE LOW to Low Z 3 3 3 3 ns t_zooe <sup>[16, 17, 18]</sup> ÖE HIGH to High Z 10 10 12 ns t_zoe <sup>[16, 17, 18]</sup> ÖE HIGH to High Z 10 10 12 ns t_zoe <sup>[16]</sup> ÖE LOW to Low Z 3 3 3 3 ns t_zoe <sup>[16]</sup> ÖE HIGH to High Z 10 10 12 ns t_zoe <sup>[16]</sup> ÖE HIGH to High Z 10 0 0 0 ns tpp(18] ÖE HIGH to Power-Down 12 15 20 ns tpp(18] ÖE HIGH to Power-Down 12 15 20 ns tpp(18] ÖE HIGH to Power-Down 12 15 20 ns tpp(18] ÖE LOW to Power-Down 12 15 20 ns tpp(18] ÖE LOW to Write End 10 12 15 20 ns | | Output Hold From Address Change | 3 | | 3 | | 3 | | ns | | tool ÖE LOW to Data Valid 8 10 12 ns t_zooe <sup>[16, 17, 18]</sup> ÖE LOW to Low Z 3 3 3 3 ns t_zooe <sup>[16, 17, 18]</sup> ÖE HIGH to High Z 10 10 12 ns t_zoe <sup>[16, 17, 18]</sup> ÖE HIGH to High Z 10 10 12 ns t_zoe <sup>[16]</sup> ÖE LOW to Low Z 3 3 3 3 ns t_zoe <sup>[16]</sup> ÖE HIGH to High Z 10 10 12 ns t_zoe <sup>[16]</sup> ÖE HIGH to High Z 10 0 0 0 ns tpp(18] ÖE HIGH to Power-Down 12 15 20 ns tpp(18] ÖE HIGH to Power-Down 12 15 20 ns tpp(18] ÖE HIGH to Power-Down 12 15 20 ns tpp(18] ÖE LOW to Power-Down 12 15 20 ns tpp(18] ÖE LOW to Write End 10 12 15 20 ns | t <sub>ACE</sub> <sup>[15]</sup> | CE LOW to Data Valid | | 12 | | 15 | | 20 | ns | | t <sub>tZCD</sub> [16, 17, 18] DE HIGH to High Z 10 10 12 ns t <sub>LZCE</sub> <sup>[16, 17, 18]</sup> CE LOW to Low Z 3 3 3 3 ns t <sub>DC</sub> <sup>[16, 17, 18]</sup> CE LOW to Power-Up 0 0 0 0 ns t <sub>DD</sub> <sup>[18]</sup> CE HIGH to Power-Down 12 15 20 ns t <sub>ABE</sub> <sup>[15]</sup> Byte Enable Access Time 12 15 20 ns WRITE CYCLE t <sub>WC</sub> Write Cycle Time 12 15 20 ns t <sub>ABC</sub> <sup>[15]</sup> CE LOW to Write End 10 12 15 ns ns t <sub>MC</sub> Write Cycle Time 12 15 20 ns ns ns t_M ns t_M ns t_M ns ns ns ns ns < | t <sub>DOE</sub> | OE LOW to Data Valid | | 8 | | 10 | | 12 | ns | | I <sub>1,20CE</sub> (16, 17, 18) CE LOW to Low Z 3 3 3 ns I <sub>1,20CE</sub> (16, 17, 18) CE HIGH to High Z 10 10 12 ns t <sub>PO</sub> (18) CE LOW to Power-Up 0 0 0 0 ns t <sub>PO</sub> (18) CE HIGH to Power-Down 12 15 20 ns t <sub>ABE</sub> (15) Byte Enable Access Time 12 15 20 ns WRITE CYCLE I <sub>WC</sub> Write Cycle Time 12 15 20 ns I <sub>SCE</sub> (15) CE LOW to Write End 10 12 15 ns I <sub>SCE</sub> (15) CE LOW to Write End 10 12 15 ns I <sub>AW</sub> Address Valid to Write End 0 0 0 ns I <sub>AW</sub> Address Set-Up to Write Start 0 0 0 ns I <sub>SA</sub> (15) Address Set-Up to Write End 10 12 15 ns I <sub>SA</sub> (15) Address Set-Up to Write End 0 0 | t <sub>LZOE</sub> [16, 17, 18] | OE LOW to Low Z | 3 | | 3 | | 3 | | ns | | t <sub>HZCE</sub> [16, 17, 18] CE HIGH to High Z 10 10 12 ns t <sub>PU</sub> <sup>[19]</sup> CE LOW to Power-Up 0 0 0 0 ns t <sub>PD</sub> <sup>[18]</sup> CE HIGH to Power-Down 12 15 20 ns t <sub>ABE</sub> <sup>[15]</sup> Byte Enable Access Time 12 15 20 ns WRITE CYCLE t <sub>WC</sub> Write Cycle Time 12 15 20 ns t <sub>SCE</sub> <sup>[15]</sup> CE LOW to Write End 10 12 15 ns t <sub>MW</sub> Address Valid to Write End 10 12 15 ns t <sub>MW</sub> Address Hold From Write End 0 0 0 ns t <sub>MA</sub> <sup>[15]</sup> Address Set-Up to Write Start 0 0 0 ns t <sub>PWE</sub> Write Pulse Width 10 12 15 ns t <sub>PWE</sub> Write Pulse Write End 0 0 0 ns t <sub>LOC</sub> Data Hold From Write End 0 0 0 ns | t <sub>HZOE</sub> [16, 17, 18] | OE HIGH to High Z | | 10 | | 10 | | 12 | ns | | tpu[18] \$\overline{\text{CE}}\$ LOW to Power-Up 0 0 0 ns tpo[18] \$\overline{\text{CE}}\$ HIGH to Power-Down 12 15 20 ns two Write Cycle Time 12 15 20 ns twc Write Cycle Time 12 15 20 ns tscc[15] \$\overline{\text{CE}}\$ LOW to Write End 10 12 15 ns tsw Address Valid to Write End 10 12 15 ns t_AW Address Hold From Write End 0 0 0 ns t_AW Address Set-Up to Write Start 0 0 0 ns t_AW Address Set-Up to Write End 10 12 15 ns t_BWE Write Pulse Width 10 12 15 ns tpWE Write Pulse Width 10 10 15 ns t_LZWE[17, 18] R/W LOW to High Z 10 10 12 ns t_LZWE[17, 18] R/W | t <sub>LZCE</sub> <sup>[16, 17, 18]</sup> | CE LOW to Low Z | 3 | | 3 | | 3 | | ns | | tpu[18] \$\overline{\text{CE}}\$ LOW to Power-Up 0 0 0 ns tpo[18] \$\overline{\text{CE}}\$ HIGH to Power-Down 12 15 20 ns two Write Cycle Time 12 15 20 ns twc Write Cycle Time 12 15 20 ns tscc[15] \$\overline{\text{CE}}\$ LOW to Write End 10 12 15 ns tsw Address Valid to Write End 10 12 15 ns t_AW Address Hold From Write End 0 0 0 ns t_AW Address Set-Up to Write Start 0 0 0 ns t_AW Address Set-Up to Write End 10 12 15 ns t_BWE Write Pulse Width 10 12 15 ns tpWE Write Pulse Width 10 10 15 ns t_LZWE[17, 18] R/W LOW to High Z 10 10 12 ns t_LZWE[17, 18] R/W | t <sub>HZCE</sub> <sup>[16, 17, 18]</sup> | CE HIGH to High Z | | 10 | | 10 | | 12 | ns | | table Byte Enable Access Time 12 15 20 ns WRITE CYCLE twc Write Cycle Time 12 15 20 ns tock Write Cycle Time 12 15 20 ns tock Write Cycle Time 10 12 15 ns tock ELOW to Write End 10 12 15 ns taw Address Valid to Write End 0 0 0 ns taw Address Set-Up to Write End 0 0 0 ns tay Write Pulse Width 10 12 15 ns tay Write Pulse Width 10 12 15 ns tay Data Hold From Write End 0 0 0 ns ns thub Data Hold From Write End 0 0 0 ns ns ns thub Data Hold From Write End 0 0 0 ns ns ns ns <t< td=""><td>t<sub>PU</sub><sup>[18]</sup></td><td>CE LOW to Power-Up</td><td>0</td><td></td><td>0</td><td></td><td>0</td><td></td><td>ns</td></t<> | t <sub>PU</sub> <sup>[18]</sup> | CE LOW to Power-Up | 0 | | 0 | | 0 | | ns | | $ \begin{array}{ c c c c c c c c } \hline \textbf{t}_{WC} & Write Cycle Time & 12 & 15 & 20 & ns \\ \hline \textbf{t}_{SCE}^{[15]} & \overline{CE} \ LOW \ to Write \ End & 10 & 12 & 15 & ns \\ \hline \textbf{t}_{AW} & Address \ Valid \ to \ Write \ End & 10 & 12 & 15 & ns \\ \hline \textbf{t}_{HA} & Address \ Valid \ to \ Write \ End & 0 & 0 & 0 & ns \\ \hline \textbf{t}_{SA}^{[15]} & Address \ Set-Up \ to \ Write \ End & 0 & 0 & 0 & ns \\ \hline \textbf{t}_{PWE} & Write \ Pulse \ Width & 10 & 12 & 15 & ns \\ \hline \textbf{t}_{PWE} & Write \ Pulse \ Width & 10 & 12 & 15 & ns \\ \hline \textbf{t}_{SD} & Data \ Set-Up \ to \ Write \ End & 10 & 10 & 15 & ns \\ \hline \textbf{t}_{HD} & Data \ Hold \ From \ Write \ End & 0 & 0 & 0 & ns \\ \hline \textbf{t}_{HZWE}^{[17, 18]} & R/\overline{W} \ LOW \ to \ High \ Z & 10 & 10 & 10 & 12 & ns \\ \hline \textbf{t}_{LZWE}^{[17, 18]} & R/\overline{W} \ HIGH \ to \ Low \ Z & 3 & 3 & 3 & ns \\ \hline \textbf{t}_{WDD}^{[19]} & Write \ Pulse \ to \ Data \ Delay & 25 & 30 & 45 & ns \\ \hline \textbf{t}_{DDD}^{[19]} & Write \ Data \ Valid \ to \ Read \ Data \ Valid & 20 & 25 & 30 & ns \\ \hline \textbf{BUSY LOW } \ from \ Address \ Match & 12 & 15 & 20 & ns \\ \hline \textbf{t}_{BHA} & \overline{BUSY} \ LOW \ from \ \overline{CE} \ LOW & 12 & 15 & 20 & ns \\ \hline \textbf{t}_{BHC} & \overline{BUSY} \ LOW \ from \ \overline{CE} \ HIGH \ from \ \overline{CE} \ HIGH & 12 & 15 & 17 & ns \\ \hline \textbf{t}_{PS} & Port \ Set-Up \ for \ Priority & 5 & 5 & 5 & 5 & ns \\ \hline \end{array}$ | t <sub>PD</sub> <sup>[18]</sup> | CE HIGH to Power-Down | | 12 | | 15 | | 20 | ns | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>ABE</sub> <sup>[15]</sup> | Byte Enable Access Time | | 12 | | 15 | | 20 | ns | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | WRITE CYCLE | <u> </u> | • | • | | • | • | • | • | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>WC</sub> | Write Cycle Time | 12 | | 15 | | 20 | | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>SCE</sub> <sup>[15]</sup> | CE LOW to Write End | 10 | | 12 | | 15 | | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | Address Valid to Write End | 10 | | 12 | | 15 | | ns | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | t <sub>HA</sub> | Address Hold From Write End | 0 | | 0 | | 0 | | ns | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>SA</sub> <sup>[15]</sup> | Address Set-Up to Write Start | 0 | | 0 | | 0 | | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>PWE</sub> | Write Pulse Width | 10 | | 12 | | 15 | | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>SD</sub> | Data Set-Up to Write End | 10 | | 10 | | 15 | | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>HD</sub> | Data Hold From Write End | 0 | | 0 | | 0 | | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>HZWE</sub> [17, 18] | $R/\overline{W}$ LOW to High Z | | 10 | | 10 | | 12 | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>LZWE</sub> [17, 18] | $R/\overline{W}$ HIGH to Low Z | 3 | | 3 | | 3 | | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>WDD</sub> <sup>[19]</sup> | Write Pulse to Data Delay | | 25 | | 30 | | 45 | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | Write Data Valid to Read Data Valid | | 20 | | 25 | | 30 | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | BUSY TIMING | [20] | • | • | • | • | | • | • | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>BLA</sub> | BUSY LOW from Address Match | | 12 | | 15 | | 20 | ns | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | t <sub>BHA</sub> | BUSY HIGH from Address Mismatch | | 12 | | 15 | | 20 | ns | | $t_{BHC}$ BUSY HIGH from $\overline{CE}$ HIGH121517ns $t_{PS}$ Port Set-Up for Priority555ns | t <sub>BLC</sub> | BUSY LOW from CE LOW | | 12 | | 15 | | 20 | ns | | t <sub>PS</sub> Port Set-Up for Priority 5 5 ns | | BUSY HIGH from CE HIGH | | 12 | | 15 | | 17 | ns | | | | Port Set-Up for Priority | 5 | | 5 | | 5 | | ns | | r··─ r | t <sub>WB</sub> | R/W HIGH after BUSY (Slave) | 0 | | 0 | | 0 | | ns | ### Notes: Notes: 14. Test conditions assume signal transition time of 3 ns or less, timing reference levels of 1.5V, input pulse levels of 0 to 3.0V, and output loading of the specified $I_{O}/I_{OH}$ and 30-pF load capacitance. 15. To access RAM, CE=L, UB=L, SEM=H. To access semaphore, CE=H and SEM=L. Either condition must be valid for the entire $t_{SCE}$ time. 16. At any given temperature and voltage condition for any given device, $t_{HZCE}$ is less than $t_{LZCE}$ and $t_{HZOE}$ is less than $t_{LZOE}$ . 17. Test conditions used are Load 2. 18. This parameter is guaranteed by design, but it is not production tested. 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. # $\textbf{Switching Characteristics} \ \, \text{Over the Operating Range}^{[14]} \, (\text{continued})$ | | | CY7C027/028<br>CY7C037/038 | | | | | | | | |----------------------------------|-----------------------------------|----------------------------|-------------------------|------|------|------|------|------|--| | | | -1 | <b>2</b> <sup>[1]</sup> | | 15 | -2 | 20 | | | | Parameter | Description | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | | t <sub>WH</sub> | R/W HIGH after BUSY HIGH (Slave) | 11 | | 13 | | 15 | | ns | | | t <sub>BDD</sub> <sup>[21]</sup> | BUSY HIGH to Data Valid | | 12 | | 15 | | 20 | ns | | | INTERRUPT T | IMING <sup>[20]</sup> | | | | | | | | | | t <sub>INS</sub> | INT Set Time | | 12 | | 15 | | 20 | ns | | | t <sub>INR</sub> | INT Reset Time | | 12 | | 15 | | 20 | ns | | | SEMAPHORE | TIMING | | | | | | | | | | t <sub>SOP</sub> | SEM Flag Update Pulse (OE or SEM) | 10 | | 10 | | 10 | | ns | | | t <sub>SWRD</sub> | SEM Flag Write to Read Time | 5 | | 5 | | 5 | | ns | | | t <sub>SPS</sub> | SEM Flag Contention Window | 5 | | 5 | | 5 | | ns | | | t <sub>SAA</sub> | SEM Address Access Time | | 12 | | 15 | | 20 | ns | | ### **Data Retention Mode** The CY7C027/028 and CY7C037/038 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{CE}$ ) must be held HIGH during data retention, within $V_{CC}$ to $V_{CC}$ 0.2V. - 2. $\overline{\text{CE}}$ must be kept between V<sub>CC</sub> 0.2V and 70% of V<sub>CC</sub> during the power-up and power-down transitions. - 3. The RAM can begin operation >t<sub>RC</sub> after $V_{CC}$ reaches the minimum operating voltage (4.5 volts). # **Timing** | Parameter | Test Conditions <sup>[22]</sup> | Max. | Unit | |--------------------|---------------------------------|------|------| | ICC <sub>DR1</sub> | @ VCC <sub>DR</sub> = 2V | 1.5 | mA | ### Notes 21. t<sub>BDD</sub> is a calculated parameter and is the greater of t<sub>WDD</sub>-t<sub>PWE</sub> (actual) or t<sub>DDD</sub>-t<sub>SD</sub> (actual). 22. CE = V<sub>CC</sub>, V<sub>in</sub> = GND to V<sub>CC</sub>, T<sub>A</sub> = 25°C. This parameter is guaranteed but not tested. # **Switching Waveforms** # Read Cycle No. 1 (Either Port Address Access)<sup>[23,24,25]</sup> # Read Cycle No. 2 (Either Port $\overline{\text{CE}/\text{OE}}$ Access)[23, 26, 27] # Read Cycle No. 3 (Either Port) [23, 25, 26, 27] Notes: 23. R/W is HIGH for read cycles. <sup>24.</sup> Device is continuously selected $\overline{CE} = V_{IL}$ and $\overline{UB}$ or $\overline{LB} = V_{IL}$ . This waveform cannot be used for semaphore reads. 25. OE = V<sub>IL</sub>. 26. Address valid prior to or coincident with CE transition LOW. 27. To access RAM, CE = V<sub>IL</sub>, UB or LB = V<sub>IL</sub>, SEM = V<sub>IH</sub>. To access semaphore, CE = V<sub>IH</sub>, SEM = V<sub>IL</sub>. # Write Cycle No. 1: R/W Controlled Timing<sup>[28, 29, 30, 31]</sup> # Write Cycle No. 2: $\overline{\text{CE}}$ Controlled Timing<sup>[28, 29, 30, 34, 35]</sup> - 28. R/W must be HIGH during all address transitions. - 29. A write occurs during all address transitions. 29. A write occurs during the overlap (t<sub>SCE</sub> or t<sub>PWE</sub>) of <u>a LOW CE</u> or <u>SEM</u> and a LOW <u>UB</u> or <u>LB</u>. 30. t<sub>HA</sub> is measured from the earlier of CE or R/W or (SEM or R/W) going HIGH at the end of write cycle. 31. If OE is LOW during a R/W controlled write cycle, the write pulse width <u>must</u> be the larger of t<sub>PWE</sub> or (t<sub>HZWE</sub> + t<sub>SD</sub>) to allow the I/O drivers to turn off and data to be placed on the bus for the required t<sub>SD</sub>. 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 required to the controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified t<sub>PWE</sub>. 32. To access RAM, CE = V<sub>IL</sub>, SEM = V<sub>IH</sub>. 33. To access upper byte, CE = V<sub>IL</sub>, UB = V<sub>IL</sub>, SEM = V<sub>IH</sub>. To access lower byte, CE = V<sub>IL</sub>, LB = V<sub>IL</sub>, SEM = V<sub>IH</sub>. 34. Transition is measured ±500 mV from steady state with a 5-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 CE or SEM LOW transition occurs simultaneously with or after the RW LOW transition, the outputs remain in the high-impedance state. # Semaphore Read After Write Timing, Either Side<sup>[37]</sup> # Timing Diagram of Semaphore Contention $^{[38,\;39,\;40]}$ - Notes: 37. CE = HIGH for the duration of the above timing (both write and read cycle). 38. I/O<sub>OR</sub> = I/O<sub>OL</sub> = LOW (request semaphore); CE<sub>R</sub> = CE<sub>L</sub> = HIGH. 39. Semaphores are reset (available to both ports) at cycle start. 40. If t<sub>SPS</sub> is violated, the semaphore will definitely be obtained by one side or the other, but which side will get the semaphore is unpredictable. # Timing Diagram of Read with BUSY (M/S=HIGH)[41] # Write Timing with Busy Input (M/S=LOW) **Note:** 41. CE<sub>L</sub> = CE<sub>R</sub> = LOW. # $\underline{\text{Bu}}$ sy Timing Diagram No.1 ( $\overline{\text{CE}}$ Arbitration) $^{[42]}$ $\overline{\text{CE}}_{\text{L}}$ Valid First: # Busy Timing Diagram No. 2 (Address Arbitration)<sup>[42]</sup> Left Address Valid First: ### **Right Address Valid First:** Note: <sup>42.</sup> If tps is violated, the busy signal will be asserted on one side or the other, but there is no guarantee to which side BUSY will be asserted. <sup>43.</sup> $t_{HA}$ depends on which enable pin $(\overline{CE}_L \text{ or } \overline{RW}_L)$ is deasserted first. 44. $t_{INS}$ or $t_{INR}$ depends on which enable pin $(\overline{CE}_L \text{ or } RW_L)$ is asserted last. ### **Architecture** The CY7C027/028 and CY7C037/038 consist of an array of 32K and 64K words of 16 and 18 bits each of dual-port RAM cells, I/O and address lines, and control signals (CE, OE, R/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 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 (BUSY pins are outputs) or as a slave (BUSY pins are inputs). The devices also have an automatic power-down feature controlled by CE. Each port is provided with its own output enable control (OE), which allows data to be read from the device. ### **Functional Description** ### **Write Operation** Data $\underline{m}$ ust be set up for a duration of $t_{SD}$ before the rising edge of R/W in order to guarantee $\underline{a}$ valid write. A write operation is controlled by either the R/W pin (see Write Cycle No. 1 waveform) or the $\overline{CE}$ pin (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<sub>DDD</sub> after the data is presented on the other port. ## **Read Operation** When reading the device, the user must assert both the $\overline{\text{OE}}$ and $\overline{\text{CE}}$ pins. Data will be available $t_{\text{ACE}}$ after $\overline{\text{CE}}$ or $t_{\text{DOE}}$ after $\overline{\text{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{\text{CE}}$ pin, and $\overline{\text{OE}}$ must also be asserted. ### Interrupts The upper two memory locations may be used for message passing. The highest memory location (7FFF for the CY7C027/37, FFFF for the CY7C028/38) is the mailbox for the right port and the second-highest memory location (7FFE for the CY7C027/37, FFFE for the CY7C028/38) 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 is summarized in *Table 2*. ### **Busy** The CY7C027/028 and CY7C037/038 provide on-chip arbitration to resolve simultaneous memory location access (contention). If both ports' CEs are asserted and an address match occurs within $t_{PS}$ of each other, the busy logic will determine which port has access. If $t_{PS}$ 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 $t_{BLA}$ after an address match or $t_{BLC}$ after CE is taken LOW ### Master/Slave A $M/\overline{S}$ pin is provided in order to expand the word width by configuring the device as either a master or <u>a slave</u>. The BUSY output of the master is connected to the BUSY 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_{BLC}$ or $t_{BLA}$ ), otherwise, the slave chip may begin a write cycle during a contention situation. When tied HIGH, the M/S pin <u>allows</u> the device to be <u>used</u> as a master and, therefore, the BUSY line is an output. BUSY can then be used to send the arbitration outcome to a slave. ### **Semaphore Operation** The CY7C027/028 and CY7C037/038 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 t<sub>SOP</sub> before attempting to read the semaphore. The semaphore value will be available t<sub>SWRD</sub> + t<sub>DOE</sub> 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 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 SEM LOW. The SEM pin functions as a chip select for the semaphore latches (CE must remain HIGH during SEM LOW). $A_{0-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 $I/O_0$ is used. If a zero is written to the left port of an available semaphore, a one will appear 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 will be 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 would immediately own the semaphore as soon as the left port released it. *Table 3* shows sample semaphore operations. When reading a semaphore, all sixteen/eighteen 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_{\mbox{\footnotesize 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. Table 1. Non-Contending Read/Write | | | In | puts | | | Oı | utputs | | |----|-----|----|------|----|-----|-------------------------------------|------------------------------------|--------------------------------------------| | CE | R/W | OE | UB | LB | SEM | I/O <sub>9</sub> -I/O <sub>17</sub> | I/O <sub>0</sub> –I/O <sub>8</sub> | Operation | | Н | Х | Х | Х | Х | Н | High Z | High Z | Deselected: Power-Down | | Х | Х | Х | Н | Н | Н | High Z | High Z | Deselected: Power-Down | | L | L | Х | L | Н | Н | Data In | High Z | Write to Upper Byte Only | | L | L | Х | Н | L | Н | High Z | Data In | Write to Lower Byte Only | | L | L | Х | L | L | Н | Data In | Data In | Write to Both Bytes | | L | Н | L | L | Н | Н | Data Out | High Z | Read Upper Byte Only | | L | Н | L | Н | L | Н | High Z | Data Out | Read Lower Byte Only | | L | Н | L | L | L | Н | Data Out | Data Out | Read Both Bytes | | Х | Х | Н | Х | Х | Х | High Z | High Z | Outputs Disabled | | Н | Н | L | Х | Х | L | Data Out | Data Out | Read Data in Semaphore Flag | | Х | Н | L | Н | Н | L | Data Out | Data Out | Read Data in Semaphore Flag | | Н | | Х | Х | Х | L | Data In | Data In | Write D <sub>IN0</sub> into Semaphore Flag | | Х | | Х | Н | Н | L | Data In | Data In | Write D <sub>IN0</sub> into Semaphore Flag | | L | Х | Х | L | Х | L | | | Not Allowed | | L | Х | Х | Х | L | L | | | Not Allowed | Table 2. Interrupt Operation Example (assumes $\overline{BUSY}_L = \overline{BUSY}_R = HIGH)^{[45]}$ | | | | Le | ft Port | | Right Port | | | | | | |-----------------------------------|------------------|----|-----|---------------------|-------------------|------------------|-----|-----|---------------------|-------------------|--| | Function | R/W <sub>L</sub> | CE | OEL | A <sub>0L-14L</sub> | INT | R/W <sub>R</sub> | CER | OER | A <sub>0R-14R</sub> | INT <sub>R</sub> | | | Set Right INT <sub>R</sub> Flag | L | L | Х | 7FFF | Х | Х | Х | Х | Х | L <sup>[47]</sup> | | | Reset Right INT <sub>R</sub> Flag | Х | Χ | Х | Х | Х | Х | L | L | 7FFF | H <sup>[46]</sup> | | | Set Left INT <sub>L</sub> Flag | Х | Χ | Х | Х | L <sup>[46]</sup> | L | L | Х | 7FFE | Х | | | Reset Left INT <sub>L</sub> Flag | Х | L | L | 7FFE | H <sup>[47]</sup> | Х | Χ | Х | Х | Х | | 45. $A_{0.15L}$ and $A_{0R-15R}$ , FFFF/FFE for the CY7C028/038. 46. If $BUSY_R = L$ , then no change. 47. If $BUSY_L = L$ , then no change. **Table 3. Semaphore Operation Example** | Function | I/O <sub>0</sub> -I/O <sub>17</sub> Left | I/O <sub>0</sub> -I/O <sub>17</sub> Right | 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 | # **Ordering Information** # 32K x16 Asynchronous Dual-Port SRAM | Speed<br>(ns) | Ordering Code | Package<br>Name | Package Type | Operating<br>Range | |-------------------|---------------|-----------------|-------------------------------------|--------------------| | 12 <sup>[1]</sup> | CY7C027-12AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | 15 | CY7C027-15AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | 20 | CY7C027-20AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | | CY7C027-20AXC | A100 | 100-Pin Pb-Free Thin Quad Flat Pack | Commercial | # 64K x16 Asynchronous Dual-Port SRAM | Speed<br>(ns) | Ordering Code | Package<br>Name | Package Type | Operating<br>Range | |-------------------|---------------|-----------------|-------------------------------------|--------------------| | 12 <sup>[1]</sup> | CY7C028-12AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | | CY7C028-12AXC | A100 | 100-Pin Pb-Free Thin Quad Flat Pack | Commercial | | 15 | CY7C028-15AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | | CY7C028-15AXC | A100 | 100-Pin Pb-Free Thin Quad Flat Pack | Commercial | | | CY7C028-15AI | A100 | 100-Pin Thin Quad Flat Pack | Industrial | | | CY7C028-15AXI | A100 | 100-Pin Pb-Free Thin Quad Flat Pack | Industrial | | 20 | CY7C028-20AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | | CY7C028-20AI | A100 | 100-Pin Thin Quad Flat Pack | Industrial | # 32K x18 Asynchronous Dual-Port SRAM | Speed<br>(ns) | Ordering Code | Package<br>Name | Package Type | Operating<br>Range | |-------------------|---------------|-----------------|-----------------------------|--------------------| | 12 <sup>[1]</sup> | CY7C037-12AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | 15 | CY7C037-15AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | 20 | CY7C037-20AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | # 64K x18 Asynchronous Dual-Port SRAM | Speed<br>(ns) | Ordering Code | Package<br>Name | Package Type | Operating<br>Range | | |-------------------|---------------|-----------------|-----------------------------|--------------------|--| | 12 <sup>[1]</sup> | CY7C038-12AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | | 15 | CY7C038-15AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | | 20 | CY7C038-20AC | A100 | 100-Pin Thin Quad Flat Pack | Commercial | | | | CY7C038-20AI | A100 | 100-Pin Thin Quad Flat Pack | Industrial | | # **Package Diagram** ### 100-Pin Thin Plastic Quad Flat Pack (TQFP) A100 100-Pin Pb-Free Thin Plastic Quad Flat Pack (TQFP) A100 All products and company names mentioned in this document may be the trademarks of their respective holders. # **Document History Page** | REV. | ECN NO. | Issue<br>Date | Orig. of Change | Description of Change | |------|---------|---------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------| | ** | 110190 | 09/29/01 | SZV | Change from Spec number: 38-00666 to 38-06042 | | *A | 122292 | 12/27/02 | RBI | Power up requirements added to Maximum Ratings Information | | *B | 236765 | 6/23/04 | YDT | Removed cross information from features section | | *C | 377454 | See ECN | PCX | Added Pb-Free Logo Added Pb-Free parts to ordering information: CY7C027-20AXC, CY7C028-12AXC, CY7C028-15AXC, CY7C028-15AI, CY7C028-15AXI |