## specializealmemoties



Integrated Device Technology, Inc.


Integrated Device Technology, Inc.

## 1990-91 SPECIALIZED MEMORIES DATA BOOK

# GENERAL INFORMATION 

GUALITY AND RELABBITY

PACRAOEDIAORAM OUTLNES

ECLPRODUCTS

## FIFO PRODUCTS

SpECIALTY MEMOMY PRODUCTS

SUBSYSTEMS PRODUCTS

## CONTENTS OVERVIEW

Historically, Integrated Device Technology has presented our product offerings entirely under one cover. For ease of use for our customers, we have divided the products into four separate data books - Logic, Specialized Memory, RISC and Static RAM.

IDT's 1990 Specialized Memories Data Book is comprised of new and revised data sheets and application notes for the ECL, FIFO, Speciality Memory and Subsystem product lines. Also included is a current, complete packaging section for all IDT product groups. This section will be updated in each subsequent data book with the latest available packages.

The Specialized Memories Data Book's Table of Contents contains a listing of the products contained in the 1990 Specialized Memories Data Book, as well as those products which we believe will be contained in the remaining three data books - the Logic Data Book is already in print, while RISC and SRAM will be published later in the year. The numbering scheme is slightly different from the past. The number in the bottom center of the page denotes the section number and the sequence of the data sheet within that section, (i.e. 5.5 would be the fifth data sheet in the fifth section). The number in the lower right hand corner is the page number of that particular data sheet.

Integrated Device Technology, a recognized leader in high-speed CMOS technology, produces a broad line of products, enabling us to provide a complete CMOS solution to designers of highperformance digital systems. Our products include industry standard devices, as well as products with speed, lower power, package and/or architectural benefits that allow the designer to achieve significantly improved system performance.

Use this book to find ordering information: Start with the Ordering Information chart at the back of each data sheet or the Cross Reference Guides (in Section 1), along with the Package Outline Index (page 4.2), to compose the complete IDT part number. Reference data on our Technology Capabilities and Quality Commitments are included in separate sections (2 and 3, respectively).

Use this book to find product data: Start with the Table of Contents, organized by product line (page 1.3), or with the Numeric Table of Contents across all product lines (page 1.4). These indexes will direct you to the page on which the complete technical data sheet can be found. Data sheets may be of the following type:

ADVANCE INFORMATION - contain initial descriptions, subject to change, for products that are in development, including features and block diagrams.

PRELIMINARY - contain descriptions for products soon to be, or recently, released to production, including features, pinouts and block diagrams. Timing data are based on simulation or initial characterization and are subject to change upon full characterization.

FINAL - contain minimum and maximum limits specified over the complete supply and temperature range for full production devices.

New products, product performance enhancements, additional package types and new product families are being introduced frequently. Please contact your local IDT sales representative to determine the latest device specifications, package types and product availability.

## LIFE SUPPORT POLICY

Integrated Device Technology's products are not authorized for use as critical components in life support devices or systems unless a specific written agreement pertaining to such intended use Is executed between the manufacturer and an officer of IDT.

1. Life support devices or systems are devices or systems which (a) are intended for surgical implant into the body or (b) support or sustain life and whose fallure to perform, when properly used In accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
2. A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the fallure of the life support device or system, or to affect its safety or effectiveness.

Note: Integrated Device Technology, Inc. reserves the right to make changes to its products or specifications at any time, without notice, in order to improve design or performance and to supply the best possible product. IDT does not assume any responsibility for use of any circuitry described other than the circuitry embodied in an IDT product. The Company makes no representations that circuitry described herein is free from patent infringement or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent, patent rights or other rights, of Integrated Device Technology, Inc.

## 1990-91 SPECIALIZED MEMORIES DATA BOOK SUMMARY TABLE OF CONTENTS

PAGE
GENERAL INFORMATION
Contents Overview ..... 1.1
Summary Table of Contents ..... 1.2
Table of Contents ..... 1.3
Numeric Table of Contents ..... 1.4
IDT Package Marking Description ..... 1.5
Cross Reference Guide ..... 1.6
TECHNOLOGY AND CAPABILITIES
IDT...Leading the CMOS Future ..... 2.1
IDT Military and DESC-SMD Program ..... 2.2
Radiation Hardened Technology ..... 2.3
IDT Leading Edge CEMOS Technology ..... 2.4
Surface Mount Technology ..... 2.5
State-of-the-Art Facilities and Capabilities. ..... 2.6
Superior Quality and Reliability ..... 2.7
QUALITY AND RELIABILITY
Quality, Service and Performance ..... 3.1
IDT Quality Conformance Program ..... 3.2
Radiation Tolerant/Enhanced/Hardened Products for Radiation Environments ..... 3.3
PACKAGE DIAGRAM OUTLINES
Thermal Performance Calculations for IDT's Packages ..... 4.1
Package Diagram Outline Index ..... 4.2
Monolithic Package Diagram Outlines ..... 4.3
Module Package Diagram Outlines ..... 4.4
ECL PRODUCTS
ECL Products ..... 5.1
FIFO PRODUCTS
FIFO Products ..... 6.1
SPECIALTY MEMORY PRODUCTS
Specialty Memory Products ..... 7.1
SUBSYSTEMS PRODUCTS
Multi-Port Modules ..... 8.1
FIFO Modules ..... 8.12
SRAM Modules ..... 8.16
Cache Modules ..... 8.41
Writable Control Store Modules ..... 8.49
Other Modules ..... 8.51
Custom Modules. ..... 8.52
SUMMARY TABLE OF CONTENTS (CONTINUED) ..... PAGE
APPLICATION AND TECHNICAL NOTES
FIFO Products Application Notes ..... 9.1
FIFO Products Technical Notes ..... 9.13
Specialty Memory Products Application Notes ..... 9.16
Subsystems Products Application Notes ..... 9.26
IDT SALES OFFICE, REPRESENTATIVE AND DISTRIBUTOR LOCATIONSBOOK
LOGIC DATA BOOK
Complex Logic Products ..... LOGIC
Standard Logic Products ..... LOGIC
RISC DATA BOOK
RISC Components ..... RISC
RISC Subsystem Products ..... RISC
STATIC RAM DATA BOOK
Static RAM Products ..... SRAM

## 1990-91 SPECIALIZED MEMORIES DATA BOOK TABLE OF CONTENTS

## GENERAL INFORMATION

Contents Overview ..... 1.1
Summary Table of Contents ..... 1.2
Table of Contents ..... 1.3
Numeric Table of Contents ..... 1.4
IDT Package Marking Description ..... 1.5
ECL Cross Reference Guide ..... 1.6
FIFO Cross Reference Guide ..... 1.7
Specialty Memory Cross Reference Guide ..... 1.8
Subsystems Cross Reference Guide ..... 1.9
TECHNOLOGY AND CAPABILITIES
IDT...Leading the CMOS Future ..... 2.1
IDT Military and DESC-SMD Program ..... 2.2
Radiation Hardened Technology ..... 2.3
IDT Leading Edge CEMOS Technology ..... 2.4
Surface Mount Technology ..... 2.5
State-of-the-Art Facilities and Capabilities ..... 2.6
Superior Quality and Reliability ..... 2.7
QUALITY AND RELIABILITY
Quality, Service and Performance ..... 3.1
IDT Quality Conformance Program ..... 3.2
Radiation Tolerant/Enhanced/Hardened Products for Radiation Environments ..... 3.3
PACKAGE DIAGRAM OUTLINES
Thermal Performance Calculations for IDT's Packages ..... 4.1
Package Diagram Outline Index ..... 4.2
Monolithic Package Diagram Outlines ..... 4.3
Module Package Diagram Outlines ..... 4.4
ECL PRODUCTS
IDT10484IDT100484
4K x 4 ECL 10K SRAM (Corner Power) ..... 5.1
$4 \mathrm{~K} \times 4$ ECL 100K SRAM (Corner Power) ..... 5.1IDT101484
IDT10A484 ..... 5.1$4 \mathrm{~K} \times 4 \mathrm{ECL}$ 10K SRAM (Center Power)
IDT100A484 $4 \mathrm{~K} \times 4$ ECL 100 K SRAM (Center Power) ..... 5.25.2
IDT101A484 $4 \mathrm{~K} \times 4$ ECL 101K SRAM (Center Power)
IDT10490 $64 \mathrm{~K} \times 1 \mathrm{ECL}$ 10K SRAM ..... 5.3
IDT100490 $64 \mathrm{~K} \times 1 \mathrm{ECL} 100 \mathrm{~K}$ SRAM ..... 5.3
IDT101490 $64 \mathrm{~K} \times 1 \mathrm{ECL} 101 \mathrm{~K}$ SRAM ..... 5.3
IDT10494 $16 \mathrm{~K} \times 4 \mathrm{ECL}$ 10K SRAM. ..... 5.4
IDT100494 $16 \mathrm{~K} \times 4 \mathrm{ECL} 100 \mathrm{~K}$ SRAM ..... 5.4
IDT101494 16K x 4 ECL 101K SRAM ..... 5.4
IDT10496LL
IDT100496LL
16K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
16K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
IDT101496LL 16K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
IDT10496RL 16K $\times 4$ Self-Timed Reg Input, Latch Output ..... 5.6
IDT100496RL $16 \mathrm{~K} \times 4$ Self-Timed Reg Input, Latch Output ..... 5.6

## 1990-91 SPECIALIZED MEMORIES DATA BOOK (CONTINUED)

PAGE

## ECL PRODUCTS (CONTINUED)

IDT101496RL 16K $\times 4$ Self-Timed Reg Input, Latch Output ..... 5.6
IDT10497
IDT100497
16K $\times 4$ Synchronous Write, Latch Output ..... 5.7
16K $\times 4$ Synchronous Write, Latch Output ..... 5.7
IDT101497 16K $\times 4$ Synchronous Write, Latch Output ..... 5.7
IDT10498IDT10049816K $\times 4$ Conditional Write, Latch Output5.8
16K $\times 4$ Conditional Write, Latch Output ..... 5.8
IDT101498 16K $\times 4$ Conditional Write, Latch Output ..... 5.8
IDT10504
IDT100504
IDT101504
IDT10506LLIDT100506LL
IDT101506LL
DT10506RLIDT100506RLIDT101506RL
IDT10507
IDT100507
IDT101507
IDT10508
IDT100508
IDT101508
IDT10509
IDT100509IDT101509
$64 \mathrm{~K} \times 4 \mathrm{ECL}$ 10K SRAM ..... 5.9
$64 \mathrm{~K} \times 4$ ECL 100K SRAM ..... 5.9
$64 \mathrm{~K} \times 4 \mathrm{ECL} 100 \mathrm{~K}$ SRAM ..... 5.9
64K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.10
$64 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.10
$64 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.10
64K $\times 4$ Self-Timed Reg Input, Latch Output ..... 5.11
$64 \mathrm{~K} \times 4$ Self-Timed Reg Input, Latch Output ..... 5.11
$64 \mathrm{~K} \times 4$ Self-Timed Reg Input, Latch Output ..... 5.11
$64 \mathrm{~K} \times 4$ Synchronous Write, Latch Output ..... 5.12
16K $\times 4$ Synchronous Write, Latch Output ..... 5.12
16K $\times 4$ Synchronous Write, Latch Output ..... 5.12
64K x 4 Conditional Write, Latch Output ..... 5.13
$64 \mathrm{~K} \times 4$ Conditional Write, Latch Output ..... 5.13
$64 \mathrm{~K} \times 4$ Conditional Write, Latch Output ..... 5.13
$32 \mathrm{~K} \times 9$ ECL 10 K SRAM ..... 5.14
$32 \mathrm{~K} \times 9$ ECL 100 K SRAM ..... 5.14
32K x 9 ECL 101K SRAM ..... 5.14
FIFO PRODUCTS
IDT7200
IDT7201
IDT7202IDT7203IDT7204IDT7205IDT7206
IDT72021
IDT72031
IDT72041
IDT72103
IDT72104
DT72105
IDT72115
IDT72125
IDT72131IDT72141
IDT72132
IDT72142
DT72200
IDT72210
IDT72420
IDT72201IDT72211IDT72421IDT72215AIDT72225A
$256 \times 9$-Bit Parallel FIFO ..... 6.1
$512 \times 9$-Bit Parallel FIFO ..... 6.1
$1024 \times 9$-Bit Parallel FIFO ..... 6.2
$2 \mathrm{~K} \times 9$-Bit Parallel FIFO ..... 6.3
$4 \mathrm{~K} \times 9$-Bit Parallel FIFO ..... 6.3
$8 \mathrm{~K} \times 9$-Bit Parallel FIFO ..... 6.4
$16 \mathrm{~K} \times 9$-Bit Parallel FIFO ..... 6.5
1K $\times 9$-Bit Parallel FIFO w/ Flags and Output Enable ..... 6.6
$2 \mathrm{~K} \times 9$-Bit Parallel FIFO w/Flags and Output Enable ..... 6.6
$4 \mathrm{~K} \times 9$-Bit Parallel FIFO w/Flags and Output Enable ..... 6.6
$2 \mathrm{~K} \times 9$-Bit Configurable Parallel-Serial FIFO ..... 6.7
4K $\times 9$-Bit Configurable Parallel-Serial FIFO ..... 6.7
$256 \times 16$-Bit Parallel-to-Serial FIFO ..... 6.8
$512 \times 16$-Bit Parallel-to-Serial FIFO ..... 6.8
$1024 \times 16$-Bit Parallel-to-Serial FIFO ..... 6.8
$2048 \times 9$-Bit Parallel-to-Serial FIFO ..... 6.9
$4096 \times 9$-Bit Parallel-to-Serial FIFO ..... 6.9
$2048 \times 9$-Bit Serial-to-Parallel FIFO ..... 6.10
$4096 \times 9$-Bit Serial-to-Parallel FIFO ..... 6.10
$256 \times 8$-Bit Parallel SyncFIFOTM (Clocked FIFO) ..... 6.11
$512 \times 8$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..... 6.11
$64 \times 8$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..... 6.11
$256 \times 9$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..... 6.12
$512 \times 9$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..... 6.12
$64 \times 9$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..... 6.12
$512 \times 18$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..... 6.13
$1024 \times 18$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..... 6.13

## 1990-91 SPECIALIZED MEMORIES DATA BOOK (CONTINUED)

PAGE

## FIFO PRODUCTS (CONTINUED)

IDT72220 $1 \mathrm{~K} \times 8$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..................................................... 6.14
IDT72230
2K $\times 8$-Bit Parallel SyncFIFO ${ }^{\text {™ }}$ (Clocked FIFO)
6.14

IDT72240
$4 \mathrm{~K} \times 8$-Bit Parallel SyncFIFO ${ }^{\text {™ }}$ (Clocked FIFO)
6.14

IDT72221
IDT72231
1K $\times 9$-Bit Parallel SyncFIFO™ (Clocked FIFO)
6.15

2K x 9-Bit Parallel SyncFIFOTM (Clocked FIFO) ..................................................... 6.15
4K x 9-Bit Parallel SyncFIFO™ (Clocked FIFO) ..................................................... 6.15
2K $\times 18$-Bit Parallel SyncFIFO™ (Clocked FIFO) .................................................. 6.16
$4 \mathrm{~K} \times 18$-Bit Parallel SyncFIFO™ (Clocked FIFO) ................................................... 6.16
$64 \times 4$ FIFO......................................................................................................... 6.17
$64 \times 5$ FIFO......................................................................................................... 6.17
$64 \times 4$ FIFO (w/Output Enable) ............................................................................. 6.17
$64 \times 5$ FIFO (w/Output Enable) ............................................................................. 6.17
$64 \times 5$ FIFO (w/Flags) .......................................................................................... 6.18
$512 \times 18$-Bit - 1 K $\times 9$-Bit BiFIFO .......................................................................... 6.19
$1 \mathrm{~K} \times 18$-Bit — $2 \mathrm{~K} \times 9$-Bit BiFIFO ........................................................................... 6.19
$512 \times 18$-Bit - 1 K $\times 9$-Bit BiFIFO .......................................................................... 6.19
1K x 18-Bit — $2 \mathrm{~K} \times 9$-Bit BiFIFO .......................................................................... 6.19
$512 \times 18$-Bit BiFIFO ............................................................................................. 6.20
1K $\times 18$-Bit BiFIFO............................................................................................... 6.20
$256 \times 18$-Bit Synchronous BiFIFO (SyncBiFIFO™ )................................................ 6.21
$512 \times 18$-Bit Synchronous BiFIFO (SyncBiFIFO™) ................................................ 6.21
SPECIALTY MEMORY PRODUCTS
IDT7130 8K (1K x 8) Dual-Port RAM (MASTER) ................................................................. 7.1
IDT7140
IDT7030
8K ( $1 \mathrm{~K} \times 8$ ) Dual-Port RAM (SLAVE)
7.1

IDT7040
8K (1K x 8) Dual-Port RAM (MASTER) ................................................................. 7.2
8K ( $1 \mathrm{~K} \times 8$ 8) Dual-Port RAM (SLAVE) ...................................................................... 7.2
9K ( $1 \mathrm{~K} \times 9$ 9) Dual-Port RAM (MASTER) ................................................................. 7.3
9K ( $1 \mathrm{~K} \times 9$ ) Dual-Port RAM (SLAVE) .................................................................... 7.3
9K ( $1 \mathrm{~K} \times 9$ ) Dual-Port RAM (MASTER w/Interrupts) ............................................... 7.4
9K ( $1 \mathrm{~K} \times 9$ ) Dual-Port RAM (SLAVE w/Interrupts) ................................................... 7.4
16K (2K x 8) Dual-Port RAM (MASTER) ..............................................................., 7.5
$16 \mathrm{~K}(2 \mathrm{~K} \times 8$ 8) Dual-Port RAM (SLAVE) ................................................................. 7.5
16K (2K x 8) Dual-Port RAM (MASTER) ............................................................... 7.6
16K (2K x 8) Dual-Port RAM (SLAVE) .................................................................. 7.6
16K (2K x 8) Dual-Port RAM (MASTER w/Interrupts) ............................................ 7.7
16K (2K x 8) Dual-Port RAM (SLAVE w/Interrupts) ................................................ 7.7
18K (2K x 9) Dual-Port RAM ................................................................................ 7.8
18K (2K x 9) Dual-Port RAM (MASTER w/Interrupts) ............................................. 7.9
18K (2K x 9) Dual-Port RAM (SLAVE w/Interrupts)................................................ 7.9
32K (2K x 16) Dual-Port RAM (MASTER) ............................................................. 7.10
32K (2K x 16) Dual-Port RAM (SLAVE) ................................................................ 7.10
32K (2K x 16) Dual-Port RAM (MASTER) ............................................................. 7.11
32K (2K x 16) Dual-Port RAM (SLAVE) ............................................................... 7.11
32K (4K x 8) Dual-Port RAM ............................................................................... 7.12
32K ( $4 \mathrm{~K} \times 8$ ) Dual-Port RAM ................................................................................ 7.13
32K (4K x 8) Dual-Port RAM (w/Semaphores) ...................................................... 7.14
32K (4K x 8) Dual-Port RAM (w/Semaphores) ...................................................... 7.15
32K ( $4 \mathrm{~K} \times$ 9) Dual-Port RAM ................................................................................ 7.16
64K ( $4 \mathrm{~K} \times 16$ ) Dual-Port RAM .............................................................................. 7.17
64K ( $8 \mathrm{~K} \times 8$ 8) Dual-Port RAM ................................................................................ 7.18
128K ( $8 \mathrm{~K} \times 16$ ) Dual-Port RAM ........................................................................... 7.19
128K ( $16 \mathrm{~K} \times 8$ ) Dual-Port RAM ............................................................................ 7.20
8K ( $1 \mathrm{~K} \times 8$ ) FourPor ${ }^{\text {TM }}$ RAM ............................................................................... 7.21
1990-91 SPECIALIZED MEMORIES DATA BOOK (CONTINUED) PAGE
SPECIALTY MEMORY PRODUCTS (CONTINUED)
IDT7052 $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ FourPort ${ }^{\text {TM }}$ RAM ..... 7.22
IDT71502 $64 \mathrm{~K}(4 \mathrm{~K} \times 16)$ Registered RAM ( $\mathrm{w} /$ SPC $^{\text {™ }}$ ) ..... 7.23
SUBSYSTEMS PRODUCTS
MULTI-PORT MODULES
IDT7M134 $8 \mathrm{~K} \times 8$ Master Dual-Port SRAM Module ..... 8.1
IDT7M144 $8 \mathrm{~K} \times 8$ Slave Dual-Port SRAM Module ..... 8.2
IDT7M135 16K x 8 Master Dual-Port SRAM Module ..... 8.1
IDT7M145 16K x 8 Slave Dual-Port SRAM Module ..... 8.2
IDT7M137
IDT7M1003
IDT7M1001
IDT7M1004
IDT7M1005
IDT7MB6056
IDT7MB1008
IDT7MB1006
IDT7MB6046
IDT7MB6036
IDT7MB6156
32K $\times 8$ Master Dual-Port SRAM Module ..... 8.3
$64 \mathrm{~K} \times 8$ Dual-Port SRAM Module ..... 8.4
$128 \mathrm{~K} \times 8$ Dual-Port SRAM Module ..... 8.4
$8 \mathrm{~K} \times 9$ Dual-Port SRAM Module ..... 8.5
16K x 9 Dual-Port SRAM Module ..... 8.5
$32 \mathrm{~K} \times 16$ Dual-Port (Shared Memory) SRAM Module ..... 8.6
32K $\times 16$ Dual-Port SRAM Module ..... 8.7
$64 \mathrm{~K} \times 16$ Dual-Port SRAM Module ..... 8.7
$64 \mathrm{~K} \times 16$ Dual-Port (Shared Memory) SRAM Module ..... 8.6
$128 \mathrm{~K} \times 16$ Dual-Port (Shared Memory) SRAM Module ..... 8.6
$32 \mathrm{~K} \times 18$ Dual-Port (Shared Memory) SRAM Module ..... 8.8
$64 \mathrm{~K} \times 18$ Dual-Port (Shared Memory) SRAM Module ..... 8.8
$128 \mathrm{~K} \times 18$ Dual-Port (Shared Memory) SRAM Module ..... 8.8
$16 \mathrm{~K} \times 32$ Dual-Port SRAM Module ..... 8.9
$8 \mathrm{~K} \times 8$ FourPort ${ }^{\text {TM }}$ SRAM Module ..... 8.10
$4 \mathrm{~K} \times 8$ FourPort $^{\text {™ }}$ SRAM Module ..... 8.10
$4 \mathrm{~K} \times 16$ FourPort $^{\text {TM }}$ SRAM Module ..... 8.11
$2 \mathrm{~K} \times 16$ FourPort $^{\text {™ }}$ SRAM Module ..... 8.11
FIFO MODULES
IDT7M205
IDT7MP2005
IDT7M206
IDT7MP2011
IDT7M207
IDT7MP2010
IDT7MP2009
$8 \mathrm{~K} \times 9-$ Bit CMOS FIFO Module ..... 8.12
8K x 9-Bit FIFO Module ..... 8.13
16K x 9-Bit CMOS FIFO Module ..... 8.12
$16 \mathrm{~K} \times 9$ Bit FIFO Module ..... 8.13
$32 \mathrm{~K} \times 9$-Bit CMOS FIFO Module ..... 8.14
$16 \mathrm{~K} \times 18$-Bit FIFO Module ..... 8.15
$32 \mathrm{~K} \times 18$-Bit FIFO Module ..... 8.15
SRAM MODULES
IDT7MC4001
$1 \mathrm{M} \times 1$ CMOS Static RAM Module ..... 8.16
IDT7M4042
256K x 4 CMOS Static RAM Module ..... 8.17
IDT7M812 $64 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.18IDT8M824S
IDT8MP824S
IDT8MP824L
IDT7MP4034
IDT7M4048
IDT7MB4048
IDT7MP4008S
IDT7MP4058L
IDT7M912
IDT7MB4040
IDT7MC4005
IDT7MB4009
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.19
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.20
128K x 8 CMOS Static RAM Module ..... 8.21
256K x 8 CMOS Static RAM Module ..... 8.22
512K $\times 8$ CMOS Static RAM Module ..... 8.23
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.23
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.24
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.25
$64 \mathrm{~K} \times 9$ CMOS Static RAM Module ..... 8.18
256K $\times 9$ CMOS Static RAM Module ..... 8.26
$16 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.27
2(16K $\times 16$ ) CMOS Static RAM Module ..... 8.28
IDT8M612$32 \mathrm{~K} \times 16$ CMOS Static RAM Module8.29
1990-91 SPECIALIZED MEMORIES DATA BOOK (CONTINUED) ..... PAGE
SRAM MODULES (CONTINUED)
DT8MP612S 32K x 16 CMOS Static RAM Module ..... 8.30
IDT8MP612L $32 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.31
IDT7M624 $64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.32
IDT8M624
IDT8MP624S
$64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.29IDT8MP624L$64 \mathrm{~K} \times 16$ CMOS Static RAM Module8.30
$64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.31
256K $\times 16$ CMOS Static RAM Module ..... 8.33
512K x 16 CMOS Static RAM Module ..... 8.34
16K x 32 CMOS Static RAM Module w/Separate Data I/O ..... 8.35
$16 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.36
$32 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.37
$64 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.38
$64 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.39
128K x 32 CMOS Static RAM Module ..... 8.37
$256 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.40
CACHE MODULES
IDT7MB6064
(2 $\times 4 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.41
IDT7MB6044 ( $2 \times 4 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.42
IDT7MB6043 ( $2 \times 8 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.43
IDT7MB6051 ( $2 \times 8 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU (Multiprocessor) ..... 8.44
IDT7MB6039 ( $2 \times 16 \mathrm{~K} \times 60$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.45
IDT7MB6049
( $2 \times 16 \mathrm{~K} \times 60$ ) Data/Instruction Cache Module for IDT79R3000 CPU (Multiprocessor) ..... 8.46
IDT7MB6040 ( $2 \times 16 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for General Purpose CPUs ..... 8.47
IDT7MB6061 ( $2 \times 16 \mathrm{~K} \times 60$ ) Data/Instruction w/Resettable Instruction Tag ..... 8.48
WRITABLE CONTROL STORE MODULES
IDT7M6032 16K x 32 Writable Control Store Static RAM Module ..... 8.49
IDT7MB6042 $8 \mathrm{~K} \times 112$ Writable Control Store Static RAM Module ..... 8.50
OTHER MODULES
Flexi-Pak Family Modules with Various Combinations of SRAMs, EPROMs and EEPROMs ..... 8.51
CUSTOM MODULES
Subsystem Custom Module Capabilities ..... 8.52
APPLICATION AND TECHNICAL NOTES
FIFO Products Application Notes
AN-01 Understanding the IDT7201/7202 FIFO ..... 9.1
AN-15 Using the IDT72103/104 Serial-Parallel FIFO ..... 9.2
AN-22 Performance Advantages with IDT's Flagged FIFOs ..... 9.3
AN-34 General Purpose (16-Bit to 8-Bit) BiFIFO Interface ..... 9.4
AN-36 The BiFIFO Parity Generation and Checking ..... 9.5
AN-39 The Programmable Flags of BiFIFOs ..... 9.6
AN-56 The BiFIFO Expansion Configuration ..... 9.7
AN-57 The BiFIFO Bypass ..... 9.8
AN-60 Designing with the IDT SyncFIFOTM - The Architecture of the Future ..... 9.9
AN-69 Depth Expansion of IDT's Synchronous FIFOs Using the Ring Counter Approach ..... 9.10
AN-71 Simplify SCSI Host Adapter Design with Bidirectional FIFO Memories ..... 9.11
AN-73 Understanding the Output Control $\overline{\mathrm{OE}}$ of the Flagged FIFOs: IDT72021/31/41 ..... 9.12
1990-91 SPECIALIZED MEMORIES DATA BOOK (CONTINUED) ..... PAGE
APPLICATION AND TECHNICAL NOTES (CONTINUED)
FIFO Products Technical Notes
TN-06 Designing with FIFOs ..... 9.13
TN-08 Operating FIFOs on Full and Empty Boundary Conditions ..... 9.14
TN-09 Cascading FIFOs or FIFO Modules ..... 9.15
Specialty Memory Products Application Notes
AN-02 Dual-Port RAMs Simplify Communication in Computer Systems ..... 9.16
AN-09 Dual-Port RAMs Yield Bit-Slice Designs without Microcode ..... 9.17
AN-14 Dual-Port RAMs with Semaphore Arbitration ..... 9.18
AN-42 Using the IDT7052 FourPort ${ }^{\text {TM }}$ SRAM ..... 9.19
AN-43 IDT FourPort ${ }^{\text {TM }}$ RAM Facilitates Multiprocessor Designs ..... 9.20
AN-45 Introduction to IDT's FourPort ${ }^{\text {TM }}$ RAM ..... 9.21
AN-59 Using IDT7024 and IDT7025 Dual-Port Static RAMs to Match System Bus Widths ..... 9.22
AN-67 Using IDT71502 RAMs in a Real-Time Debugging Tool for an R3000 Microprocessor-based System ..... 9.23
AN-68 Dual-Port RAM Simplifies PC to TMS320 Interface ..... 9.24
AN-70 Dual-Port Interrupt Expansion ..... 9.25
Subsystems Products Application Notes
AN-44 Design Guidelines for Custom Module Packages ..... 9.26
AN-74 Understanding Dual-Port Shared Memory Modules ..... 9.27
AN-75 Using the IDT7M4017 in an 8-Bit and 16-Bit Wide Organization ..... 9.28
AN-76 Using the IDT7MB6049 Cache Module with the IDT79R3000 RISC Processor in Single or Multiprocessor Systems ..... 9.29
IDT SALES OFFICE, REPRESENTATIVE AND DISTRIBUTOR LOCATIONS

## 1990-91 LOGIC DATA BOOK

## The following is a listing of the data sheets located in the 1990-91 Logic Data Book avallable under separate cover:

COMPLEX LOGIC PRODUCTS ..... PAGE
DSP AND MICROSLICETM PRODUCTS
IDT39C01 4-Bit Microprocessor Slice ..... 5.1
IDT39C10 12-Bit Sequencer ..... 5.2
IDT49C402 16-Bit Microprocessor Slice ..... 5.3
IDT49C410 16-Bit Sequencer ..... 5.4
IDT7210L $16 \times 16$ Parallel Multiplier-Accumulator ..... 5.5
IDT7216L $16 \times 16$ Parallel Multiplier ..... 5.6
IDT7217L $16 \times 16$ Parallel Multiplier (32 Bit Output) ..... 5.6
IDT7381L 16-Bit CMOS Cascadable ALU ..... 5.7
IDT7383L 16-Bit CMOS Cascadable ALU ..... 5.7
READ/WRITE BUFFER PRODUCTS
IDT73200L 16-Bit CMOS Multilevel Pipeline Register ..... 5.8
IDT73201L 16-Bit CMOS Multilevel Pipeline Register ..... 5.8
IDT73210 Fast Octal Register Transceiver w/Parity ..... 5.9
IDT73211 Fast Octal Register Transceiver w/Parity ..... 5.9
ERROR DETECTION AND CORRECTION PRODUCTS
IDT39C60 16-Bit Cascadable EDC ..... 5.10
IDT49C460 32-Bit Cascadable EDC ..... 5.11
IDT49C465 32-Bit CMOS Flow-ThruEDC Unit ..... 5.12
IDT49C466 64-BIT CMOS Flow-ThruEDC Unit ..... 5.13
GRAPHICS PRODUCTS
IDT75C457 CMOS Single 8-Bit PaletteDAC™ for True Color Applications ..... 5.14
IDT75C458 Triple 8-Bit PaletteDAC ${ }^{\text {TM }}$ ..... 5.15
IDT75C48 8-Bit Flash ADC ..... 5.16
IDT75C58 8 -Bit Flash ADC with Overflow Output ..... 5.17
STANDARD LOGIC PRODUCTS
IDT29FCT52T
Non-inverting Octal Registered Transceiver ..... 6.1
IDT29FCT53T Inverting Octal Registered Transceiver ..... 6.1
IDT29FCT520T Multi-level Pipeline Register ..... 6.2
IDT29FCT521T
IDT54/74FCT138T 1-of-8 Decoder ..... 6.2 ..... 6.3
IDT54/74FCT139T Dual 1-of-4 Decoder
IDT54/74FCT151T 8 -Input Multiplexer ..... 6.5
8 -Input Multiplexer w/3-State ..... 6.5
Quad 2-Input Multiplexer ..... 6.6
FQuad 2-Input Multiplexer w/3-State ..... 6.6
Synchronous Binary Counter w/Asynchronous Master Reset ..... 6.7
Synchronous Binary Counter w/Synchronous Reset ..... 6.7
Up/Down Binary Counter w/Preset and Ripple Clock ..... 6.8
Up/Down Binary Counter w/Separate Up/Down Clocks ..... 6.9
Inverting Octal Buffer/Line Driver ..... 6.10
Non-inverting Octal Buffer/Line Driver ..... 6.10
Non-inverting Octal Buffer/Line Driver ..... 6.10
Inverting Octal Buffer/Line Driver ..... 6.10
Non-inverting Octal Buffer/Line Driver ..... 6.10
Non-inverting Octal Transceiver ..... 6.11
1990-91 LOGIC DATA BOOK (CONTINUED) ..... PAGE
STANDARD LOGIC PRODUCTS (CONTINUED)
IDT54/74FCT640T Inverting Octal Transceiver ..... 6.11
IDT54/74FCT645T Non-inverting Octal Transceiver ..... 6.11
IDT54/74FCT273T Octal D Flip-Fiop w/Common Master Reset ..... 6.12
IDT54/74FCT299T 8 Input Universal Shift Register w/Common Parallel I/O Pins ..... 6.13
IDT54/74FCT373T Non-inverting Octal Transparent Latch w/3-State ..... 6.14
IDT54/74FCT533T Inverting Octal Transparent Latch w/3-State ..... 6.14
IDT54/74FCT573T Non-inverting Octal Transparent Latch w/3-State ..... 6.14
IDT54/74FCT374T Non-inverting Octal D Register ..... 6.15
IDT54/74FCT534T Inverting Octal D Register ..... 6.15
Non-inverting Octal D Register ..... 6.15
Octal D Flip-Flop w/Clock Enable ..... 6.16
Quad Dual-Port Register ..... 6.17
8-Bit Identity Comparator ..... 6.18
Non-inverting Octal Latched Transceiver ..... 6.19
Non-inverting Octal Registered Transceiver ..... 6.20
Inverting Octal Registered Transceiver ..... 6.20
Inverting Octal Registered Transceiver ..... 6.20
Non-inverting Octal Registered Transceiver ..... 6.20
Inverting Octal Bus Transceiver w/3-State ..... 6.21
Non-inverting Octal Bus Transceiver w/3-State ..... 6.21
Non-inverting Octal Bus Transceiver (Open Drain) ..... 6.22
Inverting Octal Bus Transceiver (Open Drain) ..... 6.22
10-Bit Non-inverting Register w/3-State ..... 6.23
9 -Bit Non-inverting Register w/Clear \& 3-State ..... 6.23
8 -Bit Non-inverting Register w/Clear \& 3-State ..... 6.23
$10-$ Bit Non-inverting Buffer ..... 6.24
10-Bit Inverting Buffer ..... 6.24
10-Bit Non-inverting Latch ..... 6.25
9 -Bit Non-inverting Latch ..... 6.25
8-Bit Non-inverting Latch ..... 6.25
Non-inverting Octal Registered Transceiver ..... 6.26
Inverting Octal Registered Transceiver ..... 6.26
Multi-level Pipeline Register ..... 6.27
16-Bit Synchronous Binary Counter ..... 6.28
High-Speed Tri-Port Bus Multiplexer ..... 6.29
Buffer/Clock Driver w/Guaranteed Skew ..... 6.30
Buffer/Clock Driver w/Guaranteed Skew ..... 6.30
Octal Register with SPC ${ }^{\text {TM }}$ ..... 6.31
Microcycle Length Controller ..... 6.32
IDT39C8XXX Family ..... 6.33
1-of-8 Decoder ..... 6.34
Dual 1-of-4 Decoder ..... 6.35
Synchronous Binary Counter w/Asynchronous Master Reset ..... 6.36
Synchronous Binary Counter w/Synchronous Reset ..... 6.36
Carry Lookahead Generator ..... 6.37
Up/Down Binary Counter w/Preset and Ripple Clocks ..... 6.38
Up/Down Binary Counter w/Separate Up/Down Clocks ..... 6.39
Inverting Octal Buffer/Line Driver ..... 6.40
Non-inverting Octal Buffer/Line Driver ..... 6.40
Non-inverting Octal Buffer/Line Driver ..... 6.40
Inverting Octal Buffer/Line Driver ..... 6.40
Non-inverting Octal Buffer/Line Driver ..... 6.40
Non-inverting Octal Transceiver ..... 6.41
Inverting Octal Transceiver ..... 6.41
1990-91 LOGIC DATA BOOK (CONTINUED) ..... PAGE
STANDARD LOGIC PRODUCTS (CONTINUED)
IDT54/74FCT645
IDT54/74FCT645 Non-inverting Octal Transceiver Non-inverting Octal Transceiver ..... 6.41 ..... 6.41
IDT54/74FCT273 Octal D Flip-Flop w/Common Master Reset ..... 6.42
IDT54/74FCT299 8 -Input Universal Shift Register w/Common Parallel I/O Pins ..... 6.43
IDT54/74FCT373 Non-inverting Octal Transparent Latch ..... 6.44
IDT54/74FCT533 Inverting Octal Transparent Latch ..... 6.44
IDT54/74FCT573 Non-inverting Octal Transparent Latch ..... 6.44
IDT54/74FCT374 Non-inverting Octal D Flip-Flop ..... 6.45
IDT54/74FCT534 Inverting Octal D Flip-Flop w/3-State ..... 6.45
IDT54/74FCT574 Non-inverting Octal D Register w/3-State ..... 6.45
IDT54/74FCT377 Octal D Flip-Flop w/Clock Enable ..... 6.46
IDT54/74FCT399 Quad Dual-Port Register ..... 6.47
IDT54/74FCT521 8 -Bit Identity Comparator ..... 6.48
IDT54/74FCT543 Non-inverting Octal Latched Transceiver ..... 6.49
IDT54/74FCT646 Non-inverting Octal Registered Transceiver ..... 6.50
IDT54/74FCT821 10-Bit Non-inverting Register w/3-State ..... 6.51
IDT54/74FCT823
9-Bit Non-inverting Register w/Clear \& 3-State ..... 6.51
IDT54/74FCT824
9 -Bit Inverting Register w/Clear \& 3-State ..... 6.51
IDT54/74FCT8258 -Bit Non-inverting Register6.51
IDT54/74FCT827 10-Bit Non-inverting Buffer ..... 6.52
IDT54/74FCT833 8 -Bit Transceiver w/Parity ..... 6.53
IDT54/74FCT841 10-Bit Non-inverting Latch ..... 6.54
IDT54/74FCT843 9 -Bit Non-inverting Latch ..... 6.54
IDT54/74FCT844 9 -Bit Inverting Latch ..... 6.54
IDT54/74FCT845 8-Bit Non-inverting Latch ..... 6.54
IDT54/74FCT861 10-Bit Non-inverting Transceiver ..... 6.55
IDT54/74FCT863 9-Bit Non-inverting Transceiver ..... 6.55
IDT54/74FCT864 9-Bit Inverting Transceiver. ..... 6.55
IDT54/74FBT240 Inverting Octal Buffer/Line Driver ..... 6.56
IDT54/74FBT241 Non-inverting Octal Buffer/Line Driver ..... 6.57
Non-inverting Octal Buffer/Line Driver ..... 6.58
IDT54/74FBT244
Non-inverting Octal Transceiver ..... 6.59
IDT54/74FBT245
Octal Transparent Latch w/3-State ..... 6.60 ..... 6.60
IDT54/74FBT373
Non-inverting Octal D Register
Non-inverting Octal D Register ..... 6.61 ..... 6.61
IDT54/74FBT540 Inverting Octal Buffer ..... 6.62
IDT54/74FBT541 Non-inverting Octal Buffer ..... 6.62
10-Bit Non-inverting Register ..... 6.63
IDT54/74FBT821
9-Bit Inverting Register ..... 6.64
IDT54/74FBT823
Non-inverting 10 -Bit Buffers/Driver ..... 6.65 ..... 6.65
IDT54/74FBT827
IDT54/74FBT827
Inverting10-Bit Buffers/Driver ..... 6.65 ..... 6.65
IDT54/74FBT828
10-Bit Non-inverting Latch
10-Bit Non-inverting Latch ..... 6.66 ..... 6.66
IDT54/74FBT841
IDT54/74FBT841
Inverting Octal Buffer/Line Driver w/25ת Series Resistor ..... 6.67
IDT54/74FBT2244 Inverting Octal Buffer/Line Driver w/ $25 \Omega$ Series Resistor ..... 6.68
IDT54/74FBT2373 Octal Transparent Latch w/3-State \& $25 \Omega$ Series Resistor ..... 6.69
IDT54/74FBT2827 Non-inverting 10 -Bit Buffers/Driver w/25 Series Resistor ..... 6.70
IDT54/74FBT2828 Inverting10-Bit Buffers/Driver w/25 Series Resistor ..... 6.70
IDT54/74FBT2841 10-Bit Memory Latch w/25 $\Omega$ Series Resistor ..... 6.71
APPLICATION AND TECHNICAL NOTES
Complex Logic Products Technical Notes
TN-02 Build a 20MIP Data Processing Unit ..... 7.1
TN-03 Using the IDT49C402A ALU ..... 7.2
1990-91 LOGIC DATA BOOK (CONTINUED) PAGE
Complex Logic Products Application Notes
AN-03 Trust Your Data with A High-Speed CMOS 6-, 32- or 64-Bit EDC ..... 7.3
16-Bit CMOS Slices - New Building Blocks Maintain MicrocodeCompatibility Yet Increase Performance7.4
AN-17 FIR Filter Implementation Using FIFOs and MACs ..... 7.5
AN-24 Designing with the IDT49C460 and IDT39C60 Error Detection and Correction Units ..... 7.6
AN-32 Implementation of Digital Filters Using IDT7320, IDT7210, IDT7216 ..... 7.7
AN-35 Address Generator in Matrix Unit Operation Engine ..... 7.8
AN-37 Designing High-Performance Systems Using the IDT PaletteDAC™ ..... 7.9
AN-63 Using the IDT75C457's PaletteDAC ${ }^{\text {™ }}$ in True Color and Monochrome Graphics Applications ..... 7.10
AN-64 Protecting Your Data with IDT's 49C465 32-Bit Flow-thruEDC™ Unit ..... 7.11
AN-65 Using IDT73200 or IDT73210 as Read and Write Buffers with R3000 ..... 7.12
Standard Logic Application Notes ..... 7.13
AN-47 Simultaneous Switching Noise ..... 7.14
AN-48 Using High-Speed Logic ..... 7.15
AN-49 Characteristics of PCB Traces ..... 7.16
AN-50 Series Termination ..... 7.17
AN-51 Power Dissipation in Clock Drivers ..... 7.18
AN-52 FCT Output Structures and Characteristics ..... 7.19
AN-53 Power-Down Operation ..... 7.20
AN-54 FCT-T Logic Family ..... 7.21
Standard Logic Technical Bulletins ..... 7.22

## RISC DATA BOOK

The following is a list of data sheets expected to be Included in the RISC Data Book due for publication 4Q90. Until its release, please refer to your 1989 Data Book Supplement.

RISC MICROPROCESSOR PRODUCTS
RISC COMPONENTS

| IDT79R3000A | Second Generation MIPS RISC CPU |
| :--- | :--- |
| IDT79R3001 | IDT RISControllerTM CPU for Embedded and Real Time Applications |
| IDT79R3010A | Floating-Point Accelerator for the R3000A and R3001 |
| IDT79R3020 | RISC CPU Write Buffer for R3000A and R3001 |
| IDT79R305x | Integrated RISC Microporccessor Family for Embedded Applications |
| IDT79R3720 | Bus Exchanger for R305x Memory Systems |
| IDT79R3721 | DRAM Controller for R305x Based Systems |
| IDT79R4000 | Third Generation RISC Microprocessor |
| IDT79R4000SP | Third Generation RISC Microporcessor for Desktop Applications |

## RISC DEVELOPMENT SYSTEMS

RS1210
RC2030
RC3240
RC3260
M/2000

RISComputer™ Development System
RISComputer ${ }^{\text {™ }}$ Development System
RISComputer ${ }^{\text {™ }}$ Development System
RISComputer™ Development System
RISComputer ${ }^{\text {™ }}$ Development System

RISC DEVELOPMENT SOFTWARE

3106 Ada
$3120 \mathrm{C}-\mathrm{SRC}$ (SPP)
3123C-SRC (SPP/e)
3178C-SRC (ASAPP)

Ada Compiler
System Programmer's Package
System Programmer's Package/e
Ada Stand-alone Programmer's Package

## RISC SUBSYSTEM PRODUCTS

RISC CPU MODULES
IDT7RS101
IDT7RS101F

IDT7RS102
IDT7RS102F
IDT7RS103
IDT7RS103F
IDT7RS104
IDT7RS104F
IDT7RS105
IDT7RS105F
IDT7RS107F

## RISC TargetSystems

IDT7RS301
IDT7RS302
IDT7RS303

## RISC DATA BOOK (CONTINUED)

RISC SUBSYSTEM PRODUCTS (CONTINUED)
RISC TargetSystems (CONTINUED)
IDT7RS304 TargetSystem ${ }^{\text {TM }}$ for IDT7RS104
IDT7RS305 TargetSystem ${ }^{\text {TM }}$ for IDT7RS105
IDT7RS307 TargetSystem ${ }^{\text {TM }}$ for IDT7RS107

## SUPPORT PRODUCTS

IDT7RS201
IDT7RS202
IDT7RS203
IDT7RS340
IDT7RS341
IDT7RS342
IDT7RS343
IDT7RS347
IDT7RS353-B
IDT7RS353-MB
IDT7RS353-S
IDT7RS353-MS
IDT7RS355-B
IDT7RS355-MB
IDT7RS355.S
IDT7RS355-MS
IDT7RS356.2B
IDT7RS356.3B
IDT7RS356-3MB
IDT7RS357-1B
IDT7RS357-1MB
IDT7RS357.2B
IDT7RS357.2MB
IDT7RS357-3B
IDT7RS357-3MB
IDT7RS361-B
IDT7RS361-MB
IDT7RS361-E
IDT7RS361-S
IDT7RS361-MS
IDT7RS363-1
IDT7RS363-2
IDT7RS364
IDT7RS365
IDT7RS366
IDT7RS382
IDT7RS383
Nubus Board
Nubus Board, Supports Nubus Memory
Nubus Board, Supports Onboard Memory
System Board
Personality Board for IDT7RS101
Personality Board for IDT7RS102
Personality Board for IDT7RS103
Personality Board for IDT7RS107
JMI C-Executive ${ }^{\text {TM }}$ Binary Code
JMI C-Executive ${ }^{\text {TM }}$ Maintenance for Binary Code
JMI C-Executive ${ }^{\text {TM }}$ SourceCode
JMI C-Executive ${ }^{\text {TM }}$ Maintenance for Source Code
Floating Point Library Binary Code
Floating Point Library Maintenance for Binary Code
Floating Point Library Source Code
Floating Point Library Maintenance for Source Code
R3000 C-Compiler Binary Code for 80286, 80386 IDT7RS356-2MB R3000
C-Compiler Maintenance for Binary Code for 80286, 80386 PC-DOS
R3000 C-Compiler Binary Code for PC SCO XENIX
R3000 C-Compiler Maintenance for Binary Code SCO XENIX
R3000 Macro Assembler Binary Code for 8086, 8088 PC-DOS
R3000 Macro Assembler Maintenance for Binary Code 8086, 8088
R3000 Macro Assembler Binary Code for 80286, 80386 PC-DOS
R3000 Macro Assembler Maintenance for Binary Code 80286, 80386
R3000 Macro Assembler Binary Code for PC SCO XENIX
R3000 Macro Assembler Maintenance for Binary Code SCO XENIX
IDT PROM Monitor Binary Code
IDT PROM Monitor Maintenance for Binary Code
IDT PROM Monitor Binary Code - in 4 EPROMs
IDT PROM Monitor Source Code
IDT PROM Monitor Maintenance for Source Code
R3000 PGA Breakout Board and HP 16500A Logic Analyzer Set-up Software
R3000 PGA Breakout Board and HP 16500A Logic Analyzer Set-up Software and 5 HP Adapters
HP 16500A Logic Analyzer Disassembler Software for 7RS300 Series TargetSystems ${ }^{\text {TM }}$
R3000 Flatpack Version
R3001 PGA Version
R3000 Evaluation Board
R3001 Evaluation Board

## MacStation ${ }^{\text {TM }}$ DEVELOPMENT SYSTEM

IDT7RS501-1 MacStationTM Development System w/IDT7RS201 Nubus Board, IDT/ux and C-Compiler
IDT7RS501-1D MacStation ${ }^{\text {TM }}$ Development System Documentation
IDT7RS501-1M MacStation ${ }^{\text {M }}$ Development System Maintenance
IDT7RS501-2

## RISC DATA BOOK (CONTINUED)

RISC SUBSYSTEM PRODUCTS (CONTINUED)
MacStation ${ }^{\text {TM }}$ DEVELOPMENT SYSTEM (CONTINUED)
IDT7RS501-3

IDT7RS501-4
IDT7RS501-5
IDT7RS501-6
IDT7RS502-1
IDT7RS502-1D
IDT7RS502-1M
IDT7RS502-2
IDT7RS502-3

IDT7RS502-4
IDT7RS502-5
IDT7RS502-6
IDT7RS503-1
IDT7RS503-1D
IDT7RS503-1M
IDT7RS551-1B
IDT7RS571-1S
IDT7RS572-1S
IDT7RS573-1B
IDT7RS573-1MB
Complete IDT7RS501 MacStation ${ }^{\text {TM }}$ Development System w/MAC II Computer, 8 MB RAM, 150MB Hard Disk, 40MB External Tape Drive, IDT7RS201 Nubus Board, IDT/ux and C-Compiler
4MB SIMM Module for MAC II
IDT7RS501 MacStation ${ }^{\text {TM }}$ Development System w/150MB External Hard Disk, IDT7RS201
Nubus Board, IDT/ux and C-Compiler
IDT7RS501 MacStation ${ }^{\text {TM }}$ Development System w/40MB External Tape Drive, IDT7RS201 Nubus Board, IDT/ux and C-Compiler
MacStation ${ }^{\text {™ }}$ Development System w/IDT7RS202 Nubus Board, 8MB Nubus RAM Board, IDT/ux and C-Compiler
MacStation ${ }^{\text {TM }}$ Development System Documentation
MacStation ${ }^{\text {™ }}$ Development System Maintenance
IDT7RS502 MacStation ${ }^{\text {TM }}$ Development System w/150MB External Hard Disk, 40MB External Tape Drive, IDT7RS202 Nubus Board, IDT/ux and C-Compiler
Complete IDT7RS502 MacStation ${ }^{\text {TM }}$ Development System w/MAC II Computer, 8MB RAM, 150MB Hard Disk, 40MB External Tape Drive, IDT7RS202 Nubus Board, IDT/ux and C-Compiler
4MB SIMM Module for MAC II
IDT7RS502 MacStation ${ }^{\text {M }}$ Development System w/150MB External Hard Disk, IDT7RS202 Nubus Board, IDT/ux and C-Compiler
IDT7RS502 MacStation ${ }^{\text {TM }}$ Development System w/40MB External Tape Drive, IDT7RS202 Nubus Board, IDT/ux and C-Compiler
MacStation ${ }^{\text {™ }}$ Development System w/16MB RAM, IDT/ux and C-Compiler
MacStation ${ }^{\text {M }}$ Development System Documentation
MacStation ${ }^{\text {TM }}$ Development System Maintenance
IDT/ux - UNIX Operating System for MacStations ${ }^{\text {TM }}$
MIPS SPP for the MAC
MIPS SPP/e for the MAC
MIPS Fortran for the MAC
Maintenance for MIPS Fortran for the MAC

## STATIC RAM DATA BOOK

The following is a list of data sheets expected to be included in the Static RAM Data Book due for publication 1Q91. Untll its release, please refer to your 1989 Data Book Supplement.

## STATIC RAM PRODUCTS

IDT6167
IDT6168
IDT6177
IDT6178
IDT61970
IDT71681
IDT71682
IDT6116
IDT7187
IDT6198
IDT7188
IDT7198
IDT61B98
IDT71981
IDT71982
IDT71B88
IDT71B98
IDT7164
IDT7165
IDT7174
IDT71B64
IDT71B65
IDT71B74
IDT7186
IDT71586
IDT7169
IDT71569
IDT71B569
IDT71B69
IDT71B79
IDT71220
IDT71222
IDT71270
IDT71257
IDT61298
IDT71258
IDT61B298
IDT71281
IDT71282
IDT71B258
IDT71256
IDT71B256
IDT71B556
IDT71259
IDT71509
IDT71559
IDT71589
IDT71027
IDT71028
IDT71024

16K x 1 w/Power-Down
4K $\times 4$ w/Power-Down
$4 \mathrm{~K} \times 4$ Cache-Tag w/Open Drain and Power-Down
$4 \mathrm{~K} \times 4$ Cache-Tag w/Power-Down
$4 \mathrm{~K} \times 4$ w/Output Enable and Power-Down
$4 \mathrm{~K} \times 4 \mathrm{w} /$ Separate I/O and Power-Down
4K $\times 4 \mathrm{w} /$ Separate I/O and Power-Down
2K $\times 8$ w/Power-Down
$64 \mathrm{~K} \times 1$ w/Power-Down
16K $\times 4$ w/Output Enable and Power-Down
16K $\times 4$ w/Power-Down
16K $\times 4$ w/Output Enable, 2 Chip Selects and Power-Down
16K $\times 4$ BiCEMOS $^{\text {TM }}$ w/Output Enable
16K $\times 4$ w/Separate I/O and Power Down
16K $\times 4$ w/Separate I/O and Power Down
$16 \mathrm{~K} \times 4$ BiCEMOSTM
16K $\times 4$ BiCEMOS w/Output Enable and 2 Chip Selects
$8 \mathrm{~K} \times 8$ w/Power-Down
8K $\times 8$ Resettable Power-Down
$8 \mathrm{~K} \times 8$ Cache-Tag w/Power-Down
$8 \mathrm{~K} \times 8$ BiCEMOS ${ }^{\text {™ }}$
$8 \mathrm{~K} \times 8$ BiCEMOS ${ }^{\text {TM }}$ Resettable
$8 \mathrm{~K} \times 8$ BiCEMOS ${ }^{\text {™ }}$ Cache-Tag
4K $\times 16$ w/Power-Down
4K $\times 16$ w/Address Latch and Power-Down
8K $\times 9$ w/Power-Down
$8 \mathrm{~K} \times 9$ w/Address Latch and Power-Down
$8 \mathrm{~K} \times 9$ BiCEMOS $^{\text {TM }}$ w/Address Latch
$8 \mathrm{~K} \times 9$ BiCEMOS $^{\text {TM }}$
$8 \mathrm{~K} \times 9$ BiCEMOS $^{\text {TM }}$ Cache-Tag
$4 \mathrm{~K} \times 18 \times 2 \mathrm{w} /$ Single Address Latch and Power-Down
$4 \mathrm{~K} \times 18 \times 2 \mathrm{w} /$ Dual Address Latches and Power-Down
4K $\times 18 \times 2$ Cache-Tag and Power-Down
256K $\times 1$ w/Power-Down
64K $\times 4$ w/Output Enable and Power-Down
$64 \mathrm{~K} \times 4$ w/Power-Down
$64 \mathrm{~K} \times 4$ BiCEMOS $^{\text {TM }}$ w/Output Enable
$64 \mathrm{~K} \times 4 \mathrm{w} /$ Separate I/O and Power-Down
$64 \mathrm{~K} \times 4 \mathrm{w} /$ Separate I/O and Power-Down
$64 \mathrm{~K} \times 4$ BiCEMOS ${ }^{\text {TM }}$
32K $\times 8$ w/Power-Down
$32 \mathrm{~K} \times 8$ BiCEMOS ${ }^{\text {TM }}$
$32 \mathrm{~K} \times 8$ BiCEMOS $^{\mathrm{TM}}$ w/Address Latch
32K $\times 9$ w/Power-Down
32K $\times 9$ w/Address Latch, Parity and Power-Down
32K $\times 9$ w/Address Latch and Power-Down
32K x 9 Burst Mode w/Power-Down
1 Meg $\times 1$ w/Power-Down
256K $\times 4$ w/Power-Down
128K x 8 w/Power-Down

# NUMERICAL TABLE OF CONTENTS 

PART NO. PAGE100484100490100494100496LL100496RL100497100498100504100506 LL100506RL100507100508100509100A484
101484101490101494
101496LL
101496RL101497101498101504101506LL101506RL101507101508101509101A484
1048410490
1049410496LL
10496RL
1049710498
10504
10506LL
10506RL1050710508
1050910A484
29FCT52
29FCT520
29FCT520T
29FCT521T
29FCT52T
29FCT53
29FCT53T
3106 Ada3120C-SRC (SPP)3123C-SRC (SPP/e)3178C-SRC (ASAPP)39C01
4K x 4 ECL 100K SRAM (Corner Power) ..... 5.1
64K x 1 ECL 100K SRAM ..... 5.3
16K x 4 ECL 100K SRAM ..... 5.4
16K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
16K x 4 Self-Timed Reg Input, Latch Output ..... 5.6
16K x 4 Synchronous Write, Latch Output ..... 5.7
$16 \mathrm{~K} \times 4$ Conditional Write, Latch Output ..... 5.8
64K x 4 ECL 100K SRAM ..... 5.9
$64 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.1
64K x 4 Self-Timed Reg Input, Latch Output ..... 5.11
16K $\times 4$ Synchronous Write, Latch Output ..... 5.12
$64 \mathrm{~K} \times 4$ Conditional Write, Latch Output ..... 5.13
$32 \mathrm{~K} \times 9 \mathrm{ECL} 100 \mathrm{~K}$ SRAM ..... 5.14
$4 \mathrm{~K} \times 4$ ECL 100 K SRAM (Center Power) ..... 5.2
4K x 4 ECL 101K SRAM (Corner Power) ..... 5.1
64K x 1 ECL 101K SRAM ..... 5.3
16K x 4 ECL 101K SRAM ..... 5.4
$16 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
$16 \mathrm{~K} \times 4$ Self-Timed Reg Input, Latch Output ..... 5.6
16K $\times 4$ Synchronous Write, Latch Output ..... 5.7
16K $\times 4$ Conditional Write, Latch Output ..... 5.8
64K x 4 ECL 100K SRAM ..... 5.9
$64 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.1
$64 \mathrm{~K} \times 4$ Self-Timed Reg Input, Latch Output ..... 5.11
$16 \mathrm{~K} \times 4$ Synchronous Write, Latch Output ..... 5.12
$64 \mathrm{~K} \times 4$ Conditional Write, Latch Output ..... 5.13
32K x 9 ECL 101K SRAM ..... 5.14
4K x 4 ECL 101K SRAM (Center Power) ..... 5.2
4K x 4 ECL 10K SRAM (Corner Power) ..... 5.1
64K x 1 ECL 10K SRAM ..... 5.3
16K x 4 ECL 10K SRAM ..... 5.4
$16 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
16K x 4 Self-Timed Reg Input, Latch Output ..... 5.6
$16 \mathrm{~K} \times 4$ Synchronous Write, Latch Output ..... 5.7
16K x 4 Conditional Write, Latch Output ..... 5.8
64K x 4 ECL 10K SRAM ..... 5.9
$64 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.1
$64 \mathrm{~K} \times 4$ Self-Timed Reg Input, Latch Output ..... 5.11
$64 \mathrm{~K} \times 4$ Synchronous Write, Latch Output ..... 5.12
$64 \mathrm{~K} \times 4$ Conditional Write, Latch Output ..... 5.13
32K x 9 ECL 10K SRAM ..... 5.14
$4 \mathrm{~K} \times 4$ ECL 10K SRAM (Center Power) ..... 5.2
Non-inverting Octal Registered Transceiver ..... LOGIC
Multi-level Pipeline Register ..... LOGIC
Multi-level Pipeline Register ..... LOGIC
Multi-level Pipeline Register ..... LOGIC
Non-inverting Octal Registered Transceiver ..... LOGIC
Inverting Octal Registered Transceiver ..... LOGIC
Inverting Octal Registered Transceiver ..... LOGIC
Ada Compiler ..... RISC
System Programmer's Package ..... RISC
System Programmer's Package/e ..... RISC
Ada Stand-alone Programmer's Package ..... RISC
4-Bit Microprocessor Slice ..... LOGIC

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

PART NO.
39C10
39C60
39C8XX
49 C 25
49 C 402
49C410
49C460
49C465
49 C 466
49FCT661
49FCT804
49FCT805
49FCT806
49FCT818
54/74FBT2240
54/74FBT2244
54/74FBT2373
54/74FBT240
54/74FBT241
54/74FBT244
54/74FBT245
54/74FBT2827
54/74FBT2828
54/74FBT2841
54/74FBT373
54/74FBT374
54/74FBT540
54/74FBT541
54/74FBT821
54/74FBT823
54/74FBT827
54/74FBT828
54/74FBT841
54/74FCT138
54/74FCT138T
54/74FCT139
54/74FCT139T
54/74FCT151T
54/74FCT157T
54/74FCT161
54/74FCT161T
54/74FCT163
54/74FCT163T
54/74FCT182
54/74FCT191
54/74FCT191T
54/74FCT193
54/74FCT193T
54/74FCT240
54/74FCT240T
54/74FCT241
54/74FCT241T
54/74FCT244
54/74FCT244T
12-Bit Sequencer ..... LOGICPAGE
16-Bit Cascadable EDC
IDT39C8XXX Family ..... LOGIC
Microcycle Length Controller ..... LOGIC
16-Bit Microprocessor Slice ..... LOGIC
16-Bit Sequencer ..... LOGIC
32-Bit Cascadable EDC ..... LOGIC
32-Bit CMOS Flow-ThruEDC Unit ..... LOGIC
64-BIT CMOS Flow-ThruEDC Unit ..... LOGIC
16-Bit Synchronous Binary Counter ..... LOGIC
High-Speed Tri-Port Bus Multiplexer ..... LOGIC
Buffer/Clock Driver.w/Guaranteed Skew ..... LOGIC
Buffer/Clock Driver w/Guaranteed Skew ..... LOGIC
Octal Register with SPC ${ }^{\text {TM }}$ ..... LOGIC
Inverting Octal Buffer/Line Driver w/ $25 \Omega$ Series Resistor ..... LOGIC
Inverting Octal Buffer/Line Driver w/ $25 \Omega$ Series Resistor ..... LOGIC
Octal Transparent Latch w/3-State \& $25 \Omega$ Series Resistor ..... LOGIC
Inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting: Octal Transceiver ..... LOGIC
Non-inverting 10 -Bit Buffers/Driver w/25 $\Omega$ Series Resistor ..... LOGIC
Inverting10-Bit Buffers/Driver w/25 2 Series Resistor ..... LOGIC
10 -Bit Memory Latch w/25 $\Omega$ Series Resistor ..... LOGIC
Octal Transparent Latch w/3-State ..... LOGIC
Non-inverting Octal D Register ..... LOGIC
Inverting Octal Buffer ..... LOGIC
Non-inverting Octal Buffer ..... LOGIC
10-Bit Non-inverting Register ..... LOGIC
9 -Bit Inverting Register ..... LOGIC
Non-inverting 10-Bit Buffers/Driver ..... LOGIC
Inverting10-Bit Buffers/Driver ..... LOGIC
10-Bit Non-inverting Latch ..... LOGIC
1-0f-8 Decoder ..... LOGIC
1 -of-8 Decoder ..... LOGIC
Dual 1-of-4 Decoder ..... LOGIC
Dual 1-of-4 Decoder ..... LOGIC
8 -Input Multiplexer ..... LOGIC
Quad 2-Input Multiplexer ..... LOGIC
Synchronous Binary Counter w/Asynchronous Master Reset ..... LOGIC
Synchronous Binary Counter w/Asynchronous Master Reset ..... LOGIC
Synchronous Binary Counter w/Synchronous Reset ..... LOGIC
Synchronous Binary Counter w/Synchronous Reset ..... LOGIC
Carry Lookahead Generator ..... LOGIC
Up/Down Binary Counter w/Preset and Ripple Clocks ..... LOGIC
Up/Down Binary Counter w/Preset and Ripple Clock ..... LOGIC
Up/Down Binary Counter w/Separate Up/Down Clocks ..... LOGIC
Up/Down Binary Counter w/Separate Up/Down Clocks ..... LOGIC
Inverting Octal Buffer/Line Driver ..... LOGIC
Inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Buffer/Line Driver ..... LOGIC

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

## PART NO.

## PAGE

54/74FCT245
54/74FCT245T
54/74FCT251T
54/74FCT257T
54/74FCT273
54/74FCT273T
54/74FCT299
54/74FCT299T
54/74FCT373
54/74FCT373T
54/74FCT374
54/74FCT374T
54/74FCT377
54/74FCT377T
54/74FCT399
54/74FCT399T
54/74FCT521
54/74FCT521T
54/74FCT533
54/74FCT533T
54/74FCT534
54/74FCT534T
54/74FCT540
54/74FCT540T
54/74FCT541
54/74FCT541T
54/74FCT543
54/74FCT543T
54/74FCT573
54/74FCT573T
54/74FCT574
54/74FCT574T
54/74FCT620T
54/74FCT621T
54/74FCT622T
54/74FCT623T
54/74FCT640
54/74FCT640T
54/74FCT645
54/74FCT645T
54/74FCT646
54/74FCT646T
54/74FCT648T
54/74FCT651T
54/74FCT652T
54/74FCT821
54/74FCT821T
54/74FCT823
54/74FCT823T
54/74FCT824
54/74FCT825
54/74FCT825T
54/74FCT827
54/74FCT827T
Non-inverting Octal Transceiver ..... LOGIC
Non-inverting Octal Transceiver ..... LOGIC
8 -Input Multiplexer w/3-State ..... LOGIC
FQuad 2-Input Multiplexer w/3-State ..... LOGIC
Octal D Flip-Flop w/Common Master Reset ..... LOGIC
Octal D Flip-Flop w/Common Master Reset ..... LOGIC
8-Input Universal Shift Register w/Common Parallel I/O Pins ..... LOGIC
8 Input Universal Shift Register w/Common Parallel I/O Pins ..... LOGIC
Non-inverting Octal Transparent Latch ..... LOGIC
Non-inverting Octal Transparent Latch w/3-State ..... LOGIC
Non-inverting Octal D Flip-Flop ..... LOGIC
Non-inverting Octal D Register ..... LOGIC
Octal D Flip-Flop w/Clock Enable ..... LOGIC
Octal D Flip-Flop w/Clock Enable ..... LOGIC
Quad Dual-Port Register ..... LOGIC
Quad Dual-Port Register ..... LOGIC
8-Bit Identity Comparator ..... LOGIC
8-Bit Identity Comparator ..... LOGIC
Inverting Octal Transparent Latch ..... LOGIC
Inverting Octal Transparent Latch w/3-State ..... LOGIC
Inverting Octal D Flip-Flop w/3-State ..... LOGIC
Inverting Octal D Register ..... LOGIC
Inverting Octal Buffer/Line Driver ..... LOGIC
Inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Buffer/Line Driver ..... LOGIC
Non-inverting Octal Latched Transceiver ..... LOGIC
Non-inverting Octal Latched Transceiver ..... LOGIC
Non-inverting Octal Transparent Latch ..... LOGIC
Non-inverting Octal Transparent Latch w/3-State ..... LOGIC
Non-inverting Octal D Register w/3-State ..... LOGIC
Non-inverting Octal D Register ..... LOGIC
Inverting Octal Bus Transceiver w/3-State ..... LOGIC
Non-inverting Octal Bus Transceiver (Open Drain) ..... LOGIC
Inverting Octal Bus Transceiver (Open Drain) ..... LOGIC
Non-inverting Octal Bus Transceiver w/3-State ..... LOGIC
Inverting Octal Transceiver ..... LOGIC
Inverting Octal Transceiver ..... LOGIC
Non-inverting Octal Transceiver ..... LOGIC
Non-inverting Octal Transceiver ..... LOGIC
Non-inverting Octal Registered Transceiver ..... LOGIC
Non-inverting Octal Registered Transceiver ..... LOGIC
Inverting Octal Registered Transceiver ..... LOGIC
Inverting Octal Registered Transceiver ..... LOGIC
Non-inverting Octal Registered Transceiver ..... LOGIC
10-Bit Non-inverting Register w/3-State ..... LOGIC
10-Bit Non-inverting Register w/3-State ..... LOGIC
9-Bit Non-inverting Register w/Clear \& 3-State ..... LOGIC
9-Bit Non-inverting Register w/Clear \& 3-State ..... LOGIC
9 -Bit Inverting Register w/Clear \& 3-State ..... LOGIC
8 -Bit Non-inverting Register ..... LOGIC
8 -Bit Non-inverting Register w/Clear \& 3-State ..... LOGIC
10-Bit Non-inverting Buffer ..... LOGIC
10-Bit Non-inverting Buffer ..... LOGIC

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

PART NO.54/74FCT828T54/74FCT83354/74FCT84154/74FCT841T54/74FCT84354/74FCT843T54/74FCT84454/74FCT84554/74FCT845T54/74FCT86154/74FCT86354/74FCT864611661298616761686177
8-Bit Transceiver w/ParityLOGIC
LOGIC
LOGIC
10-Bit Non-inverting Latch ..... LOGIC
10-Bit Non-inverting Latch ..... LOGIC
9-Bit Non-inverting Latch ..... LOGIC
9-Bit Non-inverting Latch ..... LOGIC
9-Bit Inverting Latch ..... LOGIC
8-Bit Non-inverting Latch ..... LOGIC
8 -Bit Non-inverting Latch ..... LOGIC
10-Bit Non-inverting Transceiver ..... LOGIC
9-Bit Non-inverting Transceiver ..... LOGIC
$9-$ Bit Inverting Transceiver ..... LOGIC
2K $\times 8$ w/Power-Down ..... SRAM
64K $\times 4$ w/Output Enable and Power-Down ..... SRAM
16K $\times 1$ w/Power-Down ..... SRAM
4K x 4 w/Power-Down ..... SRAM
$4 \mathrm{~K} \times 4$ Cache-Tag w/Open Drain and Power-Down ..... SRAM
4K $\times 4$ Cache-Tag w/Power-Down ..... SRAM
4K $\times 4$ w/Output Enable and Power-Down ..... SRAM
16K $\times 4$ w/Output Enable and Power-Down ..... SRAM
$64 \mathrm{~K} \times 4$ BiCEMOS $^{\text {TM }}$ w/Output Enable ..... SRAM
$16 \mathrm{~K} \times 4$ BiCEMOS $^{\text {TM }}$ w/Output Enable ..... SRAM
$64 \mathrm{~K}(8 \mathrm{~K} \times 8)$ Dual-Port RAM ..... 7.18
128K ( $16 \mathrm{~K} \times 8$ ) Dual-Port RAM ..... 7.2
$9 \mathrm{~K}(1 \mathrm{~K} \times 9$ ) Dual-Port RAM (MASTER) ..... 7.3
9K (1K x 9) Dual-Port RAM (MASTER w/Interrupts) ..... 7.4
9K (1K x 9) Dual-Port RAM (SLAVE) ..... 7.3
9K (1K x 9) Dual-Port RAM (SLAVE w/Interrupts) ..... 7.4
18K ( $2 \mathrm{~K} \times 9$ ) Dual-Port RAM ..... 7.8
18K (2K x 9) Dual-Port RAM (MASTER w/Interrupts) ..... 7.9
18K (2K x 9) Dual-Port RAM (SLAVE w/Interrupts) ..... 7.9
32K (4K x 9) Dual-Port RAM ..... 7.16
64K (4K x 16) Dual-Port RAM ..... 7.17
128K ( $8 \mathrm{~K} \times 16$ ) Dual-Port RAM ..... 7.19
$8 \mathrm{~K}(1 \mathrm{~K} \times 8)$ Dual-Port RAM (MASTER) ..... 7.2
16K (2K $\times 8$ ) Dual-Port RAM (MASTER) ..... 7.6
8K ( $1 \mathrm{~K} \times 8$ ) Dual-Port RAM (SLAVE) ..... 7.2
16K ( $2 \mathrm{~K} \times 8$ ) Dual-Port RAM (SLAVE) ..... 7.6
$8 \mathrm{~K}(1 \mathrm{~K} \times 8)$ FourPort ${ }^{\text {TM }}$ RAM ..... 7.21
16K (2K x 8) FourPort ${ }^{\text {TM }}$ RAM ..... 7.22
128K $\times 8$ w/Power-Down ..... SRAM
1 Meg $\times 1$ w/Power-Down ..... SRAM
256K $\times 4$ w/Power-Down ..... SRAM
$4 \mathrm{~K} \times 18 \times 2 \mathrm{w} /$ Single Address Latch and Power-Down ..... SRAM
4K $\times 18 \times 2$ w/Dual Address Latches and Power-Down ..... SRAM
$32 \mathrm{~K} \times 8$ w/Power-Down ..... SRAM
256K $\times 1$ w/Power-Down ..... SRAM
$64 \mathrm{~K} \times 4$ w/Power-Down ..... SRAM
32K $\times 9$ w/Power-Down ..... SRAM
$4 \mathrm{~K} \times 18 \times 2$ Cache-Tag and Power-Down ..... SRAM
64K $\times 4$ w/Separate I/O and Power-Down ..... SRAM
$64 \mathrm{~K} \times 4 \mathrm{w} /$ Separate I/O and Power-Down ..... SRAM
8K (1K x 8) Dual-Port RAM (MASTER) ..... 7.1
16K (2K x 8) Dual-Port RAM (MASTER) ..... 7.5

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

## PART NO. <br> PAGE

71321
7133
7133SALLA
7134
71342
71342 SALA
7134SALLA
7140
7142
71421
7143
7143SALLA
71502
71509
71559
71569
71586
71589
7164
7165
71681
71682
7169
7174
7186
7187
7188
7198
71981
71982
71B256
71 B258
71 B556
71B569
71B64
71 B65
71B69
$71 B 74$
71B79
71 B88
71 B98
7200
7201
7202
72021
7203
72031
7204
72041
7205
7206
72103
72104
72105

16K (2K x 8) Dual-Port RAM (MASTER w/Interrupts) ................................... 7.7
32K (2K x 16) Dual-Port RAM (MASTER) ....................................................... 7.1
32K (2K x 16) Dual-Port RAM (MASTER) ...................................................... 7.11
32K (4K x 8) Dual-Port RAM ........................................................................ 7.12
32K (4K x 8) Dual-Port RAM (w/Semaphores) .............................................. 7.14
32K (4K x 8) Dual-Port RAM (w/Semaphores) .............................................. 7.15
32K (4K x 8) Dual-Port RAM ......................................................................... 7.13
8K (1K x 8) Dual-Port RAM (SLAVE) ............................................................. 7.1
16K (2K x 8) Dual-Port RAM (SLAVE) ........................................................... 7.5
16K (2K x 8) Dual-Port RAM (SLAVE w/Interrupts) ....................................... 7.7
32K (2K x 16) Dual-Port RAM (SLAVE) ........................................................ 7.1
32K (2K x 16) Dual-Port RAM (SLAVE) ........................................................ 7.11
64K (4K x 16) Registered RAM (w/SPC ${ }^{\text {TM }}$ ) .................................................... 7.24
32K x 9 w/Address Latch, Parity and Power-Down ....................................... SRAM
32K $\times 9$ w/Address Latch and Power-Down ................................................... SRAM
$8 \mathrm{~K} \times 9$ w/Address Latch and Power-Down .................................................... SRAM
$4 \mathrm{~K} \times 16$ w/Address Latch and Power-Down .................................................. SRAM
32K x 9 Burst Mode w/Power-Down ............................................................... SRAM
8K x 8 w/Power-Down .................................................................................. SRAM
8K x 8 Resettable Power-Down.................................................................... SRAM
$4 \mathrm{~K} \times 4 \mathrm{w} /$ Separate I/O and Power-Down ....................................................... SRAM
$4 \mathrm{~K} \times 4$ w/Separate I/O and Power-Down ....................................................... SRAM
8K x 9 w/Power-Down ................................................................................... SRAM
8K x 8 Cache-Tag w/Power-Down ................................................................ SRAM
4K x 16 w/Power-Down ............................................................................... SRAM
64K x 1 w/Power-Down .............................................................................. SRAM
16K x 4 w/Power-Down ................................................................................. SRAM
16K $\times 4$ w/Output Enable, 2 Chip Selects and Power-Down ......................... SRAM
16K x 4 w/Separate I/O and Power Down ...................................................... SRAM
16K x 4 w/Separate I/O and Power Down .................................................... SRAM
32K x 8 BiCEMOS™ .................................................................................... SRAM

32K $\times 8$ BiCEMOS ${ }^{\text {¹ }}$ w/Address Latch .......................................................... SRAM
8K x 9 BiCEMOS ${ }^{\text {M }}$ w/Address Latch ............................................................. SRAM

8K x 8 BiCEMOS ${ }^{\text {M }}$ Resettable ..................................................................... SRAM

8K $x 8$ BiCEMOS ${ }^{\text {¹ }}$ Cache-Tag ..................................................................... SRAM
8K x 9 BiCEMOS™ Cache-Tag ...................................................................... SRAM

16K $\times 4$ BiCEMOS w/Output Enable and 2 Chip Selects ............................. SRAM
$256 \times 9$-Bit Parallel FIFO ................................................................................ 6.1
$512 \times 9$-Bit Parallel FIFO ............................................................................... 6.1
$1024 \times 9$-Bit Parallel FIFO .............................................................................. 6.2
$1 \mathrm{~K} \times 9$-Bit Parallel FIFO w/ Flags and Output Enable .................................. 6.6
$2 \mathrm{~K} \times 9$-Bit Parallel FIFO ................................................................................ 6.3
$2 \mathrm{~K} \times 9$-Bit Parallel FIFO w/Flags and Output Enable .................................... 6.6
$4 \mathrm{~K} \times 9$-Bit Parallel FIFO ................................................................................... 6.3
$4 \mathrm{~K} \times 9$-Bit Parallel FIFO w/Flags and Output Enable .................................... 6.6
8K x 9-Bit Parallel FIFO ................................................................................... 6.4
$16 \mathrm{~K} \times 9$-Bit Parallel FIFO ............................................................................. 6.5
$2 \mathrm{~K} \times 9$-Bit Configurable Parallel-Serial FIFO .................................................. 6.7
$4 \mathrm{~K} \times 9$-Bit Configurable Parallel-Serial FIFO .................................................. 6.7
$256 \times 16$-Bit Parallel-to-Serial FIFO ............................................................... 6.8

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

PART NO. PAGE

7210L
72115
72125
72131
72132
72141
72142
7216L
7217L
72200
72201
72210
72211
72215A
72220
72221
72225A
72230
72231
72235
72240
72241
72245
72401
72402
72403
72404
72413
72420
72421
7251
72510
72511
7252
72520
72521
72605
72615
73200L
73201L
73210
73211
7381L
7383L
75C457
75C458
75 C 48
75C58
79R3000A
79R3001
79R3010A
79R3020
79R305x
79R3720
$16 \times 16$ Parallel Multiplier-Accumulator :........................................................ LOGIC
$512 \times 16$-Bit Parallel-to-Serial FIFO ................................................................ 6.8
$1024 \times 16$-Bit Parallel-to-Serial FIFO ............................................................... 6.8
$2048 \times 9$-Bit Parallel-to-Serial FIFO ................................................................ 6.9
$2048 \times 9$-Bit Serial-to-Parallel FIFO ............................................................... 6.1
$4096 \times 9$-Bit Parallel-to-Serial FIFO ............................................................... 6.9
$4096 \times 9$-Bit Serial-to-Parallel FIFO .............................................................. 6.1
$16 \times 16$ Parallel Multiplier ............................................................................. LOGIC
$16 \times 16$ Parallel Multiplier (32 Bit Output) ...................................................... LOGIC
$256 \times 8$-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) .......................................... 6.11
$256 \times 9$-Bit Parallel SyncFIFO ${ }^{\text {тм }}$ (Clocked FIFO) .......................................... 6.12
$512 \times 8$-Bit Parallel SyncFIFO™ (Clocked FIFO) ........................................... 6.11
$512 \times 9$-Bit Parallel SyncFIFO™ (Clocked FIFO) ........................................... 6.12
$512 \times 18$-Bit Parallel SyncFIFO™ (Clocked FIFO) ......................................... 6.13
$1 \mathrm{~K} \times 8$-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) ............................................ 6.14
1K x 9-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) ............................................ 6.15
$1024 \times 18$-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) ...................................... 6.13
$2 \mathrm{~K} \times 8$-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) .............................................. 6.14
2K $\times$ 9-Bit Parallel SyncFIFO ${ }^{\text {TM }}$ (Clocked FIFO) ............................................. 6.15
2K x 18-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) .......................................... 6.16
$4 \mathrm{~K} \times 8$-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) ............................................. 6.14
4K x 9-Bit Parallel SyncFIFO ${ }^{\text {TM }}$ (Clocked FIFO) ............................................ 6.15
$4 \mathrm{~K} \times 18$-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) .......................................... 6.16
$64 \times 4$ FIFO ................................................................................................... 6.17
$64 \times 5$ FIFO .................................................................................................. 6.17
$64 \times 4$ FIFO (w/Output Enable) ....................................................................... 6.17
$64 \times 5$ FIFO (w/Output Enable) ....................................................................... 6.17
$64 \times 5$ FIFO (w/Flags) ..................................................................................... 6.18
$64 \times 8$-Bit Parallel SyncFIFO. ${ }^{\text {TM }}$ (Clocked FIFO) ............................................ 6.11
$64 \times 9$-Bit Parallel SyncFIFO ${ }^{\text {M }}$ (Clocked FIFO) ............................................ 6.12
$512 \times 18$-Bit — $1 \mathrm{~K} \times 9$-Bit BiFIFO ................................................................. 6.19
$512 \times 18$-Bit - 1K x 9-Bit BiFIFO .................................................................. 6.19
$512 \times 18$-Bit BiFIFO ....................................................................................... 6.2
1K x 18-Bit - $2 \mathrm{~K} \times 9$-Bit BiFIFO ................................................................... 6.19
1K x 18-Bit — $2 \mathrm{~K} \times$ 9-Bit BiFIFO ................................................................... 6.19
1K x 18-Bit BiFIFO ............................................................................................ 6.2
$256 \times 18$-Bit Synchronous BiFIFO (SyncBiFIFO ${ }^{\text {TM }}$ ) ........................................ 6.21
$512 \times 18$-Bit Synchronous BiFIFO (SyncBiFIFO ${ }^{\text {TM }}$ ) ........................................ 6.21
16-Bit CMOS Multilevel Pipeline Register ...................................................... LOGIC
16-Bit CMOS Multilevel Pipeline Register ...................................................... LOGIC
Fast Octal Register Transceiver w/Parity ....................................................... LOGIC
Fast Octal Register Transceiver w/Parity ...................................................... LOGIC
16-Bit CMOS Cascadable ALU ...................................................................... LOGIC
16-Bit CMOS Cascadable ALU ...................................................................... LOGIC
CMOS Single 8-Bit PaletteDACTM for True Color Applications....................... LOGIC
Triple 8-Bit PaletteDAC ${ }^{\text {TM }}$............................................................................... LOGIC
8-Bit Flash ADC ............................................................................................. LOGIC
8-Bit Flash ADC with Overtlow Output ........................................................... LOGIC
Second Generation MIPS RISC CPU ............................................................ RISC
IDT RISController ${ }^{\text {TM }}$ CPU for Embedded and Real Time Applications .......... RISC
Floating-Point Accelerator for the R3000A and R3001 ................................ RISC
RISC CPU Write Buffer for R3000A and R3001 ............................................ RISC
Integrated RISC Microporccessor Family for Embedded Applications .......... RISC
Bus Exchanger for R305x Memory Systems ................................................ RISC

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

## PART NO. <br> PAGE

79R3721
79R4000
79R4000SP
7M1001
7M1002
7M1003
7M1004
7M1005
7M134
7M135
7M137
7M144
7M145
7M205
7M206
7M207
7M4003
7M4013
7M4016
7M4017
7M4042
7M4048
7M6032
7M624
7M812
7M912
7MB1006
7MB1008
7MB1041
7MB1042
7MB1043
7MB1044
7MB4009
7MB4040
7MB4048
7MB6036
7MB6039
7MB6040
7MB6042
7MB6043
7MB6044
7MB6046
7MB6049
7MB6051
7MB6056
7MB6061
7MB6064
7MB6136
7MB6146
7MB6156
7MC4001
DRAM Controller for R305x Based Systems ..... RISC
Third Generation RISC Microprocessor ..... RISC
Third Generation RISC Microporcessor for Desktop Applications ..... RISC
$128 \mathrm{~K} \times 8$ Dual-Port SRAM Module ..... 8.4
16K $\times 32$ Dual-Port SRAM Module ..... 8.9
$64 \mathrm{~K} \times 8$ Dual-Port SRAM Module ..... 8.4
$8 \mathrm{~K} \times 9$ Dual-Port SRAM Module ..... 8.5
$16 \mathrm{~K} \times 9$ Dual-Port SRAM Module ..... 8.5
$8 \mathrm{~K} \times 8$ Master Dual-Port SRAM Module ..... 8.1
16K $\times 8$ Master Dual-Port SRAM Module ..... 8.1
$32 \mathrm{~K} \times 8$ Master Dual-Port SRAM Module ..... 8.3
8K $\times 8$ Slave Dual-Port SRAM Module ..... 8.2
$16 \mathrm{~K} \times 8$ Slave Dual-Port SRAM Module ..... 8.2
$8 \mathrm{~K} \times 9$-Bit CMOS FIFO Module ..... 8.12
$16 \mathrm{~K} \times 9$-Bit CMOS FIFO Module ..... 8.12
$32 \mathrm{~K} \times 9$-Bit CMOS FIFO Module ..... 8.14
$32 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.37
$128 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.37
$256 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.33
$64 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.38
$256 \mathrm{~K} \times 4$ CMOS Static RAM Module ..... 8.17
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.23
16K $\times 32$ Writable Control Store Static RAM Module ..... 8.49
$64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.32
$64 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.18
$64 \mathrm{~K} \times 9$ CMOS Static RAM Module ..... 8.18
$64 \mathrm{~K} \times 16$ Dual-Port SRAM Module ..... 8.7
$32 \mathrm{~K} \times 16$ Dual-Port SRAM Module ..... 8.7
$8 \mathrm{~K} \times 8$ FourPort ${ }^{\text {TM }}$ SRAM Module ..... 8.1
$4 \mathrm{~K} \times 8$ FourPor ${ }^{\text {TM }}$ SRAM Module ..... 8.1
$4 \mathrm{~K} \times 16$ FourPort $^{\text {TM }}$ SRAM Module ..... 8.11
$2 \mathrm{~K} \times 16$ FourPort $^{T M}$ SRAM Module ..... 8.11
2(16K x 16) CMOS Static RAM Module ..... 8.28
$256 \mathrm{~K} \times 9$ CMOS Static RAM Module ..... 8.26
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.23
128K $\times 16$ Dual-Port (Shared Memory) SRAM Module ..... 8.6
( $2 \times 16 \mathrm{~K} \times 60$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.45
( $2 \times 16 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for General Purpose CPUs ..... 8.47
$8 \mathrm{~K} \times 112$ Writable Control Store Static RAM Module ..... 8.5
( $2 \times 8 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.43
( $2 \times 4 \mathrm{~K} \times 64$ ) Data/lnstruction Cache Module for IDT79R3000 CPU ..... 8.42
$64 \mathrm{~K} \times 16$ Dual-Port (Shared Memory) SRAM Module ..... 8.6
( $2 \times 16 \mathrm{~K} \times 60$ ) Data/Instruction Cache Module for IDT79R3000 CPU (Multiprocessor) ..... 8.46
( $2 \times 8 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU (Multiprocessor) ..... 8.44
32K x 16 Dual-Port (Shared Memory) SRAM Module ..... 8.6
( $2 \times 16 \mathrm{~K} \times 60$ ) Data/Instruction w/Resettable Instruction Tag ..... 8.48
( $2 \times 4 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.41
$128 \mathrm{~K} \times 18$ Dual-Port (Shared Memory) SRAM Module ..... 8.8
$64 \mathrm{~K} \times 18$ Dual-Port (Shared Memory) SRAM Module ..... 8.8
32K x 18 Dual-Port (Shared Memory) SRAM Module ..... 8.8
$1 \mathrm{M} \times 1$ CMOS Static RAM Module ..... 8.16

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

PART NO. PAGE

7MC4005
7MC4032
7MP2005
7MP2009
7MP2010
7MP2011
7MP4008S
7MP4031
7MP4034
7MP4036
7MP4045
7MP4047
7MP4058L
7RS101
7RS101F
7RS102
7RS102F
7RS103
7RS103F
7RS104
7RS104F
7RS105
7RS105F
7RS107F
7RS201
7RS202
7RS203
7RS301
7RS302
7RS303
7RS304
7RS305
7RS307
7RS340
7RS341
7RS342
7RS343
7RS347
7RS353-B
7RS353-MB
7RS353-MS
7RS353-S
7RS355-B
7RS355-MB
$16 \mathrm{~K} \times 16$ CMOS Static RAM Module ............................................................. 8.27
$16 \mathrm{~K} \times 32$ CMOS Static RAM Module w/Separate Data I/O ........................... 8.35
8K x 9-Bit FJFO Module .................................................................................. 8.13
32K x 18-Bit FIFO Module .............................................................................. 8.15
16K x 18-Bit FIFO Module ............................................................................ 8.15
16K x 9 Bit FIFO Module ............................................................................... 8.13
512K x 8 CMOS Static RAM Module ............................................................. 8.24
$16 \mathrm{~K} \times 32$ CMOS Static RAM Module ............................................................ 8.36
256K x 8 CMOS Static RAM Module ............................................................. 8.22
$64 \mathrm{~K} \times 32$ CMOS Static RAM Module ............................................................. 8.39
256K x 32 CMOS Static RAM Module ........................................................... 8.4
$512 \mathrm{~K} \times 16$ CMOS Static RAM Module ........................................................ 8.34
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module .......................................................... 8.25
R3000 Module w/64K I-Cache, 64K D-Cache, 4 Word Read Buffer
and 1 Word Write Buffer.............................................................. RISC
R3000, R3010 Module w/64K I-Cache, 64K D-Cache, 4 Word Read
Buffer and 1 Word Write Buffer ...................................................... RISC
R3000 Module w/16K I-Cache, 16K D-Cache, 1 Word Read Buffer
and 1 Word Write Buffer.............................................................. RISC
R3000, R3010 Module w/16K I-Cache, 16K D-Cache, 1 Word Read
Buffer and 1 Word Write Buffer ................................................... RISC
R3000 Module w/16K I-Cache and 16K D-Cache ........................................ RISC
R3000, R3010 Module w/16K I-Cache and16K D-Cache ............................ RISC
R3001 Module w/ 128K I-Cache, 128K D-Cache, 1 Word Read Buffer
and 1 Word Write Buffer................................................................ RISC
R3001, R3010 Module w/128K I-Cache, 128K D-Cache, 1 Word
Read Buffer and 1 Word Write Buffer ............................................ RISC
R3000 Module w/32K I-Cache, 16K D-Cache, 1 Word Read Buffer,
1 Word Write Buffer and IDT Bus ................................................... RISC
R3000, R3010 Module w/32K I-Cache, 16 K D-Cache, 1 Word
Read Buffer, 1 Word Write Buffer and IDT Bus .................................. RISC
R3000, R3010 Module w/64K I-Cache, 64K D-Cache, 0R3020 and
1 Word Read Buffer .................................................................................................
Nubus Board ...........................................................................................................................
Nubus Board, Supports Nubus Memory ..................................................... RISC
Nubus Board, Supports Onboard Memory ................................................. RISC
TargetSystem ${ }^{\text {TM }}$ for IDT7RS101 ................................................................ RISC
TargetSystem ${ }^{\text {TM }}$ for IDT7RS102............................................................... RISC
TargetSystem ${ }^{\text {™ }}$ for IDT7RS103 ................................................................ RISC
TargetSystem ${ }^{\text {M }}$ for IDT7RS104 ................................................................ RISC
TargetSystem ${ }^{\text {M }}$ for IDT7RS105 ................................................................ RISC
TargetSystem™ for IDT7RS107 ................................................................ RISC
System Board .......................................................................................... RISC
Personality Board for IDT7RS101 ............................................................. RISC
Personality Board for IDT7RS102 ............................................................. RISC
Personality Board for IDT7RS103 ............................................................. RISC
Personality Board for IDT7RS107 RISC Board, IDT/ux and C-Compiler

RISC
JMI C-Executive ${ }^{\text {TM }}$ Binary Code ................................................................ RISC
JMI C-Executive ${ }^{\text {TM }}$ Maintenance for Binary Code ....................................... RISC
JMI C-Executive ${ }^{\text {TM }}$ Maintenance for Source Code ........................................ RISC
JMI C-Executive™ SourceCode ................................................................. RISC
Floating Point Library Binary Code ............................................................. RISC
Floating Point Library Maintenance for Binary Code ................................... RISC

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

PART NO. PAGE

7RS355-MS
7RS355-S
7RS356-2B

7RS356-3B
7RS356-3MB
7RS357-1B
7RS357-1MB
7RS357-2B
7RS357-2MB
7RS357-3B
7RS357-3MB
7RS361-B
7RS361-E
7RS361-MB
7RS361-MS
7RS361-S
7RS363-1
7RS363-2
7RS364
7RS365
7RS366
7RS382
7RS383
7RS501-1

7RS501-1D
7RS501-1M
7RS501-2

7RS501-3

7RS501-4
7RS501-5
7RS501-6

7RS502-1

7RS502-1D
7RS502-1M
7RS502-2

7RS502-3
Floating Point Library Maintenance for Source Code .................................... RISC
Floating Point Library Source Code RISC Board, IDT/ux and C-Compiler RISC
R3000 C-Compiler Binary Code for 80286, 80386 IDT7RS356-2MB R3000 C-Compiler Maintenance for Binary Code for 80286, 80386 PC-DOS ..... RISC
R3000 C-Compiler Binary Code for PC SCO XENIX ..... RISC
R3000 C-Compiler Maintenance for Binary Code SCO XENIX. ..... RISC
R3000 Macro Assembler Binary Code for 8086, 8088 PC-DOS ..... RISC
R3000 Macro Assembler Maintenance for Binary Code 8086, 8088 ..... RISC
R3000 Macro Assembler Binary Code for 80286, 80386 PC-DOS ..... RISC
R3000 Macro Assembler Maintenance for Binary Code 80286, 80386 ..... RISC
R3000 Macro Assembler Binary Code for PC SCO XENIX ..... RISC
R3000 Macro Assembler Maintenance for Binary Code SCO XENIX ..... RISC
IDT PROM Monitor Binary Code ..... RISC
IDT PROM Monitor Binary Code - in 4 EPROMs ..... RISC
IDT PROM Monitor Maintenance for Binary Code ..... RISC
IDT PROM Monitor Maintenance for Source Code ..... RISC
IDT PROM Monitor Source Code ..... RISC
R3000 PGA Breakout Board and HP 16500A Logic Analyzer Set-up Software ..... RISC
R3000 PGA Breakout Board and HP 16500A Logic Analyzer Set-up Software and 5 HP Adapters ..... RISC
HP 16500A Logic Analyzer Disassembler Software for 7RS300 Series TargetSystems ${ }^{\text {TM }}$ ..... RISC
R3000 Flatpack Version ..... RISC
R3001 PGA Version ..... RISC
R3000 Evaluation Board ..... RISC
R3001 Evaluation Board ..... RISC
MacStation ${ }^{\text {TM }}$ Development System w/IDT7RS201 Nubus Board,
IDT/Ux and C-Compiler ..... RISC
MacStation ${ }^{\text {™ }}$ Development System Documentation ..... RISC
MacStation ${ }^{\mathrm{TM}}$ Development System Maintenance ..... RISC
MacStation ${ }^{\text {™ }}$ Development System w/150MB External Hard Disk, 40MB External Tape Drive, IDT7RS201 Nubus Board, IDT/ux and C-Compiler ..... RISC
Complete IDT7RS501 MacStation ${ }^{\text {M }}$ Development System w/MAC II Computer, 8MB RAM, 150MB Hard Disk, 40 MB External Tape Drive, IDT7RS201 Nubus ..... RISC
4MB SIMM Module for MAC II ..... RISC
IDT7RS501 MacStation ${ }^{\text {TM }}$ Development System w/150MB External Hard Disk, IDT7RS201 Nubus Board, IDT/ux and C-Compiler ..... RISC
IDT7RS501 MacStation ${ }^{\text {TM }}$ Development System w/40MB External Tape Drive, IDT7RS201 Nubus Board, IDT/ux and C-Compiler ..... RISC
MacStation ${ }^{\text {TM }}$ Development System w/IDT7RS202 Nubus Board, 8MB Nubus RAM Board, IDT/ux and C-Compiler ..... RISC
MacStation ${ }^{\text {TM }}$ Development System Documentation ..... RISC
MacStation ${ }^{\text {TM }}$ Development System Maintenance ..... RISC
IDT7RS502 MacStation ${ }^{\text {TM }}$ Development System w/150MB External Hard Disk, 40MB External Tape Drive, IDT7RS202 Nubus Board, IDT/ux and C-Compiler ..... RISC
Complete IDT7RS502 MacStation ${ }^{\text {TM }}$ Development System w/MAC II Computer, 8 MB RAM, 150 MB Hard Disk, 40 MB External Tape Drive, IDT7RS202 Nubus ..... RISC

## NUMERICAL TABLE OF CONTENTS (CONTINUED)

PART NO. PAGE
7RS502-4 4MB SIMM Module for MAC II ..... RISC
7RS502-6
7RS503-1
7RS503-1D7RS503-1M7RS551-1B7RS571-1S7RS572-1S7RS573-1B7RS573-1MB8M6128M6248M824S8MP612L8MP612S
8MP624L
8MP624S
8MP824L8MP824SFlexi-Pak Family
M/2000RC2030RC3240RC3260RS1210
7RS502-5 IDT7RS502 MacStation ${ }^{\text {TM }}$ Development System w/150MB External Hard Disk, IDT7RS202 Nubus Board, IDT/ux and C-Compiler ..... RISC DT7RS502 MacStation™ Development System w/40MB External Tape Drive, IDT7RS202 Nubus Board, IDT/ux and C-Compiler ..... RISC
MacStation ${ }^{\text {TM }}$ Development System w/16MB RAM, IDT/ux and C-Compiler ..... RISC
MacStation ${ }^{\text {TM }}$ Development System Documentation ..... RISC
MacStation ${ }^{\text {TM }}$ Development System Maintenance ..... RISC
IDT/ux — UNIX Operating System for MacStations ${ }^{T M}$ ..... RISC
MIPS SPP for the MAC ..... RISC
MIPS SPP/e for the MAC ..... RISC
MIPS Fortran for the MAC ..... RISC
Maintenance for MIPS Fortran for the MAC ..... RISC
$32 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.29
$64 \mathrm{~K} \times 16 \mathrm{CMOS}$ Static RAM Module ..... 8.29
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.19
$32 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.31
$32 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.3
$64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.31
$64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.3
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.21
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.2
Modules with Various Combinations of SRAMs, EPROMs and EEPROMs ..... 8.51
RISComputer ${ }^{\text {TM }}$ Development System ..... RISC
RISComputer ${ }^{\text {TM }}$ Development System ..... RISC
RISComputer ${ }^{\text {TM }}$ Development System ..... RISC
RISComputer ${ }^{\text {™ }}$ Development System ..... RISC
RISComputer ${ }^{\text {TM }}$ Development System ..... RISC

## IDT PACKAGE MARKING DESCRIPTION

## PART NUMBER DESCRIPTION

IDT's part number identifies the basic product, speed, power, package(s) available, operating temperature and processing grade. Each data sheet has a detailed description, using the part number, for ordering the proper product for the user's application. The part number is comprised of a series of alpha-numeric characters:

1. An "IDT" corporate identifier for Integrated Device Technology, Inc.
2. A basic device part number composed of alpha-numeric characters.
3. A device power identifier, composed of one or two alpha characters, is used to identify the power options. In most cases, the following alpha characters are used: "S" or "SA" is used for the standard product's power. " $L$ " or "LA" is used for lower power than the standard product.
4. A device speed identifier, when applicable, is either alpha characters, such as "A" or "B", or numbers, such as 20 or 45. The speed units, depending on the product, are in nanoseconds or megahertz.
5. A package identifier, composed of one or two characters. The data sheet should be consulted to determine the packages available and the package identifiers for that particular product.
6. A temperature/process identifier. The product is available in either the commercial or military temperature range, processed to a commercial specification, or the product is available in the military temperature range with full compliance to MIL-STD-883. Many of IDT's products have burn-in included as part of the standard commercial process flow.
7. A special process identifier, composed of alpha characters, is used for products which require radiation enhancement (RE) or radiation tolerance (RT).

Example for Monolithic Devices:


* Field Identifier Applicable To All Products


## ASSEMBLY LOCATION DESIGNATOR

IDT uses various locations for assembly. These are identified by an alpha character in the last letter of the date code marked on the package. Presently, the assembly location alpha character is as follows:
$A=$ Anam, Korea
$\mathbf{I}=$ USA
$P=$ Penang, Malaysia

## MIL-STD-883C COMPLIANT DESIGNATOR

IDT ships military products which are compliant to the latest revision of MIL-STD-883C. Such products are identified by a "C"designation onthe package. The location of this designator is specified by internal documentation at IDT.

Example for Subsystem Modules:


| Code | Substrate and Pin Type | Component Type |
| :---: | :--- | :--- |
| $\mathbf{P}$ | FR-4 DIP (Dual In-Line Package) | Plastic |
| C | CERAMIC DIP (Dual In-Line Package) | Ceramic |
| $\mathbf{N}$ | CERAMIC DIP (Dual In-Line Package) | Plastic |
| K | FR-4 QIP (Quad In-Line Package) | Plastic |
| CK | CERAMIC QIP (Quad In-Line Package) | Ceramic |
| $\mathbf{H}$ | FR-4 HIP (Hex In-Line Package) | Plastic |
| CH | CERAMIC QIP (Quad In-Line Package) | Ceramic |
| G | CERAMIC PGA (Pin Grid Array) | Ceramic |
| S | FR-4 SIP (Single In-Line Package) | Plastic |
| CS | CERAMIC SIP (Single In-Line Package) | Ceramic |
| V | FR-4 DSIP (Dual Single In-Line Package) | Plastic |
| CV | CERAMIC DSIP (Dual Single In-Line Package) | Ceramic |
| Z | FR-4 ZIP (Zip-zap In-Line Package) | Plastic |
| M | FR-4 SIMM (Single In-Line Memory Module) | Plastic |

## NOTES:

1. FR-4 is a multi-layered, glass filled epoxy laminate substrate.
2. Ceramic is a multi-layered, $\infty$-fired ceramic substrate.
3. Plastic refers to all surface mount devices available in various non-hermetically sealed packages (i.e. SOIC, SOJ, Flat Packs, etc.).
4. Ceramic refers to all surface mount devices available in various hermetically sealed packages (i.e. LCC, ceramic Flat Packs, etc.).

|  | CYPRESS-ASPEN | FUJITSU | HITACHI | NATIONAL | SYNERGY | IDT | Speed | Competitors' Package | Pinout |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| XXX492 2KX9 BICMOS or BIPOLAR ECL-I/O SELF-TIMED SRAM (STRAM) |  |  |  |  |  |  |  |  |  |
| 10K |  |  |  | NM4492W5 |  |  | 5 | 64 CERQUAD-. 965 | center power |
|  |  |  |  | NM4492W7 |  |  | 7 | 64 CERQUAD-. 965 | center power |
|  |  |  |  | NM4492W10 |  | IDT10496RL10C $\dagger$ | 10 | 64 CERQUAD-. 965 | center power |
| 100 K |  |  |  | NM100492W5 |  |  | 5 | 64 CERQUAD-. 965 | center power |
|  |  |  |  | NM100492W7 |  |  | 7 | 64 CERQUAD. 965 | center power |
|  |  |  |  | NM100492W10 |  | IDT100496RL10C $\dagger$ | 10 | 64 CERQUAD- 965 | center power |

XXX484 4KX4 BICMOS or BIPOLAR ECL-I/O SRAM

| 10K |  | MBM10A484-5F |  |  | SY10484-5FCF | IDT10A484S5E | 5 | 28 CERPACK-. 400 | center power |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MBM10A484-5C |  |  | SY10484-5DCF | IDT10A484S5C | 5 | 28 SB/CERDIP-. 400 | center power |
|  | CY10E484-7JC |  |  |  |  | IDT10A484S7Y* | 7 | 28 PLCC | center power |
|  | CY10E484-7KC |  |  |  |  | IDT10A484S7E | 7 | 28 CERPACK-. 400 | center power |
|  | CY10E484-7DC |  |  |  |  | IDT10A484S7C | 7 | 28 SB/CERDIP-. 400 | center power |
|  |  | MBM10484A-8F |  |  | SY10484-8FC | IDT10A484S8E | 8 | 28 CERPACK-. 400 | corner power |
|  |  | MBM10484A-8C |  |  | SY10484-8DC | IDT10484S8C | 8 | 28 SB/CERDIP-. 400 | corner power |
|  |  | MBM10484A-10F |  |  | SY10484-10FC | IDT10A484S10E | 10 | 28 CERPACK-. 400 | corner power |
|  |  | MBM10484A-10C |  |  | SY10484-10DC | IDT10484S10C | 10 | 28 SB/CERDIP-. 400 | corner power |
|  |  | MBM10484-15F |  |  |  | IDT10A484S10E | 15 | 28 CERPACK-. 400 | corner power |
|  |  | MBM10484-15C |  |  |  | IDT10484S10C | 15 | 28 SB/CERDIP-. 400 | corner power |
| 100K |  |  |  |  | SY100484-5FCF | IDT100A484S5E | 5 | 28 CERPACK- 400 | center power |
|  |  |  |  |  | SY100484-5DCF | IDT100A484S5C | 5 | 28 SB/CERDIP- 400 | center power |
|  | CY100E484-7JC |  |  |  |  | IDT100A484S7Y* | 7 | 28 PLCC | center power |
|  | CY100E484-7KC |  |  |  |  | IDT100A484S7E | 7 | 28 CERPACK-. 400 | center power |
|  | CY100E484-7DC |  |  |  |  | IDT100A484S7C | 7 | 28 SB/CERDIP- 400 | center power |
|  |  | MBM100484A-8F |  |  | SY100484-8FC | IDT100484S8E | 8 | 28 CERPACK-. 400 | corner power |
|  |  | MBM100484A-8C |  |  | SY100484-8DC | IDT100484S8C | 8 | 28 SB/CERDIP-. 400 | corner power |
|  | CY100E484-10JC |  |  |  |  | IDT100A484S10Y* | 10 | 28 PLCC | center power |
|  | CY100E484-10KC |  |  |  |  | IDT100A484S10E | 10 | 28 CERPACK-. 400 | center power |
|  | CY100E484-10DC |  |  |  |  | IDT100A484S10C | 10 | 28 SB/CERDIP-. 400 | center power |
|  |  | MBM100484A-10F |  |  | SY100484-10FC | IDT100484S10E | 10 | 28 CERPACK-. 400 | corner power |
|  |  | MBM100484A-10C |  |  | SY100484-10DC | IDT100484S10C | 10 | 28 SB/CERDIP- 400 | corner power |
|  |  | MBM100484-15F |  |  |  | IDT100484S15E | 15 | 28 CERPACK-. 400 | corner power |
|  |  | MBM100484-15C |  |  |  | IDT100484S15C | 15 | 28 SB/CERDIP- 400 | corner power |
| 101K |  | MBM101A484-5F |  |  | SY101484-5FCF | IDT101A484S5E | 5 | 28 CERPACK- 400 | center power |
|  | - . | MBM101A484-5C |  |  | SY101484-5DCF | IDT101A484S5C | 5 | 28 SB/CERDIP-. 400 | center power |
|  | CY1E484-7JC |  |  |  |  | IDT101A484S7Y* | 7 | 28 PLCC | center power |
|  | CY1E484-7KC |  |  |  |  | IDT101A484S7E | 7 | 28 CERPACK-. 400 | center power |
|  | CY1E484-7DC |  |  |  |  | IDT101A484S7C | 7 | 28 SB/CERDIP-. 400 | center power |



ECL CROSS REFERENCE GUIDE

|  | CYPRESS-ASPEN | FUJITSU | HITACHI | NATIONAL | SYNERGY | IDT | Speed | Competitors' Package | Pinout |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | SY101484-8FC | IDT101484S8E | 8 | 28 CERPACK- 400 | corner power |
|  |  |  |  |  | SY101484-8DC | IDT101484S8C | 8 | 28 SB/CERDIP- 400 | corner power |
|  |  |  |  |  | SY101484-10FC | IDT101484S10E | 10 | 28 CERPACK-. 400 | corner power |
|  |  |  |  |  | SY101484-10DC | IDT101484S10C | 10 | 28 SB/CERDIP- 400 | corner power |
| XXX486 4KX4 BICMOS or BIPOLAR ECL-I/O SELF-TIMED SRAM (STRAM) |  |  |  |  |  |  |  |  |  |
| 10K |  | MBM10486LL-13C |  |  |  | IDT10496LL13C $\dagger$ | 13 | 28 SB/CERDIP-. 400 | center power |
|  |  | MBM10486RR-13C |  |  |  | IDT10496RL12C $\dagger$ | 13 | 28 SB/CERDIP- 400 | center power |
|  |  | MBM10486RL-13C |  |  |  | IDT10496RL12C $\dagger$ | 13 | 28 SB/CERDIP- 400 | center power |
| 100K |  | MBM100486LL-13C |  |  |  | IDT100496LL13C $\dagger$ | 13 | 28 SB/CERDIP- 400 | center power |
|  |  | MBM 100486RR-13C |  |  |  | IDT100496RL12C $\dagger$ | 13 | 28 SB/CERDIP. 400 | center power |
|  |  | MBM 100486 RL -13C |  |  |  | IDT 100496RL12C $\dagger$ | 13 | 28 SB/CERDIP-. 400 | center power |
| XXX494 16Kx4 BICMOS or BIPOLAR ECL-I/O SRAM |  |  |  |  |  |  |  |  |  |
| 10K | CY10E494-7JC |  |  |  |  | IDT10494S7Y* | 7 | 28 PLCC | center power |
|  | CY10E494-7KC | MBM10494-7F |  |  |  | IDT 10494STY* | 7 | 28 CERPACK. 400 | center power |
|  | CY10E494-7DC | MBM10494-7C |  |  |  | IDT10494S7C | 7 | 28 SB/CERDIP. 400 | center power |
|  |  | MBM10494-8F |  |  |  | IDT10494S8Y* | 8 | 28 CERPACK- 400 | center power |
|  |  | MBM10494-8C |  |  |  | IDT10494S8C | 8 | 28 SB/CERDIP-. 400 | center power |
|  | CY10E494-10JC |  | HM10494F-10 |  |  | IDT10494S10Y* | 10 | 28 PLCC | center power |
|  | CY10E494-10KC |  | HM10494-10 | NM10494F10 |  | IDT10494S10Y* | 10 | 28 CERPACK-400 | center power |
|  | CY10E494-10DC |  |  | NM10494D10 |  | IDT10494S10C | 10 | 28 SB/CERDIP. 400 | center power |
|  | CY10E494-12JC |  |  |  |  | IDT10494S10Y* | 12 | 28 PLCC | center power |
|  | CY10E494-12KC |  |  | NM10494F12 |  | IDT10494S10Y* | 12 | 28 CERPACK-400 | center power |
|  | CY10E494-12DC |  | , | NM10494D12 |  | IDT10494S10C | 12 | 28 SB/CERDIP- 400 | center power |
|  |  | MBM10C494-15F |  | NM10494F15 |  | IDT10494S15Y* | 15 | 28 CERPACK- 400 | center power |
|  |  | MBM10C494-15C |  | NM10494D15 |  | IDT10494S15C | 15 | 28 SB/CERDIP- 400 | center power |
| 100K |  |  | HM100494F-10 |  |  | IDT100494S10Y* | 10 | 28 CERPACK-. 400 | center power |
|  |  |  | HM100494-10 |  |  | IDT100494S10C | 10 | 28 SB/CERDIP. 400 | center power |
|  | CY100E494-12JC |  |  |  |  | IDT100494S10Y* | 12 | 28 PLCC | center power |
|  | CY100E494-12KC |  | HM100494F-12 |  |  | IDT100494S10Y* | 12 | 28 CERPACK-400 | center power |
|  | CY100E494-12VC |  |  |  |  | IDT100494S10Y | 12 | 28 SO- 300 | center power |
|  | CY100E494-12DC |  | HM100494-12 |  |  | IDT100494S10C | 12 | 28 SB/CERDIP-. 400 | center power |
|  |  | MBM100C494-15F |  | NM100494F15 |  | IDT100494S15Y* | 15 | 28 CERPACK- 400 | center power |
|  |  | MBM100C494-15C |  | NM100494D15 |  | IDT100494S15C | 15 | 28 SB/CERDIP- 400 | center power |
|  |  |  |  | NM100494F18 |  | IDT100494S15Y* | 18 | 28 CERPACK-400 | center power |
|  |  |  |  | NM100494D18 |  | IDT100494S15C | 18 | 28 SB/CERDIP- 400 | center power |
| 101K | CY1E494-7JC |  |  |  |  | IDT101494S7Y* | 7 | 28 PLCC | center power |
|  | CY1E494-7KC | MBM101494-7F |  |  |  | IDT101494S7Y* | 7 | 28 CERPACK- 400 | center power |
|  | CY1E494-7DC | MBM101494-7C |  |  |  | IDT101494S7C | 7 | 28 SB/CERDIP-. 400 | center power |


|  |  | CYPRESS-ASPEN | FUJITSU | HITACHI | NATIONAL | SYNERGY | IDT | Speed | $\begin{gathered} \hline \begin{array}{c} \text { Competitors' } \\ \text { Package } \end{array} \\ \hline \end{gathered}$ | Pinout |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MBM101494-8F |  |  |  | IDT101494S8 ${ }^{\text {\% }}$ | 8 | 28 CERPACK- 400 | center power |
|  |  |  | MBM101494-8C |  |  |  | IDT101494S8C | 8 | 28 SB/CERDIP- 400 | center power |
|  |  | CY1E494-10JC |  |  |  |  | IDT101494S10Y* | 10 | 28 PLCC | center power |
|  |  | CY1E494-10KC |  | HM101494F-10 |  |  | IDT101494S10Y* | 10 | 28 CERPACK- 400 | center power |
|  |  | CY1E494-10DC |  | HM101494-10 |  |  | IDT101494S10C | 10 | 28 SB/CERDIP- 400 | center power |
|  |  |  |  | HM101494F-12 |  |  | IDT101494S10Y* | 12 | 28 CERPACK- 400 | center power |
|  |  |  |  | HM101494-12 |  |  | IDT101494S10C | 12 | 28 SB/CERDIP-. 400 | center power |
| $\stackrel{\rightharpoonup}{6}$ | XXX490 64K×1 BiCMOS or BIPOLAR ECL-I/O SRAM |  |  |  |  |  |  |  |  |  |
|  | 10K |  |  |  |  |  | IDT10490S8D | 8 | 22 CERDIP- 300 | corner power |
|  |  |  |  | HM10490-10 |  |  | IDT10490S 10 D | 10 | 22 CERDIP- 300 | corner power |
|  |  |  |  | HM10490-12 |  |  | IDT10490S12D | 12 | 22 CERDIP- 300 | corner power |
|  |  |  | MBM10490-15F |  |  |  | IDT10490S15Y* | 15 | 22 FLATPACK 300 | corner power |
|  |  |  | MBM10C490-15F |  |  |  | IDT10490S $15{ }^{*}$ | 15 | 22 FLATPACK 300 | corner power |
|  |  |  | MBM10490-15C |  |  |  | IDT10490S15D | 15 | 22 SB/CERDIP- 300 | corner power |
|  |  |  | MBM10C490-15C |  |  |  | IDT10490S 150 | 15 | 22 SB/CERDIP- 300 | corner power |
|  |  |  | MBM10490-25F |  |  |  | IDT10490S20\%* | 25 | 22 FLATPACK 300 | corner power |
|  |  |  | MBM10490-25C |  |  |  | IDT10490S20D | 25 | 22 SB/CERDIP- 300 | corner power |
|  | 100K |  |  |  |  |  | IDT100490S8D | 8 | 22 CERDIP- 300 | corner power |
|  |  |  |  | HM100490-10 |  |  | IDT100490S10D | 10 | 22 CERDIP. 300 | corner power |
|  |  |  |  | HM100490-12 |  |  | IDT100490S12D | 12 | 22 CERDIP- 300 | corner power |
|  |  |  | MBM100490-15F |  |  |  | IDT100490S15Y* | 15 | 22 FLATPACK-300 | corner power |
|  |  |  | MBM100C490-15F. |  |  |  | IDT100490S15Y* | 15 | 22 FLATPACK 300 | corner power |
|  |  |  | MBM100490-15C |  |  |  | IDT100490S15D | 15 | 22 SB/CERDIP-. 300 | corner power |
|  |  |  | MBM100C490-15C |  |  |  | IDT100490S15D | 15 | 22 SB/CERDIP- 300 | corner power |
|  |  |  | MBM100490-25F |  |  |  | IDT 100490S20Y* | 25 | 22 FLATPACK 300 | corner power |
|  |  |  | MBM100490-25C |  |  |  | IDT100490S20D | 25 | 22 SB/CERDIP- 300 | corner power |
|  | 101K |  |  |  |  |  | IDT101490S8D | 8 | 22 CERDIP- 300 | corner power |
|  |  |  |  | HM101490-10 |  |  | IDT101490S10D | 10 | 22 CERDIP- 300 | corner power |
|  |  |  |  | HM101490-12 |  |  | IDT101490D12D | 12 | 22 CERDIP- 300 | corner power |
|  | XXX50 | $64 \mathrm{~K} \times 4 \mathrm{BiCMOS}$ or | OLAR ECL-I/O SRA |  |  |  |  |  |  |  |
|  | 10 K |  |  | HM10504F-10 |  |  | IDT10504S10Y* | 10 | 28 CERPACK-400 | center power |
|  |  |  |  | HM10504F-12 |  |  | IDT10504S12Y* | 12 | 28 CERPACK- 400 | center power |
|  | 100 K |  |  | HM100504F-10 |  |  | IDT100504S10Y* | 10 | 28 CERPACK- 400 | center power |
|  |  |  |  | HM 100504F-12 |  |  | IDT100504S12Y* | 12 | 28 CERPACK- 400 | center power |
|  |  |  | MBM100C504-15F |  | NM100504F15 |  |  | 15 | 28 CERPACK- 400 | center power |
|  |  |  | MBM100C504-15C |  |  |  | IDT100504S15C | 15 | 32 SB- 400 | center power |
| $\omega$ |  |  |  |  | NM100504D15 |  |  | 15 | 28 SB- 400 | corner power |
|  |  |  |  |  | NM100504F18 |  |  | 18 | 28 CERPACK- 400 | center power |


|  | CYPRESS-ASPEN | FUJITSU | HITACHI | NATIONAL | SYNERGY | IDT | Speed | Competitors' Package | Pinout |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | NM100504D18 |  |  | 18 | 28 SB- 400 | comer power |
| 101K |  |  | HM101504F-10 |  |  | IDT101504S10Y* | 10 | 32 CERPACK- 400 | center power |
|  |  |  | HM101504F-12 |  |  | IDT101504S12Y* | 12 | 32 CERPACK- 400 | center power |
|  |  |  |  | NM5104F12 |  |  | 12 | 28 CERPACK- 400 | center power |
|  |  |  |  | NM5104D12 |  |  | 12 | 28 SB- 400 | corner power |
|  |  |  |  | NM5104F15 |  |  | 15 | 28 CERPACK-400 | center power |
|  |  |  |  | NM5104D15 |  |  | 15 | 28 SB- 400 | corner power |

NOTES:

1. BOLD FACE TYPE indicates exact replacement
2. Same function but in SOJ package; Flatpacks frequently have unique pinouts and do not cross between vendors.
3. $\dagger$ Not a direct replacement, but can be considered as altemative for new designs

## FIFO

## CROSS REFERENCE GUIDE

| AMD | IDT | AMD (CON'T.) | IDT | AMD (CON'T.) | IDT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Am7200 | IDT7200S/L | Am7202-80PC |  |  | 80 J |
| Am7200-25PC | 25TP | Am7202-25RC |  |  |  |
| Am7200-35PC | 35 TP | Am7202-35RC <br> Am7202-50RC | 25TP | Am7204-35DC <br> Am7204-50DC | 50D |
| Am7200-50PC | 50 TP |  | 50TP | Am7204-65DC | 65D |
| Am7200-65PC | 65TP | Am7202-65RC | 65TP | Am7204-80DC | 80D |
| Am7200-80PC | 80TP | Am7202-80RC <br> Am7202-25JC | 80TP | Am7204-40/BXA | 40DB |
| Am7200-25DC | 25D |  | 25 J | Am7204-50/BXA | 50DB |
| Am7200-35DC | 35D | Am7202-35JC | 35J | Am7204-65/BXA | $\begin{aligned} & 65 \mathrm{DB} \\ & 80 \mathrm{DB} \end{aligned}$ |
| Am7200-50DC | 50D | Am7202-50JC <br> Am7202-65JC | 50J | Am7204-80/BXA |  |
| Am7200-65DC | 65D |  |  | $67 \mathrm{C401}$ | IDT72401L |
| Am7200-80DC | 80D | Am7202-80JC | 80J | 67 C 401 -35N |  |
| Am7200-25RC | 25TP | Am7202-25DC Am7202-35DC | $\begin{aligned} & 25 \mathrm{D} \\ & 35 \mathrm{D} \end{aligned}$ | 67C401-25N $67 \mathrm{C} 401-15 \mathrm{~N}$ | $\begin{aligned} & 35 P \\ & 25 P \end{aligned}$ |
| Am7200-35RC | 35TP | Am7202-50DC | $\begin{aligned} & 35 \mathrm{D} \\ & \text { 50D } \end{aligned}$ |  | $\begin{aligned} & 25 r \\ & 15 P \end{aligned}$ |
| Am7200-65RC | 65 TP | Am7202-65DC | 65D | $67 \mathrm{C} 401-10 \mathrm{~N}$ | 10 P |
| Am7200-80RC | 80TP | $\begin{gathered} \text { Am7202-80DC } \\ \text { Am7202-40/BXA } \end{gathered}$ | $\begin{gathered} 80 D \\ 40 \mathrm{DB} \end{gathered}$ | $67 \mathrm{C} 401-35 \mathrm{~J}$$67 \mathrm{C} 401-25 \mathrm{~J}$ | 35D |
| Am7200-25JC | 25J |  |  |  |  |
| Am7200-35JC | 35 J | Am7202-50/BXA <br> Am7202-65/BXA | 50DB 65DB 80DB | $\begin{aligned} & 67 \mathrm{C} 401-15 \mathrm{~J} \\ & 67 \mathrm{C} 401-10 \mathrm{~J} \end{aligned}$ | $\begin{aligned} & 15 \mathrm{D} \\ & 10 \mathrm{D} \end{aligned}$ |
| Am7200-50JC | 50 J |  |  | 67401 |  |
| Am7200-65JC | 65 J | Am7202-80/BXA |  |  |  |
| Am7200-80JC | 80 J |  |  | $\begin{gathered} 67401 \mathrm{~A}-\mathrm{N} \\ 67401-\mathrm{N} \\ 67401 \mathrm{~A}-\mathrm{J} \\ 67401-\mathrm{J} \end{gathered}$ | 15 P10 P |
| Am7200-50/BXA | 50DB | Am7203 | IDT7203S/L |  |  |
| Am7200-65/BXA | 65DB | Am7203-25PC | 25P |  | 10D |
| Am7200-80/BXA | 80DB | Am7203-35PC | 35P | C67401 |  |
| Am7201 | IDT7201SA/LA | Am7203-50PC |  | C67401A-NC67401-N | 15P |
| Am7201-25PC | 25P | Am7203-65PC | 80P |  | 10P |
| Am7201-35PC | 35P | Am7203-80PC <br> Am7203-25RC |  | C67401-N C67401A-J | $\begin{aligned} & 15 \mathrm{D} \\ & 10 \mathrm{D} \end{aligned}$ |
| Am7201-50PC | 50P | $\begin{aligned} & \text { Am7203-35RC } \\ & \text { Am7203-50RC } \end{aligned}$ | 35 TP | $\begin{gathered} \text { C67401A-J } \\ \text { C67401-J } \end{gathered}$ |  |
| Am7201-65PC | 65P |  | 50TP | 57C401 |  |
| Am7201-25RC | 25 TP | $\begin{aligned} & \text { Am7203-50RC } \\ & \text { Am7203-65RC } \end{aligned}$ | 80TP | 57C401-12J | 15DB |
| Am7201-35RC | 35 TP | $\begin{aligned} & \text { Am7203-80RC } \\ & \text { Am7203-25JC } \end{aligned}$ |  | 57401 |  |
| Am7201-50RC | 50 TP | Am7203-35JC | 25 J 35 J |  | $\begin{aligned} & \text { 10DB } \\ & \text { 10DB } \end{aligned}$ |
| Am7201-65RC | 65TP | $\begin{aligned} & \text { Am7203-50JC } \\ & \text { Am7203-65JC } \end{aligned}$ | 50J | $57401 \cdot \mathrm{~J}$ |  |
| Am7201-25JC | 25J |  | 65 J | C57401 |  |
| Am7201-35JC | 35J | Am7203-35DC | 35D | $\begin{aligned} & \text { C57401A-J } \\ & \text { C57401-J } \end{aligned}$ | $\begin{aligned} & \text { 10DB } \\ & \text { 10DB } \end{aligned}$ |
| Am7201-50JC | 50 J |  | 50D |  |  |
| Am7201-65JC | 65 J | $\begin{aligned} & \text { Am7203-50DC } \\ & \text { Am7203-65DC } \end{aligned}$ |  | 67C402 | IDT72402L |
| Am7201-80JC | 80 J | Am7203.80DC Am7203-40/BXA | 80D |  |  |
| Am7201-35DC | 35D |  | $\begin{aligned} & 40 \mathrm{DB} \\ & 50 \mathrm{DB} \\ & 65 \mathrm{DB} \\ & 800 \mathrm{~B} \end{aligned}$ | 67C402-35N <br> 67C402-25N <br> $67 \mathrm{C} 402-15 \mathrm{~N}$ <br> 67C402-10N <br> 67C402-35J <br> 67C402-25J <br> 67C402-15J <br> 67C402-10J | 35P |
| Am7201-50DC | 50 D | Am7203-40/BXA <br> Am7203-50/BXA <br> Am7203-65/BXA <br> Am7203-80/BXA |  |  | 25P |
| Am7201-65DC | 65D |  |  |  | 15P |
| Am7201-80DC | 80D |  |  |  | 10P |
| Am7201-40/BXA | 40DB | Am7204 | IDT7204S/L |  | 25D |
| Am7201-50/BXA | 50DB | Am7204-25PC <br> Am7204-35PC <br> Am7204-50PC <br> Am7204-65PC <br> Am7204-80PC <br> Am7204-25JC <br> Am7204-35JC <br> Am7204-50JC <br> Am7204-65JC | $\begin{aligned} & 25 \mathrm{P} \\ & 35 \mathrm{P} \\ & 50 \mathrm{P} \\ & 65 \mathrm{P} \\ & 80 \mathrm{P} \\ & 25 \mathrm{~J} \\ & 35 \mathrm{~J} \\ & 50 \mathrm{~J} \\ & 65 \mathrm{~J} \end{aligned}$ |  | 15D |
| Am7201-65/BXA | 65DB |  |  |  | 10 D |
| Am7201-80/BXA | 80DB |  |  | 67402 |  |
| Am7202 | IDT7202SA/LA |  |  | 67402A-N | 15P |
| Am7202-25PC | 25P |  |  |  | 10P |
| Am7202-35PC | 35P |  |  | $\begin{gathered} 67402-\mathrm{N} \\ 67402 \mathrm{~A}-\mathrm{J} \\ 67402-\mathrm{J} \end{gathered}$ | $\begin{aligned} & 15 \mathrm{D} \\ & 10 \mathrm{D} \end{aligned}$ |
| Am7202-50PC | 50P |  |  |  |  |
| Am7202-65PC | 65 P |  |  |  |  |

FIFO CROSS REFERENCE


FIFO CROSS REFERENCE

| DALLAS | IDT | SAMSUNG (Con't.) | IDT | TI (Con't.) | IDT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DS2009 | IDT7201SA/LA | KM75C03AJ-25 <br> KM75C03AJ-35 <br> KM75C03AJ-50 <br> KM75C03AJ-80 <br> KM75C03AN-25 <br> KM75C03AN-35 <br> KM75C03AN-50 <br> KM75C03AN-80 | $\begin{aligned} & 25 \mathrm{~J} \\ & 35 \mathrm{~J} \\ & 50 \mathrm{~J} \\ & 80 \mathrm{~J} \\ & 25 \mathrm{TP} \\ & 35 \mathrm{TP} \\ & 50 \mathrm{TP} \\ & 80 \mathrm{TP} \end{aligned}$ | 54/74ALS234 | IDT72403L |
| DS2009-35DS2009-50DS2009-65DS2009-80DS2009R-35DS2009R-50DS2009R-65DS2009R-80 | $\begin{aligned} & 35 \mathrm{P} \\ & 50 \mathrm{P} \\ & 65 \mathrm{P} \\ & 80 \mathrm{P} \\ & 35 \mathrm{~J} \\ & 50 \mathrm{~J} \\ & 65 \mathrm{~J} \\ & 80 \mathrm{~J} \end{aligned}$ |  |  | SN74ALS234-30N SN54ALS234-25J | $\begin{gathered} 35 \mathrm{P} \\ 25 \mathrm{DB} \end{gathered}$ |
|  |  |  |  | 54/74ALS235 | IDT72413L |
|  |  |  |  | SN74ALS235-25N | $\begin{array}{r} 25 \mathrm{P} \\ 25 \mathrm{SO} \\ 25 \mathrm{DB} \end{array}$ |
|  |  |  |  | SN74ALS235-25DW |  |
|  |  |  |  | SN54ALS235-20 |  |
|  |  | SHARP | IDT | CYPRESS | IDT |
| DS2010 | IDT7202SA/LA | L.H5495 | IDT7200L | CY7C420 | IDT7201SALA |
| DS2010-35 <br> DS2010-50 <br> DS2010-65 <br> DS2010-80 <br> DS2010R-35 <br> DS2010R-50 <br> DS2010R-65 <br> DS2010R-80 | $\begin{aligned} & 35 \mathrm{P} \\ & 50 \mathrm{P} \\ & 65 \mathrm{P} \\ & 80 \mathrm{P} \\ & 35 \mathrm{~J} \\ & 50 \mathrm{~J} \\ & 65 \mathrm{~J} \\ & 80 \mathrm{~J} \end{aligned}$ | LH5495D-25 <br> LH5495D-35 <br> LH5495U-25 <br> LH5495U-35 | $\begin{gathered} 25 \mathrm{TP} \\ 35 \mathrm{TP} \\ 25 \mathrm{~J} \\ 35 \mathrm{~J} \end{gathered}$ | CY7C420-30PC CY7C420-40PC CY7C420-65PC CY7C420.30DC CY7C420-40DC CY7C420-65DC CY7C420-30DMB CY7C420-40DMB CY7C420-65DMB |  |
|  |  |  |  |  | 25 P35 P65 P25 D35 D65 D30 DB40 DB65 DB |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  | LH5496 | IDT7201LA |  |  |
|  |  | LH5496-25 <br> LH5496-35 <br> LH5496-50 | - 25P |  |  |
|  |  |  | $\begin{aligned} & 35 P \\ & 50 P \end{aligned}$ |  |  |
| DS2011 | IDT7203S/L |  |  |  |  |
| DS2011-35 | 35P | LH5496D-25 | 25TP | CY7C421 | 65DB |
| DS2011-50 | 50P | LH54960-35 | 35 TP | CY7C421-30PC |  |
| DS2011-65 | 65P | LH5496D-50 | 50TP | CY7C421-40PC <br> CY7C421-65PC | 35 TP |
| DS2011-80 | 80P | LH5496U-20 | 20J |  | -65TP |
| DS2011R-35 | 35 J | LH5496U-25 | 25 J | CY7C421-65PC CY7C421-30JC | 25 J |
| DS2011R-50 | 50J | LH5496U-35 | 35J | CY7C421-40JC CY7C421-65JC | 35J |
| DS2011R-65 | 65 J | LH5497 | IDT7202LA |  | 65 J |
| DS2011R-80 | 80J |  | 25P | $\begin{aligned} & \text { CY7C421-65JC } \\ & \text { CY7C421-30VC } \end{aligned}$ | $\begin{aligned} & 25 \mathrm{Y} \\ & 35 \mathrm{Y} \end{aligned}$ |
| SAMSUNG | IDT | LH5497-35 |  |  |  |
| KM75C01A | IDT7201SA/LA | $\begin{gathered} \text { LH5497-50 } \\ \text { LH5497D-25 } \end{gathered}$ | 35 P 50 P | CY7C421-65VC CY7C421-30DC CY7C421-40DC | 65Y |
| KM75C01AP-25 | 25P |  | 25TP |  | 35 TC |
| KM75C01AP-35 | 35P | $\begin{aligned} & \text { LH5497D-35 } \\ & \text { LH5497D-50 } \end{aligned}$ | 35 TP | CY7C421-40DC <br> CY7C421-65DC | 65TC |
| KM75C01AP-50 | 50P |  | 50TP | CY7C421-65DC <br> CY7C421-30DMB | 30 TCB |
| KM75C01AP-80 | 80P | LH5497U-25 |  | CY7C421-40DMB | 40TCB |
| KM75C01AJ-25 | 25 J | LH5497U-35 | $\begin{aligned} & 25 \mathrm{~J} \\ & 35 \end{aligned}$ | CY7C421-65DMB CY7C421-30LMB | $65 \mathrm{TCB}$ |
| KM75C01AJ-35 | 35J | LH5498 | IDT7203L |  | 40LB |
| KM75C01AJ-50 | 50 J | LH5498-20 | 20P | CY7C421-40LMB <br> CY7C421-65LMB |  |
| KM75C01AJ-80 | 80 J | LH5498-25 | 25P |  | 65LB |
| KM75C01AN-25 | 25TP | LH5498-35 | 35P | CY7C424 | IDT7202SALA |
| KM75C01AN-35 KM75C01AN-50 | 35 TP 50 TP | LH5498-50 |  | CY7C424-30PC | 25P |
| KM75C01AN-80 | 80 TP | LH5498D-20 | 20TP | $\begin{aligned} & \text { CY7C424-40PC } \\ & \text { CY7C424-65PC } \end{aligned}$ | 35P65 |
| KM75C02A | IDT7202SA/LA | LH5498D-35 | $35 \mathrm{TP}$ |  |  |
| KM75C02AP-25 | 25P | LH5498D-50 | $\begin{aligned} & 50 \mathrm{TP} \\ & 20 \mathrm{~J} \end{aligned}$ | CY7C424-30DC | 25D |
| KM75C02AP-35 | 35P | LH5498U-20 |  | CY7C424-40DC CY7C424-65DC | $\begin{aligned} & 350 \\ & 650 \end{aligned}$ |
| KM75C02AP-50 | 50P | LH5498U-25 | $\begin{aligned} & 25 \mathrm{~J} \\ & 35 \mathrm{~J} \end{aligned}$ | $\begin{aligned} & \text { CY7C424-65DC } \\ & \text { CY7C424-30DMB } \\ & \text { CY7C424-40DMB } \end{aligned}$ | 30DB 40DB 65DB |
| KM75C02AP-80 | 80P | LH5498U-35 |  |  |  |
| KM75C02AJ-25 | 25 J | LH5499 | IDT7204L | CY7C424-65DMB |  |
| KM75C02AJ-35 | 35J | $\begin{aligned} & \text { LH5499-20 } \\ & \text { LH5499-25 } \end{aligned}$ | 20 P | CY7C425 | 65DB |
| KM75C02AJ-50 | 50 J |  | 25P | CY7C425-30PC | 25TP |
| KM75C02AJ-80 KM75C02AN-25 | 80 TP | LH5499-35LH5499-50 |  | $\begin{aligned} & \text { CY7C425-40PC } \\ & \text { CY7C425-65PC } \end{aligned}$ | 35TP |
| KM75C02AN-35 | 35 TP |  | 35 P 50 P |  | 65TP25J |
| KM75C02AN-50 | 50 TP | LH5499U-20 | $20 \mathrm{~J}$ | CY7C425-65PC CY7C425-30JC |  |
| KM75C02AN-80 | 80TP | LH5499-U35 | $\begin{aligned} & 25 \mathrm{~J} \\ & 35 \mathrm{~J} \end{aligned}$ | CY7C425-40JC <br> CY7C425-65JC | 65J |
| KM75C03A | IDT7203SA/LA | TI | IDT |  | 25Y |
| KM75C03AP-25 | 25P | 54/74ALS236 | IDT72401L | $\begin{aligned} & \text { CY7C425-30VC } \\ & \text { CY7C425-40VC } \end{aligned}$ | 65 Y |
| KM75C03AP-35 | 35P |  |  | CY7C425-40VC CY7C425-65VC CY7C425-30DC |  |
| KM75C03AP-50 | 50P | SN74ALS236-30N | $35 P$ |  | $\begin{aligned} & 25 \mathrm{TC} \\ & 35 \mathrm{TC} \end{aligned}$ |
| KM75C03AP-80 | 80P | SN54ALS236-25J | 250B | $\begin{aligned} & \text { CY7C425-30DC } \\ & \text { CY7C425-40DC } \end{aligned}$ |  |


| CYPRESS (Con't.) | IDT | CYPRESS (Con't.) | IDT | CYPRESS (Con't.) | IDT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CY7C425-65DC | 657 C | CY7C433 |  | CY7C403-25DMB | 25DB |
| CY7C425-30DMB | 30 TCB 40 TCB | CY7C433-25PC | ${ }^{25 T P}$ | CY7C403-15DMB | 15DB |
| CY7C425-65DMB | 65 TCB | CY7C433-40PC | 35TP | CY7C404 | IDT72404L |
| CY7C425-30LMB | 30 LB | CY7C433-65PC | 65TP |  |  |
| CY7C425-40LMB | ${ }^{40 L B}$ | CY7C433-25VC | $25 Y$ | CY7C404-25PC CY7C404-15PC | 25P 15 P |
| CY7C425-65LMB | 65LB | CY7C433-30VC | 35 Y | CY7C404-10PC | 10P |
| CY7C428 | IDT7203S/L | CY7C433-40VC | $40 Y$ | CY7C404-25DC | 25D |
| CY7C428-20PC | 20P | CY7C432/433 | IDT7204S | CY7C404-15DC | 15D |
| CY7C428-25PC | 25P | CY7C433-65VC | 65 Y |  |  |
| CY7C428-30PC | 25P | CY7C433-25JC | 25 J |  |  |
| CY7C428-40PC | 35 P | CY7C433-30Jc | 25 J |  |  |
| CY7C428-65PC | 65P | CY7C433-40JC | 35J |  |  |
| CY7C428-20DC | 20 D | CY7C433-65JC | 65J |  |  |
| CY7C428-25DC | 25 D | CY7C433-30DMB | 30TCB |  |  |
| CY7C428-30DC | 25 D | CY7C433-40DMB | 40тCB |  |  |
| CY7C428-40DC | 35 D | CY7C433-65DMB | 65TCB |  |  |
| CY7C428-25DMB | 20 DB | CY7C433-30LMB | 30LB |  |  |
| CY7C428-30DMB | 30 DB | CY7C433-40LMB CY7C433-65LMB | ${ }_{65}^{40 \mathrm{LB}}$ |  |  |
| CY7C428-65DMB | 650DB | CY3341 | IDT72401L |  |  |
| CY7C429 |  | CY3341-2PC | 10 P |  |  |
| CY7C429-20PC | 20TP | CY3341PC | 10 P |  |  |
| CY7C429-25PC | 25TP | CY33410¢ | 10 D |  |  |
| CY7C429-30PC | 25TP | CY3341-2DMB | 10DB |  |  |
| CY7C429-40PC | 35TP | CY3341DMB | 10DB |  |  |
| CY7C429-20JC | 20 J | CY7C401 |  |  |  |
| CY7C429-25JC | 25 J | CY7C401-25PC | 25P |  |  |
| CY7C429-30JC | 25 J | CY7C401-15PC | 15P |  |  |
| CY7C429-40JC | 35 J | CY7C401-10PC | 10 P |  |  |
| CY7C429-65JC | 65 J | CY7C401-5PC | 10P |  |  |
| CY7C429-20DC | 20 TC | CY7C401-25DC | 25D |  |  |
| CY7C429-25DC | 25 TC | CY7C401-15DC | 15D |  |  |
| CY7C429-30DC | 25 TC | CY7C401-10DC | 10D |  |  |
| CY7C429-40DC CY7C429-65DC | 35TC | CY7C401-5DC | 10D |  |  |
| CY7C429.20VC | 20 Y | CY7C401-25DMB | 25DB |  |  |
| CY7C429-25VC | 25 Y | CY7C401-10DMB | 10DB |  |  |
| CY7C429-30VC | 30 Y | CY7C402 | 1DT72402L |  |  |
| CY7C429-65VC | 65 Y | CY7C402-25PC | 25P |  |  |
| CY7C429-25DMB | 20TCB | CY7C402-15PC | 15P |  |  |
| CY7C429-30DMB | зотCB | CY7C402-10PC | 10P |  |  |
| CY7C429-40DMB | 40TCB | CY7C402-5PC | 10P |  |  |
| CY7C429-65DMB | 65TCB | CY7C402-25DC | 25D |  |  |
| CY7C432/433 | IDT7204S | CY7C402-15DC | 15 D |  |  |
| CY7C432-25PC | 25P | CY7C402-5DC | 10 D |  |  |
| CY7C432-30PC | 25P | CY7C402-25DMB | 25DB |  |  |
| CY7C432-40PC | 35P | CY7C402-15DMB | 15DB |  |  |
| CY7C432-65PC | 65 P | CY7C402-10DMB | 10DB |  |  |
| CY7C432-300 | 250 | CY7C403 | 1DT72403L |  |  |
| CY7C432-40DC | 35 D | CY7C403-25PC | 25P |  |  |
| CY7C432-65DC | 65D | CY7C403-15PC | 15P |  |  |
| CY7C432-25DMB | 25DB | CY7C403-10PC | 10P |  |  |
| CY7C432-30DMB | 30 DB | CY7C403-25DC | 25D |  |  |
| CY7C432-40DMB | 40DB | CY7C403-15DC | 15D |  |  |
| CY7C432-65DMB | 65DB | CY7C403-10DC | 10D |  |  |



SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7130SA90CB |  |  |  |
| IDT7130SA90L48B |  |  |  |
| IDT7130SA90L52B |  |  |  |
| IDT7130SA90FB |  |  |  |
| IDT7130SA100P |  | AM2130-10PC |  |
| IDT7130SA100C |  | AM2130-10DC |  |
| IDT7130SA100L48 |  |  |  |
| IDT7130SA100L52 |  | AM2130-10LC |  |
| IDT7130SA100J |  | AM2130-10JC |  |
| IDT7130SA100F |  |  |  |
| IDT7130SA100CB |  | AM2130-10/BXC |  |
| IDT7130SA100L48B |  |  |  |
| IDT7130SA100L52B |  |  |  |
| IDT7130SA100FB |  |  |  |
| IDT7130SA120CB |  | AM2130-12/BXC |  |
| IDT7130SA120L48B |  |  |  |
| IDT7130SA120L52B |  |  |  |
| IDT7130SA120F8 |  |  |  |
|  |  |  |  |
| IDT7130LA35P |  |  |  |
| IDT7130LA35C |  |  |  |
| IDT7130LA35L48 |  |  |  |
| IDT7130LA35L52 |  |  |  |
| IDT7130LA35J |  |  |  |
| IDT7130LA35F |  |  |  |
| IDT7130LA45P |  |  |  |
| ID77130LA45C |  |  |  |
| IDT7130LA45L48 |  |  |  |
| IDT7130LA45L52 |  |  |  |
| IDT7130LA45J |  |  |  |
| IDT7130LA45F |  |  |  |
| IDT7130LA45CB |  |  |  |
| IDT7130LA45L48B |  |  |  |
| IDT7130LA45L52B |  |  |  |
| IDT7130LA45FB |  |  |  |
| IDT7130LA55P |  |  |  |
| IDT7130LA55C |  |  |  |
| IDT7130LA55L48 |  |  |  |
| IDT7130LA55L52 |  |  |  |
| IDT7130LA55J |  |  |  |
| IDT7130LA55F |  |  |  |
| IDT7130LA55CB |  |  |  |
| IDT7130LA55L48B |  |  |  |
| IDT7130LA55L52B | . |  |  |
| IDT7130LA55FB |  |  |  |
| IDT7130LA70P |  |  |  |


| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7130LA70C |  |  | . |
| IDT7130LA70L48 |  |  |  |
| IDT7130LA70L52 |  |  |  |
| IDT7130LA70J |  |  |  |
| IDT7130LA70F |  |  |  |
| IDT7130LA70CB |  |  |  |
| IDT7130LA70L48B |  |  |  |
| IDT7130LA70L52B |  |  |  |
| IDT7130LA70FB |  |  |  |
| IDT7130LA90P |  |  |  |
| IDT7130LA90C |  |  |  |
| IDT7130LA90L48 |  |  |  |
| IDT7130LA90L52 |  |  |  |
| IDT7130LA90J |  |  |  |
| IDT7130LA90F |  |  |  |
| IDT7130LA90CB |  |  |  |
| 1DT7130LA90L48B |  |  |  |
| IDT7130LA90L52B |  |  |  |
| IDT7130LA90FB |  |  |  |
| IDT7130LA100P |  |  |  |
| IDT7130LA100C |  |  |  |
| IDT7130LA100L48 |  |  |  |
| IDT7130LA100L52 |  |  |  |
| IDT7130LA100J |  |  |  |
| IDT7130LA100F |  |  |  |
| IDT7130LA100CB |  |  |  |
| IDT7130LA100L48B |  |  |  |
| IDT7130LA100L52B |  |  |  |
| IDT7130LA100FB |  |  |  |
| IDT7130LA120CB |  |  |  |
| IDT7130LA120L48B |  |  |  |
| IDT7130LA120L52B |  |  |  |
| IDT7130LA120FB |  |  |  |
|  |  |  |  |
| IDT7132SA35P | CY7C132-35PC |  | VT7132-35PC |
| IDT7132SA35C | CY7C132-35DC |  |  |
| IDT7132SA35L48 | CY7C132-35LC |  |  |
| IDT7132SA35L52 |  |  |  |
| IDT7132SA35J |  |  | VT7132-35QC |
| IDT7132SA35F |  |  |  |
| IDT7132SA45P | CY7C132-45PC |  | VT7132-45PC |
| IDT7132SA45C | CY7C132-45DC |  |  |
| IDT7132SA45L48 | CY7C132-45LC |  |  |
| IDT7132SA45L52 |  |  |  |
| IDT7132SA45J |  |  | VT7132-45QC |
| IDT7132SA45F |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7132SA45CB | CY7C132-45DMB |  |  |
| IDT7132SA45L48B | CY7C132-45LMB |  |  |
| IDT7132SA45L52B |  |  |  |
| IDT7132SA45FB |  |  |  |
| IDT7132SA55P | CY7C132-55PC |  | VT7132-55PC |
| IDT7132SA55C | CY7C132-55DC |  |  |
| IDT7132SA55L.48 | CY7C132-55LC |  |  |
| IDT7132SA55L52 |  |  |  |
| IDT7132SA55J |  |  | VT7132-55QC |
| IDT7132SA55F |  |  |  |
| IDT7132SA55CB | CY7C132-55DMB |  |  |
| IDT7132SA55L48B | CY7C132-55LMB |  |  |
| IDT7132SA55L52B |  |  |  |
| IDT7132SA55FB |  |  |  |
| IDT7132SA70P |  |  | VT7132-70PC |
| IDT7132SA70C |  |  |  |
| IDT7132SA70L48 |  |  |  |
| IDT7132SA70L52 |  |  |  |
| IDT7132SA70, |  |  | VT7132-70QC |
| IDT7132SA70F |  |  |  |
| IDT7132SA70CB |  |  |  |
| IDT7132SA70L48B |  |  |  |
| IDT7132SA70L52B |  |  |  |
| IDT7132SA70FB |  |  |  |
| IDT7132SA90P |  |  | VT7132-90PC |
| IDT7132SA90C |  |  |  |
| IDT7132SA90L48 |  |  |  |
| IDT7132SA90L52 |  |  |  |
| IDT7132SA90J |  |  | VT7132-900C |
| IDT7132SA90F |  |  |  |
| IDT7132SA90CB |  |  |  |
| IDT7132SA90L48B |  |  |  |
| IDT7132SA90L52B |  |  |  |
| IDT7132SA90FB |  |  |  |
| IDT7132SA100P |  |  |  |
| IDT7132SA100C |  |  |  |
| IDT7132SA100L48 |  |  |  |
| IDT7132SA100L52 |  |  |  |
| IDT7132SA100J |  |  |  |
| IDT7132SA100F |  |  |  |
| IDT7132SA100CB |  |  |  |
| IDT7132SA100L48B |  |  |  |
| IDT7132SA100L52B |  |  |  |
| IDT7132SA100FB | . |  |  |
| IDT7132SA120CB |  |  |  |
| IDT7132SA120L48B |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS |  | AMD |
| :--- | :--- | :--- | :--- |
| IDT7132SA120L52B |  |  | VLSI |
| IDT7132SA120FB |  |  |  |
|  |  |  |  |
| IDT7132LA35P |  |  |  |
| IDT7132LA35C |  |  |  |
| IDT7132LA35L48 |  |  |  |
| IDT7132LA35L52 |  |  |  |
| IDT7132LA35J |  |  |  |
| IDT7132LA35F |  |  |  |
| IDT7132LA45P |  |  |  |
| IDT7132LA45C |  |  |  |
| ID7132LA45L48 |  |  |  |
| ID77132LA45L52 |  |  |  |
| IDT7132LA45J |  |  |  |
| IDT7132LA45F |  |  |  |
| IDT7132LA45CB |  |  |  |
| IDT7132LA45L48B |  |  |  |
| IDT7132LA45L52B |  |  |  |
| IDT7132LA45FB |  |  |  |
| IDT7132LA55P |  |  |  |
| IDT7132LA55C |  |  |  |
| IDT7132LA55L48 |  |  |  |
| IDT7132LA55L52 |  |  |  |
| IDT7132LA55J |  |  |  |
| IDT7132LA55F |  |  |  |
| IDT7132LA55CB |  |  |  |
| IDT7132LA55L48B |  |  |  |
| IDT7132LA55L52B |  |  |  |
| IDT7132LA55FB |  |  |  |
| IDT7132LA70P |  |  |  |
| IDT7132LA70C |  |  |  |
| ID77132LA70L48 |  |  |  |
| IDT7132LA70L52 |  |  |  |
| IDT7132LA70J |  |  |  |
| IDT7132LA70F |  |  |  |
| IDT7132LA70CB |  |  |  |
| IDT7132LA70L48B |  |  |  |
| IDT7132LA70L52B |  |  |  |
| IDT7132LA70FB |  |  |  |
| IDT7132LA90P |  |  |  |
| IDT7132LA90C |  |  |  |
| IDT7132LA90L48 |  |  |  |
| ID77132LA90L52 |  |  |  |
| IDT7132LA90J |  |  |  |
|  |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7132LA90L48B |  |  |  |
| IDT7132LA90L52B |  |  |  |
| IDT7132LA90FB |  |  |  |
| IDT7132LA100P |  |  |  |
| IDT7132LA100C |  |  |  |
| IDT7132LA100L48 |  |  |  |
| IDT7132LA100L52 |  |  |  |
| IDT7132LA100J |  |  |  |
| IDT7132LA100F |  |  |  |
| IDT7132LA100CB |  |  |  |
| IDT7132LA100L48B |  |  |  |
| IDT7132LA100L52B |  |  |  |
| IDT7132LA100FB |  |  |  |
| IDT7132LA120CB |  |  |  |
| IDT7132LA120L48B |  |  |  |
| IDT7132LA120L52B |  |  |  |
| IDT7132LA120FB |  |  |  |
|  |  |  |  |
| IDT71321SA35J | CY7C136-35JC |  | VT71321-35QC |
| IDT71321SA35L52 | CY7C136-35LC |  |  |
| IDT71321SA45J | CY7C136-45JC |  | VT71321-45QC |
| IDT71321SA45L52 | CY7C136-45LC |  |  |
| IDT71321SA45L52B | CY7C136-45LMB |  |  |
| IDT71321SA55J | CY7C136-55JC |  |  |
| IDT71321SA55L52 | CY7C136-55LC |  |  |
| IDT71321SA55L52B | CY7C136-55LMB |  |  |
| IDT71321SA70L52B |  |  |  |
|  |  |  |  |
| IDT71321LA35J |  |  |  |
| IDT71321LA35L52 |  |  |  |
| IDT71321LA45J |  |  |  |
| IDT71321LA45L52 |  |  |  |
| IDT71321LA45L52B |  |  |  |
| IDT71321LA55J |  |  |  |
| IDT71321LA55L52 |  |  |  |
| IDT71321LA55L52B |  |  |  |
| ID771321LA70L52B |  |  |  |
|  |  |  |  |
| IDT71322S35P |  |  |  |
| IDT71322S35C |  |  |  |
| IDT71322S35J |  |  |  |
| IDT71322S35L48 |  |  |  |
| IDT71322S45P |  |  |  |
| IDT71322S45C |  |  |  |
| IDT71322S45J |  |  |  |
| IDT71322S45L48 |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT71322S45CB |  |  |  |
| IDT71322S45L48B |  |  |  |
| IDT71322S55P |  |  |  |
| IDT71322S55C |  |  |  |
| IDT71322S55J |  |  |  |
| IDT71322S55L48 |  |  |  |
| IDT71322S55CB |  |  |  |
| IDT71322S55L48B |  |  |  |
| IDT71322S70P |  |  |  |
| IDT71322S70C |  |  |  |
| IDT71322S70J |  |  |  |
| IDT71322S70L48 |  |  |  |
| IDT71322S70CB |  |  |  |
| IDT71322S70L48B |  |  |  |
|  |  |  |  |
| IDT71322L35P |  |  |  |
| IDT71322L35C |  |  |  |
| IDT71322L35J |  |  |  |
| IDT71322L35L48 |  |  |  |
| IDT71322L45P |  |  |  |
| IDT71322L45C |  |  |  |
| IDT71322L45J |  |  |  |
| IDT71322L45L48 |  |  |  |
| IDT71322L45CB |  |  |  |
| IDT71322L45L48B |  |  |  |
| IDT71322L55P |  |  |  |
| IDT71322L55C |  |  |  |
| IDT71322L55J |  |  |  |
| IDT71322L55L48 |  |  |  |
| IDT71322L55CB |  |  |  |
| IDT71322L55L48B |  |  |  |
| IDT71322L70P |  |  |  |
| IDT71322L70C |  |  |  |
| IDT71322L70J |  |  |  |
| IDT71322L70L48 |  |  |  |
| IDT71322L70CB |  |  |  |
| IDT71322L70L48B |  |  |  |
|  |  |  |  |
| IDT7133S45XC |  |  |  |
| IDT7133S45J |  |  |  |
| IDT7133S45L68 |  |  |  |
| IDT7133S45G |  |  |  |
| IDT7133S55XC |  |  |  |
| IDT7133S55J |  |  |  |
| IDT7133S55L68 |  |  |  |
| IDT7133S55G |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS |  | AMD |
| :--- | :--- | :--- | :--- |
| IDT7133S55L68B |  |  | VLSI |
| IDT7133S55GB |  |  |  |
| IDT7133S70XC |  |  |  |
| IDT7133S70J |  |  |  |
| IDT7133S70L68 |  |  |  |
| IDT7133S70G |  |  |  |
| IDT7133S70XCB |  |  |  |
| IDT7133S70L68B |  |  |  |
| IDT7133S70GB |  |  |  |
| IDT7133S90XC |  |  |  |
| IDT7133S90 |  |  |  |
| IDT7133S90L68 |  |  |  |
| IDT7133S90G |  |  |  |
| IDT7133S90XCB |  |  |  |
| IDT7133S90L68B |  |  |  |
| IDT7133S90GB |  |  |  |
|  |  |  |  |
| IDT7133L45XC |  |  |  |
| IDT1342S45J |  |  |  |
| IDT7133L45J |  |  |  |
| IDT7133L45L68 |  |  |  |
| IDT71342S35L52 |  |  |  |
| IDT733L45G |  |  |  |
| IDT7133L55XC |  |  |  |
| IDT7133L55J |  |  |  |
| IDT7713333 |  |  |  |
| IDT7133L55L68 |  |  |  |
| IDT7133L55G |  |  |  |
| IDT7133L55GBB |  |  |  |
| IDT7133L70XC |  |  |  |
| IDT7133L70J |  |  |  |
| IDT7133L70L68 |  |  |  |
| IDT7133L70G |  |  |  |
| IDT7133L70XCB |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT71342S45L52B |  |  |  |
| IDT71342S55L52 |  |  |  |
| IDT71342S55J |  |  |  |
| IDT71342S55L52B |  |  |  |
| IDT71342S70L52 |  |  |  |
| IDT71342S70J |  |  |  |
| IDT71342S70L52B |  |  |  |
|  |  |  |  |
| IDT7140SA35P | CY7C140-35PC |  |  |
| IDT7140SA35C | CY7C140-35DC |  |  |
| IDT7140SA35L48 | CY7C140-35LC |  |  |
| IDT7140SA35L52 | CY7C141-35LC |  |  |
| IDT7140SA35J | CY7C141-35JC |  |  |
| IDT7140SA35F |  |  |  |
| IDT7140SA45P | CY7C140-45PC |  |  |
| IDT7140SA45C | CY7C140-45DC |  |  |
| IDT7140SA45L48 | CY7C140-45LC |  |  |
| IDT7140SA45L. 52 | CY7C141-45LC |  |  |
| IDT7140SA45J | CY7C141-45JC |  |  |
| IDT7140SA45F |  |  |  |
| IDT7140SA45CB | CY7C140-45DMB |  |  |
| IDT7140SA45L48B | CY7C140-45LMB |  |  |
| IDT7140SA45L52B | CY7C141-45LMB |  |  |
| IDT7140SA45FB |  |  |  |
| IDT7140SA55P | CY7C140-55PC | AM2140-55PC |  |
| IDT7140SA55C | CY7C140-55DC | AM2140-55DC |  |
| IDT7140SA55L48 | CY7C140-55LC |  |  |
| IDT7140SA55L52 | CY7C141-55LC | AM2140-55LC |  |
| IDT7140SA55J | CY7C141-55JC | AM2140-55JC |  |
| IDT7140SA55F |  |  |  |
| IDT7140SA55CB | CY7C140-55DMB |  |  |
| IDT7140SA55L48B | CY7C140-55LMB |  |  |
| IDT7140SA55L52B | CY7C141-55LMB |  |  |
| IDT7140SA55FB |  |  |  |
| IDT7140SA70P |  | AM2140-70PC |  |
| IDT7140SA70C |  | AM2140-70DC |  |
| IDT7140SA70L48 |  |  |  |
| IDT7140SA70L52 |  | AM2140-70LC |  |
| IDT7140SA70J |  | AM2140-70JC |  |
| IDT7140SA70F |  |  |  |
| IDT7140SA70CB |  | AM2140-70/BXC |  |
| IDT7140SA70L48B |  |  |  |
| IDT7140SA70L52B |  |  |  |
| IDT7140SA70FB |  |  |  |
| IDT7140SA90P |  |  |  |
| IDT7140SA90C |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7140SA90L48 |  |  |  |
| IDT7140SA90L52 |  |  |  |
| ID77140SA90J |  |  |  |
| IDT7140SA90F |  |  |  |
| IDT7140SA90CB |  |  |  |
| IDT7140SA90L48B |  |  |  |
| IDT7140SA90L.52B |  |  |  |
| IDT7140SA90FB |  |  |  |
| IDT7140SA100P |  | AM2140-10PC |  |
| IDT7140SA100C |  | AM2140-10DC |  |
| IDT7140SA100L48 |  |  |  |
| IDT7140SA100L52 |  | AM2140-10LC |  |
| IDT7140SA100J |  | AM2140-10JC |  |
| IDT7140SA100F |  |  |  |
| IDT7140SA100CB |  | AM2140-10/BXC |  |
| IDT7140SA100L48B |  |  |  |
| IDT7140SA100L52B |  |  |  |
| IDT7140SA100FB |  |  |  |
| IDT7140SA120CB |  | AM2140-12/BXC |  |
| IDT7140SA120L48B |  |  |  |
| IDT7140SA120L52B |  |  |  |
| IDT7140SA120FB |  |  |  |
|  |  |  |  |
| IDT7140LA35P |  |  |  |
| IDT7140LA35C |  |  |  |
| IDT7140LA35L48 |  |  |  |
| IDT7140LA35L52 |  |  |  |
| IDT7140LA35J |  |  |  |
| IDT7140LA35F |  |  |  |
| IDT7140LA45P |  |  |  |
| IDT7140LA45C |  |  |  |
| IDT7140LA45L48 |  |  |  |
| IDT7140LA45L52 |  |  |  |
| IDT7140LA45J |  |  |  |
| IDT7140LA45F |  |  |  |
| IDT7140LA45CB |  |  |  |
| IDT7140LA45L48B |  |  |  |
| IDT7140LA45L52B |  |  |  |
| IDT7140LA45FB |  |  |  |
| IDT7140LA55P |  |  |  |
| IDT7140LA55C |  |  |  |
| IDT7140LA55L48 |  |  |  |
| IDT7140LA55L52 |  |  |  |
| IDT7140LA55J |  |  |  |
| IDT7140LA55F |  |  |  |
| IDT7140LA55CB |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7140LA55L48B |  |  |  |
| IDT7140LA55L52B |  |  |  |
| IDT7140LA55FB |  |  |  |
| IDT7140LA70P |  |  |  |
| IDT7140LA70C |  |  |  |
| IDT7140LA70L48 |  |  |  |
| IDT7140LA70L 52 |  |  |  |
| IDT7140LA70J |  |  |  |
| IDT7140LA70F |  |  |  |
| IDT7140LA70CB |  |  |  |
| IDT7140LA70L48B |  |  |  |
| IDT7140LA70L52B |  |  |  |
| IDT7140LA70FB |  |  |  |
| ID77140LA90P |  |  |  |
| IDT7140LA90C |  |  |  |
| IDT7140LA90L48 |  |  |  |
| IDT7140LA90L52 |  |  |  |
| IDT7140LA90J |  |  |  |
| IDT7140LA90F |  |  |  |
| IDT7140LA90CB |  |  |  |
| IDT7140LA90L48B |  |  |  |
| IDT7140LA90L52B |  |  |  |
| IDT7140LA90FB |  |  |  |
| IDT7140LA100P |  |  |  |
| IDT7140LA100C |  |  |  |
| IDT7140LA100L48 |  |  |  |
| IDT7140LA100L52 |  |  |  |
| IDT7140LA100J |  |  |  |
| IDT7140LA100F |  |  |  |
| IDT7140LA100CB |  |  |  |
| IDT7140LA100L48B |  |  |  |
| IDT7140LA100L52B |  |  |  |
| IDT7140LA100FB |  |  |  |
| IDT7140LA120CB |  |  |  |
| IDT7140LA120L48B |  |  |  |
| IDT7140LA120L52B |  |  |  |
| IDT7140LA120FB |  |  |  |
|  |  |  |  |
| IDT7142SA35P | CY7C142-35PC |  | VT7142-35PC |
| IDT7142SA35C | CY7C142-35DC |  |  |
| IDT7142SA35L48 | CY7C142-35LC |  |  |
| IDT7142SA35L52 |  |  |  |
| IDT7142SA35J |  |  | VT7142-35QC |
| IDT7142SA35F |  |  |  |
| IDT7142SA45P | CY7C142-45PC |  | VT7142-45PC |
| IDT7142SA45C | CY7C142-45DC |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7142SA45L48 | CY7C142-45LC |  |  |
| IDT7142SA45L52 |  |  |  |
| IDT7142SA45J |  |  | VT7142-45QC |
| IDT7142SA45F |  |  |  |
| IDT7142SA45CB | CY7C142-45DMB |  |  |
| IDT7142SA45L48B | CY7C142-45LMB |  |  |
| IDT7142SA45L52B |  |  |  |
| IDT7142SA45FB |  |  |  |
| IDT7142SA55P | CY7C142-55PC |  | VT7142-55PC |
| IDT7142SA55C | CY7C142-55DC |  |  |
| IDT7142SA55L48 | CY7C142-55LC |  |  |
| IDT7142SA55L52 |  |  |  |
| IDT7142SA55J |  |  | VT7142-55QC |
| IDT7142SA55F |  |  |  |
| IDT7142SA55CB | CY7C142-55DMB |  |  |
| IDT7142SA55L48B | CY7C142-55LMB |  |  |
| IDT7142SA55L52B |  |  |  |
| IDT7142SA55FB |  |  |  |
| IDT7142SA70P |  |  | VT7142-70PC |
| IDT7142SA70C |  |  |  |
| IDT7142SA70L48 |  |  |  |
| IDT7142SA70L52 |  |  |  |
| IDT7142SA70J |  |  | VT7142-70QC |
| IDT7142SA70F |  |  |  |
| IDT7142SA70CB |  |  |  |
| IDT7142SA70L48B |  |  |  |
| IDT7142SA70L52B |  |  |  |
| IDT7142SA70FB |  |  |  |
| IDT7142SA90P |  |  | VT7142-90PC |
| IDT7142SA90C |  |  |  |
| IDT7142SA90L48 |  |  |  |
| IDT7142SA90L52 |  |  |  |
| IDT7142SA90J |  |  | VT7142-90QC |
| IDT7142SA90F |  |  |  |
| IDT7142SA90CB |  |  |  |
| IDT7142SA90L48B |  |  |  |
| IDT7142SA90L52B |  |  |  |
| IDT7142SA90FB |  |  |  |
| IDT7142SA100P |  |  |  |
| IDT7142SA100C |  |  |  |
| IDT7142SA100L48 |  |  |  |
| IDT7142SA100L52 |  |  |  |
| IDT7142SA100J |  |  |  |
| IDT7142SA100F |  |  |  |
| IDT7142SA100CB |  |  |  |
| IDT7142SA100L48B |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7142SA100L52B |  |  |  |
| IDT7142SA100FB |  |  |  |
| IDT7142SA120CB |  |  |  |
| IDT7142SA120L48B |  |  |  |
| IDT7142SA120L52B |  |  |  |
| IDT7142SA120FB |  |  |  |
|  |  |  |  |
| IDT7142LA35P |  |  |  |
| IDT7142LA35C |  |  |  |
| IDT7142LA35L48 |  |  | . |
| IDT7142LA35L52 |  |  |  |
| IDT7142LA35J |  |  |  |
| IDT7142LA35F |  |  |  |
| IDT7142LA45P |  |  |  |
| IDT7142LA45C |  |  |  |
| IDT7142LA45L48 |  |  |  |
| IDT7142LA45L52 |  |  |  |
| IDT7142LA45J |  |  |  |
| IDT7142LA45F |  |  |  |
| IDT7142LA45CB |  |  |  |
| IDT7142LA45L48B |  |  |  |
| IDT7142LA45L52B |  |  |  |
| IDT7142LA45FB |  |  |  |
| IDT7142LA55P |  |  |  |
| IDT7142LA55C |  |  |  |
| IDT7142LA55L48 |  |  |  |
| IDT7142LA55L52 |  |  |  |
| IDT7142LA55J |  |  |  |
| IDT7142LA55F |  |  |  |
| IDT7142LA55CB |  |  |  |
| IDT7142LA55L48B |  |  |  |
| IDT7142LA55L52B |  |  |  |
| IDT7142LA55FB |  |  |  |
| IDT7142LA70P |  |  |  |
| IDT7142LA70C |  |  |  |
| IDT7142LA70L48 |  |  |  |
| IDT7142LA70L52 |  |  |  |
| IDT7142LA70J |  |  |  |
| IDT7142LA70F |  |  |  |
| IDT7142LA70CB |  |  |  |
| IDT7142LA70L48B |  |  |  |
| IDT7142LA70L52B |  |  |  |
| IDT7142LA70FB |  |  |  |
| IDT7142LA90P |  |  |  |
| IDT7142LA90C |  |  |  |
| IDT7142LA90L48 |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7142LA90L52 |  |  |  |
| IDT7142LA9OJ |  |  |  |
| IDT7142LA90F |  |  |  |
| IDT7142LA90CB |  |  |  |
| IDT7142LA90L48B |  |  |  |
| IDT7142LA90L52B |  |  |  |
| IDT7142LA90FB |  |  |  |
| IDT7142LA100P |  |  |  |
| IDT7142LA100C |  |  |  |
| IDT7142LA100L48 |  |  |  |
| IDT7142LA100L52 |  |  |  |
| IDT7142LA100J |  |  |  |
| IDT7142LA100F |  |  |  |
| IDT7142LA100CB |  |  |  |
| IDT7142LA100L48B |  |  |  |
| IDT7142LA100L52B |  |  |  |
| IDT7142LA100FB |  |  |  |
| IDT7142LA120CB |  |  |  |
| IDT7142LA120L48B |  |  |  |
| IDT7142LA120L52B |  |  |  |
| IDT7142LA120FB |  |  |  |
|  |  |  |  |
| IDT71421SA35J | CY7C146-35JC |  | VT71421-35QC |
| IDT71421SA35L52 | CY7C146-35LC |  |  |
| IDT71421SA45J | CY7C146-45JC |  | VT71421-45QC |
| IDT71421SA45L52 | CY7C146-45LC |  |  |
| IDT71421SA45L52B | CY7C146-45LMB |  |  |
| IDT71421SA55J | CY7C146-55JC |  |  |
| IDT71421SA55L52 | CY7C146-55LC |  |  |
| IDT71421SA55L52B | CY7C146-55LMB |  |  |
| IDT71421SA70L52B |  |  |  |
|  |  |  |  |
| IDT71421LA35J |  |  |  |
| IDT71421LA35L52 |  |  |  |
| IDT71421LA45J |  |  |  |
| IDT71421LA45L52 |  |  |  |
| IDT71421LA45L52B |  |  |  |
| IDT71421LA55J |  |  |  |
| IDT71421LA55L52 |  |  |  |
| IDT71421LA55L52B |  |  |  |
| IDT71421LA70L52B |  |  |  |
|  |  |  |  |
| IDT7134S35P |  |  |  |
| IDT7134S35C |  |  |  |
| IDT7134S35J |  |  |  |
| IDT7134S35L52 |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7134S45P |  |  |  |
| IDT7134S45C |  |  |  |
| IDT7134S45J |  |  |  |
| IDT7134S45L52 |  |  |  |
| IDT7134S45CB |  |  |  |
| IDT7134S45L52B |  |  |  |
| IDT7134S55P |  |  |  |
| IDT7134S55C |  |  |  |
| IDT7134S55J |  |  |  |
| IDT7134S55L52 |  |  |  |
| IDT7134S55CB |  |  |  |
| IDT7134S55L52B |  |  |  |
| IDT7134S70P |  |  |  |
| IDT7134S70C |  |  |  |
| IDT7134S70, |  |  |  |
| IDT7134S70L52 |  |  |  |
| ID77134S70CB |  |  |  |
| IDT7134S70L52B |  |  |  |
|  |  |  |  |
| IDT7134L35P |  |  |  |
| IDT7134L35C |  |  |  |
| IDT7134L35J |  |  |  |
| IDT7134L35L52 |  |  |  |
| IDT7134L45P |  |  |  |
| IDT7134L45C |  |  |  |
| IDT7134L45J |  |  |  |
| IDT7134L45L52 |  |  |  |
| IDT7134L45CB |  |  |  |
| IDT7134L45L52B |  |  |  |
| IDT7134L55P |  |  |  |
| IDT7134L55C |  |  |  |
| IDT7134L55J |  |  |  |
| IDT7134L55L52 |  |  |  |
| IDT7134L55CB |  |  |  |
| IDT7134L55L52B |  |  |  |
| IDT7134L70P |  |  |  |
| IDT7134L70C |  |  |  |
| IDT7134L70J |  |  |  |
| IDT7134L70L52 |  |  |  |
| IDT7134L70CB |  |  |  |
| IDT7134L70L52B |  |  |  |
|  |  |  | . |
| IDT7143S45XC |  |  |  |
| IDT7143S45J |  |  |  |
| IDT7143S45L68 |  |  |  |
| IDT7143S45G |  |  |  |


| IDT | CYPRESS | AMD | VLSI |
| :---: | :---: | :---: | :---: |
| IDT7143S55XC |  |  |  |
| IDT7143S55J |  |  |  |
| IDT7143S55L68 |  |  |  |
| IDT7143S55G |  |  |  |
| IDT7143S55L.68B |  |  |  |
| IDT7143S55GB |  |  |  |
| IDT7143S70XC |  |  |  |
| IDT7143S70 |  |  |  |
| IDT7143S70L68 |  |  |  |
| IDT7143S70G |  |  |  |
| IDT7143S70XCB |  |  |  |
| IDT7143S70L68B |  |  |  |
| IDT7143S70GB |  |  |  |
| IDT7143S90XC |  |  |  |
| IDT7143S90 |  |  |  |
| IDT7143S90L68 |  |  |  |
| IDT7143S90G |  |  |  |
| IDT7143S90XCB |  |  |  |
| IDT7143S90L68B |  |  |  |
| IDT7143S90GB |  |  |  |
|  |  |  |  |
| IDT7143L45XC |  |  |  |
| IDT7143L45J |  |  |  |
| IDT7143L45L68 |  |  |  |
| IDT7143L45G |  |  |  |
| IDT7143L55XC |  |  |  |
| IDT7143L55J |  |  |  |
| IDT7143L55L68 |  |  |  |
| IDT7143L55G |  |  |  |
| IDT7143L55L68B |  |  |  |
| IDT7143L55GB |  |  |  |
| IDT7143L70XC |  |  |  |
| IDT7143L70, |  |  |  |
| IDT7143L70L68 |  |  |  |
| IDT7143L70G |  |  |  |
| IDT7143L70XCB |  |  |  |
| IDT7143L70L68B |  |  |  |
| IDT7143L70GB |  |  |  |
| IDT7143L90XC |  |  |  |
| IDT7143L90J |  |  |  |
| IDT7143L90L68 |  |  |  |
| IDT7143L90G |  |  |  |
| IDT7143L90XCB |  |  |  |
| IDT7143L90L68B |  |  |  |
| IDT7143L90GB |  |  |  |

SMP CROSS REFERENCE GUIDE

| IDT | CYPRESS | AMD | VLSI |
| :--- | :--- | :--- | :--- |
| IDT71342L35L52 |  |  |  |
| IDT71342L35J |  |  |  |
| IDT71342L45L52 |  |  |  |
| IDT71342L45J |  |  |  |
| IDT71342L45L52B |  |  |  |
| IDT71342L55L52 |  |  |  |
| IDT71342L55J |  |  |  |
| IDT71342L55L52B |  |  |  |
| IDT71342L70L52 |  |  |  |
| IDT71342L70J |  |  |  |
| IDT71342L70L52B |  |  |  |



| CYPRESS/MULTICHIP P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | CYPRESS/MULTICHIP ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| CYM1240HD-35MB CYM1240HD-45MB | $\begin{aligned} & \text { 7M4042S35CB } \\ & 7 \mathrm{M} 4042 \mathrm{~S} 45 \mathrm{CB} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 1 \text { MEG (256K X 4) JEDEC } \\ & 28 \text { PIN DIP } \end{aligned}$ |
| CYM1420HD-30C CYM1420HD-35C <br> CYM1420HD-45C <br> CYM1420HD-55C <br> CYM1420HD-70C | 8M824S30C <br> 8M824S35C <br> 8M824S35N <br> 8M824S45C <br> 8M824S45N <br> 8M824S50C <br> 8M824S50N <br> 8M824S70C <br> 8M824S70N |  | 1 MEG ( 128 KX 8 ) JEDEC 32 PIN DIP |
| CYM1421HD-70MB CYM1421HD-85MB CYM1421HD-100MB | 8M824S70CB 8M824S85CB 8M824S100CB |  | 1 MEG (128K X 8) JEDEC 32 PIN DIP <br> [Low power version] |
| CYM1422PS-35C CYM1422PS-45C CYM1422PS-55C | $\begin{aligned} & \text { 8MP824S35S } \\ & \text { 8MP824S45S } \\ & \text { 8MP824S55S } \end{aligned}$ |  | 1 MEG (128K X 8) 30 PIN SIP |
| CYM1441PZ-25C CYM1441PZ-35C CYM1441PZ-45C |  | $\begin{aligned} & \text { 7MP4034S25Z } \\ & \text { 7MP4034S35Z } \\ & \text { 7MP4034S45Z } \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \text { MEG ( } 256 \mathrm{~K} \times 8 \text { ) JEDEC } \\ & 60 \text { PIN ZIP } \end{aligned}$ |
| CYM1460PS-45C CYM1460PS-55C CYM1460PS-70C | 7MP4008S45S 7MP4008S55S 7MP4008S70S |  | $\begin{aligned} & 4 \text { MEG ( } 512 \mathrm{~K} \times 8 \text { ) } \\ & 36 \text { PIN SIP } \end{aligned}$ |
| CYM1461PS-70C CYM1461PS-85C CYM1461PS-100C | $\begin{aligned} & \text { 7MP4008L70S } \\ & \text { 7MP4008L85S } \\ & \text { 7MP4008L100S } \end{aligned}$ | $\begin{aligned} & \text { 7MP4058L70S } \\ & \text { 7MP4058L85S } \\ & \text { 7MP4058L100S } \end{aligned}$ | $4 \text { MEG (512K } \times 8)$ 36 PIN SIP |
| CYM1464PD-45C CYM1464PD-55C CYM1464PD-70C | 7MB4048S45P 7MB4048S50P 7M4048L70N |  | 4 MEG (512K X 8) JEDEC 32 PIN DIP |
| CYM1540PS-30C CYM1540PS-35C CYM1540PS-45C |  | 7MB4040S25P 7MB4040S35P 7MB4040S45P | $\begin{aligned} & 2 \text { MEG (256K X 9) } \\ & 44 \text { PIN SIP } \end{aligned}$ |
| CYM1541PD-25C CYM1541PD-35C CYM1541PD-45C | 7MB4040S25P 7MB4040S35P 7MB4040S45P |  | $\begin{aligned} & 2 \text { MEG ( } 256 \mathrm{~K} \times 9 \text { ) } \\ & 44 \text { PIN DIP } \end{aligned}$ |
| CYM1610HD-25C CYM1610HD-35C CYM1610HD-45C CYM1610HD-50C | $\begin{aligned} & 8 \mathrm{M} 656 \mathrm{~S} 40 \mathrm{C} \\ & 8 \mathrm{M} 656 \mathrm{~S} 50 \mathrm{C} \end{aligned}$ | $\begin{aligned} & \text { 8M656S40C } \\ & 8 \mathrm{M} 656 \mathrm{~S} 40 \mathrm{C} \end{aligned}$ | $\begin{aligned} & 256 \mathrm{~K}(16 \mathrm{~K} \times 16) \\ & 40 \text { PIN DIP } \end{aligned}$ |
| CYM1611HV-20C CYM1611HV-25C CYM1611HV-30C CYM1611HV-35C CYM1611HV-45C | 7MC4005S20CV <br> 7MC4005S25CV <br> 7MC4005S30CV <br> 7MC4005S35CV <br> 7MC4005S45CV |  | $\begin{aligned} & 256 \mathrm{~K}(16 \mathrm{~K} \times 16) \\ & 36 \text { PIN DSIP } \end{aligned}$ |
| CYM1620HD-30C <br> CYM1620HD-35C <br> CYM1620HD-45C <br> CYM1620HD-55C | $\begin{aligned} & \text { 8M624S30C } \\ & \text { 8M624S35C } \\ & \text { 8M624S45C } \\ & 8 \mathrm{M} 624 \mathrm{~S} 50 \mathrm{C} \end{aligned}$ |  | 1 MEG (64K X 16) JEDEC 40 PIN DIP |


| CYPRESS/MULTICHIP P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | CYPRESS/MULTICHIP ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| CYM1621HD-25C CYM1621HD-30C CYM1621HD-35C CYM1621HD-45C | $\begin{aligned} & \text { 7M624SS25C } \\ & 7 \mathrm{M} 624 \mathrm{~S} 30 \mathrm{C} \\ & 7 \mathrm{M} 624 \mathrm{S35C} \\ & 7 \mathrm{M} 624 \mathrm{~S} 45 \mathrm{C} \\ & \hline \end{aligned}$ |  | 1 MEG ( $64 \mathrm{~K} \times 16$ ), (128K X 8), (256K X 4) 40 PIN DIP |
| CYM1622HV-25C CYM1622HV-35C CYM1622HV-45C |  | 7MP4028 7MP4028 7MP4028 | 1 MEG (64K X 16) 40 PIN DSIP |
| CYM1623HD-70MB CYM1623HD-85MB CYM1623HD-100MB | 8M624S70CB 8M624S85CB 8M624S100CB |  | 1 MEG (64K X 16) JEDEC 40 PIN DIP [low power version] |
| CYM1624PV-25C CYM1624PV-35C CYM1624PV-45C | 7 MP 4028 S 25 V 7MP4028S35V $7 \mathrm{MP4028S45V}$ |  | 1 MEG (64K X 16) 40 PIN DSIP |
| CYM1626PS-30C CYM1626PS-35C CYM1626PS-45C | 8MP624S30S 8MP624S35S 8MP624S45S |  | 1 MEG ( $64 \mathrm{~K} \times 16$ ) 40 PIN SIP |
| CYM1641HD-25C CYM1641HD-35C CYM1641HD-45C CYM1641HD-55C | 7M4016S25C 7M4016S35C 7M4016S45C 7M4016S55C |  | 4 MEG (256K X 16) 48 PIN DIP |
| CYM1821PZ-15C <br> CYM1821PZ-20C <br> CYM1821PZ-25C <br> CYM1821PZ-35C <br> CYM1821PZ-45C | 7MP4031S15Z <br> 7MP4031S20Z <br> 7MP4031S25Z <br> 7MP4031S35Z <br> 7MP4031S35Z |  | 512K (16K X 32) JEDEC 64 FR-4 ZIP |
| CYM1822HV-20C CYM1822HV-25C CYM1822HV-30C CYM1822HV-35C CYM1822HV-45C | 7MC4032S20CV <br> 7MC4032S25CV <br> 7MC4032S30CV <br> 7MC4032S35CV <br> 7MC4032S45CV |  | 512K (16K X 32) 88 PIN DSIP |
| CYM1830HD-25C CYM1830HD-30C CYM1830HD-35C CYM1830HD-45C CYM1830HD-55C | 7M4017S25C 7M4017S30C 7M4017S35C 7M4017S45C 7M4017S50C |  | $\begin{aligned} & 2 \text { MEG (64K X 32) } \\ & 60 \text { PIN DIP } \end{aligned}$ |
| CYM1831PZ-25C CYM1831PZ-30C CYM1831PZ-35C CYM1831PZ-45C | $\begin{aligned} & \hline \text { 7MP4036S25Z } \\ & \text { 7MP4036S30Z } \\ & \text { 7MP4036535Z } \\ & \text { 7MP4036S35Z } \\ & \hline \end{aligned}$ |  | 2 MEG (64K X 32) JEDEC 64 PIN ZIP |
| CYM1831PM-25C CYM1831PM-30C CYM1831PM-35C CYM1831PM-45C | 7MP4036S25M 7MP4036S30M 7MP4036S35M 7MP4036S35M |  | 2 MEG (64K X 32) JEDEC 64 PIN SIMM |
| CYM1832PZ-25C CYM1832PZ-35C CYM1832PZ-45C CYM1832PZ-55C |  | $\begin{aligned} & \hline \text { 7MP4036S25Z } \\ & \text { 7MP4036S35Z } \\ & \text { 7MP4036S35Z } \\ & \text { 7MP4036S35Z } \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \text { MEG (64K } \times 32 \text { ) } \\ & 60 \text { PIN ZIP } \end{aligned}$ |
| CYM1840HD-30C CYM1840HD-35C CYM1840HD-45C CYM1840HD-55C | 7M4067S30C 7M4067S35C 7M4067S45C 7M4067S55C |  | 8 MEG (256K X 32) 60 PIN DIP |
| CYM1841PZ-30C CYM1841PZ-35C CYM1841PZ-45C CYM1841PZ-55C | 7MP4045S30Z 7MP4045S35Z 7MP4045S45Z 7MP4045S55Z |  | 8 MEG (256K X 32) JEDEC 64 PIN ZIP |

SSD CROSS REFERENCE GUIDE

| CYPRESS/MULTICHIP P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | CYPRESS/MULTICHIP ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| CYM1841PM-30C CYM1841PM-35C CYM1841PM-45C CYM1841PM-55C | 7MP4045S30M <br> 7MP4045S35M <br> 7MP4045S45M <br> 7MP4045S55M |  | 8 MEG (256K X 32) JEDEC <br> 64 PIN SIMM |
| DENSE-PAC P/N | $\begin{gathered} \text { IDT P/N } \\ \text { DIRECT } \\ \text { EQUIVALENT } \end{gathered}$ | IDT P/N SIMILAR PART | DENSE-PAC ORG/PACKAGE |
| DPS16X5-XXX | 7MP564 <br> 7MP564 |  | $80 \mathrm{~K}(16 \mathrm{~K} \times 5)$ $28 \text { PIN SIP }$ |
| DPS16X17-25 <br> DPS16X17-35 <br> DPS16X17-45 <br> DPS16X17-55 | $\begin{aligned} & 7 \mathrm{MC} 4005 \mathrm{~S} 25 \mathrm{CV} \\ & 7 \mathrm{MC} 4005 \mathrm{~S} 35 \mathrm{CV} \\ & 7 \mathrm{MC} 4005 \mathrm{~S} 45 \mathrm{CV} \\ & 7 \mathrm{MC} 4005 \mathrm{~S} 55 \mathrm{CV} \end{aligned}$ |  | $\begin{aligned} & 256 \mathrm{~K}(16 \mathrm{~K} \mathrm{X} \mathrm{16)} \\ & 36 \mathrm{PIN} \text { DSIP } \end{aligned}$ |
| DPS257-XXX | 7M656 <br> 7M656 <br> 7M656 <br> 7M656 |  | $\begin{gathered} 256 \mathrm{~K}(16 K \times 16) \\ (32 K \times 8) \\ (64 K \times 4) \end{gathered}$ $40 \text { PIN DIP }$ |
| DPS1024-25C <br> DPS1024-35C <br> DPS1024-45C <br> DPS1024-55C |  | $\begin{aligned} & \text { 7M624 } \\ & \text { 7M624 } \\ & \text { 7M624 } \\ & \text { 7M624 } \end{aligned}$ | $\begin{aligned} & 1 \text { MEG (256K X 4), } \\ & \text { (128K X 8)., (64K X 16) } \\ & 42 \text { PIN DIP } \end{aligned}$ |
| DPS1026-25C <br> DPS1026-35C <br> DPS1026-45C <br> DPS1026-55C |  | 7M624 <br> 7M624 <br> 7M624 <br> 7M624 | $\begin{aligned} & 1 \text { MEG (256K X 4), } \\ & \text { (128K X 8), ( } 64 \mathrm{~K} \times 16 \text { ) } \\ & 40 \text { PIN DIP } \end{aligned}$ |
| DPS1027-25C <br> DPS1027-35C <br> DPS1027-45C <br> DPS1027-55C | $\begin{aligned} & \text { 7M624S25C } \\ & \text { 7M624S35C } \\ & \text { 7M624S45C } \\ & 7 \mathrm{M} 624 \mathrm{~S} 55 \mathrm{C} \end{aligned}$ |  | $\begin{aligned} & 1 \text { MEG (256K X 4), } \\ & \text { (128K X 8), (64K X 16) } \\ & 40 \text { PIN DIP } \end{aligned}$ |
| DPS2516-25C <br> DPS2516-35C <br> DPS2516-45C <br> DPS2516-55C |  | 7M4016 <br> 7M4016 <br> 7M4016 <br> 7M4016 | $\begin{aligned} & 4 \text { MEG ( } 256 \mathrm{~K} \times 16 \text { ) } \\ & 44 \text { PIN DIP } \end{aligned}$ |
| $\begin{aligned} & \text { DPS4648-85C } \\ & \text { DPS4648-100C } \\ & \text { DPS4648-120C } \\ & \text { DPS4648-150C } \\ & \hline \end{aligned}$ |  | 7M812 <br> 7M812 <br> 7M812 <br> 7M812 | $512 \mathrm{~K}(64 \mathrm{~K} \times 8)$ <br> 32 PIN DIP |
| DPS5124-45C DPS5124-55C |  | $\begin{aligned} & \text { 7MP4034 } \\ & \text { 7MP4034 } \end{aligned}$ | $\begin{aligned} & 2 \text { MEG (512K X4), } \\ & \text { (256K X 8) } \\ & 54 \text { PIN DIP } \end{aligned}$ |
| DPS6432-35C <br> DPS6432-45C <br> DPS6432-55C <br> DPS6432-70C | 7M4017S35C <br> 7M4017S45C <br> 7M4017S55C <br> 7M4017S70C |  | $2 \text { MEG ( } 64 K \times 32)$ 60 PIN DIP |
| $\begin{aligned} & \text { DPS6433-85C } \\ & \text { DPS6433-100C } \\ & \text { DPS6433-120C } \\ & \text { DPS6433-150C } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { 7MP4034, 7M4017 } \\ & \text { 7MP4034, 7M4017 } \\ & \text { 7MP4034, 7M4017 } \\ & \text { 7MP4034, 7M4017 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \text { MEG (64K X 32) } \\ & \text { (128K X 16), ( } 256 \mathrm{~K} \times 8 \text { ) } \\ & 60 \text { PIN DIP } \\ & \text { [low power version] } \end{aligned}$ |
| DPS6433-55C DPS6433-70C DPS6433-100C |  | 7M4017S55C 7M4017S70C 7M4017S70C | 2 MEG ( $64 \mathrm{~K} \times 32$ ) 60 PIN DIP [low power version] |
| DPS8645-XXX | $\begin{aligned} & \text { 7MP456 } \\ & \text { 7MP456 } \end{aligned}$ |  | $\begin{aligned} & 256 \mathrm{~K}(64 \mathrm{~K} \times 4) \\ & 28 \text { PIN SIP } \end{aligned}$ |
| DPS8808-XXX | 7M864 <br> 7M864 |  | 64K ( 8 KX X) 28 PIN DIP |


| DENSE-PAC P/N | $\begin{aligned} & \text { IDT P/N } \\ & \text { DIRECT } \\ & \text { EQUIVALENT } \end{aligned}$ | IDT P/N SIMILAR PART | DENSE-PAC ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| DPS8M612-85C <br> DPS8M612-100C <br> DPS8M612-120C <br> DPS8M612-150C | 8M612S85C <br> 8M612S100C <br> 8M612S100C <br> 8M612S100C |  | $\begin{aligned} & 512 \mathrm{~K}(32 \mathrm{~K} \times 16) \\ & 40 \text { PIN DIP } \end{aligned}$ |
| DPS8M624-85C <br> DPS8M624-100C <br> DPS8M624-120C <br> DPS8M624-150C | 8M624S85C <br> 8M624S100C <br> 8M624S100C <br> 8M624S100C |  | $1 \text { MEG (64K X 16) }$ 40 PIN DIP |
| DPS8M656-35C DPS8M656-40C DPS8M656-70C | 8M656S40C 8M656S70C | 8M656S40C | $\begin{aligned} & 256 \mathrm{~K}(16 \mathrm{~K} \times 16) \\ & 40 \text { PIN DIP } \end{aligned}$ |
| DPS10241-25C <br> DPS10241-35C <br> DPS10241-45C <br> DPS10241-55C | 7MC4001S35CS 7MC4001S45CS 7MC4001S55CS | 7MC4001S35C | $\begin{aligned} & 1 \text { MEG ( } 1024 \mathrm{~K} \times 1) \\ & 30 \text { PIN SIP } \end{aligned}$ |
| DPS40256-XXX | 8M856 <br> 8M856 |  | $\begin{aligned} & 256 \mathrm{~K}(32 \mathrm{~K} \times 8) \\ & 28 \mathrm{PIN} \text { DIP } \end{aligned}$ |
| DPS41257-XXX | $\begin{aligned} & 8 M 856 \\ & 8 M 856 \end{aligned}$ |  | $\begin{aligned} & 256 \mathrm{~K}(32 \mathrm{~K} \mathrm{X} 8) \\ & 28 \text { PIN DIP } \end{aligned}$ |
| $\begin{aligned} & \text { DPS41288-70C } \\ & \text { DPS } 41288-85 \mathrm{C} \\ & \text { DPS41288-100C } \\ & \hline \end{aligned}$ | 8M824S70C | $\begin{aligned} & \text { 8M824L70N } \\ & \text { 8M824L85N } \\ & 8 \mathrm{M} 824 \mathrm{~L} 100 \mathrm{~N} \end{aligned}$ | 1 MEG (128K X 8) 32 PIN DIP |
| DPS45128-85C <br> DPS45128-100C <br> DPS45128-120C <br> DPS45128-150C |  | 7MP4008 <br> 7MP4008 <br> 7MP4008 <br> 7MP4008 | $4 \text { MEG (512K } \times 8)$ $48 \text { PIN DIP }$ |
| DPS45129-85C <br> DPS45129-100C <br> DPS45129-120C <br> DPS45129-150C | 7M4016S55C <br> 7M4016S55C <br> 7M4016S55C <br> 7M4016S55C |  | $4 \text { MEG (256K X 16) }$ $48 \text { PIN DIP }$ |
| $\begin{aligned} & \text { DPS512S8-85C } \\ & \text { DPS512S8-100C } \\ & \text { DPS512S8-120C } \\ & \text { DPS512S8-150C } \end{aligned}$ | $\begin{aligned} & \text { 7M4048L85N } \\ & \text { 7M4048L100N } \\ & \text { 7M4048L120N } \\ & \text { 7M4048L120N } \end{aligned}$ |  | $4 \text { MEG (512K X 8) }$ <br> 32 PIN DIP |
| DPS3232V | 7M4003SXXCH |  | $1 \text { MEG (32K X 32) }$ 66 PIN HIP |
| DPE3232V | 7M7004SXXCH |  | 1 MEG (32K X 32) EEPROM 66 PIN HIP |
| EDI P/N | $\begin{gathered} \text { IDT P/N } \\ \text { DIRECT } \\ \text { EQUIVALENT } \end{gathered}$ | IDT P/N SIMILAR PART | $\begin{gathered} \text { EDI } \\ \text { ORG/PACKAGE } \end{gathered}$ |
| EDI8M4257C35C4B EDI8M4257C45C4B EDI8M4257C55C4B | 7M4042S35CB 7M4042S45CB 7M4042S55CB |  | 1 MEG (256K X 4) JEDEC 28 PIN DIP |
| EDI8M8128C35C6C EDI8M8128C45C6C EDI8M8128C55C6C EDI8M8128C45C6B EDI8M8128C55C6B EDI8M8128C70C6B | 8M824S35C <br> 8M824S45C <br> 8M824S50C <br> 8M824S45CB <br> 8M824S50CB <br> 8M824S70CB | 8M824S35N, 8MP824S35S 8M824S45N, 8MP824S45S 8M824S50N, 8MP824S50S | $1 \text { MEG }(128 \mathrm{~K} \times 8) \text { JEDEC }$ 32 PIN DIP |
| EDI8M8128C60P6C EDI8M8128C70P6C EDI8M8128C100P6C EDI8M8128C120P6C EDI8M8128C150P6C | 8M824S60N <br> 8M824L70N <br> 8M824L100N <br> 8M824L100N <br> 8M824L100N | 8M824S60C, 8MP824S60S 8M824S70C, 8MP824L70S 8MP824L100S 8MP824L100S 8MP824L100S | $1 \text { MEG (128K X 8) JEDEC }$ 32 PIN DIP |


| EDI P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | $\begin{gathered} \text { EDI } \\ \text { ORG/PACKAGE } \end{gathered}$ |
| :---: | :---: | :---: | :---: |
| EDI8M8128C85C6B EDI8M8128C1006CB EDI8M8128C1206CB <br> EDI8M8128C1506C | 8M824S85CB 8M824S100CB 8M824S100CB 8M824S100CB |  | 1 MEG (128K X 8) JEDEC 32 PIN DIP [low power version] |
| EDI8M8256C70P6C <br> EDI8M8256C85P6C <br> EDI8M8256C100P6C <br> EDI8M8256C120P6C <br> EDI8M8256C150P6C | 7M4068L70N <br> 7 M 4068 L 85 N <br> 7M4068L100N <br> 7M4068L120N <br> 7M4068L120N |  | 2 MEG (256K X 8) JEDEC 32 PIN DIP |
| EDI8F8257C85B6C EDI8F8257C100B6C EDI8F8257C120B6C EDI8F8257C150B6C | 7M4068L85N 7M4068L100N 7M4068L120N 7M4068L120N |  | 2 MEG (256K X 8) JEDEC 32 PIN DIP |
| EDI8M8257C85P6C EDI8M8257C100P6C EDI8M8257C120P6C <br> ED18M8257C150P6C | 7M4068L85N 7M4068L100N 7M4068L120N 7M4068L120N |  | $\begin{aligned} & 2 \text { MEG (256K X 8) JEDEC } \\ & 32 \text { PIN DIP } \end{aligned}$ |
| EDI8F8257C45MSC <br> EDI8F8257C55MSC <br> EDI8F8257C70MSC |  | 7MP4034S45Z <br> 7MP4034S45Z <br> 7MP4034S45Z | 2 MEG (256K X 8) 36 PIN SIP |
| EDI8F8258C45MSC EDI8F8258C55MSC EDI8F8258C70MSC |  | 7MP4034S45Z <br> 7MP4034S45Z <br> 7MP4034S45Z | 2 MEG (256K X 8) 36 PIN SIP |
| EDI8M8512C85P6C EDI8M8512C100P6C EDI8M8512C120P6C EDI8M8512C150P6C EDI8M8512C85C6B EDI8M8512C100C6B EDI8M8512C120C6B EDI8M8512C150C6B | 7M4048L85N <br> 7M4048L100N <br> 7M4048L120N <br> 7M4048L120N <br> 7M4048S85CB <br> 7M4048S100CB <br> 7M4048S120CB <br> 7M4048S120CB |  | 4 MEG (512K X 8) JEDEC 32 PIN DIP |
| EDI8F8512C45M6C EDI8F8512C55M6C EDI8F8512C70M6C EDI8M8512C45M6B EDI8M8512C55M6B EDI8M8512C70M6B | 7MB4048S45P <br> 7MB4048S55P <br> 7M4048L70N <br> 7M4048S45CB <br> 7M4048S55CB <br> 7 M 4048 S 70 CB |  | 4 MEG (512K X 8) JEDEC 32 PIN DIP |
| EDH816H16C-25CC-Z <br> EDH816H16C-35CC-Z <br> EDH816H16C-45CC-Z <br> EDH816H16C-25CMHR-Z <br> EDH816H16C-35CMHR-Z <br> EDH816H16C-45CMHR-Z | 7MC4005S25CV $7 \mathrm{MC4005S35CV}$ 7 MC 4005 S 45 CV 7MC4005S25CVB 7MC4005S35CVB 7MC4005S45CVB |  | 256K (16K X 16) $36 \text { PIN DSIP }$ |
| EDI8F1664C100PC EDI8F1664C120PC EDI8F1664C150PC | 8M624S70C 8M624S70C 8M624S70C | 8MP624L100S 8MP624L100S 8MP624L100S | 1 MEG ( $64 \mathrm{~K} \times 16$ ) 40 PIN DIP |
| EDI8M1664C45C6C <br> EDI8M1664C55C6C <br> EDI8M1664C60C6C <br> EDI8M1664C70C6C <br> EDI8M1664C85C6C <br> EDI8M1664C100C6C <br> EDI8M1664C55C6B <br> EDI8M1664C60C6B <br> EDI8M1664C70C6B <br> EDI8M1664C85C6B <br> EDI8M1664C100C6B | 8M624S50C 8M624S50C 8M624S60C 8M624S70C 8M624S850C 8M624S100C 8M624S50CB 8M624S60CB 8M624S70CB 8M624S85CB 8M624S100CB |  | 1 MEG ( $64 \mathrm{~K} \times 16$ ) JEDEC 40 PIN DIP |

SSD CROSS REFERENCE GUIDE

|  | $\begin{array}{c}\text { IDT P/N } \\ \text { DIRECT }\end{array}$ |  | $\begin{array}{c}\text { IDT P/N } \\ \text { SIMILAR } \\ \text { EDI P/N }\end{array}$ |
| :--- | :--- | :--- | :--- |
| EQUIVALENT |  |  |  |$]$

SSD CROSS REFERENCE GUIDE

| EDI P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | $\begin{gathered} \text { EDI } \\ \text { ORG/PACKAGE } \end{gathered}$ |
| :---: | :---: | :---: | :---: |
| EDI8M8130P90CB EDI8M8130P100CB EDI8M8130P120CB EDI8M8130P150CB |  | 8M824 <br> 8M824 <br> 8M824 <br> 8M824 | $\begin{aligned} & 1 \text { MEG (128K X 8) } \\ & 32 \text { PIN DIP } \\ & \text { [dual chip enable] } \\ & \text { [low power version] } \end{aligned}$ |
| EDI8M864C50CC EDI8M864C60CC EDI8M864C70CC EDI8M864C80CC EDI8M864C90CC EDI8M864C100CC EDI8M864C120CC EDI8M864C150CC EDI8M864C50CB EDI8M864C60CB EDI8M864C70CB EDI8M864C80CB EDI8M864C90CB EDI8M864C100CB EDI8M864C120CB EDI8M864C150CB |  | 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 <br> 7M812 | $512 \mathrm{~K}(64 \mathrm{~K} \times 8)$ <br> 32 PIN DIP |
| $\begin{aligned} & \text { EDH81H256C-55 } \\ & \text { EDH81H256C-70 } \end{aligned}$ | 7MC156S55CS 7MC156S70CS | 7MP156 | $\begin{aligned} & 256 \mathrm{~K}(256 \mathrm{~K} \times 1) \\ & 28 \mathrm{PIN} \mathrm{SIP} \\ & \hline \end{aligned}$ |
| EDH84H64C-35CC-D3 EDH84H64C-45CC-D3 EDH84H64C-55CC-D3 EDH84H64C-35CMHR-D3 EDH84H64C-35CMHR-D3 EDH84H64C-35CMHR-D3 EDH84H64C-35CMHR-D3 |  | 7MP456 | $\begin{aligned} & 256 \mathrm{~K}(64 \mathrm{~K} \mathrm{X} \mathrm{4)} \\ & 24 \text { PIN DIP } \end{aligned}$ |
| EDH84H64C-35CC-S EDH84H64C-45CC-S EDH84H64C-55CC-S | $\begin{aligned} & \text { 7MP456S35S } \\ & \text { 7MP456S45S } \\ & \text { 7MP456S55S } \\ & \hline \end{aligned}$ |  | 256K (64K X 4) <br> 28 PIN SIP |
| EDH8808HC-55CMHR EDH8808HC-70CMHR EDH8808C-10CMHR EDH8808C-12CMHR EDH8808C-15CMHR EDH8808CL-20CMHR EDH8808CL-25CMHR EDH8808A-10CMHR EDH8808A-12CMHR EDH8088A-15CMHR EDH8808AL-20CMHR EDH8808AL-25CMHR | 8M864L85CB <br> 8M864L120CB <br> 8M864L150CB <br> 8M864L150CB <br> 8M864L150CB <br> 7M864L85CB <br> 7M864L120CB <br> 7M864L150CB <br> 7M864L150CB <br> 7M864L150CB | 8M864L55CB 8M864L75CB | 64K (8K X 8) 28 PIN DIP |
| EDH8832C-12C <br> EDH8832C-15C <br> EDH8832C-20C <br> EDH8832C-12CMHR <br> EDH8832C-15CMHR <br> EDH8832C-20CMHR | 8M856L85C <br> 8M856L85C <br> 8M856L85C <br> 8M856L100CB <br> 8M856L100CB <br> 8M856L100CB | 7M856S <br> 7M856S <br> 7M856S <br> 7M856S <br> 7M856S <br> 7M856S | $\begin{aligned} & 256 \mathrm{~K}(32 \mathrm{~K} \mathrm{X} 8 \text { ) } \\ & 28 \text { PIN DIP } \end{aligned}$ |
| EDH8832HC-45CMHR EDH8832HC-55CMHR EDH8832HC-70CMHR EDH8832HC-85CMHR | 7M856S45CB <br> 7M856S55CB <br> 7M856S65CB <br> 7M856S75CB | 8M856L <br> 8M856L <br> 8M856L <br> 8M856L | $\begin{aligned} & 256 \mathrm{~K}(32 \mathrm{~K} \times 8) \\ & 28 \text { PIN DIP } \end{aligned}$ |


| MICRON TECHNOLOGY P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | MICRON ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| MT85C8128-30 MT85C8128-35 MT85C8128-45 | $\begin{aligned} & \text { 8M824S30C } \\ & \text { 8M824S35C } \\ & \text { 8M824S45C } \end{aligned}$ |  | $\begin{aligned} & 1 \text { MEG ( } 128 \mathrm{KX} \text { 8) JEDEC } \\ & 32 \text { PIN DIP } \end{aligned}$ |
| MT85C1632-30 MT85C1632-35 MT85C1632-45 | 8M612S30C 8M612S35C 8M612S45C |  | 512K (32K X 16) JEDEC 40 PIN DIP |
| MT85C1664-30 MT85C1664-35 MT85C1664-45 | 8M624S30C 8M624S35C 8M624S45C |  | 1 MEG (64K X 16) JEDEC 40 PIN DIP |
| MT8C16256-30 MT8C16256-35 MT8C16256-45 | 7MB4066S30P 7MB4066S35P 7MB4066S45P |  | 4 MEG (256K X 16) JEDEC 48 PIN DIP |
| MT8C3216-15 <br> MT8C3216-20 <br> MT8C3216-25 <br> MT8C3216-30 <br> MT8C3216-35 <br> MT8C3216-45 | 7MP4031S15Z <br> 7MP4031S20Z <br> 7MP4031S25Z <br> 7MP4031S30Z <br> 7MP4031S35Z <br> 7MP4031S35Z |  | 512K (16K X 32) JEDEC 64 PIN ZIP |
| MT8C3264-25 MT8C3264-30 MT8C3264-35 MT8C3264-45 | 7MP4036S25Z 7MP4036S30Z 7MP4036S35Z 7MP4036S35Z |  | 2 MEG ( $64 \mathrm{~K} \times 32$ ) JEDEC 64 PIN ZIP |
| MT8C32256-30 <br> MT8C32256-35 MT8C32256-45 | $\begin{aligned} & \text { 7MP4045S30Z } \\ & \text { 7MP4045S35Z } \\ & \text { 7MP4045S45Z } \end{aligned}$ |  | 8 MEG (256K X 32) JEDEC 64 PIN ZIP |
| MOSAIC P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | $\begin{gathered} \text { MOSAIC } \\ \text { ORG/PACKAGE } \end{gathered}$ |
| $\begin{aligned} & \text { MS1256CS-25 } \\ & \text { MS1256CS-35 } \\ & \hline \end{aligned}$ |  | 7MP156, 7MC156 7MP156, 7MC156 | $\begin{aligned} & 256 \mathrm{~K}(256 \mathrm{~K} \times 1) \\ & 25 \mathrm{PIN} \text { SIP } \end{aligned}$ |
| MS8128SLU-55 <br> MS8128SU-70 <br> MS8128SL-10 | 8M824S50C <br> 8M824S70C <br> 8M824S70C | 8M824SXXN, 8MP824 | 1 MEG (128K X 8) 32 PIN DIP |
| MS8256RKL-10 MS8256RKL-12 |  | $\begin{aligned} & \text { 7MP4034 } \\ & 7 M P 4034 \end{aligned}$ | $\begin{aligned} & 2 \mathrm{MEG}(256 \mathrm{~K} \times 8) \\ & 32 \mathrm{PIN} \text { SIP } \\ & \hline \end{aligned}$ |
| MS8512FKX-85 MS8512FKX-10 MS8512FKX-12 | 7M4048L85N 7M4048L100N 7M4048L120N |  | 4 MEG (512K X 8) JEDEC 32 PIN DIP |
| MS8512SCMB-85 MS8512SCMB-10 MS8512SCMB-12 | 7M4048S85CB 7M4048S100CB 7M4048S120CB |  | 4 MEG (512K X 8) JEDEC 32 PIN DIP |
| MS8512SC-45 <br> MS8512SC-55 <br> MS8512SC-70 | 7MB4048S45P 7MB4048S50P 7M4048L70N |  | 4 MEG (512K X 8) JEDEC 32 PIN DIP |
| MS8512SCMB-45 MS8512SCMB-55 MS8512SCMB-70 | 7M4048S45CB 7M4048S50CB 7M4048S70CB |  | 4 MEG (512K X 8) JEDEC 32 PIN DIP |
| MS8512RKX-10 MS8512RKX-12 MS8512RKX-15 | 7MP4008L100S <br> 7MP4008L100S <br> 7MP4008L100S | 7MP4058L100S <br> 7MP4058L120S <br> 7MP4058L120S | 4 MEG (512K X 8) 36 PIN SIP |
| MS1664FKX-30 MS1664FKX-35 MS1664FKX-45 | 8M624S30C 8M624S35C 8M624S45C |  | 1 MEG (64K X 16) JEDEC 40 PIN DIP |

SSD CROSS REFERENCE GUIDE

| MOSAIC P/N | $\begin{gathered} \text { IDT P/N } \\ \text { DIRECT } \\ \text { EQUIVALENT } \end{gathered}$ | IDT P/N SIMILAR PART | MOSAIC ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| MS1664BCX-25 <br> MS1664BCX-35 <br> MS1664BCXMB-25 <br> MS1664BCXMB-35 | $\begin{aligned} & \text { 7M624S25C } \\ & \text { 7M624S35C } \\ & \text { 7M624S25CB } \\ & \text { 7M624S35CB } \end{aligned}$ |  | 1 MEG (64K X 16) 40 PIN DIP |
| MS3216RKX-15 MS3216RKX-20 MS3216RKX-25 MS3216RKX-35 MS3216RKX-45 | 7MP4031S15Z <br> 7MP4031S20Z <br> 7MP4031S25Z <br> 7MP4031S35Z <br> 7MP4031S35Z |  | $\text { 512K (16K } \times 32 \text { ) JEDEC }$ $64 \text { PIN ZIP }$ |
| PUMA 2S1000 | 7M4003SXXCH |  | 1 MEG (32K X 32) 66 PIN HIP |
| PUMA 2E1000 | 7M7004SXXCH |  | 1 MEG (32K X 32) EEPROM 66 PIN HIP |
| MS3264FKX-25 <br> MS3264FKX-35 <br> MS3264FKX-45 <br> MS3264FKX-55 | $\begin{aligned} & \text { 7M4017S35C } \\ & \text { 7M4017S40C } \\ & \text { 7M4017S50C } \end{aligned}$ | 7MP4036S25Z | $2 \text { MEG (64K X 32) }$ <br> 60 PIN DIP |
| MS3264RKX-25 MS3264RKX-35 MS3264RKX-45 | $\begin{aligned} & \text { 7MP4036S25Z } \\ & \text { 7MP4036S35Z } \\ & \text { 7MP4036S45Z } \\ & \hline \end{aligned}$ |  | $2 \text { MEG (64K X 32) JEDEC }$ 64 PIN ZIP |
| MS32256FKX-35 MS32256FKX-45 MS32256FKX-55 | 7M4067S35C 7M4067S45C 7M4067S55C |  | $\begin{aligned} & 8 \text { MEG (256K X 32) } \\ & 60 \text { PIN DIP } \end{aligned}$ |
| MS32256RKX-35 MS32256RKX-45 MS32256RKX-55 | $\begin{aligned} & \text { 7MP4045S35Z } \\ & \text { 7MP4045S45Z } \\ & \text { 7MP4045S55Z } \end{aligned}$ |  | 8 MEG (256K X 32) JEDEC 64 PIN ZIP |
| MISC. VENDORS P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | MISC. VENDORS ORG/PACKAGE |
| AEP |  | . |  |
| AEPSS4K32 |  | 7MC4032 | $128 \mathrm{~K}(4 \mathrm{~K} \times 32)$ |
| AEPSS8K32 |  | 7MC4032 | 256K (8K X 32) |
| AEPSS64K8 |  | 7M812 | 512K (64K X 8) |
| AEPSS256K8 |  | 7MP4034 | 2 MEG ( $256 \mathrm{~K} \times 8$ ) |
| AEPSS256K9-25 <br> AEPSS256K9-35 <br> AEPSS256K9-45 <br> AEPSS256K9-55 |  | $\begin{aligned} & \text { 7MB4040 } \\ & \text { 7MB4040 } \\ & \text { 7MB4040 } \\ & \text { 7MB4040 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \text { MEG ( } 256 \mathrm{~K} X 9 \text { ) } \\ & 44 \text { PIN SIP } \end{aligned}$ |
| AEPSS128K8 |  | 8M824, 8MP824 | 1 MEG (128K $\times 8$ ) |
| AEPSS32K16 |  | 8M612, 8MP612 | $512 \mathrm{~K}(32 \mathrm{~K} \mathrm{X} \mathrm{16)}$ |
| AEPSS128K16 |  | 7M4016 | 2 MEG (128K X16) |
| AEPSS2M8 |  | $\begin{aligned} & \text { NA } \\ & \text { NA } \end{aligned}$ | 16 MEG (2M X 8) 40 PIN SIP |
| AEPSS512K8-35 AEPSS512K8-55 AEPSS512K8-70 AEPSS512K8-85 AEPSS512K8-10 AEPSS512K8-12 | 7MP4008S35S <br> 7MP4008S55S <br> 7MP4008S70S <br> 7MP4008S70S <br> 7MP4008S70S <br> 7MP4008S70S |  | $\begin{aligned} & 4 \text { MEG (512K X 8) } \\ & 36 \text { PIN SIP } \end{aligned}$ |
| AEPSS512K8-10SL AEPSS512K8-12SL | $\begin{aligned} & \text { 7MP4008L100S } \\ & \text { 7MP4008L100S } \end{aligned}$ |  | 4 MEG (512K X 8) 36 PIN SIP <br> [low power version] |


| MISC. VENDORS P/N | $\begin{gathered} \text { IDT P/N } \\ \text { DIRECT } \\ \text { EQUIVALENT } \end{gathered}$ | IDT P/N SIMILAR PART | MISC. VENDORS ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| ARRAY TECHNOLOGY |  |  |  |
| AT212SZ-15 AT212SZ-20 |  |  | $512 \mathrm{~K}(16 \mathrm{~K} \times 32)$ <br> 94 PIN ZIP <br> REGISTERED, SEP. I/O |
| AT212 |  |  | $512 \mathrm{~K}(16 \mathrm{~K} \times 32)$ <br> 64 PIN DIP <br> REGISTERED |
| AT612CP-35 AT612CP-40 | 8M612S35C 8M612S40C |  | 512 K (32K X 16) JEDEC 40 PIN DIP |
| AT656CP |  | 8M656 <br> 8M656 | $256 \mathrm{~K}(16 \mathrm{~K} \times 16)$ 40 PIN DIP |
| HARRIS |  |  |  |
| HM-8808S, AS-100 HM-8808B, AB-120 HM-8808, A-150 |  |  | 64K (8K X 8) JEDEC 28 PIN DIP |
| HM-8816HB-70 HM-8816H-85 HM-92560 |  | 7M856, 8M656 | ```128K (16K X 8) JEDEC 28 PIN DIP 256K (32K X 8), (16K X 16) SYNCHRONOUS 48 PIN DIP``` |
| FUJITSU |  |  |  |
| MB85402-30 MB85402-40 | 7MC4005S30CV 7MC4005S35CV |  | $256 \mathrm{~K}(16 \mathrm{~K} \times 16)$ <br> 36 PIN DSIP |
| MB85403A-40 MB85403A-50 |  | 7MP4034S35Z 7MP4034S45Z | $2 \text { MEG (256K X 8) }$ <br> 44 PIN DSIP |
| MB85410-30 MB85410-40 |  | $\begin{aligned} & 7 M 812 \\ & 7 \mathrm{M} 812 \\ & \hline \end{aligned}$ | 512K (64K X 8) JEDEC 60 PIN ZIP |
| $\begin{aligned} & \text { MB85411-35 } \\ & \text { MB85411-40 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { 7M912 } \\ & 7 \mathrm{M} 912 \\ & \hline \end{aligned}$ | $512 \mathrm{~K}(64 \mathrm{~K} \mathrm{X} \mathrm{9})$ <br> 70 PIN ZIP |
| MB85414-30 <br> MB85414-40 | 7MP4031S25Z <br> 7MP4031S35Z |  | 512K (16K X 32) JEDEC 64 PIN ZIP |
| MB85415-35 <br> MB85415-40 |  | 7MP4031S25Z 7MP4031S35Z | $512 \mathrm{~K}(16 \mathrm{~K} \times 36)$ 70 PIN ZIP |
| $\begin{aligned} & \text { MB85420-40 } \\ & \text { MB85420-50 } \end{aligned}$ |  | 7MP4034S35Z 7MP4034S45Z | 2 MEG (256K X 8) JEDEC 60 PIN ZIP |
| HITACHI |  |  |  |
| HM66203-10 <br> HM66203-12 <br> HM66203-15 |  | 8M824, 8MP824 8M824, 8MP824 8M824, 8MP824 | $1 \text { MEG ( } 128 \mathrm{~K} \times 8 \text { ) }$ <br> 32 PIN DIP |
| HM66203L-10 HM66203L-12 HM66203L-15 |  | 8M824L, 8MP824L 8M824L, 8MP824L 8M824L, 8MP824L | 1 MEG (128K X 8) JEDEC 32 PIN DIP <br> [low power version] |
| HM66204-12 HM66204-15 | 8M824L100N 8M824L100N |  | 1 MEG (128K X 8) JEDEC 32 PIN DIP |
| HM62256P-8 <br> HM62256P-10 <br> HM62256P-12 | 7M856S85C 7M856S85C 7M856S85C |  | $256 \mathrm{~K}(32 \mathrm{~K} \times 8)$ <br> 28 PIN DIP |
| HM62256LP-8 HM62256LP-10 HM62256LP-12 | 8M856L85C 8M856L85C 8M856L85C |  | 256K (32K X 8) 28 PIN DIP LOW POWER |


| MISC. VENDORS P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | MISC. VENDORS ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| INOVA |  |  |  |
| S128K8-55C <br> S128K8-70C <br> S128K8-85C <br> S128K8-70M <br> S128K8.85M <br> S128K8-100M <br> S128K8-120M | 8M824S50C 8M824S60C 8M824S70C 8M824S70CB 8M824S85CB 8M824S100CB 8M824S100CB | 8M824SXXN, 8MP824 8M824SXXN, 8MP824 | 1 MEG (128K X 8) JEDEC 32 PIN DIP |
| S128K8L-70MC |  | 8M824S70CB | 1 MEG (128K X 8) JEDEC 32 PIN DIP <br> [low power version] |
| S32K8-55C <br> S32K8-70C <br> S32K8-85C <br> S32K8-70M <br> S32K8-85M <br> S32K8-100M | 7M856S50C <br> 7M856S70C <br> 7M856S85C <br> 7M856S65CB <br> 7M856S75CB <br> 7M856S90CB | 8M856L <br> 8M856LXXCB | 256K (32K X 8) JEDEC $28 \text { PIN DIP }$ |
| LOGIC DEVICES |  |  |  |
| LMM4016-25 <br> LMM4016-35 <br> LMM4016-45 <br> LMM4016-55 | 7M4016S25C <br> 7M4016S35C <br> 7M4016S45C <br> 7M4016S55C |  | $4 \text { MEG (256K X 16) }$ 48 PIN DIP |
| LMM624-25 <br> LMM624-35 <br> LMM624-45 <br> LMM624-55 | $\begin{aligned} & \text { 7M624S25C } \\ & 7 \mathrm{M} 624 \mathrm{~S} 35 \mathrm{C} \\ & 7 \mathrm{M} 624 \mathrm{~S} 45 \mathrm{C} \\ & 7 \mathrm{M} 624 \mathrm{~S} 55 \mathrm{C} \end{aligned}$ |  | $1 \text { MEG ( } 64 \mathrm{~K} \times 16 \text { ) }$ 40 PIN DIP |
| LMM824-40 <br> LMM824-45 <br> LMM824-50 <br> LMM824-60 <br> LMM824-70 <br> LMM824-85 <br> LMM824-100 | 8M824S40C <br> 8M824S40N <br> 8M824S45C <br> 8M824S45N <br> 8M824S50C <br> 8M824S50N <br> 8M824S60C <br> 8M824S60N <br> 8M824L70N <br> 8M824S70C <br> 8M824S70N <br> 8M824L85N <br> 8M824L100N |  | 1 MEG (128K X 8) JEDEC 32 PIN DIP |
| LMM456-25 <br> LMM456-30 <br> LMM456-35 <br> LMM456-45 | $\begin{aligned} & \text { 7MP456S25S } \\ & \text { 7MP456S30S } \\ & \text { 7MP456S35S } \\ & \text { 7MP456S45S } \end{aligned}$ |  | $256 \mathrm{~K}(64 \mathrm{~K} \times 4)$ <br> 28 PIN SIP |
| MARCONI |  |  |  |
| SF63000 | 7M4016 |  | $\begin{aligned} & 1 \text { MEG (256K X 16), } \\ & (512 \mathrm{~K} \times 8) \\ & 48 \text { PIN DIP } \\ & \hline \end{aligned}$ |
| MEMORY X |  |  |  |
| MXS32032LZ |  | 7M4003 <br> 7M4003 | $1 \text { MEG (32K X 32) }$ $80 \text { PIN ZIP }$ |
| MICROELECTRONICS |  |  |  |
|  | 8M824L100N 8M824L100N 8M824L100N |  | 1 MEG (128K X 8) JEDEC 32 PIN DIP |


| MISC. VENDORS P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | MISC. VENDORS ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| MITSUBISHI |  |  |  |
| MH12808TNA-85 <br> MH12808TNA-10 <br> MH12808TNA-12 <br> MH12808TNA-15 | $\begin{aligned} & \text { 8M824L85N } \\ & \text { 8M824L100N } \\ & \text { 8M824L100N } \\ & 8 \mathrm{M} 824 \mathrm{~L} 100 \mathrm{~N} \end{aligned}$ | 8M824S, 8MP824 8M824S, 8MP824 8M824S, 8MP824 8M824S, 8MP824 | $\begin{aligned} & 1 \text { MEG (128K X 8) JEDEC } \\ & 32 \text { PIN DIP } \end{aligned}$ |
| MH12908TNA-85 MH12908TNA-10 MH12908TNA-12 MH12908TNA-15 |  | 8M824L,8M824S,8MP824 8M824L,8M824S,8MP824 8M824L,8M824S,8MP824 8M824L,8M824S,8MP824 | $\begin{aligned} & 1 \text { MEG ( } 128 \mathrm{KX} 8 \text { ) JEDEC } \\ & 32 \text { PIN DIP } \end{aligned}$ |
| MH25608TNA-85L <br> MH25608TNA-10L <br> MH25608TNA-12L <br> MH25608TNA-15L |  | $\begin{aligned} & \text { 7MP4034 } \\ & \text { 7MP4034 } \\ & \text { 7MP4034 } \\ & \text { 7MP4034 } \end{aligned}$ | $\begin{aligned} & 2 \text { MEG ( } 256 \mathrm{~K} \times 8 \text { ) JEDEC } \\ & 32 \text { PIN DIP } \end{aligned}$ |
| MH25608TNA-85H <br> MH25608TNA-10H <br> MH25608TNA-12H <br> MH25608TNA-15H |  | $\begin{aligned} & \text { 7MP4034 } \\ & \text { 7MP4034 } \\ & \text { 7MP4034 } \\ & \text { 7MP4034 } \\ & \hline \end{aligned}$ | 2 MEG (256K X 8) JEDEC 32 PIN DIP <br> [low power version] |
| MH51208SN-70L MH51208SN-85L MH51208SN-10L MH51208SN-12L MH51208SN-15L |  | 7MP4008 <br> 7MP4008 <br> 7MP4008 <br> 7MP4008 <br> 7MP4008 | 4 MEG (512K X 8) 64 PIN SIMM |
| MH51208SN-70H <br> MH51208SN-85H <br> MH51208SN-10H <br> MH51208SN-12H <br> MH51208SN-15H |  | $\begin{aligned} & \text { 7MP4008 } \\ & \text { 7MP4008 } \\ & \text { 7MP4008 } \\ & \text { 7MP4008 } \\ & \text { 7MP4008 } \end{aligned}$ | 4 MEG (512K X 8) 64 PIN SIMM [low power version] |
| MH25608S1N-70 <br> MH25608S1N-85 <br> MH25608S1N-10 <br> MH25608S1N-12 <br> MH25608S1N-15 |  | $\begin{aligned} & \text { 7MP4034 } \\ & \text { 7MP4034 } \\ & \text { 7MP4034 } \\ & \text { 7MP4034 } \\ & \text { 7MP4034 } \end{aligned}$ | $2 \text { MEG (256K X 8) }$ $35 \text { PIN SIMM }$ |
| MOTOROLA |  |  |  |
| MCM3264-20 MCM3264-25 MCM3264-30 | $\begin{aligned} & \text { 7MP4036S20Z } \\ & \text { 7MP4036S25Z } \\ & \text { 7MP4036S30Z } \end{aligned}$ |  | $2 \text { MEG (64K X 32) JEDEC }$ 64 PIN ZIP |
| $\begin{aligned} & \text { MCM8256-20 } \\ & \text { MCM8256-25 } \\ & \text { MCM8256-30 } \end{aligned}$ |  | $\begin{aligned} & \text { 7MP4034S20Z } \\ & \text { 7MP4034S25Z } \\ & \text { 7MP4034S25Z } \end{aligned}$ | $\begin{aligned} & 2 \text { MEG ( } 256 \mathrm{~K} \times 8 \text { ) JEDEC } \\ & 60 \text { PIN ZIP } \end{aligned}$ |
| MOSEL |  |  |  |
| MS88128 (100ns) MS88128 (120ns) MS88128 (150ns) | 8M824S50C 8M824S50C 8M824S50C | 8M824SXXN, 8MP824 | $\begin{aligned} & 1 \text { MEG ( } 128 \mathrm{KX} 8 \text { ) JEDEC } \\ & 32 \text { PIN DIP } \end{aligned}$ |
| NEC |  |  |  |
| MC-120 | 8M824S50C | 8M824SXXN, 8MP824 | 1 MEG (128K X 8) JEDEC 32 PIN DIP |
| VALTRONIC |  |  |  |
| M107-100 M107-120 M107-150 | 7M624S100C 7M624S100C 7M624S100C | 8M624, 8MP624 | $1 \text { MEG (64K X 16) }$ 40 PIN DIP |
| XXX (120ns) | 7M856S85C |  | 256K (32K X 8) JEDEC 28 PIN DIP |


| MISC. VENDORS P/N | IDT P/N DIRECT EQUIVALENT | IDT P/N SIMILAR PART | MISC. VENDORS ORG/PACKAGE |
| :---: | :---: | :---: | :---: |
| VITAREL |  |  |  |
| VMS10A24-100 <br> VMS10A24-150 <br> VMS10A24-200 |  | 8M824SXXN, 8MP824 7M624, 8M624, 8MP624 | $\begin{aligned} & 1 \text { MEG (64K X 16), } \\ & \text { (128K X 8), (64K X } 8 \text { ) } \\ & 40 \text { PIN DIP } \end{aligned}$ |
| VMS32K8-45 <br> VMS32K8-55 <br> VMS32K8-70 | 7M856S45C 7M856S50C 7M856S70C | 8M856L | 256K (32K X 8) JEDEC 28 PIN DIP |
| VMS128K8M-55 <br> VMS128K8M-60 | $\begin{aligned} & 8 \mathrm{M} 824 \mathrm{~S} 50 \mathrm{C} \\ & 8 \mathrm{M} 824 \mathrm{~S} 60 \mathrm{C} \end{aligned}$ | 8M824SXXN, 8MP824, 8M824L | 1 MEG (128K X 8) JEDEC 32 PIN DIP |
| WHITE TECHNOLOGY |  |  |  |
| WS-128K8-70CM | 8M824S70CB |  | 1 MEG (128K X 8) JEDEC 32 PIN DIP |
| ZYREL |  |  |  |
| $\begin{aligned} & \text { Z108-10 } \\ & \text { Z108-15 } \end{aligned}$ | $\begin{aligned} & \text { 8M824S70C } \\ & \text { 8M824S70C } \end{aligned}$ | 8M824SXXN, 8MP824 | $1 \text { MEG (128K X 8) JEDEC }$ 32 PIN DIP |

# TECHNOLOGY AND CAPABILITIES 

OUALITY AND RELIABLITY

## PACRAGE DIAGRAM OUTLINES

ECL PRODUCTS

Fro products

SPECLALY MEMORY PRODUCTS

SUBSYSTEMS PRODUCTS

## IDT...LEADING THE CMOS FUTURE

A major revolution is taking place in the semiconductor industry today. A new technology is rapidly displacing older NMOS and bipolar technologies as the workhorse of the 80's andbeyond. That technology is high-speed CMOS. Integrated Device Technology, a company totally predicated on and dedicated to implementing high-performance CMOS products, is on the leading edge of this dramatic change.

Beginning with the introduction of the industry's fastest CMOS $2 \mathrm{~K} \times 8$ static RAM, IDT has grown into a company with multiple divisions producing a wide range of high-speed CMOS circuits that are, in almost every case, the fastest available. These advanced products are produced with IDT's proprietary CEMOS ${ }^{\text {m }}$ technology, a twin-well, dry-etched, stepper-aligned process utilizing progressively smaller dimensions.

From inception, IDT's product strategy has been to apply the advantages of it's extremely fast CEMOS technology to produce the integrated circuit elements required to implement high-performance digital systems. IDT's goal is to provide the circuits necessary to create systems which are far superior to previous generations in performance, reliability, cost weight and size. Many of the company's innovative product designs offer higher levels of integration, advanced architectures, higher density packaging and system enhancement features that are establishing tomorrow's industry standards. The company is committed to providing its customers with an everexpanding series of these high-speed, lower-power IC solutions to system design needs.

IDT's commitment, however, extends beyond state-of-theart technology and advanced products to providing the highest
level of customer service and satisfaction in the industry. Producing products to exacting quality standards that provide excellent, long-term reliability is given the same level of importance and priority as device performance. IDT is also dedicated to delivering these high-quality advanced products on time. The company would like to be known not only for its technological capabilities, but also for providing its customers with quick, responsive and courteous service.

IDT's product families are available in both commercial and military grades. As a bonus, commercial customers obtain the benefits of military processing disciplines, established to meet or exceed the stringent criteria of the applicable military specifications.

IDT is the leading U.S. supplier of high-speed CMOS circuits. The company's high-performance fast SRAM , FCT logic family, high-density modules, FIFOs, complex logic products, specialty memories, ECL I/OBiCEMOSTM memories, RISC subsystems, and the 32-bit RISC microprocessor family complement eachother to provide high-speed CMOS solutions to a wide range of applications and systems.

Dedicated to maintaining its leadership position as a state-of-the-art IC manufacturer, IDT will continue to focus on maintaining its technology edge as well as developing a broader range of innovative products. New products and speed enhancements are continuously being added to each of the existing product families and additional product lines will be introduced. Contact your IDTfield representative orfactory marketing engineer to determine the latest product offerings. If you're building state-of-the-art equipment, IDT wants to help you solve some of your design problems.

## IDT MILITARY AND DESC-SMD PROGRAM

IDT is a leading supplier of military, high-speed CMOS circuits. The company's high-performance Static RAMs, FCT Logic Family, Complex Logic (CLP), FIFOs, Specialty Memories (SMP), ECL $1 / \mathrm{O}$ BiCMOS Memories, 32 -bit RISC Microprocessor, RISC Subsystems and high-density Subsystems Modules product lines complement each other to provide high-speed CMOS solutions to a wide range of military applications and systems. Most of these product lines offer Class B products which are fully compliant to the latest revision of MIL-STD-883, Paragraph 1.2.1. In addition, IDT offers Radiation Tolerant (RT), as well as Radiation Enhanced (RE), products.

IDT has an active program with the Defense Electronic Supply Center (DESC) to list all of IDT's military compliant
devices on Standard Military Drawings (SMD). The SMD program allows standardization of militarized products and reduction of the proliferation of non-standard source control drawings. This program will go far toward reducing the need for each defense contractor to make separate specification control drawings for purchased parts. IDT plans to have SMDs for many of its product offerings. Presently, IDT has 88 devices which are listed or pending listing. The devices are from IDT's SRAM, FCT Logic family, Complex Logic (CLP), FIFOs and Specialty Memories (SMP) product families. IDT expects to add another 20 devices to the SMD program in the near future. Users should contact either IDT or DESC for current status of products in the SMD program.

| SMD |  | SMD |  | SMD |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SRAM | IDT | LOGIC | IDT | CLP | IDT |
| 84036/D | 6116 | 5962-87630/B | 54FCT244/A | 5962-87708/A | 39C10B \& C |
| 5962-88740 | 6116LA | 5962-87629/C | 54FCT245/A | 5962-88535 | 39C01 |
| 84132/B | 6167 | 5962-86862/A | 54FCT299/A | 5962-88533/A | 49C460A |
| 5962-86015/A | 7187 | 5962-87644/A | 54FCT373/A | 5962-88613 | 39C60A |
| 5962-86859 | 6198/7198/7188 | 5962-87628/C | 54FCT374/A | 5962-88643 | 49C410 |
| 5962-86705/A | 6168 | 5962-87627 | 54FCT377/A | 5962-88743 | 75C48S |
| 5962-85525/A | 7164 | 5962-87654/A | 54FCT138/A | 5962-XXXXX | 75 C 58 |
| 5962-88552 | 71256L | 5962-87655 | 54FCT240/A | 5962-XXXXX | 75C458S |
| 5962-88662 | 71256 S | 5962-87656/A | 54FCT273/A | 5962-89517 | 49C402/A |
| 5962-88611 | 71682L | 5962-89533 | 54FCT861AB | 5962-86893 | 7216L |
| 5962-88681/A | 71258 S | 5962-89506 | 54FCT827AB | 5962-87686 | 7217L |
| 5962-88545 | 71258L | 5962-88575 | 54FCT841AB | 5962-88733 | 7210 |
| 5962-88544 | 71257L | 5962-88608 | 54FCT821AB | 5962-XXXXX | 49C402L |
| 5962-88725/A | 712575 | 5962-88543/A | 54FCT521/A | 5962-XXXXX | 7320L |
| 5962-89690 | 6116 | 5962-88640 | 54FCT161/A | 5962-XXXXX | 7321L |
| 5962-89691 | 7164 | 5962-88639 | 54FCT573/A | 5962-XXXXX | 7383L |
| 5962-89692 | 7188 | 5962-88656 | 54FCT823AB | 5962-XXXXX | 7209L |
| 5962-89712 | 71982 | 5962-88657 | 54FCT163/A |  |  |
|  | IDT | 5962-88674 | 54FCT825A/B |  |  |
| SMP | IDT | 5962-88661 | 54FCT863AB |  |  |
| 5962-86875/A | 7130/7140 | 5962-88775 | 54FCT646AB |  |  |
| 5962-87002/A | 7132/7142 | 5962-89508 | 54FCT139/A |  |  |
| 5962-88610/A | 7133S/7143S | 5962-89665 | 54FCT824AB |  |  |
| 5962-88665/A | 7133L/7143L | 5962-88651 | 54FCT533/A |  |  |
|  |  | 5962-88652 | 54FCT182/A |  |  |
| FIFO | IDT | 5962-88653 | 54FCT645AB |  |  |
|  |  | 5962-88654 | 54FCT640AB |  |  |
| 5962-87531 | 7201LA | 5962-88655 | 54FCT534/A |  |  |
| 5962-86846/A | 72404 | 5962-89767 | 54FCT540/A |  |  |
| 5962-88669 | 72035 | 5962-89766 | 54FCT541/A |  |  |
| 5962-89568 | 7204L | 5962-89733 | 54FCT191/A |  |  |
| 5962-89536 | 7202L | 5962-89732 | 54FCT241/A |  |  |
| 5962-89863 | 7201S | 5962-89652 | 54FCT399/A |  |  |
| 5962-89523 | 72403L | 5962-89513 | 54FCT574/A |  |  |
| 5962-89666 | 7200L | 5962-89731 | 54FCT833A/B |  |  |
| 5962-89942 | 72103L | 5962-88675 | 54FCT845AB |  |  |
| 5962-89943 | 72104L | 5962-89730 | 54FCT543/A |  |  |
| 5962-89567 | 7203L |  |  |  |  |

2509 tot 01

## RADIATION HARDENED TECHNOLOGY

IDT manufactures and supplies radiation hardened products for military/aerospace applications. Utilizing special processing and starting materials, IDT's radiation hardened devices are able to survive in hostile radiation environments. Intotaldose, dose rate and environments where single event upset is of concern, IDT products are designed to continue functioning without loss of performance. IDT can supply all its products on these processes. Total Dose radiation testing is performed in-
house on an ARACOR X-Ray system. External facilities are utilized for device research on gamma cell, LINAC and other radiation equipment. IDT has an on-going research and development program for improving radiation handling capabilities (See "IDT Radiation Tolerant/Enhanced Products for Radiation Environments" in Section 3) of IDT products/ processes.

## IDT LEADING EDGE CEMOS TECHNOLOGY

## HIGH-PERFORMANCE CEMOS

From IDT's beginnings in 1980, it has had a belief in and a commitment to CMOS. The company developed a highperformance version of CMOS, called enhanced CMOS (CEMOS), that allows the design and manufacture of leadingedge components. It incorporates the best characteristics of traditional CMOS, including low power, high noise immunity
and wide operating temperature range; it also achieves speed and output drive equal or superior to bipolar Schottky TTL. The last decade has seen development and production of four "generations" of IDT's CEMOS technology with process improvements which have reduced IDT's electrical effective (Leff) gate lengths by more than 50 percent from 1.3 microns (millionths of a meter) in 1981 to 0.6 microns in 1989.

|  | CEMOS I | CEMOS II |  | CEMOS III | CEMOS V | CEMOS VI |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Calendar Year | 1981 | 1983 | 1985 | 1987 | 1989 | 1990 |
| Drawn <br> Feature Size | $2.5 \mu$ | $1.7 \mu$ | $1.3 \mu$ | $1.2 \mu$ | $1.0 \mu$ | $0.8 \mu$ |
| Leff | $1.3 \mu$ | $1.1 \mu$ | $0.9 \mu$ | $0.8 \mu$ | $0.6 \mu$ | $0.45 \mu$ |
| Basic  <br> Proces <br> Enhancements Dual-well, <br> Wet Etch, <br> Projection <br> Aligned | Dry Etch, <br> Stepper | Shrink, <br> Spacer | Silicide, <br> BPSG, <br> BiCEMOS I | BiCEMOS II | BiCEMOS III |  |

2514 drw 01
CEMOS IV = CEMOS III - scaled process optimized for high-speed logic.
Figure 1.

Continual advancement of CEMOS technology allows IDT to implement progressively higher levels of integration and achieve increasingly faster speeds maintaining the company's established position as the leader in high-speed CMOS integrated circuits. In addition, the fundamental process technology has been extended to add bipolar elements to the CEMOS platform. IDT's BiCEMOS process combines the ultra-high speeds of bipolar devices with the lower power and cost of CMOS, allowing us to build even faster components than straight CMOS at a slightly higher cost.


Figure 2. Fifteen-Hundred-Power Magnification ScannIng Electron Microscope (SEM) Photos of the Four Generations of IDT's CEMOS Technology


2514 dw 03
Figure 3. IDT CEMOS Device Cross Section

## ALPHA PARTICLES

Random alpha particles can cause memory cells to temporarily lose their contents or suffer a "soft error." Traveling with high energy levels, alpha particles penetrate deep into an integrated chip. As they burrow into the silicon, they leave a trail of free electron-hole pairs in their wake.

The cause of alpha particles is well documented and understood in the industry. IDT has considered various techniques to protect the cells from this hazardous occurrence. These techniques include dual-well structures (Figures 3 and 4) and a polymeric compound for die coating. Presently, a polymeric compound is used in many of IDT's SRAMs; however, the specific techniques used may vary and change from one device generation to the next as the industry and IDT improve the alpha particle protection technology.

## LATCHUP IMMUNITY

A combination of careful design layout, selective use of guard rings and proprietary techniques have resulted in virtual elimination of latchup problems often associated with older CMOS processes (Figure 5). The use of NPN and N-channel 1/O devices eliminates hole injection latchup. Double guard ring structures are utilized on all input and output circuits to absorb injected electrons. These effectively cut off the current paths into the internal circuits to essentially isolate l/O circuits. Compared to older CMOS processes which exhibit latchup characteristics with trigger currents from $10-20 \mathrm{~mA}$, IDT products inhibit latchup at triggercurrents substantially greater than this.


2

Figure 4. IDT CEMOS Bull-In High Alpha Particle Immunity


2514 dww 05
Figure 5. IDT CEMOS Latchup Suppression

# SURFACE MOUNT TECHNOLOGY <br> AND <br> IDT'S MODULE PRODUCTS 

Requirements for circuit area reduction, utilizing the most efficient and compact component placement possible and the needs of production manufacturing for electronics assemblies are the driving forces behind the advancement of circuit-board assembly technologies. These needs are closely associated with the advances being made in surface mount devices (SMD) and surface mount technology (SMT) itself. Yet, there are two major issues with SMT in production manufacturing of electronic assemblies: high capital expenditures and complexity of testing.

The capital expenditure required to convert to efficient production using SMT is still too high for the majority of electronics companies, regardless of the $20-60 \%$ increase in the board densities which SMT can bring. Because of this high barrier to entry, we will continue to see a large market segment [large even compared to the exploding SMT market] using traditional through-hole packages (i.e. DIPs, PGAs, etc) and assembly techniques. How can these types of companies take advantage of SMD and SMT? Let someone else, such as IDT, do it for them by investing time and money in SMT and then in return offer through-hole products utilizing SMT processes. Products which fit this description are multi-chip modules, consisting of SMT assembled SMDs on a throughhole type substrate. Modules enable companies to enjoy SMT density advantages and traditional package options without the expensive startup costs required to do SMT in-house.

Although subcontracting this type of work to an assembly house is an alternative, there still is the other issue of testing, an area where many contract assembly operations fall short of IDT's capability and experience. Prerequisites for adequate module testing sophisticated high performance parametric testers, customized test fixtures, and most importantly the experience to tests today's complex electronic devices. Companies can therefore take advantage of IDT's experience in testing and manufacturing high performance CMOS multi-chip modules.

At IDT, SMD components are electrically tested, environmentally screened, and performance selected for each IDT module. All modules are $100 \%$ tested as if they are a separate functional component and are guaranteed to meet all specified parameters at the module output without the customer having to understand the modules' internal workings.

Other added benefits companies get by using IDT's CMOS module products are:

1) a wide variety of high performance, through-hole products utilizing SMD packaged components,
2) fast speeds compared with NMOS based products,
3) low power consumption compared with bipolar technologies, and
4) low cost manufacturability compared with GaAs based products.

IDT has recognized the problems of SMT and began offering CMOS modules as part of its standard product portfolio. IDT modules combine the advantages of:

1) the low power characteristics of IDT's CEMOS* and BiCEMOS ${ }^{\text {m }}$ products,
2) the density advantages of first class SMD components including those from IDT's components divisions, and
3) experience in system leveldesign, manufacturing, and testing with its own in-house SMT operation.

IDT currently has two divisions (Subsystems and RISC Subsystems) dedicated to the development of module products ranging from simple memory modules to complex VME sized application specific modules to full system level CPU boards. These modules have surface mount devices assembled on both sides of either a multi-layer glass filled epoxy (FR-4) or a multi-layer co-fired ceramic substrate. Assembled modules come available in industry standard through-hole packages and other space-saving module packages. Industry proven vapor-phase or IR reflow techniques are used to solder the SMDs to the substrate during the assembly process. Because of our affiliation with IDT's experienced semiconductor manufacturing divisions, we thoroughly understand and therefore test all modules to the applicable datasheet specifications and customer requirements.

Thus, IDT is able to offer today's electronic design engineers a unique solution for their "need-more-for-less" problem modules. These high speed, high performance products offer the density advantages of SMD and SMT, the added benefit of low power CMOS technology, and throughhole packaged electronics without the high cost of doing it inhouse.

## STATE-OF-THE-ART FACILITIES AND CAPABILITIES

Integrated Device Technology is headquartered in Santa Clara, California - the heart of the "Silicon Valley." The company's operations are housed in seven facilities totaling over 500,000 square feet. These facilities house all aspects of business from research and development to design, wafer fabrication, assembly, environmental screening, test and administration. In-house capabilities include scanning electron microscope (SEM) evaluation, particle impact noise detection (PIND), plastic and hermetic packaging, military and commercial testing, burn-in, life test and a full complement of environmental screening equipment.

The over-200,000-square-foot corporate headquarters campus is composed of four buildings. The largest facility on this site is a 100,000 square foot, two-building complex. The first building, a 60,000 square foot facility, is dedicated to the Complex Logic, Standard Logic and RISC Microprocessor product lines, as well as hermetic and plastic package assembly, logic products' test, burn-in, mark and QA, and a reliability/failure analysis lab.

IDT's Packaging and Assembly Process Development teams are located here. To keep pace with the development of new products and to enhance the IDT philosophy of "Innovation," these teams have ultra modern, integrated and correspondingly sophisticated equipment and environments at their disposal. All manufacturing is completed in dedicated clean room areas (Class 10K minimum), with all preseal operations accomplished under Class 100 laminar flow hoods.

Development of assembly materials, processes and equipment is accomplishedunder a fully operational production environment to ensure reliability and repeatable product. The Hermetic Manufacturing and Process Development team is currently producing custom products to the strict requirements of MIL-STD-883. The fully automated plastic facility is currently producing high volumes of USA-manufactured product, while developingstate-of-the-art surface mount technology patterned after MIL-STD-883.
The second building of the complex houses sales, marketing, finance and MIS.
The RISC Subsystems and Subsystems Modules Divisions are located behind the two-building complex in a 54,000 square foot facility. Also located at this facility are Quality Assurance and wafer fabrication services.
Directly across the street from the two-building complex is a newly acquired 50,000 square foot facility that houses
administrative services, Northwest Area Sales, Human Resources, International Planning andShipping and Receiving functions.

IDT's largest and newest facility, opened in 1990 in San Jose, California, is a multi-purpose 150,000 square foot, ultra modern technology development center. This facility houses a 25,000 square foot, combined Class 1 (a maximum of one particle per cubic foot of 0.2 micron or larger), sub-half-micron R\&D fabrication facility and a wafer fabrication area. This fab supports both production volumes of IDT products, including some next generation SRAMs, and the R\&D efforts of the technology development staff. Technology developmentefforts targeted for the center include advanced silicon processing and wafer fabrication techniques. A test area to support both production and research is located on-site. The building is also the new home of the FIFO and ECL product lines.

IDT's second largest facility is located in Salinas, California, about an hour away from Santa Clara. This 95,000 square foot facility, located on 14 acres, is the Static RAM Division and Specialty Memory product line. Constructed in 1985, this facility houses an ultra-modern 25,000 square foot highvolume wafer fabrication area measured at Class 2-to-3 (a maximum of 2 to 3 particles per cubic foot of 0.2 micron or larger) clean room conditions. Careful design and construction of this fabrication area created a clean room environment far beyond the 1985 average for U.S. fab areas. This made possible the production of large volumes of high-density submicron geometry, fast static RAMs. This facility also houses shipping areas for IDT's leadership family of CMOS static RAMs. This site will expand to accommodate a 250,000 square foot complex.
To extend these philosophies while maintaining strict control of our processes, IDT has an operational Assembly and Test facility located in Penang, Malaysia. This facility assembles product to USA standards, with all assemblies done under laminar flow conditions (Class 100) untilthe silicon is encased in its final packaging. All products in this facility are manufactured to the quality control requirements of MIL-STD883.

All of IDT's facilities are aimed at increasing our manufacturing productivity to supply ever larger volumes of high-performance, cost-effective leadership CMOS products.

## SUPERIOR QUALITY AND RELIABILITY

Maintaining the highest standards of quality in the industry on all products is the basis of Integrated Device Technology's manufacturing systems and procedures. From inception, quality and reliability are built into all of IDT's products. Quality is "designedin" at every stage of manufacturing - as opposed to being "tested-in" later - in order to ensure impeccable performance.

Dedicated commitment to fine workmanship, along with development of rigid controls throughout wafer fab, device assembly and electricaltest, create inherently reliable products. Incoming materials are subjected to carefulinspections. Quality monitors, or inspections, are performed throughout the manufacturing flow.

IDT military grade monolithic hermetic products are designed to meet or exceed the demanding Class B reliability levels of MIL-STD-883 and MIL-M-38510, as defined by Paragraph 1.2.1 of MIL-STD-883.

Product flow and test procedures for all monolithic hermetic military grade products are in accordance with the latest revision and notice of MIL-STD-883. State-of-the-art production techniques and computer-based test procedures are coupled with tight controls and inspections to ensure that products meet the requirements for $100 \%$ screening. Routine quality conformance lot testing is performed as defined in MIL-STD883, Methods 5004 and 5005.

For IDT module products, screening of the fully assembled substrates is performed, in addition to the monolithic level screening, to assure package integrity and mechanical
reliability. All modules receive 100\% electrical tests (DC, functional and dynamic switching) to ensure compliance with the "subsystem" specifications.

By maintaining these high standards and rigid controls throughout every step of the manufacturing process, IDT ensures that commercial, industrial and military grade products consistently meet customer requirements for quality, reliability and performance.

## SPECIAL PROGRAMS

Class S. IDT also has all manufacturing, screening and test capabilities in-house (except X-ray and some Group D tests) to perform complete Class S processing per MIL-STD883 on all IDT products and has supplied Class S products on several programs.

Radiation Hardened. IDT has developed and supplied several levels of radiation hardened products for military/ aerospace applications to perform at various levels of dose rate, total dose, single event upset (SEU), upset and latchup. IDT products maintain nearly their same high-performance levels built to these special process requirements. The company has in-house radiation testing capability used both in process development and testing of deliverable product. IDT also has a separate group within the company dedicated to supplying products for radiation hardened applications and to continue research and development of process and products to further improve radiation hardening capabilities.

# GENERAA INFORMATION 

# TECHNOLOGV AND CAPABLITIES 

## QUALITY AND RELIABILITY

## PACKAGEDIAGRAMOUTLINES

## ECL PRODUCTS

## FFOPRODUCTS

## SPECIALTY MEMORY PRODUCTS

SUESVSTEMS PRODUCTS

## QSP-QUALITY, SERVICE AND PERFORMANCE

Quality from the beginning, is the foundation for IDT's commitment to supply consistently high-quality products to our customers. IDT's quality commitment is embodied in its all pervasive Constant Quality Improvement (CQI) program. Everyone who influences the quality of the product-from the designer to the shipping clerk-is committed to constantly improving the product quality.

## LOGIC PRODUCTS DIVISION'S FOCUS

"To make quantitative constant improvement in the quality of our actions that result in the supply of leadership products in conformance to the requirements of our customers."

IDT's Logic Products Division has dedicated its efforts to constant quantitative improvements in quality. The result, a supply of leadership products that conform to the requirements of our customers.

## LOGIC PRODUCTS DIVISION'S PRODUCT ASSURANCE STRATEGY FOR CQI

Measurable standards are essential to the success of CQI. All the processes contributing to the final quality of the product need to be monitored, measured and improved upon through the use of statistical tools.


PRODUCT FLOW

Our customers receive the benefit of our optimized systems. Installed to enhance quality and reliability, these systems provide accurate and timely reporting on the effectiveness of manufacturing controls and the reliability and quality performance of IDT logic products and services.


These systems and controls concentrate on CQlby focusing on the following key elements:

## Statistical Techniques

Using statisticaltechniques, including Statistical Process Control (SPC) to determine whether the product/ processes are under control.

## Standardization

Implementing policies, procedures and measurement techniques that are common across different operational areas.

## Documentatlon

Documenting and training in policies, procedures, measurement techniques and updating through characterization/ capability studies.

## Productivity Improvement

Using constant improvement teams made up from employees at all levels of the organization.

## Leadership

Focusing on quality as a key business parameter and strategic strength.

## Total Employee Particlpation

Incorporating the CQI program into the IDT Corporate Culture.

## Customer Service

Supporting the customer, as a partner, through performance review and pro-active problem solving.

## People Excellence

Committing to growing, motivating and retaining people throughtraining, goal setting, performance measurement and review.

## PRODUCT FLOW

Product quality starts here. IDT has mechanisms and procedures in place that monitor and control the quality of our development activities. From the calibration of design capture libraries through process technology and product characterization that establish whether the performance, ratings and reliability criteria have been met. This includes failure analysis of parts that will improve the prototype product.

At the pre-production stage once again in-house qualification tests assure the quality and reliability of the product. All specifications and manufacturing flows are established and personnel trained before the product is placed into production.

## Manufacturing

To make CQl during the manufacturing stage, control items are determined for major manufacturing conditions. Data is gathered and statistical techniques are used to control specific manufacturing processes that affect the quality of the product.

In-process and final inspections are fed back to earlier processes to improve product quality. All product is burnedin (where applicable) before $100 \%$ inspection of electrical characteristics takes place.

Products which pass final inspection are then subject to Quality Assurance and Reliability Tests. This data is used to improve manufacturing processes and provide reliability predictions of field applications.

## Inventory and Shipping

Controls in shipping focus on ensuring parts are identified and packaged correctly. Care is also taken to see that the correct paperwork is present and the product being shipped was processed correctly.

## SERVICE FLOW

Quality not only applies to the product but to the quality -of -service we give our customers. Services is also constantly improved.

## Order Procedures

Checks are made at the order entry stage to ensure the correct processing of the Customer's product. After verification and data entry the Acknowledgements (sent to Customers) are again checked to ensure details are correct. As part of the CQI program, the results of these verifications are analyzed using statistical techniques and corrective actions are taken.

## Production Control

Production Control (P.C.) is responsible for the flow and logistics of material as it moves through the manufacturing processes. The quality of the actions taken by P.C. greatly impinges on the quality of service the customer receives. Because many of our customers have implemented Just-inTime (JIT) manufacturing practices, IDT as a supplier also has
to adopt these same disciplines. As a result, employees receive extensive training and the performance level of key actions are kept under constant review. These key actions include:

Quotation response and accuracy.
Scheduling response and accuracy.
Response and accuracy of Expedites.
Inventory, management, and effectiveness.
On time delivery.

## Customer Support

IDT has a worldwide network of sales offices and Technical Development Centers. These provide local customer support on business transactions, and in addition, support customers on applications information, technical services, benchmarking of hardware solutions, and demonstration of various Development Workstations.

The key to CQI is the timely resolution of defects and implementation of the corrective actions. This is no more important than when product failures are found by a customer. When failures are found at the customer's incoming inspection, in the production line, or the field application, the Logic Products Division Quality Assurance group is the focal point for the investigation of the cause of failure and implementation of the corrective action. IDT constantly improves the level of support we give our customers by monitoring the response time to customers that have detected a product failure. Providing the customer with an analysis of the failure, including corrective actions and the statistical analysis of defects, brings CQI full circle-full support of our customers and their designs with high-quality products.

## SUMMARY

In 1990, IDT made the commitment to "Leadership through Quality, Service, and Performance Products".
We believe by following that credo IDT and our cusotmers will be successful in the coming decade. With the implementation of the CQI strategy within the Logic Products Division, we will satisfy our goal...
"Leadership through Quality, Service and Performance Products".

## IDT QUALITY CONFORMANCE PROGRAM

## A COMMITMENT TO QUALITY

Integrated Device Technology's monolithic and modular assembly products are designed, manufactured and tested in accordance with the strict controls and procedures required by Military Standards. The documentation, design and manufacturing criteria of the Quality and Reliability Assurance Program were developed and are being maintained to the most current revisions of MIL-38510 as defined by paragraph 1.2.1 of MIL-STD-883 and MIL-STD-883 requirements.

Product flow and test procedures for all Class B monolithic hermetic Military Grade microcircuits are in full compliance with paragraph 1.2.1 of MIL-STD-883. State-of-the-art production techniques and computer-based test procedures are coupled with stringent controls and inspections to ensure that products meet the requirements for $100 \%$ screening and quality conformance tests as defined in MIL-STD-883, Methods 5004 and 5005.

Product flow and test procedures for all plastic and commercial hermetic products are in accordance with industry practices for producing highly reliable microcircuits to ensure that products meet the IDT requirements for $100 \%$ screening and quality conformance tests.

By maintaining these high standards and rigid controls throughout every step of the manufacturing process, IDT ensures that our products consistently meet customer requirements for quality, reliability and performance.

## SUMMARY

## Monolithic Hermetic Package Processing Flow ${ }^{(1)}$

Refer to the Monolithic Hermetic Package Processing Flow diagram. All test methods refer to MIL-STD-883 unless otherwise stated.

1. Wafer Fabrication: Humidity, temperature and particulate contamination levels are controlled and maintained according to criteria patterned after Federal Standard 209, Clean Room and Workstation Requirements. Allcriticalworkstations are maintained at Class 100 levels or better.

Wafers fromeachwaferfabrication area are subjected to Scanning Electron Microscope analysison aperiodic basis.
2. Die-Sort Visual Inspection: Wafers are cut and separated and the individual die are $100 \%$ visually inspected to strict IDT-defined internal criteria.
3. Dle Shear Monitor: To ensure die attach integrity, product samples are routinely subjected to a shear strength test per Method 2019.
4. Wire Bond Monitor: Product samples are routinely subjected to a strengthtest per Method2011, Condition D , to ensure the integrity of the lead bond process.
5. Pre-Cap Visual: Before the completed package is sealed, $100 \%$ of the product is visually inspected to Method 2010, Condition B criteria.
6. Environmental Conditioning: $100 \%$ of the sealed product is subjected to environmental stress tests. These thermal and mechanical tests are designed to eliminate units with marginal seal, die attach or lead bond integrity.
7. Hermetic Testing: $100 \%$ of the hermetic packages are subjected to fine and gross leak seal tests to eliminate marginally sealed units or units whose seals may have become defective as a result of environmental conditioning tests.
8. Pre-Burn-In Electrical Test: Each product is $100 \%$ electrically tested at an ambient temperature of $+25^{\circ} \mathrm{C}$ to IDT data sheet or the customer specification.
9. Burn-In: $100 \%$ of the Military Grade product is burned-in under dynamic electrical conditions to the time and temperature requirements of Method 1015, Condition D. Except for the time, Commercial Grade product is burned-in as applicable to the same conditions as Military Grade devices.
10. Post-Burn-In Electrical: After burn-in, $100 \%$ of the Class B Military Grade product is electrically tested to IDT data sheet or customer specifications over the $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range. Commercial Grade products are sample tested to the applicable temperature extremes.
11. Mark: All product is marked with product type and lot code identifiers. MIL-STD-883 compliant Military Grade products are identified with the required compliant code letter.
12. Quality Conformance Tests: Samples of the Military Grade product which have been processed to the $100 \%$ screening tests of Method 5004 are routinely subjected to the quality conformance requirements of Method 5005.


SEE FINAL PROCESSING FLOW FOR REMAINDER OF OPERATIONS AND NOTES

## SUMMARY

## Monolithic Plastic Package Processing Flow

Refer to the Monolithic Plastic Package Processing Flow diagram. All test methods refer to MIL-STD-883 unless otherwise stated.

1. Wafer Fabrication: Humidity, temperature and particulate contamination levels are controlled and maintained according to criteria pattemed after Federal Standard 209, Clean Room and Workstation Requirements. Allcriticalworkstations are maintained at Class 100 levels or better.

Topside silicon nitride passivation is all applied to all wafers for better moisture barrier characteristics.

Wafers fromeachwaferfabrication area are subjected to Scanning ElectronMicroscope analysison aperiodic basis.
2. Die-Sort Visual Inspection: Wafers are $100 \%$ visually inspected to strict IDT defined internal criteria.
3. Die Push Test: To ensure die attach integrity, product samples are routinely subjected to die push tests.
4. Wire Bond Monitor: Product samples are routinely subjected to wire bond pull tests to ensure the integrity of the lead bond process.
5. Pre-Cap Visual: Before the package is molded, $100 \%$ of the product is visually inspected to criteria patterned after MIL-STD-883, Method 2010, Condition B.
6. Post Mold Cure: Plastic encapsulated devices are baked to ensure an optimum plastic seal so as to enhance moisture barrier characteristics.
7. Pre-Burn-In Electrical: Each product is $100 \%$ electricallytested at an ambient temperature of $+25^{\circ} \mathrm{C}$ to IDT data sheet or the customer specification.
8. Burn-In: Except for MSI Logic family devices where it may be obtained as an option, all Commercial Grade plastic package products are burned-in 16 hours at $+125^{\circ} \mathrm{C}$ (or equivalent), utilizing the same burn-in conditions as the Military Grade product.
9. Post-Burn-In Electrical: After burn-in, $100 \%$ of the plastic product is electrically tested to IDT data sheet or customer specifications at the maximum temperature extreme. The minimum temperature extreme is tested periodically on an audit basis.
10. Mark: All product is marked with product type and lot code identifiers.
11. Quality Conformance Inspection: Samples of the plastic product which have been processed to the $100 \%$ screening requirements are subjected to the Periodic Quality Conformance Inspection Program. Where indicated, the test methods are patterned after MIL-STD-883 criteria.

## Monolithic Plastic Package Processing Flow



NOTE:

1. All screens are $100 \%$ unless otherwise noted.
2. All electrical test programs are per the applicable IDT test specification.
3. IDT performs a $100 \%$ electrical test at $+25^{\circ} \mathrm{C}$ with a $5 \%$ PDA limit at this point.
4. © = Quality sample inspection.

Monolithic Hermetic Package Final Processing Flow

| Operation | MIL-STD-883 <br> Test Method | Milltary Compliant Class B | Commerclal |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Military Temp. Range | Commercial Temp. Range |
| Burn-In | $1015 / \mathrm{D}$ at $+125^{\circ} \mathrm{C}$ Min. or Equivalent | $\begin{aligned} & 100 \% \\ & 160 \text { Hours } \end{aligned}$ | $\begin{gathered} 100 \% \\ 16 \text { to } 160 \text { Hours } \end{gathered}$ | $\begin{gathered} 100 \% \\ \text { 16to160 Hours } \end{gathered}$ |
| Post Burn-In Electrical: Static (DC), Functional and Switching (AC) ${ }^{(2)}$ | IDT Spec. | $\begin{aligned} & 100 \% \\ & +25,-55 \text { and } \\ & +125^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ | $\begin{aligned} & 100 \% \\ & +125^{\circ} \mathrm{C} \end{aligned}$ | $\begin{aligned} & 100 \% \\ & +70^{\circ} \mathrm{C} \end{aligned}$ |
| Percent Defective Allowed (PDA) ${ }^{(4)}$ | 5004 or IDT Spec. | 5\% | 10\% | 10\% |
| Group A Electrical: Static (DC), Functional and Switching (AC) ${ }^{(2)}$ | 5005 and IDT Spec. | $\begin{aligned} & \text { Sample } \\ & -55 \text { and }+125^{\circ} \mathrm{C} \end{aligned}$ | $\begin{aligned} & \text { Sample } \\ & +125^{\circ} \mathrm{C} \end{aligned}$ | Sample $+70^{\circ} \mathrm{C}$ |
| Mark/Lead Straighten | IDT Spec. | 100\% | 100\% | 100\% |
| $+25^{\circ} \mathrm{C}$ Electrical ${ }^{(2)}$ | IDT Spec. | 100\% ${ }^{(5)}$ | 100\% | 100\% |
| Final Visual/Pack | IDT Spec. | 100\% | 100\% | 100\% |
| Quality Conformance Inspection | 5005 (Group B, C, D) | Yes | - | - |
| Quality Shipping Inspection (Visual/Plant Clearance) | IDT Spec. | Sample | Sample | Sample |

## NOTES:

1. All screens are $100 \%$ unless otherwise noted.
2. All electrical test programs are per the applicable IDT test specification.
3. This hermeticity sample is performed after all lead finish operations.
4. If a lot fails the $5 \%$ PDA but is $\leq 10 \%$, the lot may be resubmitted to burn-in one time only to the same time and temperature conditions as first submission. The subsequent post burn-in electrical test at $+25^{\circ} \mathrm{C}$ will be performed to a PDA of $3 \%$.
5. IDT performs a $100 \%$ electrical test at $+25^{\circ} \mathrm{C}$ with a $2 \%$ PDA limit at this point to satisfy group A requirements, and considers this to be equivalent to the group A requirement of an LTPD of 2 , with an accept number of 0 . If a lot fails the $2 \%$ PDA limit, it may be rescreened one time only to a tightened PDA limit of $1.5 \%$.
6. (Q) = Quality sample inspection.

## MODULE SURFACE MOUNT ASSEMBLY PROCESSING FLOW (*)

Refer to the Module Assembly Package Processing Flow diagrams Figures 1 and 2 for additional information. All test methods refer to MIL-STD-883 unless othenwise stated. Refer to Table 1 for additional information on module testing.

## HERMETIC FLOW

## Components

1. Hermetic Military Grade Class B monolithic microcircuit components used in Subsystems modules are manufactured to the applicable datasheet specifications and screened in compliance with the applicable Mil-Std-883 quality criteria.
2. Hermetic Military Grade Class S and Rad Hard monolithic microcircuit components available upon request. Please consult your IDT sales representative for additional information regarding these non-standard process and quality flows
3. Hermetic Commercial Grade monolithic microcircuit products used in Subsystems modules differ from Military Grade components only in the time of burn-in and electrical test temperature ranges.
4. Passive components such as chip capacitors, resistors are obtained from qualified vendors to the applicable military and IDT specifications.

## Modules

1. Module Assembly: The active and passive components and substrates used in the assembly of modules are subjected to incoming electrical and mechanical inspection per IDT's requirements. The components are then mounted onto a co-fired multi-layer ceramic substrate using either vapor phase or IR reflow techniques.
2. Pre-Burn-In Electrical Test: Every module is electrically tested(Static "DC", Functional "AC", and Dynamic Switching " $A C$ "; hereafter simply referred to as Electrical Testing) at an ambient temperature of $+25^{\circ} \mathrm{C}$ to IDT datasheet parameter specification or to customer specification.
3. Burn-In: All Military Grade modules are burned-in under conditions per Mil-Std-883, Method 1015, Condition D, for $44+/-4$ hours at an ambient temperature of $+125^{\circ} \mathrm{C}$. Commercial grade modules are not bumed-in.
4. Post-Burn-In Electrical \& PDA Calculation: Results of a $+25^{\circ} \mathrm{C}$ post burn-in Electrical test are used to calculate a PDA (Percent Defective Allowed) on the entire module lot. A maximum of $10 \%$ is imposed on all Military modules. Commercial grade modules are not burned-in and therefore PDA requirements are not applicable.
5. Post-Burn-In Electrical: All Class B Military Grade modules are Electrically Tested to IDT datasheet specification or customer specification at the military temperature limits of $-55^{\circ} \mathrm{C}$ and $+125^{\circ} \mathrm{C}$. Commercial grade products are tested to the commercial temperatures of $+25^{\circ} \mathrm{C}$ and $+70^{\circ} \mathrm{C}$.
6. QA Electrical Test Audit: A sample of Military grade modules are taken after each Electrical Test (at either temperature extreme) and subjected to a Quality Conformance Electrical Audit at $-55^{\circ} \mathrm{C}$ and $+125^{\circ} \mathrm{C}$ with a LTPD 7/1, in accordance to Mil-Std-883 requirements. Commercial grade modules are sampled tested at +70 ${ }^{\circ} \mathrm{C}$ to the same LTPD of $7 / 1$.
7. Mark: All electrically acceptable modules are marked with product type and lot code identifiers. Military Grade products are identified with the required compliancy code letter as specified in Mil-Std-883, unless otherwise specified by customer.
8. $100 \%$ Group A \& Final Electrical: A Final Electrical Test at $+25^{\circ} \mathrm{C}$ is imposed on all modules with a $5 \%$ PDA limit to satisfy Mil-Std-883 Group A requirements.
9. External Visual: Prior to shipment, all modules undergo a final visual inspection for applicable workmanship criteria per IDT's specification.
10. Quality Conformance Tests: Samples of the Military Grade modules are routinely subjected to Quality Conformance inspections requiring ongoing quality data for Mil-Std-883 Test Methods Group B, C, and D (only when such tests are applicable to module level parameters). This data is available upon request.

## NOTE:

1. For special processing or additional quality requirements beyond those mentioned above, such as SEM analysis, $X$-ray inspection, Particle Impact Noise Detection (PIND) test, or other customer specified screening flows, please contact your IDT sales representative.

## NON-HERMETIC FLOW

## Components

1. Non-Hermetic or Plastic Commercial Grade monolithic microcircuit products used in Subsystems modules are manufactured to the applicable datasheet specifications and screened to the applicable IDT Quality Conformance requirements.
2. Passive components such as chip capacitors, resistors are obtained from qualified vendors to the applicable commercial and IDT specifications.

## Modules

1. Module Assembly: The active and passive components and substrates used in the assembly of modules are subjected to incoming electrical and mechanical inspection per IDT's requirements. The components are then mounted onto a glass filled epoxy (FR-4) multi-layer substrate using either vapor phase or IR reflow techniques.
2. Electrical Test: Every module is electrically tested (Static "DC", Functional "AC", and Dynamic Switching "AC"; hereafter simply refered to as Electrical Testing) at an ambient temperature of $+25^{\circ} \mathrm{C}$ to IDT datasheet parameter specification or to customer specification.
3. Electrical Test: All Commercial Grade modules are Electrically Tested to IDT datasheet specifications or customer specifications at commercial temperatures of $+25^{\circ} \mathrm{C}$ and $+70^{\circ} \mathrm{C}$.
4. QA Electrical Test Audit: A sample of modules are taken and subjected to a Quality Conformance Electrical Audit at $+25^{\circ} \mathrm{C}$ and $+70^{\circ} \mathrm{C}$ with a LTPD $7 / 1$. This is pattemed after Mil-Std-883 requirements.
5. Mark: All electrically acceptable modules are marked with product type and lot code identifiers, unless otherwise specified by customer.
6. $100 \%$ Group A \& Final Electrical: A Final Electrical Test at $+25^{\circ} \mathrm{C}$ is imposed on all modules at this stage of processing with a 5\% PDA limit.
7. External Visual: Prior to shipment, all modules undergo a final visual inspection for applicable workmanship criteria per IDT's specification.



| Operation | Test Method | Hermetle Military | Hermetlc Commercial | FR-4 Commerclal |
| :---: | :---: | :---: | :---: | :---: |
| Pre-Burn-in Electrical Test (Static DC, Function AC and Switching AC] | IDT Data Sheet Specification | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ |
| Burn-in | $\begin{aligned} & \text { MIL-STD-883 } \\ & \text { Method 1015/D } \end{aligned}$ | $100 \%$ at $+25^{\circ} \mathrm{C}$ for $44 \pm 4$ Hours | N.A. | N.A. |
| Post-Burn-in Electrical Test (Static DC, Function AC and Switching AC] | IDT Data Sheet Specification | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ |
| Percent Defective Allowed (P.D.A.) (See Note 2) | MIL-STD-883 Method 5004 | 10\% | N.A. | N.A. |
| Post-Burn-in Electrical Test (Static DC, Function AC and Switching AC] | IDT Data Sheet Specification | $100 \%$ at $-55^{\circ} \mathrm{C}$ and $+125^{\circ} \mathrm{C}$ | $100 \%$ at $+25^{\circ} \mathrm{C}$ and $+70^{\circ} \mathrm{C}$ | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \text { and }+70^{\circ} \mathrm{C} \end{gathered}$ |
| (Sample) Quality Audit Electrical Test (Static DC, Function AC and Switching AC] (See Note 3) | IDT Specification | Sample at $-55^{\circ} \mathrm{C}$ and $+125^{\circ} \mathrm{C}$ LTPD $7 / 1$ | SAMPLE <br> at $+25^{\circ} \mathrm{C}$ and $+70^{\circ} \mathrm{C}$ <br> LTPD 7/1 | SAMPLE <br> at $+25^{\circ} \mathrm{C}$ and $+70^{\circ} \mathrm{C}$ <br> LTPD 7/1 |
| Group A and Final Electrical Test (Static DC, Function AC and Switching AC] | IDT Data Sheet Specification | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ | $\begin{gathered} 100 \% \\ \text { at }+25^{\circ} \mathrm{C} \end{gathered}$ |
| Percent Defective Allowed (P.D.A.) (See Note 4) | IDT Specification | 5\% | 5\% | 5\% |
| Quality Conformance Inspection) (See Note 5 | Reference MIL-STD-883 Method 5005 | 5\% | N.A. | N.A. |

## NOTES:

1. All Electrical Tests are guard-banded by temperature and voltage and take into account test equipment variations.
2. If a lot fails P.D.A., the lot may be resubmitted (one time only) to burn-in, for the same burn-in specifications. A subsequent post-burn-in retest at $25^{\circ} \mathrm{C}$ must then pass 5\% P.D.A.
3. If a lot fails LTPD $7 / 1$, the lot may be resubmitted (one time only) to test for the same temperatures. This subsequent retest must then pass a $100 \%$ critical
4. These test results satisfy Group A requirements and is considered to be equivalent to an LTPD of 5 with an accept number of 1 . If this lot fails P.D.A. of $5 \%$, it may be rescreened to (for one time only) to a P.D.A. of $3 \%$.
5. IDT Quality Conformance Inspection is patterned after MIL-STD-883, Method 5005 for monolithic microcircuits requiring periodic data sampling for Group $B, C$, and $D$ parameters. The new method for multi-chip modules is currently under development by the military.

## RADIATION TOLERANT/ENHANCED/HARDENED PRODUCTS FOR RADIATION ENVIRONMENTS

## INTRODUCTION

The need for high-performance CMOS integrated circuits in military and space systems is more critical today than ever before. The low power dissipation that is achieved using CMOS technology, along with the high complexity and density levels, makes CMOS the nearly ideal component for all types of applications.

Systems designed for military or space applications are intended for environments where high levels of radiation may be encountered. The implication of a device failure within a military or space system clearly is critical. IDT has made a significant contribution toward providing reliable radiationtolerant systems by offering integrated circuits with enhanced radiation tolerance. Radiation environments, IDT process enhancements and device tolerance levels achieved are described below.

## THE RADIATION ENVIRONMENT

There are four different types of radiation environments that are of concern to builders of military and space systems. These environments and their effects on the device operation, summarized in Figure 1, are as follows:

Total Dose Accumulation refers to the total amount of accumulated gamma rays experienced by the devices in the system, and is measured in RADS (SI) for radiation units experienced at the silicon level. The physical effect of gamma rays on semiconductor devices is to cause threshold shifts (Vt shifts) of both the active transistors as well as the parasitic field transistors. Threshold voltages decrease as total dose is accumulated; at some point, the device will begin to exhibit parametric failures as the input/output and supply currents increase. At higher radiation accumulation levels, functional failures occur. In memory circuits, however, functional failures due to memory cell failure often occur first.

Burst Radiation or Dose Rate refers to the amount of radiation, usually photons or electrons, experienced by the devices in the system due to a pulse event, and is measured in RADS (SI) per second. The effect of a high dose rate or burst of radiation on CMOS integrated circuits is to cause temporary upset of logic states and/or CMOS latch-up. Latchup can cause permanent damage to the device.

Single Event Upset (SEU) is a transient logic state change caused by high-energy ions, such as energetic cosmic rays, striking the integrated circuits. As the ion passes through the silicon, charge is either created through ionization or direct nuclear collision. If collected by a circuit node, this excess charge can cause a change in logic state of the circuit. Dynamic nodes that are not actively held at a particular logic state (dynamic RAM cells for example) are the most susceptible. These upsets are transient, but can cause system failures known as "soft errors."

Neutron Irradiation will cause structural damage to the silicon lattice which may lead to device leakage and, ultimately, functional failure.

| Radlation <br> Category | Primary <br> Particle | Source | Effect |
| :--- | :--- | :--- | :--- |
| Total Dose | Gamma | Space or <br> Nuclear <br> Event | Permanent |
| Dose Rate | Photons | Nuclear <br> Event | Temporary <br> Upset of Logic <br> State or <br> Latch-up |
| SEU | Cosmic <br> Rays | Space | Temporary <br> Upset of <br> Logic State |
| Neutron | Neutrons | Nuclear <br> Event | Device Leakage <br> Due to Silicon <br> Lattice Damage |

Figure 1.

## DEVICE ENHANCEMENTS

Of the four radiation environments above, IDT has taken considerable data on the first two, Total Dose Accumulation and Dose Rate. IDT has developed a process that significantly improves the radiation tolerance of its devices within these environments. Prevention of SEU failures is usually accomplished by system-level considerations, such as Error Detection and Correction (EDC) circuitry, since the occurrence of SEUs is not particularly dependent on process technology. Through IDT's customer contracts, SEU has been gathered on some devices. Little is yet known about the effects of neutron-induced damage. For more information on SEU testing, contact IDT's Radiation Hardened Product Group.

Enhancements to IDT's standard process are used to create radiation enhanced and tolerant processes. Field and gate oxides are "hardened"to make the device less susceptible to radiation damage by modifying the process architecture to allow lower temperature processing. Device implants and Vts adjustments allow more Vt margin. In addition to process changes, IDT's radiation enhanced process utilizes epitaxial substrate material. The use of epi substrate material provides a lower substrate resistance environment to create latch-up free CMOS structures.

## RADIATION HARDNESS CATEGORIES

Radiation Enhanced ('RE) or Radiation Tolerant ('RT) versions of IDT products follow IDT's military product data sheets whenever possible (consult factory). IDT's Total Dose Test plan exposes a sample of die on a wafer to a particular Total Dose level via ARACOR X-Ray radiation. This Total Dose Test plan qualifies each 'RE or 'RT wafer to a Total Dose level. Only waters with sampled die that pass Total Dose level tests are assembled and used for orders (consult factory for more details on Total Dose sample testing). With regard to Total Dose testing, clarifications/exceptions to MIL-STD-883, Methods 5005 and 1019 are required. Consult factory for more details.

The 'RE and 'RT process enhancements enable IDT to offer integrated circuits with varying grades of radiation tolerance or radiation "hardness".

- Radiation Enhanced process uses Epi wafers and is able to provide Logic devices that can be Total Dose qualified to 10K RADs (Si) or greater by IDT's ARACOR X-Ray Total Dose sample die test plan (Total Dose levels require negotiation, consult factory for more details).
- Radiation Tolerant Logic product uses standard wafer/ process material that is qualified to 10 K RADs (Si) Total Dose by IDT's ARACOR X-Ray Total Dose sample die test plan.

Integrated Device Technology can provide Radiation Tolerant/Enhanced versions of all Logic product types (some speed grades may not be available as 'RE).

Please contact your IDT sales representative or factory marketing to determine availability and price of any IDT product processed in accordance with one of these levels of radiation hardness.

## CONCLUSION

There has been widespread interest within the military and space community in IDT's CMOS product line for its radiation hardness levels, as well as its high-performance and low power dissipation. To serve this growing need for CMOS circuits that must operate in a radiation environment, IDT has created a separate group within the company to concentrate on supplying products for these applications.Continuing research and development of process and products, including the use of in-house radiation testing capability, will allow Integrated Device Technology to offer continuously increasing levels of radiation-tolerant solutions.

TECHMOLOCY ARD CAPARMMTES

GUALMY AMD HELABMLTY

## PACKAGE DIAGRAM OUTLINES

## THERMAL PERFORMANCE CALCULATIONS FOR IDT'S PACKAGES

Since most of the electrical energy consumed by microelectronic devices eventually appears as heat, poor thermal performance of the device or lack of management of this thermal energy can cause a variety of deleterious effects. This device temperature increase can exhibit itself as one of the key variables in establishing device performance and long term reliability; on the other hand, effective dissipation of internally generated thermal energy can, if properly managed, reduce the deleterious effects and improve component reliability.

A few key benefits of IDT's enhanced CEMOS ${ }^{\text {TM }}$ process are: low power dissipation, high speed, increased levels of integration, wider operating temperature ranges and lower quiescent power dissipation. Because the reliability of an integrated circuit is largely dependent on the maximum temperature the device attains during operation, and as the junction stability declines with increases in junctiontemperature (TJ), it becomes increasingly important to maintain a low (TJ).

CMOS devices stabilize more quickly and at greatly lower temperature than bipolar devices under normal operation. The accelerated aging of an integrated circuit canbe expressed as an exponential function of the junction temperature as:

$$
t A=\text { to } \exp \left[\frac{E a}{k}\left(\frac{1}{T O}-\frac{1}{T J}\right)\right]
$$

where
t $A=$ lifetime at elevated junction (TJ) temperature
to $=$ normal lifetime at normal junction (TO) temperature
$\mathrm{Ea}=$ activation energy (ev)
$\mathrm{k}=$ Boltzmann's constant ( $8.617 \times 10^{-5} \mathrm{ev} / \mathrm{k}$ )
i.e. the lifetime of a device could be decreased by a factor of 2 for every $10^{\circ} \mathrm{C}$ increase temperature.

To minimize the deleterious effects associated with this potential increase, IDT has:

1. Optimized our proprietary low-power CEMOS fabrication process to ensure the active junction temperature rise is minimal.
2. Selected only packaging materials that optimize heat dissipation, which encourages a cooler running device.
3. Physically designed all package components to enhance the inherent material properties and to take full advantage of heat transfer and radiation due to case geometries.
4. Tightly controlled the assembly procedures to meet or exceed the stringent criteria of MIL-STD-883_to ensure maximum heat transfer between die and packaging materials.
The following figures graphically illustrate the thermal values of IDT's current package families. Each envelop (shaded area) depicts a typical spread of values due to the influence of a number of factors which include: circuit size, package cavity size and die attach integrity. The following range of values are to be used as a comprehensive characterization of the major variables rather than single point of reference.

When calculating junction temperature (TJ), it is necessary to know the thermal resistance of the package ( $\theta J A$ ) as measured in "degree celsius perwatt". With the accompanying data, the following equation can be used to establish thermal performance, enhance device reliability and ultimately provide you, the user, with a continuing series of high-speed, lowpower CMOS solutions to your system design needs.

$$
\begin{aligned}
& \theta J A=[T J-T A] / P \\
& T J=T A+P[\theta J A]=T A+P[\theta J C+\theta C A]
\end{aligned}
$$

where

$\theta=$ Thermal resistance
$\mathrm{J}=$ Junction
$P=$ Operational power of device (dissipated)
$\mathrm{T}_{\mathrm{A}}=$ Ambient temperature in degree celsius
$T J=$ Temperature of the junction
TC = Temperature of case/package
$\theta C A=$ Case to Ambient, thermal resistance-usually a measure of the heat dissipation due to natural or forced convection, radiation and mounting techniques.
$\theta J C=$ Junction to Case, thermal resistance-usually measured with reference to the temperature at a specific point on the package (case) surface. (Dependent on the package material properties and package geometry.)
$\theta J A=$ Junction to Ambient, thermal resistance-usually. measured with respect to the temperature of a specified volume of still air. (Dependent on $\theta \mathrm{Jc}+$ $\theta J A$ which includes the influence of area and environmental condition.)


## PACKAGE DIAGRAM OUTLINE INDEX

SECTION PAGEMONOLITHIC PACKAGE DIAGRAM OUTLINES ..... 4.3
PKG. DESCRIPTION
P16-1 $\quad 16-$ Pin Plastic DIP ( 300 mil ) ..... 29
P18-1 18-Pin Plastic DIP ( 300 mil ) ..... 30
P20-1 20-Pin Plastic DIP ( 300 mil ) ..... 30
P22-1 22-Pin Plastic DIP ( 300 mil ) ..... 29
P24-1 24-Pin Plastic DIP (300 mil) ..... 30
P24-2 24-Pin Plastic DIP (600 mil) ..... 31
P28-1 28-Pin Plastic DIP ( 600 mil ) ..... 31
P28-2 28-Pin Plastic DIP ( 300 mil) ..... 29
P32-1 32-Pin Plastic DIP ( 600 mil ) ..... 31
P32-2 32-Pin Plastic DIP ( 300 mil ) ..... 29
P40-1 40-Pin Plastic DIP ( 600 mil ) ..... 31
P48-1 48-Pin Plastic DIP (600 mil) ..... 31
P64-1 64-Pin Plastic DIP (900 mil) ..... 31
D16-1 16-Pin CERDIP ( 300 mil ) ..... 1
D18-1 18-Pin CERDIP ( 300 mil ) ..... 1
D20-1 20-Pin CERDIP ( 300 mil ) ..... 1
D22-1 22-Pin CERDIP ( 300 mil ) ..... 1
D24-1 24-Pin CERDIP ( 300 mil ) ..... 1
D24-2 24-Pin CERDIP ( 600 mil ) ..... 2
D28-1 28-Pin CERDIP ( 600 mil ) ..... 2
D28-2 28-Pin CERDIP (wide body) ..... 2
D28-3 28-Pin CERDIP ( 300 mil ) ..... 1
D32-1 32-Pin CERDIP (wide body) ..... 2
D40-1 40-Pin CERDIP ( 600 mil ) ..... 2
D40-2 40-Pin CERDIP (wide body) ..... 2
C20-1 20-Pin Sidebraze DIP ( 300 mil ) ..... 3
C22-1 22-Pin Sidebraze DIP (300 mil) ..... 3
C24-1 24-Pin Sidebraze DIP ( 300 mil ) ..... 3
C24-2 24-Pin Sidebraze DIP ( 600 mil ) ..... 5
C28-1 28-Pin Sidebraze DIP ( 300 mil ) ..... 3
C28-2 28-Pin Sidebraze DIP ( 400 mil ) ..... 4
C28-3 28-Pin Sidebraze DIP ( 600 mil ) ..... 5
C32-1 32-Pin Sidebraze DIP ( 600 mil ) ..... 5
C32-2 32-Pin Sidebraze DIP ( 400 mil ) ..... 4
C32-3 32-Pin Sidebraze DIP ( 300 mil ) ..... 3
C40-1 40-Pin Sidebraze DIP ( 600 mil ) ..... 5
C48-1 48-Pin Sidebraze DIP ( 400 mil ) ..... 4
C48-2 48-Pin Sidebraze DIP ( 600 mil ) ..... 5
C64-1 64-Pin Sidebraze DIP (900 mil) ..... 6
C64-2 64-Pin Topbraze DIP ( 900 mil) ..... 7
C68-1 68-Pin Sidebraze DIP ( 600 mil ) ..... 5
PG68-2 68-Lead Plastic Pin Grid Array (cavity up) ..... 43
PG84-2 84-Lead Plastic Pin Grid Array (cavity up) ..... 43
PG208-2 208-Lead Plastic Pin Grid Array (cavity up) ..... 43
G68-1 68-Lead Pin Grid Array (cavity up) ..... 19
G68-2 68-Lead Pin Grid Array (cavity down) ..... 25
G84-1 84 -Lead Pin Grid Array (cavity up - $12 \times 12$ grid) ..... 20
G84-2 84-Lead Pin Grid Array (cavity down) ..... 26
G84-3 84-Lead Pin Grip Array (cavity up - $11 \times 11$ grid) ..... 21
MONOLITHIC PACKAGE DIAGRAM OUTLINES (Continued) ..... 4.3
PKG. DESCRIPTION
G84-4 84-Lead Pin Grid Array (cavity down - MIPS)27
G108-1 108-Lead Pin Grid Array (cavity up) ..... 22
G144-1 144-Lead Pin Grid Array (cavity down) ..... 28
G144-2 144-Lead Pin Grid Array (cavity up) ..... 23
G208-1 208-Lead Pin Grid Array (cavity up) ..... 24
SO16-1 16-Pin Small Outline IC (gull wing) ..... 32
SO16-2 16-Pin Small Outline IC (J-bend) ..... 35
SO16-5 $16-\mathrm{Pin}$ Small Outline IC (EIAJ - .0315 pitch) ..... 34
SO16-6 16-Pin Small Outline IC (EIAJ - . 050 pitch) ..... 34
SO18-1 18-Pin Small Outline IC (gull wing) ..... 32
SO18-6 18-Pin Small Outline IC (EIAJ - . 050 pitch) ..... 34
SO20-1 20-Pin Small Outline IC (J-bend) ..... 35
SO20-2 20-Pin Small Outline IC (gull wing) ..... 32
SO20-5 20-Pin Small Outline IC (EIAJ - . 0315 pitch) ..... 34
SO20-6 20-Pin Small Outline IC (EIAJ - . 050 pitch) ..... 34
SO24-2 24-Pin Small Outline IC (gull wing) ..... 32
SO24-3 24-Pin Small Outline IC (gull wing) ..... 32
SO24-4 24-Pin Small Outline IC (J-bend) ..... 35
SO24-5 24-Pin Small Outline IC (EIAJ - . 0315 pitch) ..... 34
SO24-6 24-Pin Small Outline IC (EIAJ - . 050 pitch) ..... 34
SO28-2 28-Pin Small Outline IC (gull wing) ..... 33
SO28-3 28-Pin Small Outline IC (gull wing) ..... 33
SO28-4 28-Pin Small Outline IC (J-bend - 350 mil) ..... 36
SO28-5 28-Pin Small Outline IC (J-bend - 300 mil ) ..... 36
SO28-6 28-Pin Small Outline IC (EIAJ - . 050 pitch) ..... 34
SO32-2 32-Pin Small Outline IC ( J -bend) ..... 36
SO48-1 48-Pin Small Outline IC (SSOP - gull wing) ..... 37
SO56-1 56-Pin Small Outline IC (SSOP - gull wing) ..... 37
J18-1 18-Pin Plastic Leaded Chip Carrier (rectangular) ..... 42
J20-1 20-Pin Plastic Leaded Chip Carrier (square) ..... 41J28-1J32-1J44-1J52-1J68-1J84-1
L20-1
28-Pin Plastic Leaded Chip Carrier (square) ..... 41
32-Pin Plastic Leaded Chip Carrier (rectangular) ..... 42
44-Pin Plastic Leaded Chip Carrier (square) ..... 41
52-Pin Plastic Leaded Chip Carrier (square) ..... 41
68-Pin Plastic Leaded Chip Carrier (square) ..... 41
84-Pin Plastic Leaded Chip Carrier (square) ..... 41
20-Pin Leadless Chip Carrier (rectangular) ..... 18120-2
20-Pin Leadless Chip Carrier (square) ..... 16
22-Pin Leadless Chip Carrier (rectangular) ..... 18
L22-1
24-Pin Leadless Chip Carrier (rectangular) ..... 18 ..... 18
L24-1
L24-1
28-Pin Leadless Chip Carrier (square) ..... 16
L28-1
L28-1
28-Pin Leadless Chip Carrier (rectangular)
28-Pin Leadless Chip Carrier (rectangular) ..... 18
L32-1 32-Pin Leadless Chip Carrier (rectangular) ..... 18L44-1
44-Pin Leadless Chip Carrier (square) ..... 16
48-Pin Leadless Chip Carrier (square) ..... 16
52-Pin Leadless Chip Carrier (square) ..... 17
L52-2 52-Pin Leadless Chip Carrier (square) ..... 17
L68-1 68-Pin Leadless Chip Carrier (square) ..... 17
L68-2 68-Pin Leadless Chip Carrier (square) ..... 17
MONOLITHIC PACKAGE DIAGRAM OUTLINES (Continued) ..... 4.3
PKG. DESCRIPTION ..... PAGE
E16-1 16-Lead CERPACK ..... 13
E20-1 20-Lead CERPACK ..... 13
E24-1 24-Lead CERPACK ..... 13
E28-1 28-Lead CERPACK ..... 13
E28-2 28-Lead CERPACK ..... 13
CQ68-1 68-Lead CERQUAD (straight leads) ..... 14
CQ84-1 84-Lead CERQUAD (J-bend) ..... 15
F20-1 20-Lead Flatpack ..... 8
20-Lead Flatpack (. 295 body) ..... 8
F24-1 24-Lead Flatpack ..... 8
F28-1 28-Lead Flatpack ..... 8
F28-2 28-Lead Flatpack ..... 8
F48-1 48-Lead Quad Flatpack ..... 9
F64-1 64-Lead Quad Flatpack ..... 9
F68-1 68-Lead Quad Flatpack ..... 10
F84-1 84-Lead Quad Flatpack (cavity down) ..... 11
F172-1 172-Lead Quad Flatpack (MIPS) ..... 12
PQ80-2 80-Lead Plastic Quad Flatpack (IEAH) ..... 39
PQ100-1 100-Lead Plastic Quad Flatpack (JEDEC) ..... 28
PQ100-2 100-Lead Plastic Quad Flatpack (EIAJ) ..... 39
PQ120-2 120-Lead Plastic Quad Flatpack (EIAJ) ..... 39
PQ128-2 128-Lead Plastic Quad Flatpack (EIAN) ..... 39
PQ132-1 132-Lead Plastic Quad Flatpack (JEDEC) ..... 38
PQ144-2 144-Lead Plastic Quad Flatpack (EIAJ) ..... 40
PQ160-2 160-Lead Plastic Quad Flatpack (EIAJ) ..... 40
PQ184-2 184-Lead Plastic Quad Flatpack (EIAJ) ..... 40
PQ208-2 208-Lead Plastic Quad Flatpack (EIAJ) ..... 40
MODULE PACKAGE DIAGRAM OUTLINES ..... 4.4
M1 28-Pin Ceramic Sidebraze DIP ..... 1
M2 28-Pin Ceramic Sidebraze DIP ..... 2
M3 32-Pin Ceramic Sidebraze DIP ..... 3
M4 32-Pin Ceramic Sidebraze DIP ..... 4
M5 32-Pin FR-4 DIP ..... 4
32-Pin Ceramic Sidebraze DIP ..... 5
32-Pin Ceramic Sidebraze DIP ..... 6
40-Pin Ceramic Sidebraze DIP ..... 7
40-Pin Ceramic Sidebraze DIP ..... 8
40-Pin Ceramic Sidebraze DIP ..... 9
40-Pin Ceramic Sidebraze DIP ..... 10
40-Pin Ceramic Sidebraze DIP ..... 11
44-Pin FR-4 DIP ..... 12
44-Pin FR-4 DIP ..... 13
48-Pin Ceramic Sidebraze DIP ..... 14
60-Pin Ceramic Sidebraze DIP ..... 15
64-Pin Ceramic Sidebraze DIP ..... 15
80-Pin Ceramic Sidebraze QIP ..... 16
80-Pin Ceramic Sidebraze QIP ..... 17

## SECTION PAGE

MODULE PACKAGE DIAGRAM OUTLINES (Continued) ..... 4.4
M20 92-Pin FR-4 QIP ..... 18
M21 92-Pin FR-4 QIP ..... 19
92-Pin FR-4 QIP ..... 20
104-Pin FR-4 QIP ..... 21
104-Pin FR-4 QIP ..... 22
104-Pin FR-4 QIP ..... 23
120-Pin FR-4 QIP ..... 24
120-Pin FR-4 QIP ..... 25
128-Pin FR-4 QIP ..... 26
128-Pin FR-4 QIP ..... 27
132-Pin FR-4 QIP ..... 28
164-Pin FR-4 QIP ..... 29
66-Pin Ceramic Sidebraze HIP ..... 30
121-Pin Ceramic Sidebraze PGA ..... 31
28-Pin FR-4 SIP ..... 32
30-Pin Ceramic Sidebraze SIP ..... 33
30-Pin FR-4 SIP ..... 34
36-Pin FR-4 SIP ..... 34
36-Pin FR-4 SIP ..... 35
40-Pin FR-4 SIP ..... 35
40-Pin FR-4 SIP ..... 35
45-Pin FR-4 SIP ..... 36
36-Pin Ceramic Sidebraze DSIP ..... 37
M43 88-Pin Ceramic Sidebraze DSIP ..... 37
M44 42-Pin FR-4 ZIP ..... 38
52-Pin FR-4 ZIP ..... 38
64-Pin FR-4 ZIP ..... 39
M46
64-Pin FR-4 ZIP ..... 39
40-Pin FR-4 SIMM ..... 40
M4840-Pin FR-4 SIMM40


## DUAL IN-LINE PACKAGES



NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. THE MINIMUM LIMIT FOR DIMENSION b1 MAY BE . 023 FOR CORNER LEADS.

## 16-28 LEAD CERDIP (300 MIL)

| DWG \# | D16-1 |  | D18-1 |  | D20-1 |  | $D 22-1$ |  | D24-1 |  | D28-3 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 16 |  | 18 |  | 20 |  | 22 |  | 24 |  | 28 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | .140 | .200 | .140 | .200 | .140 | .200 | .105 | .175 | .105 | .175 | .105 | .175 |
| b | .015 | .021 | .015 | .021 | .015 | .021 | .015 | .021 | .015 | .021 | .015 | .021 |
| b1 | .038 | .060 | .038 | .060 | .038 | .060 | .038 | .060 | .045 | .065 | .045 | .065 |
| C | .009 | .012 | .009 | .012 | .009 | .012 | .009 | .012 | .009 | .014 | .009 | .014 |
| D | .750 | .830 | .880 | .930 | .935 | 1.060 | 1.050 | 1.080 | 1.240 | 1.280 | 1.440 | 1.490 |
| E | .285 | .310 | .285 | .310 | .285 | .310 | .285 | .310 | .285 | .310 | .285 | .310 |
| E1 | .290 | .320 | .290 | .320 | .290 | .320 | .290 | .320 | .300 | .320 | .300 | .320 |
| e | .100 | BSC | .100 | BSC | .100 | BSC | .100 | BSC | .100 | BSC | .100 | BSC |
| L | .125 | .175 | .125 | .175 | .125 | .175 | .125 | .175 | .125 | .175 | .125 | .175 |
| L1 | .150 | - | .150 | - | .150 | - | .150 | - | .150 | - | .150 | - |
| Q | .015 | .055 | .015 | .055 | .015 | .060 | .015 | .060 | .015 | .060 | .015 | .060 |
| S | .020 | .080 | .020 | .080 | .020 | .080 | .020 | .080 | .030 | .080 | .030 | .080 |
| S1 | .005 | - | .005 | - | .005 | - | .005 | - | .005 | - | .005 | - |
| $\alpha$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | 0 | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ |

## DUAL IN-LINE PACKAGES (Continued)

## 24-40 LEAD CERDIP (600 MIL)

| DWG \# | D24-2 |  | D28-1 |  | D40-1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 24 |  | 28 |  | 40 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX |
| A | .090 | .190 | .090 | .200 | .160 | .220 |
| b | .014 | .023 | .014 | .023 | .014 | .023 |
| b1 | .038 | .060 | .038 | .065 | .038 | .065 |
| C | .008 | .012 | .008 | .014 | .008 | .014 |
| D | 1.230 | 1.290 | 1.440 | 1.490 | 2.020 | 2.070 |
| E | .500 | .610 | .510 | .545 | .510 | .545 |
| E1 | .590 | .620 | .590 | .620 | .590 | .620 |
| e | .100 BSC | .100 | BSC | .100 BSC |  |  |
| L | .125 | .200 | .125 | .200 | .125 | .200 |
| L1 | .150 | - | .150 | - | .150 | - |
| Q | .015 | .060 | .020 | .060 | .020 | .060 |
| S | .030 | .080 | .030 | .080 | .030 | .080 |
| S1 | .005 | - | .005 | - | .005 | - |
| $\alpha$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ |

## 28-40 LEAD CERDIP (WIDE BODY)

| DWG \# | D28-2 |  | D32-1 |  | D40-2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 28 |  | 32 |  | 40 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX |
| A | .090 | .200 | .120 | .210 | .160 | .220 |
| b | .014 | .023 | .014 | .023 | .014 | .023 |
| b1 | .038 | .065 | .038 | .065 | .038 | .065 |
| C | .008 | .014 | .008 | .014 | .008 | .014 |
| D | 1.440 | 1.490 | 1.625 | 1.675 | 2.020 | 2.070 |
| E | .570 | .600 | .570 | .600 | .570 | .600 |
| E1 | .590 | .620 | .590 | .620 | .590 | .620 |
| e | .100 | BSC | .100 | BSC | .100 BSC |  |
| L | .125 | .200 | .125 | .200 | .125 | .200 |
| L1 | .150 | - | .150 | - | .150 | - |
| Q | .020 | .060 | .020 | .060 | .020 | .060 |
| S | .030 | .080 | .030 | .080 | .030 | .080 |
| S1 | .005 | - | .005 | - | .005 | - |
| $\alpha$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ |

## DUAL IN-LINE PACKAGES (Continued)

20-32 LEAD SIDE BRAZE (300 MIL)


NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

| DWG \# | C20-1 |  | C22-1 |  | C24-1 |  | C28-1 |  | C32-3 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 20 |  | 22 |  | 24 |  | 28 |  | 32 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 090 | 200 | . 100 | 200 | . 090 | 200 | . 090 | 200 | 090 | 200 |
| b | . 014 | . 023 | . 014 | . 023 | . 015 | . 023 | . 014 | . 023 | . 014 | . 023 |
| b1 | . 040 | . 060 | . 038 | . 060 | . 040 | 060 | . 040 | . 060 | . 040 | . 060 |
| C | . 008 | . 015 | . 008 | . 015 | . 008 | . 015 | . 008 | . 015 | . 008 | . 014 |
| D | . 970 | 1.060 | 1.040 | 1.120 | 1.180 | 1.230 | 1.380 | 1.420 | 1.580 | 1.640 |
| E | 220 | . 310 | 260 | 310 | 220 | . 310 | 220 | . 310 | 280 | . 310 |
| E1 | 290 | 320 | 290 | 320 | 290 | 320 | 290 | . 320 | 290 | 320 |
| e | . 100 BSC |  | . 100 BSC |  | . 100 BSC |  | . 100 BSC |  | . 100 BSC |  |
| L | . 125 | . 200 | . 125 | . 200 | . 125 | . 200 | . 125 | 200 | . 100 | . 175 |
| L1 | . 150 | - | . 150 | - | . 150 | - | . 150 | - | . 150 | - |
| Q | . 015 | . 060 | . 015 | . 060 | . 015 | . 060 | . 015 | . 060 | . 030 | 060 |
| S | . 030 | 065 | . 030 | . 065 | . 030 | . 065 | . 030 | . 065 | . 030 | 065 |
| S1 | . 005 | - | . 005 | - | . 005 | - | . 005 | - | . 005 | - |
| S2 | . 005 | - | . 005 | - | . 005 | - | . 005 | - | 005 | - |

DUAL IN-LINE PACKAGES (Continued)
28-48 LEAD SIDE BRAZE (400 MIL)


48 LEAD OPTION


NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

| DWG \# | C28-2 |  | C32-2 |  | C48-1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 28 |  | 32 |  | 48 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX |
| A | .090 | .200 | .090 | .200 | .085 | .190 |
| b | .014 | .023 | .014 | .023 | .014 | .023 |
| b1 | .040 | .060 | .040 | .060 | .040 | .060 |
| C | .008 | .014 | .008 | .014 | .008 | .014 |
| D | 1.380 | 1.420 | 1.580 | 1.640 | 1.690 | 1.730 |
| E | .380 | .420 | .380 | .410 | .380 | .410 |
| E1 | .390 | .420 | .390 | .420 | .390 | .420 |
| e | .100 BSC | .100 | BSC | .070 | BSC |  |
| L | .100 | .175 | .100 | .175 | .125 | .175 |
| L1 | .150 | - | .150 | - | .150 | - |
| Q | .030 | .060 | .030 | .060 | .020 | .070 |
| S | .030 | .065 | .030 | .065 | .030 | .065 |
| S1 | .005 | - | .005 | - | .005 | - |
| S2 | .005 | - | .005 | - | .005 | - |

## DUAL IN-LINE PACKAGES (Continued)

24-68 LEAD SIDE BRAZE (600 MIL)


NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

| DWG 4 | C24-2 |  | C28-3 |  | C32-1 |  | C40-1 |  | C48-2 |  | C68-1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HOF LDS (N) | 24 |  | 28 |  | 32 |  | 40 |  | 48 |  | 68 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 090 | . 190 | . 085 | . 190 | . 100 | . 190 | . 085 | . 190 | . 100 | . 190 | . 085 | . 190 |
| b | . 015 | . 023 | . 015 | . 022 | . 015 | . 023 | . 015 | . 023 | . 015 | . 023 | . 015 | . 023 |
| b1 | . 040 | . 060 | . 038 | . 060 | . 040 | . 060 | . 038 | . 060 | . 040 | . 060 | . 040 | . 060 |
| C | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 |
| D | 1.180 | 1.220 | 1.380 | 1.430 | 1.580 | 1.640 | 1.980 | 2.030 | 2.370 | 2.430 | 2.380 | 2.440 |
| E | . 575 | . 610 | . 580 | . 610 | . 580 | . 610 | . 580 | . 610 | . 550 | . 610 | . 580 | . 610 |
| E1 | . 595 | . 620 | . 595 | . 620 | . 590 | . 620 | . 595 | . 620 | . 590 | . 620 | . 580 | . 620 |
| e | . 100 BSC |  | . 100 BSC |  | . 100 BSC |  | . 100 BSC |  | . 100 BSC |  | . 070 BSC |  |
| L | . 125 | . 175 | . 125 | . 175 | . 125 | . 175 | . 125 | . 175 | . 125 | . 175 | . 125 | . 175 |
| L1 | . 150 | - | . 150 | - | . 150 | - | . 150 | - | . 150 | - | . 150 | - |
| Q | . 020 | . 060 | . 020 | . 065 | . 020 | . 060 | . 020 | . 060 | . 020 | . 060 | . 020 | . 070 |
| S | . 030 | . 065 | . 030 | . 065 | . 030 | . 065 | . 030 | . 065 | . 030 | . 065 | . 030 | . 065 |
| S1 | . 005 | - | . 005 | - | . 005 | - | . 005 | - | . 005 | - | . 005 | - |
| S2 | . 010 | - | . 010 | - | . 005 | - | . 010 | - | . 005 | - | . 005 | - |

## DUAL IN-LINE PACKAGES (Continued)

## 64 LEAD SIDE BRAZE ( 900 MIL )



NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - bASIC LEAD SPACING BETWEEN CENTERS.

| DWG \# |  | C64-1 |  |
| :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 64 |  |  |
| SYMBOL | MIN | MAX |  |
| A | .110 | .190 |  |
| b | .014 | .023 |  |
| b1 | .040 | .060 |  |
| C | .008 | .015 |  |
| D | 3.160 | 3.240 |  |
| E | .884 | .915 |  |
| E1 | .890 | .920 |  |
| e | .100 | BSC |  |
| L | .125 | .200 |  |
| L1 | .150 | - |  |
| Q | .015 | .070 |  |
| S | .030 | .065 |  |
| S1 | .005 | - |  |
| S2 | .005 | - |  |

## DUAL IN-LINE PACKAGES (Continued)

## 64 LEAD TOP BRAZE (900 MIL)



NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

| DWG \# | C64-2 |  |
| :---: | :---: | :---: |
| \# OF LDS (N) | 64 |  |
| SYMBOL | MIN | MAX |
| A | .120 | .180 |
| b | .015 | .021 |
| b1 | .040 | .060 |
| C | .009 | .012 |
| D | 3.170 | 3.240 |
| E | .790 | .810 |
| E1 | .880 | .815 |
| E2 | .640 | .660 |
| e | .100 | BSC |
| L | .125 | .160 |
| L1 | .150 | - |
| Q | .020 | .100 |
| S | .030 | .065 |
| S1 | .005 | - |
| S2 | .005 | - |

## FLATPACKS

## 20-28 LEAD FLATPACK



## NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

| DWG \# | F20-1 |  | F20-2 |  | F24-1 |  | F28-1 |  | F28-2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 20 |  | 20 (.295 BODY) |  | 24 |  | 28 |  | 28 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 045 | . 092 | . 045 | . 092 | . 045 | . 090 | . 045 | . 090 | . 045 | . 115 |
| b | . 015 | . 019 | . 015 | . 019 | . 015 | . 019 | . 015 | . 019 | . 015 | . 019 |
| C | . 003 | . 006 | . 003 | . 006 | . 003 | . 006 | . 004 | . 007 | . 003 | . 007 |
| D | - | . 540 | - | . 540 | - | . 640 | . 710 | . 740 | . 710 | . 740 |
| E | . 340 | . 360 | . 245 | . 303 | . 360 | . 420 | . 480 | . 520 | . 460 | . 520 |
| E2 | . 130 | - | . 130 | - | . 180 | - | . 180 | - | . 180 | - |
| E3 | . 030 | - | . 030 | - | . 030 | - | . 040 | - | . 040 | - |
| e | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  |
| K | . 008 | . 015 | . 008 | . 015 | . 008 | . 015 | . 008 | . 015 | . 008 | . 015 |
| L | . 250 | . 370 | . 250 | . 370 | . 250 | . 370 | . 250 | . 370 | . 250 | . 370 |
| Q | . 010 | . 040 | . 010 | . 040 | . 010 | . 040 | . 010 | . 045 | . 010 | . 045 |
| S | - | . 045 | - | . 045 | - | . 045 | - | . 045 | - | . 045 |
| S1 | . 005 | - | . 005 | - | . 005 | - | . 005 | - | . 005 | - |

## FLATPACKS (Continued)

## 48-64 LEAD QUAD FLATPACK



NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

| DWG \# | F48-1 |  | F64-1 |  |
| :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 48 |  | 64 |  |
| SYMBOL | MIN | MAX | MIN | MAX |
| A | .089 | .108 | .070 | .090 |
| A1 | .079 | .096 | .060 | .078 |
| A2 | .058 | .073 | .030 | .045 |
| b | .018 | .022 | .016 | .020 |
| C | .008 | .010 | .009 | .012 |
| D/E | - | .750 | .885 | .915 |
| D1/E1 | .100 REF |  | .075 REF |  |
| D2/E2 | .550 BSC | .750 BSC |  |  |
| e | .050 BSC |  | .050 BSC |  |
| L | .350 | .450 | .350 | .450 |
| ND/NE | 12 |  | 16 |  |

## FLATPACKS (Continued)

## 68 LEAD QUAD FLATPACK



| DWG \# |  | F68-1 |  |
| :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 68 |  |  |
| SYMBOL | MIN | MAX |  |
| A | .080 | .145 |  |
| A1 | .070 | .090 |  |
| b | .014 | .021 |  |
| C | .008 | .012 |  |
| D/E | 1.640 | 1.870 |  |
| D1/E1 | .926 | .970 |  |
| D2/E2 | .800 BSC |  |  |
| $e$ | .050 | BSC |  |
| L | .350 | .450 |  |
| ND/NE | 17 |  |  |

## FLATPACKS (Continued)

84 LEAD QUAD FLATPACK (CAVITY DOWN)


| DWG \# |  | F84-1 |  |
| :---: | :---: | :---: | :---: |
| If OF LDS (N) | 84 |  |  |
| SYMBOL | MIN | MAX |  |
| A | - | .140 |  |
| A1 | - | .105 |  |
| b | .014 | .020 |  |
| C | .007 | .013 |  |
| D/E | 1.485 | 1.615 |  |
| D1/E1 | 1.130 | 1.170 |  |
| D2/E2 | 1.000 BSC |  |  |
| D3/E3 | .500 BSC |  |  |
| e | .050 BSC |  |  |
| L | .350 | .450 |  |
| ND/NE | 21 |  |  |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. CROSS HATCHED AREA INDICATES INTEGRAL METALLC HEAT SINK.


FLATPACKS (Continued)
172 LEAD QUAD FLATPACK (MIPS)


| DWG \# | F172-1 |  |
| :---: | :---: | :---: |
| \# OF LDS (N) | 172 |  |
| SYMBOL | MIN | MAX |
| $A$ | - | .130 |
| A1 | - | .105 |
| $b$ | .006 | .010 |
| C | .004 | .008 |
| D/E | 1.580 | 1.620 |
| D1/E1 | 1.135 | 1.165 |
| D2/E2 | 1.050 BSC |  |
| $D 3 / E 3$ | .525 BSC |  |
| $e$ | $.025 ~ B S C$ |  |
| L | .220 | .230 |
| ND/NE | 43 |  |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.


## CERPACKS

16-28 LEAD CERPACK


NOTES:

1. ALL DIMENSION ARE IN INCHES, UNLESS OTHERMSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

| DWG \# | E16-1 |  | E20-1 |  | E24-1 |  | E28-1 |  | E28-2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 16 |  | 20 |  | 24 |  | 28 |  | 28 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | .055 | .085 | .045 | .092 | .045 | .090 | .045 | .115 | .045 | .090 |
| b | .015 | .019 | .015 | .019 | .015 | .019 | .015 | .019 | .015 | .019 |
| C | .0045 | .006 | .0045 | .006 | .0045 | .006 | .0045 | .009 | .0045 | .006 |
| D | .370 | .430 | - | .540 | - | .640 | - | .740 | - | .740 |
| E | .245 | .285 | .245 | .300 | .300 | .420 | .460 | .520 | .340 | .380 |
| E1 | - | .305 | - | .305 | - | .440 | - | .550 | - | .400 |
| e | .050 | BSC | .050 | BSC | .050 | BSC | .050 | BSC | .050 | BSC |
| K | .008 | .015 | .008 | .015 | .008 | .015 | .008 | .015 | .008 | .015 |
| L | .250 | .370 | .250 | .370 | .250 | .370 | .250 | .370 | .250 | .370 |
| Q | .026 | .040 | .026 | .040 | .026 | .040 | .026 | .045 | .026 | .045 |
| S | - | .045 | - | .045 | - | .045 | - | .045 | - | .045 |
| S1 | .005 | - | .005 | - | .005 | - | .005 | - | .005 | - |

## CERQUADS

## 68 LEAD CERQUAD (STRAIGHT LEADS)



NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

| DWG \# |  | CQ68-1 |  |
| :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 68 |  |  |
| SYMBOL | MIN | MAX |  |
| A | .115 | .165 |  |
| b | .008 | .013 |  |
| C | .0045 | .008 |  |
| D/E | .860 | 1.100 |  |
| D1/E1 | .460 | .500 |  |
| D3/E3 | .400 REF |  |  |
| $e$ | .025 BSC |  |  |
| L | .200 | .300 |  |
| ND/NE | 17 |  |  |

## CERQUADS (Continued)

## 84 LEAD CERQUAD (J-BEND)



| DWG \# | CQ84-1 |  |
| :---: | :---: | :---: |
| \# OF LDS (N) | 84 |  |
| SYMBOL | MIN | MAX |
| A | .155 | .200 |
| A1 | .090 | .120 |
| b1 | .022 | .032 |
| b | .013 | .023 |
| C | .006 | .013 |
| D/E | 1.170 | 1.190 |
| D1/E1 | 1.138 | 1.162 |
| D2/E2 | 1.100 | .1 .150 |
| D3/.E3 | 1.000 BSC |  |
| e | .050 BSC |  |
| ND/NE | 21 |  |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

## LEADLESS CHIP CARRIERS



| DWG \# | L20-2 |  | L28-1 |  | L44-1 |  | L48-1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| O OF LDS (N) | 20 |  | 28 |  | 44 |  | 48 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 064 | . 100 | . 064 | . 100 | . 064 | . 120 | . 055 | . 120 |
| A1 | . 054 | . 066 | . 050 | . 088 | . 054 | . 088 | . 045 | . 090 |
| B1 | . 022 | . 028 | . 022 | . 028 | . 022 | . 028 | . 017 | . 023 |
| B2 | . 072 REF |  | . 072 REF |  | . 072 REF |  | . 072 REF |  |
| B3 | . 006 | . 022 | . 006 | . 022 | . 006 | . 022 | . 005 | . 022 |
| D/E | . 342 | . 358 | . 442 | . 460 | . 640 | . 660 | . 554 | . 572 |
| D1/E1 | . 200 BSC |  | . 300 BSC |  | . 500 BSC |  | . 440 BSC |  |
| D2/E2 | . 100 BSC |  | . 150 BSC |  | . 250 BSC |  | . 220 BSC |  |
| D3/E3 | - | . 358 | - | . 460 | - | . 560 | . 500 | . 535 |
| e | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  | . 040 BSC |  |
| e1 | . 015 | - | . 015 | - | . 015 | - | . 015 | - |
| h | . 040 REF |  | . 040 REF |  | . 040 REF |  | . 012 RADIUS |  |
| $J$ | . 020 REF |  | . 020 REF |  | . 020 REF |  | . 020 REF |  |
| L | . 045 | . 055 | . 045 | . 055 | . 045 | . 055 | . 033 | . 047 |
| 11 | . 045 | . 055 | . 045 | . 055 | . 045 | . 055 | . 033 | . 047 |
| L2 | . 077 | . 093 | . 077 | . 093 | . 077 | . 093 | . 077 | . 093 |
| L3 | . 003 | . 015 | . 003 | . 015 | . 003 | . 015 | . 003 | . 015 |
| ND/NE | 5 |  | 7 |  | 11 |  | 12 |  |

## LEADLESS CHIP CARRIERS (Continued)

> 52-68 LEAD LCC (SQUARE)

| DWG \# | L52-1 |  | L52-2 |  | L68-2 |  | L68-1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 52 |  | 52 |  | 68 |  | 68 |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 061 | . 087 | . 082 | . 120 | . 082 | . 120 | . 065 | . 120 |
| A1 | . 051 | . 077 | . 072 | . 088 | . 072 | . 088 | . 055 | . 075 |
| B1 | . 022 | . 028 | . 022 | . 028 | . 022 | . 028 | . 008 | . 014 |
| B2 | . 072 REF |  | . 072 REF |  | . 072 REF |  | . 072 REF |  |
| B3 | . 006 | . 022 | . 006 | . 022 | . 006 | . 022 | . 006 | . 022 |
| D/E | . 739 | . 761 | . 739 | . 761 | . 938 | . 962 | . 554 | . 566 |
| D1/E1 | . 600 BSC |  | . 600 BSC |  | . 800 BSC |  | . 400 BSC |  |
| D2/E2 | . 300 BSC |  | . 300 BSC |  | . 400 BSC |  | . 200 BSC |  |
| D3/E3 | - | . 661 | - | . 661 | - | . 862 | - | . 535 |
| e | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  | . 025 BSC |  |
| e1 | . 015 | - | . 015 | - | . 015 | - | . 015 | - |
| h | . 040 REF |  | . 040 REF |  | . 040 REF |  | . 040 REF |  |
| $J$ | . 020 REF |  | . 020 REF |  | . 020 REF |  | . 020 REF |  |
| L | . 045 | . 055 | . 045 | . 055 | . 045 | . 055 | . 045 | . 055 |
| L1 | . 045 | . 055 | . 045 | . 055 | . 045 | . 055 | . 045 | . 055 |
| L2 | . 077 | . 093 | . 075 | . 093 | . 077 | . 093 | . 077 | . 093 |
| L3 | . 003 | . 015 | . 003 | . 015 | . 003 | . 015 | . 003 | . 015 |
| ND/NE | 13 |  | 13 |  | 17 |  | 17 |  |

LEADLESS CHIP CARRIERS (Continued)


NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.

20-32 LEAD LCC (RECTANGULAR)



## PIN GRID ARRAYS

68 PIN PGA (CAVITY UP)


| DWG \# |  | G68-1 |  |
| :---: | :---: | :---: | :---: |
| $\#$ OF PINS (N) | 68 |  |  |
| SYMBOL | MIN | MAX |  |
| A | .070 | .145 |  |
| $\phi$ B | .016 | .020 |  |
| $\phi$ B1 | - | .080 |  |
| $\phi$ B2 | .040 | .060 |  |
| D/E | 1.140 | 1.180 |  |
| D1/E1 | 1.000 BSC |  |  |
| $e$ | .100 BSC |  |  |
| L | .120 | .140 |  |
| $M$ | 11 |  |  |
| $Q$ | .040 | .060 |  |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SMMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL " $N$ " REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.

## PIN GRID ARRAYS (Continued)

84 PIN PGA (CAVITY UP - $12 \times 12$ GRID)


| DWG \#\# | G84-1 |  |
| :---: | :---: | :---: |
| 7 OF PINS (N) | 84 |  |
| SYMBOL | MIN | MAX |
| A | . 077 | . 145 |
| \$8 | . 016 | . 020 |
| ¢ ${ }^{\text {B1 }}$ | . 040 | . 080 |
| - ${ }^{\text {B2 }}$ | . 040 | . 060 |
| D/E | 1.180 | 1.235 |
| D1/E1 | 1.100 BSC |  |
| e | . 100 BSC |  |
| L | . 120 | . 140 |
| M | 12 |  |
| Q | . 040 | . 060 |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SYMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL "N" REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.

## PIN GRID ARRAYS (Continued)

84 PIN PGA (CAVITY UP - 11 X 11 GRID)


| DWG \# |  | G84-3 |  |
| :---: | :---: | :---: | :---: |
| P OF PINS (N) | 84 |  |  |
| SYMBOL | MIN | MAX |  |
| A | .070 | .145 |  |
| $\phi B$ | .016 | .020 |  |
| QB1 | - | .080 |  |
| $\phi B 2$ | .040 | .060 |  |
| D/E | 1.080 | 1.120 |  |
| D1/E1 | 1.000 BSC |  |  |
| e | .100 |  |  |
| BSC |  |  |  |
| L | .120 | .140 |  |
| Q | 11 |  |  |
|  | .040 | .060 |  |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SYMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL "N" REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.

## PIN GRID ARRAYS (Continued)

108 PIN PGA (CAVITY UP)


| DWG \# | G108-1 |  |
| :---: | :---: | :---: |
| \# OF PINS (N) | 108 |  |
| SMMBOL | MIN | MAX |
| A | . 070 | . 145 |
| ¢ ${ }^{\text {B }}$ | . 016 | . 020 |
| \$B1 | - | . 080 |
| ¢ ${ }^{\text {B2 }}$ | . 040 | . 060 |
| D/E | 1.188 | 1.212 |
| D1/E1 | 1.100 BSC |  |
| e | . 100 BSC |  |
| L | . 120 | . 140 |
| M | 12 |  |
| 0 | . 040 | . 060 |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SYMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL " $N$ " REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.

## PIN GRID ARRAYS (Continued)

144 PIN PGA (CAVITY UP)


| DWG \# | G144-2 |  |
| :---: | :---: | :---: |
| \# OF PINS (N) | 145 |  |
| SYMBOL | MIN | MAX |
| A | . 082 | . 125 |
| ¢ B | . 016 | . 020 |
| ¢ ${ }^{\text {B1 }}$ | . 060 | . 080 |
| 9B2 | . 040 | . 060 |
| D/E | 1.559 | 1.590 |
| D1/E1 | 1.400 BSC |  |
| e | . 100 BSC |  |
| L | . 120 | . 140 |
| M | 15 |  |
| Q | . 040 | . 060 |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SYMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL "N" REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.
6. EXTRA PIN (D-4) ELECTRICALLY CONNECTED TO D-3.

208 PIN PGA (CAVITY UP)


| DWG \# |  | G208-1 |  |
| :---: | :---: | :---: | :---: |
| $\#$ OF PINS (N) | 208 |  |  |
| SYMBOL | MIN | MAX |  |
| A | .070 | .145 |  |
| $\phi B$ | .016 | .020 |  |
| $\phi B 1$ | - | .080 |  |
| $\phi$ B2 | .040 | .060 |  |
| D/E | 1.732 | 1.780 |  |
| D1/E1 | 1.600 BSC |  |  |
| e | .100 BSC |  |  |
| L | .125 | .140 |  |
| M | 17 |  |  |
| Q | .040 | .060 |  |

NOTES:

1. ALI DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SYMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL " $N$ " REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.

## PIN GRID ARRAYS (Continued)

68 PIN PGA (CAVITY DOWN)


| DWG \# | G68-2 |  |
| :---: | :---: | :---: |
| \# OF PINS (N) | 68 |  |
| SYMBOL | MIN | MAX |
| A | .077 | .095 |
| фB | .016 | .020 |
| $\phi B 1$ | .060 | .080 |
| $\phi$ B2 | .040 | .060 |
| D/E | 1.098 | 1.122 |
| D1/E1 | 1.000 | BSC |
| e | .100 |  |
| BSC |  |  |
| M | .120 | .140 |
| Q1 | 11 |  |
|  | .025 | .060 |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SYMBOL " $M$ " REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL " $N$ " REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.

## PIN GRID ARRAYS (Continued)

84 PIN PGA (CAVITY DOWN)


| DWG \#, | G84-2 |  |
| :---: | :---: | :---: |
| \# OF PINS (N) | 84 |  |
| SYMBOL | MIN | MAX |
| A | . 077 | . 145 |
| ¢ ${ }^{\text {B }}$ | . 016 | . 020 |
| ¢ ${ }^{\text {B } 1}$ | . 060 | . 080 |
| 9B2 | . 040 | . 060 |
| D/E | 1.180 | 1.235 |
| D1/E1 | 1.100 BSC |  |
| e | . 100 BSC |  |
| L | . 100 | . 120 |
| M | 12 |  |
| Q1 | . 025 | . 060 |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SMMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL " $N$ " REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.

## PIN GRID ARRAYS (Continued)

## 84 PIN PGA (CAVITY DOWN - MIPS)



| DWG \# | G84-4 |  |
| :---: | :---: | :---: |
| \# OF PINS (N) | 84 |  |
| SYMBOL | MIN | MAX |
| A | . 077 | . 145 |
| ¢ ${ }^{\text {B }}$ | . 016 | . 020 |
| ¢ $\mathrm{B}^{1}$ | . 060 | . 080 |
| 9B2 | . 040 | . 060 |
| D/E | 1.180 | 1.235 |
| D1/E1 | 1.100 BSC |  |
| e | . 100 BSC |  |
| L | . 120 | . 140 |
| M | 12 |  |
| Q1 | . 025 | . 060 |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SYMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL " $N$ " REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.
6. CROSS HATCHED AREA INDICATES INTEGRALI METALLC HEAT SINK.

## PIN GRID ARRAYS (Continued)

144 PIN PGA (CAVITY DONN)


| DWG \# |  | G144-1 |  |
| :---: | :---: | :---: | :---: |
| \# OF PINS (N) | 144 |  |  |
| SYMBOL | MIN | MAX |  |
| A | .082 | .100 |  |
| बB | .016 | .020 |  |
| $\phi$ B1 | .060 | .080 |  |
| $\phi$ B2 | .040 | .060 |  |
| D/E | 1.559 | 1.590 |  |
| D1/E1 | 1.400 BSC |  |  |
| Q | .100 |  |  |
| BSC |  |  |  |
| L | .120 | .140 |  |
| M | 15 |  |  |
| Q1 | .025 | .060 |  |

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWSE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. SYMBOL "M" REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL " $N$ " REPRESENTS THE NUMBER OF PINS
5. CHAMFERED CORNERS ARE IDT'S OPTION.

PLASTIC DUAL IN-LINE PACKAGES
16-32 LEAD PLASTIC DIP (300 MIL)




NOTES:

1. ALL DIMENSIONS ARE $\operatorname{IN}$ INCHES, UNLESS OTHERWISE SPECIFIED.
2. D \& E1 DO NOT INCLUDE MOLD FLASH OR PROTRUSIONS.

| DWG ${ }^{\text {\% }}$ | P16-1 |  | P22-1 |  | P28-2 |  | P32-2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 16 |  | 22 |  | 28 |  | 32 |  |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 140 | . 165 | 145 | . 165 | . 145 | . 180 | . 145 | . 180 |
| A1 | . 015 | . 035 | . 015 | . 035 | . 015 | . 030 | . 015 | . 030 |
| b | . 015 | . 022 | . 015 | . 022 | . 015 | . 022 | . 016 | . 022 |
| b1 | . 050 | . 070 | . 050 | . 065 | . 045 | . 065 | . 045 | . 060 |
| c | . 008 | . 012 | . 008 | . 012 | . 008 | . 015 | . 008 | . 015 |
| D | . 745 | . 760 | 1.050 | 1.060 | 1.345 | 1.375 | 1.545 | 1.585 |
| E | . 300 | . 325 | . 300 | . 320 | . 300 | . 325 | . 300 | . 325 |
| E1 | . 247 | . 260 | . 240 | . 270 | . 270 | . 295 | . 275 | . 295 |
| e | . 090 | . 110 | . 090 | . 110 | . 090 | . 110 | . 090 | . 110 |
| © ${ }^{\text {A }}$ | . 310 | . 370 | . 310 | . 370 | . 310 | . 400 | . 310 | . 400 |
| L | . 120 | . 150 | . 120 | . 150 | . 120 | . 150 | . 120 | . 150 |
| $\alpha$ | $0^{\circ}$ | $15^{\circ}$ | $0 \cdot$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ |
| S | . 015 | . 035 | . 020 | . 040 | . 020 | : 042 | . 020 | . 060 |
| Q1 | . 050 | . 070 | . 055 | . 075 | . 055 | . 065 | . 055 | . 065 |

PLASTIC DUAL IN-LINE PACKAGES (Continued)


## PLANE

NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. D \& E1 DO NOT INCLUDE MOLD FLASH OR PROTRUSIONS.

18-24 LEAD PLASTIC DIP (300 MIL - FULL LEAD)

| DWG | P18-1 |  | P20-1 |  | P24-1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 18 |  | 20 |  | 24 |  |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX |
| A | .140 | .165 | .145 | .165 | .145 | .165 |
| A1 | .015 | .035 | .015 | .035 | .015 | .035 |
| b | .015 | .020 | .015 | .020 | .015 | .020 |
| b1 | .050 | .070 | .050 | .070 | .050 | .065 |
| C | .008 | .012 | .008 | .012 | .008 | .012 |
| D | .885 | .910 | 1.022 | 1.040 | 1.240 | 1.255 |
| E | .300 | .325 | .300 | .325 | .300 | .320 |
| E1 | .247 | .260 | .240 | .280 | .250 | .275 |
| e | .090 | .110 | .090 | .110 | .090 | .110 |
| eA | .310 | .370 | .310 | .370 | .310 | .370 |
| L | .120 | .150 | .120 | .150 | .120 | .150 |
| $\alpha$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ |
| S | .040 | .060 | .025 | .070 | .055 | .075 |
| 01 | .050 | .070 | .055 | .075 | 055 | .070 |

# PLASTIC DUAL IN-LINE PACKAGES (Continued) 

24-48 LEAD PLASTIC DIP (600 MIL)

| \#OF LEAD : | P24-2 |  | P28-1 |  | P32-1 |  | P40-1 |  | P48-1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 24 |  | 28 |  | 32 |  | 40 |  | 48 |  |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 160 | . 185 | . 160 | . 185 | . 170 | . 190 | . 160 | . 185 | . 170 | 200 |
| A1 | . 015 | . 035 | . 015 | . 035 | . 015 | . 050 | . 015 | . 035 | . 015 | . 035 |
| b | . 015 | . 020 | . 015 | . 020 | . 016 | . 020 | . 015 | . 020 | . 015 | 020 |
| b1 | . 050 | . 065 | . 050 | , 065 | . 045 | . 055 | . 050 | . 065 | . 050 | . 065 |
| C | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 |
| D | 1.240 | 1.260 | 1.420 | 1.460 | 1.645 | 1.655 | 2.050 | 2.070 | 2.420 | 2.450 |
| E | . 600 | . 620 | . 600 | . 620 | . 600 | . 625 | . 600 | . 620 | . 600 | . 620 |
| E1 | -. 530 | . 550 | . 530 | . 550 | . 530 | . 550 | . 530 | . 5.10 | . 530 | . 560 |
| e | . 090 | . 110 | . 090 | . 110 | . 090 | . 110 | . 090 | . 110 | . 090 | . 110 |
| eA | . 610 | . 670 | . 610 | . 670 | . 610 | . 670 | . 610 | . 670 | . 610 | . 670 |
| L | . 120 | . 150 | . 120 | . 150 | . 125 | . 135 | . 120 | . 150 | . 120 | . 150 |
| $\alpha$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ |
| S | . 060 | . 080 | . 055 | . 080 | . 070 | . 080 | . 070 | . 085 | . 060 | . 075 |
| 01 | 060 | 080 | 060 | 080 | . 065 | . 075 | 060 | 080 | 060 | 080 |

64 LEAD PLASTIC DIP ( 900 MIL )

| DWG \# | P64-1 |  |
| :---: | :---: | :---: |
| \# OF LEADS (N) | 64 |  |
| SYMBOLS | MIN | MAX |
| $A$ | .180 | .230 |
| A1 | .015 | .040 |
| $b$ | .015 | .020 |
| b1 | .050 | .065 |
| c | .008 | .012 |
| D | 3.200 | 3.220 |
| E | .900 | .925 |
| e | .790 | .810 |
| eA | .090 | .110 |
| L | .120 | .150 |
| $\alpha$ | 0 | 150 |
| S | .045 | .065 |
| Q1 | .080 | .090 |

## SMALL OUTLINE IC



PIN


NOTES:

1. ALL DIMENSIONS ARE IN INCHES, ULESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. D \& E DO NOT INCLUDE MOLD FLASH OR PROTRUSIONS AND TO BE MEASURED FROM THE BOTTOM OF PKG.
4. FORMED LEADS SHALL BE PLANAR WITH RESPECT TO ONE ANOTHER WITHIN .004" AT THE SEATING PLANE.


16-24 LEAD SMALL OUTLINE (GULL WING)

| DWG \# | S016-1 |  | S018-1 |  | S020-2 |  | S024-2 |  | S024-3 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 16 (.300) |  | 18 (.300) |  | 20 (.300 ${ }^{\text {² }}$ ) |  | 24 (.300") |  | 24 (.300") |  |
| SYMBOL | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 095 | . 1043 | . 095 | . 1043 | . 095 | . 1043 | . 095 | . 1043 | . 110 | . 120 |
| A1 | . 005 | . 0118 | . 005 | . 0118 | . 005 | . 0118 | . 005 | . 0118 | . 005 | . 0118 |
| B | . 014 | . 020 | . 014 | . 020 | . 014 | . 020 | . 014 | . 020 | . 014 | . 020 |
| C | . 0091 | . 0125 | . 0091 | . 0125 | . 0091 | 0125 | . 0091 | . 0125 | . 007 | . 011 |
| D | . 403 | . 413 | . 447 | . 462 | . 497 | . 511 | . 600 | . 614 | . 620 | . 630 |
| e | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  |
| E | . 292 | . 2992 | . 292 | . 2992 | . 292 | . 2992 | . 292 | . 2992 | . 295 | . 305 |
| h | . 010 | . 020 | . 010 | . 020 | . 010 | . 020 | . 010 | . 020 | . 012 | . 020 |
| H | . 400 | . 419 | . 400 | . 419 | . 400 | . 419 | . 400 | . 419 | . 406 | . 419 |
| L | . 018 | . 045 | . 018 | . 045 | . 018 | . 045 | . 018 | . 045 | . 028 | . 045 |
| $\alpha$ | $0^{\circ}$ | 8* | $0 \times$ | $8 \cdot$ | $0{ }^{\circ}$ | $8{ }^{\circ}$ | $0{ }^{\circ}$ | $8{ }^{\circ}$ | $0{ }^{\circ}$ | $8{ }^{\circ}$ |
| S | . 023 | . 035 | . 023 | . 035 | . 023 | . 035 | . 023 | . 035 | . 032 | . 043 |

## SMALL OUTLINE IC (Continued)



28 LEAD SMALL OUTLINE (GULL WING)

| DWG \# | SO28-2 |  | SO28-3 |  |
| :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | $28\left(.300^{n \prime}\right)$ |  | $28\left(.330^{n \prime}\right)$ |  |
| SYMBOL | MIN | MAX | MIN | MAX |
| A | .095 | .1043 | .110 | .120 |
| A1 | .005 | .0118 | .005 | .014 |
| B | .014 | .020 | .014 | .019 |
| C | .0091 | .0125 | .006 | .010 |
| D | .700 | .712 | .718 | .728 |
| e | .050 | BSC | .050 | BSC |
| E | .292 | .2992 | .340 | .350 |
| h | .010 | .020 | .012 | .020 |
| H | .400 | .419 | .462 | .478 |
| L | .018 | .045 | .028 | .045 |
| $\alpha$ | $0^{\circ}$ | $8^{\circ}$ | $0^{\circ}$ | $8^{\circ}$ |
| S | .023 | .035 | .023 | .035 |

## SMALL OUTLINE IC (Continued)

## 16-24 LEAD SMALL OUTLINE (EIAJ - . 0315 PITCH)

| DWG \# | SO16-5 |  | SO20-5 |  | SO24-5 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 16 |  | 20 |  | 24 |  |  |  |
| SYMBOLS | MIN | MAX | MIN |  | MAX | MIN |  | MAX |
| A | .057 | .071 | .069 | .083 | .069 | .083 |  |  |
| A1 | .002 TYP | .002 TYP | .002 TYP |  |  |  |  |  |
| B | .012 | .020 | .012 | .020 | .012 | .020 |  |  |
| C | .006 | .010 | .006 | .010 | .006 | .010 |  |  |
| D | .248 | .271 | .331 | .354 | .382 | .405 |  |  |
| E | .165 | .180 | .205 | .220 | .205 | .220 |  |  |
| e | .0315 | BSC | .0315 | BSC | .0315 BSC |  |  |  |
| H | .232 | .256 | .295 | .319 | .295 | .319 |  |  |
| L | .010 | - | .010 | - | .010 | - |  |  |
| $\alpha$ | $0^{\circ}$ | $8^{\circ}$ | $0^{\circ}$ | $8^{\circ}$ | $0^{\circ}$ | $8^{\circ}$ |  |  |

16-28 LEAD SMALL OUTLINE (EIAJ - . 050 PITCH)

| DWG \# | S016-6 |  | S018-6 |  | S020-6 |  | S024-6 |  | S028-6 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 16 |  | 18 |  | 20 |  | 24 |  | 28 |  |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 057 | . 071 | . 069 | . 083 | . 069 | . 083 | . 069 | . 083 | . 083 | . 098 |
| A1 | . 002 TYP |  | . 002 TYP |  | . 002 TYP |  | . 002 TYP |  | . 002 TYP |  |
| B | . 012 | . 020 | . 012 | . 020 | . 012 | . 020 | . 012 | . 020 | . 012 | . 020 |
| C | . 006 | . 010 | . 006 | . 010 | . 006 | . 010 | . 006 | . 010 | . 006 | . 010 |
| D | . 382 | . 406 | . 437 | . 453 | . 4.80 | . 504 | . 580 | . 603 | . 720 | . 740 |
| E | . 165 | . 180 | . 205 | . 220 | . 205 | . 220 | . 205 | . 220 | . 290 | . 300 |
| e | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  |
| H | . 232 | . 256 | . 295 | . 319 | . 295 | . 319 | . 295 | . 319 | . 378 | . 402 |
| L | . 010 | - | . 010 | - | . 010 | - | . 010 | - | . 010 | - |
| $\alpha$ | 0 | $8{ }^{\circ}$ | 0 | $8{ }^{\circ}$ | $0^{\circ}$ | $8{ }^{\circ}$ | $0^{\circ}$ | $8{ }^{\circ}$ | $0^{\circ}$ | $8{ }^{\circ}$ |

## SMALL OUTLINE IC (Continued)



NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. D1 \& E1 DO NOT INCLUDE MOLD FLASH OR PROTRUSION AND TO BE MEASURED FROM THE BOTTOM OF THE PKG.
4. FORMED LEADS SHALL BE PLANAR WITH RESPECT TO ONE ANOTHER WITHIN .004" at the seating plane


16-24 LEAD SMALL OUTLINE (J-BEND)

| DWG \# | S016-2 |  | SO20-1 |  | S024-4 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \% OF LDS (N) | 16 LD | 300*) | 20 L | 300*) | 24 LD | . $300{ }^{\text {¹) }}$ |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 120 | . 140 | . 120 | . 140 | . 130 | . 148 |
| A1 | . 078 | . 095 | . 078 | . 095 | . 082 | . 095 |
| B | . 020 | . 024 | . 020 | . 024 | . 026 | . 032 |
| B1 | . 014 | . 020 | . 014 | . 020 | . 015 | . 020 |
| C | . 008 | . 013 | . 008 | . 013 | . 007 | . 011 |
| D1 | . 400 | . 412 | . 500 | . 512 | . 620 | . 630 |
| E | . 335 | . 347 | . 335 | . 347 | . 335 | . 345 |
| E1 | . 292 | . 300 | . 292 | . 300 | . 295 | . 305 |
| E2 | . 262 | . 272 | . 262 | . 272 | . 260 | . 280 |
| e | . 050 BSC |  | . 050 BSC |  | . 050 BSC |  |
| h | . 010 | . 020 | . 010 | . 020 | . 010 | . 020 |
| S | . 023 | . 035 | . 023 | . 035 | . 032 | . 043 |

SMALL OUTLINE IC (Continued)


NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. D1 \& E1 DO NOT INCLUDE MOLD FLASH OR PROTRUSION AND TO BE MEASURED FROM THE BOTTOM OF THE PKG.
4. FORMED LEADS SHALL BE PLANAR WITH RESPECT TO ONE ANOTHER WITHIN .004" AT THE SEATING PLANE.


28-32 LEAD SMALL OUTLINE (J-BEND)

| DWG \# |  | SO28-5 |  | SO28-4 |  | SO32-2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 28 LD (.300 $)$ |  | 28 LD (.350" |  | 32 LD (.300 $)$ |  |  |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX |  |
| A | .120 | .140 | .130 | .148 | .130 | .148 |  |
| A1 | .078 | .095 | .082 | .095 | .082 | .095 |  |
| B | .020 | .024 | .026 | .032 | .026 | .032 |  |
| B1 | .014 | .020 | .016 | .020 | .016 | .020 |  |
| C | .008 | .013 | .007 | .011 | .008 | .013 |  |
| D1 | .700 | .712 | .720 | .730 | .820 | .830 |  |
| E | .335 | .347 | .380 | .390 | .330 | .340 |  |
| E1 | .292 | .300 | .345 | .355 | .295 | .305 |  |
| E2 | .262 | .272 | .310 | .330 | .260 | .275 |  |
| e | .050 |  | BSC | .050 | BSC | .050 |  |
| h | .012 | .020 | .012 | .020 | .012 | .020 |  |
| S | .023 | .035 | .023 | .035 | .032 | .043 |  |

## SMALL OUTLINE IC (Continued)

48 \& 56 LEAD SMALL OUTLINE (SSOP - GULL WING)


| DWG \# | SO48-1 |  | SO56-1 |  |
| :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | $48\left(.300^{\prime \prime}\right)$ |  | $56\left(.300^{\prime \prime}\right)$ |  |
| SYMBOL | MIN | MAX | MIN | MAX |
| A | .095 | .110 | .095 | .110 |
| A1 | .008 | .016 | .008 | .016 |
| b | .008 | .012 | .008 | .012 |
| C | .005 | .009 | .005 | .009 |
| D | .620 | .630 | .720 | .730 |
| E | .291 | .299 | .291 | .299 |
| e | .025 | BSC | .025 |  |
| BSC |  |  |  |  |
| H | .395 | .420 | .395 | .420 |
| L | .015 | .025 | .015 | .025 |
| $\alpha$ | .020 | .040 | .020 | .040 |
|  | $0^{\circ}$ | $8^{\circ}$ | 0 | $8^{\circ}$ |

## PLASTIC QUAD FLATPACKS

## 100-132 LEAD PLASTIC QUAD FLATPACK (JEDEC)



NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. PIN 1 IDENTIFIER CAN BE POSITIONED AT EITHER ONE OF THESE TWO LOCATIONS.
4. DIMENSIONS D1, D2, E1, AND E2 DO NOT INCLUDE MOLD PROTRUSIONS. ALLOWABLE MOLD PROTRUSIONS ARE AS FOLLOWS:
D1 \& E1 $=.010 \mathrm{MAX}$.
$D 2 \& E 2=.007$ MAX.
5. ND \& NE REPRESENT NUMBERS OF LEADS IN D \& E DIRECTIONS RESPECTIVELY.

| DWG \# | P0100-1 |  | P0132-1 |  |
| :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 100 |  | 132 |  |
| SYMBOLS | MIN | MAX | MIN | MAX |
| A | . 160 | . 180 | . 160 | . 180 |
| A1 | . 020 | . 040 | . 020 | . 040 |
| B | . 008 | . 016 | . 008 | . 016 |
| b1 | . 008 | . 012 | . 008 | . 012 |
| C | . 0055 | . 008 | . 0055 | . 008 |
| D | . 875 | . 885 | 1.075 | 1.085 |
| D1 | . 747 | . 753 | . 947 | . 953 |
| D2 | . 897 | . 903 | 1.097 | 1.103 |
| D3 | . 600 REF |  | . 800 REF |  |
| e | . 025 BSC |  | . 025 BSC |  |
| E | . 875 | . 885 | 1.075 | 1.085 |
| E1 | . 747 | . 753 | . 947 | . 953 |
| E2 | . 897 | . 903 | 1.097 | 1.103 |
| E3 | . 600 REF |  | . 800 REF |  |
| L | . 020 | . 030 | . 020 | . 030 |
| $\alpha$ | 0 | $8^{\circ}$ | $0^{\circ}$ | $8^{\circ}$ |
| ND/NE | 25/25 |  | 33/33 |  |

## PLASTIC QUAD FLATPACKS (Continued)

## 80-128 LEAD PLASTIC QUAD FLATPACK (EIAJ)



## NOTES:

1. ALL DIMENSIONS ARE $\mathbb{N}$ INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. D1 \& E1 DO NOT INCLUDE MOLD PROTRUSION. ALLOWABLE PROTRUSION IS . 010 PER SIDE.
4. ND \& NE REPRESENT NUMBERS OF LEADS IN D \& E DIRECTIONS RESPECTIVELY.
5 THE 3.9 mm FOOTPRINT IS STANDARD, HOWEVER THE 3.2 mm IS OPTIONAL \& CAN BE REQUESTED.


| DWG \# | PQ80-2 |  | PQ100-2 |  | PQ120-2 |  | PQ128-2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 80 |  | 100 |  | 120 |  | 128 |  |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 110 | . 124 | . 110 | . 124 | . 136 | . 156 | . 136 | . 156 |
| A1 | . 010 | - | . 010 | - | . 010 | - | . 010 | - |
| A2 | . 100 | . 120 | . 100 | . 120 | . 125 | . 144 | . 125 | . 144 |
| C | . 005 | . 008 | . 005 | . 008 | . 005 | . 008 | . 005 | . 008 |
| D | . 937 | . 945 | . 937 | . 945 | 1.252 | 1.260 | 1.252 | 1.260 |
| D1 | . 783 | 791 | . 783 | 791 | 1.098 | 1.106 | 1.098 | 1.106 |
| D3 | . 724 REF |  | 742 REF |  | . 913 REF |  | . 976 REF |  |
| E | 701 | . 709 | 701 | . 709 | 1.252 | 1.260 | 1.252 | 1.260 |
| E1 | . 547 | . 555 | . 547 | . 555 | 1.098 | 1.106 | 1.098 | 1.106 |
| E3 | 472 REF |  | . 486 REF |  | . 913 REF |  | . 976 REF |  |
| L | . 026 | 037 | . 026 | . 037 | . 026 | . 037 | . 026 | . 037 |
| ND/NE | 16/24 |  | 20/30 |  | 30/30 |  | 32/32 |  |
| P | . 0315 BSC |  | . 026 BSC |  | . 026 BSC |  | . 0315 BSC |  |
| W | . 010 | . 018 | . 012 | . 018 | . 012 | . 018 | . 012 | . 018 |
| ZD | . 032 |  | . 023 |  | . 094 |  | . 063 |  |
| ZE | . 039 |  | . 032 |  | . 094 |  | . 063 |  |


| ALT. D [5] | .909 | .917 | .909 | .917 | 1.224 | 1.232 | 1.224 | 1.232 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ALT. E [5] | .673 | .681 | .673 | .681 | 1.224 | 1.232 | 1.224 | 1.232 |

## PLASTIC QUAD FLATPACKS (Continued)

144-208 LEAD PLASTIC QUAD FLATPACK (EIAJ)

| DWG $\frac{1}{1}$ | PQ144-2 |  | PQ160-2 |  | PQ184-2 |  | PQ208-2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS (N) | 144 |  | 160 |  | 184 |  | 208 |  |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 136 | . 156 | . 136 | . 156 | . 136 | . 156 | . 136 | . 156 |
| A1 | . 010 | - | . 010 | - | . 010 | - | . 010 | - |
| A2 | . 125 | . 144 | . 125 | . 144 | . 125 | . 144 | . 125 | . 144 |
| C | . 005 | . 008 | . 005 | . 008 | . 005 | . 008 | . 005 | . 008 |
| D | 1.224 | 1.232 | 1.224 | 1.232 | 1.224 | 1.232 | 1.224 | 1.232 |
| D1 | 1.098 | 1.106 | 1.098 | 1.106 | 1.098 | 1.106 | 1.098 | 1.106 |
| D3 | . 896 RF |  | 998 REF |  | . 886 REF |  | 1.004 REF |  |
| E | 1.224 | 1.232 | 1.224 | 1.232 | 1.224 | 1.232 | 1.224 | 1.232 |
| E1 | 1.098 | 1.106 | 1.098 | 1.106 | 1.098 | 1.106 | 1.098 | 1.106 |
| E3 | . 896 REF |  | . 998 REF |  | . 886 REF |  | 1.004 REF |  |
| L | . 026 | . 037 | . 026 | . 037 | . 026 | . 037 | . 026 | . 037 |
| ND/NE | 36/36 |  | 40/40 |  | 46/46 |  | 52/52 |  |
| P | . 026 BSC |  | . 026 BSC |  | . 020 BSC |  | . 020 BSC |  |
| W | . 009 | . 014 | . 009 | . 014 | . 009 | . 014 | . 009 | . 014 |
| ZD | . 103 |  | . 052 |  | . 108 |  | . 049 |  |
| ZE | 103 |  | . 052 |  | . 108 |  | . 049 |  |

## PLASTIC LEADED CHIP CARRIERS

## 20-84 LEAD PLCC (SQUARE)



NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS
3. D \& E DO NOT INCLUDE MOLD FLASH OR PROTRUSIONS.
4. FORMED LEADS SHALL BE PLANAR WITH RESPECT TO ONE ANOTHER WITHIN . OO4" AT THE SEATING PLANE.
5. ND \& NE REPRESENT NUMBER OF LEADS IN D \& E DIRECTIONS RESPECTIVELY.
6. D1 \& E1 SHOULD BE MEASURED FROM THE BOTTOM OF THE PKG.

| DWG \# | J20-1 |  | J28-1 |  | 344-1 |  | J52-1 |  | J68-1 |  | J84-1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \% OF LOS | 20 |  | 28 |  | 44 |  | 52 |  | 68 |  | 84 |  |
| SYMBOL | MIN | MAX | MIN | MA | MIT | MAX | MIT | MA | MI | MAX | MIN | MAX |
| A | . 165 | . 180 | . 165 | . 180 | . 165 | . 180 | . 165 | . 180 | . 165 | . 180 | . 165 | . 180 |
| A1 | . 095 | . 115 | . 095 | . 115 | . 095 | . 115 | . 095 | . 115 | . 095 | . 115 | . 095 | . 115 |
| B | . 026 | . 032 | . 026 | . 032 | . 026 | . 032 | . 026 | . 032 | . 026 | . 032 | . 026 | . 032 |
| b1 | . 013 | . 021 | . 013 | . 021 | . 013 | . 021 | . 013 | . 021 | . 013 | . 021 | . 013 | . 021 |
| C | . 020 | . 040 | . 020 | . 040 | . 020 | . 040 | . 020 | . 040 | . 020 | . 040 | . 020 | . 040 |
| C1 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 | . 008 | . 012 |
| D | . 385 | . 395 | . 485 | . 495 | . 685 | . 695 | . 785 | . 795 | . 985 | . 995 | 1.185 | 1.195 |
| D1 | . 350 | . 356 | . 450 | . 456 | . 650 | . 656 | . 750 | . 756 | . 950 | . 956 | 1.150 | 1.156 |
| D2/E2 | . 290 | . 330 | . 390 | 430 | . 590 | . 630 | . 690 | 730 | . 890 | . 930 | 1.090 | 1.130 |
| D3/E3 | . 200 | REF | . 300 | REF | . 500 | REF | . 600 | REF | . 800 | REF | 1.000 | REF |
| E | . 385 | 395 | . 485 | . 495 | . 685 | . 695 | . 785 | . 795 | . 985 | . 995 | 1.185 | 1.195 |
| E1 | . 350 | . 356 | . 450 | . 456 | . 650 | . 656 | . 750 | . 756 | . 950 | . 956 | 1.150 | 1.156 |
| e | . 050 | BSC | . 050 | BSC | . 050 | BSC | . 050 | BSC | . 050 | BSC | . 050 | BSC |
| ND/NE | 5 | 5 |  | 7 |  | 11 | 1 | 3 |  | 7 |  | 21 |

## PLASTIC LEADED CHIP CARRIERS (Continued)

## 18-32 LEAD PLCC (RECTANGULAR)



| DWG \# | J18-1 |  | J32-1 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF LDS | 18 |  | 32 |  |  |  |
| SYMBOL | MIN | MAX | MIN | MAX |  |  |
| A | .120 | .140 | .120 | .140 |  |  |
| A1 | .075 | .095 | .075 | .095 |  |  |
| B | .026 | .032 | .026 | .032 |  |  |
| b1 | .013 | .021 | .013 | .021 |  |  |
| C | .015 | .040 | .015 | .040 |  |  |
| C1 | .008 | .012 | .008 | .012 |  |  |
| C2 | - | - | .005 | .015 |  |  |
| D | .320 | .335 | .485 | .495 |  |  |
| D1 | .289 | .293 | .449 | .453 |  |  |
| D2 | .225 | .265 | .390 | .430 |  |  |
| D3 | .150 | REF | .300 | REF |  |  |
| E | .520 | .535 | .585 | .595 |  |  |
| E1 | .489 | .493 | .549 | .553 |  |  |
| E2 | .422 | .465 | .490 | .530 |  |  |
| E3 | .200 |  | REF | .400 |  | REF |
| e | .050 | BSC | .050 | BSC |  |  |
| ND/NE | 4 |  |  | $/ 5$ |  |  |

NOTES:

1. ALL DIMENSIONS ARE $\operatorname{IN}$ INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC LEAD SPACING BETWEEN CENTERS.
3. $D$ \& E DO NOT INCLUDE MOLD FLASH OR PROTRUSIONS.
4. FORMED LEADS SHALL BE PLANAR WITH RESPECT TO ONE ANOTHER WITHIN .004" AT THE SEATING PLANE.
5. ND \& NE REPRESENT NUMBERS OF LEADS IN D \& E DIRECTIONS RESPECTIVELY.
6. D1 \& E1 SHOULD BE MEASURED MEASURED FROM THE BOTTOM OF THE PACKAGE.

## PLASTIC PIN GRID ARRAYS

## 68-208 PIN PGA (CAVITY UP)



## NOTES:

1. ALL DIMENSIONS ARE IN INCHES, UNLESS OTHERWISE SPECIFIED.
2. BSC - BASIC PIN SPACING BETWEEN CENTERS.
3. SYMBOL " $M$ " REPRESENTS THE PGA MATRIX SIZE.
4. SYMBOL "N" REPRESENTS THE NUMBER OF PINS.
5. DIM. "A" INCLUDES BOTH THE PKG BODY \& THE LID. IT DOES NOT INCLUDE HEATSINK OR OTHER ATTACHED FEATURES.
6. PIN DIAMETER "C" EXCLUDES SOLDER DIP OR OTHER LEAD FINISH.
7. PIN TIPS MAY HAVE RADIUS OR CHAMFER.

| DWG No. | PG | 8-2 |  | 4-2 | PG | 8-2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# OF PINS (N) |  |  |  |  | 208 | PIN |
| SYMBOLS | MIN | MAX | MIN | MAX | MIN | MAX |
| A | . 115 | . 160 | . 115 | . 160 | . 115 | . 160 |
| C | . 016 | . 020 | . 016 | . 020 | . 016 | . 020 |
| D | 1.140 | 1.180 | 1.140 | 1.180 | 1.740 | 1.780 |
| D1 | 1.000 BSC |  | 1.000 BSC |  | 1.600 BSC |  |
| E | 1.140 | 1.180 | 1.140 | 1.180 | 1.740 | 1.780 |
| E1 | 1.000 BSC |  | 1.000 BSC |  | 1.600 BSC |  |
| e | . 100 BSC |  | . 100 BSC |  | . 100 BSC |  |
| L | . 100 | . 160 | . 100 | . 160 | . 100 | . 160 |
| M | 11 |  | 11 |  | 17 |  |
| Q | . 040 | . 070 | . 040 | . 070 | . 040 | . 070 |

## DUAL IN-LINE PACKAGES

28-Pin Ceramic Sidebraze DIP - M1


## DUAL IN-LINE PACKAGES (Continued)

28-PIn Ceramic Sidebraze DIP - M2



BOTTOM VIEW

## DUAL IN-LINE PACKAGES (Continued)

## 32-PIn Ceramic Sidebraze DIP - M3


bоtTOM VIEW

## DUAL IN-LINE PACKAGES (Continued)

32-PIn Ceramic Sidebraze DIP - M4

## MODULE DIMENSIONS FOR PACKAGE M4 ARE NOT YET AVAILABLE. PLEASE CONSULT THE FACTORY FOR FURTHER DETAILS.



BOTTOM VIEW

DUAL IN-LINE PACKAGES (Continued)
32-Pin Ceramic Sidebraze DIP - M6


## DUAL IN-LINE PACKAGES (Continued)

32-PIn Ceramic Sidebraze DIP - M7


## DUAL IN-LINE PACKAGES (Continued)

40-Pin Ceramic Sidebraze DIP - M8


## DUAL IN-LINE PACKAGES (Continued)

40-Pin Ceramic Sidebraze DIP - M9


## DUAL IN-LINE PACKAGES (Continued)

40-Pin Ceramic Sidebraze DIP - M10


## DUAL IN-LINE PACKAGES (Continued)

40-PIn Ceramic Sidebraze DIP - M11


## DUAL IN-LINE PACKAGES (Continued)

40-Pin Ceramic Sidebraze DIP - M12

$\frac{0.035}{0.060}$
0.100
$\frac{0.015}{0.022}$

## DUAL IN-LINE PACKAGES (Continued)

44-PIn FR-4 DIP - M13



## DUAL IN-LINE PACKAGES (Continued)

44-PIn FR-4 DIP - M14


BOTTOM VIEW

## DUAL IN-LINE PACKAGES (Continued)

48-PIn Ceramic Sidebraze DIP - M15



## DUAL IN-LINE PACKAGES (Continued)

60-PIn Ceramic Sidebraze DIP - M16


## 64-PIn Ceramic Sidebraze DIP - M17



## QUAD IN-LINE PACKAGES

## 80-Pin Ceramic Sidebraze QIP - M18




BOTTOM VIEW

QUAD IN-LINE PACKAGES (Continued)
80-Pin Ceramic Sidebraze QIP - M19


## QUAD IN-LINE PACKAGES (Continued)

92-PIn FR-4 QIP - M20


## QUAD IN-LINE PACKAGES (Continued)

92-PIn FR-4 QIP - M21


## QUAD IN-LINE PACKAGES (Continued)

92-PIn FR-4 QIP - M22


## QUAD IN-LINE PACKAGES (Continued)

104-Pin FR-4 QIP - M23


## QUAD IN-LINE PACKAGES (Continued)

104-Pin FR-4 QIP - M24


## QUAD IN-LINE PACKAGES (Continued)

104-Pin FR-4 QIP - M25


QUAD IN-LINE PACKAGES (Continued)

## 120-PIn FR-4 QIP - M26



Pin 1 TOP VIEW


## QUAD IN-LINE PACKAGES (Continued)

## 120-Pin FR-4 QIP - M27



BOTTOM VIEW

## QUAD IN-LINE PACKAGES (Continued)

128-Pin FR-4 QIP - M28


Pin 1 TOP VIEW


BOTTOM VIEW

## QUAD IN-LINE PACKAGES (Continued)

128-Pin FR-4 QIP - M29


BOTTOM VIEW

## QUAD IN-LINE PACKAGES (Continued)

132-PIn FR-4 QIP - M30


BOTTOM VIEW

## QUAD IN-LINE PACKAGES (Continued)

164-PIn FR-4 QIP - M31


BOTTOM VIEW

## HEX IN-LINE PACKAGES

66-PIn Ceramic Sidebraze HIP - M32


## PIN GRID ARRAY PACKAGES

121-Pin Ceramic Sidebraze PGA - M33


Pin A1

## SINGLE IN-LINE PACKAGES

28-PIn FR-4 SIP - M34


FRONT VIEW


BACK VIEW


## SINGLE IN-LINE PACKAGES (Continued)

30-PIn Ceramic Sidebraze SIP - M35


## SINGLE IN-LINE PACKAGES (Continued)

30-PIn FR-4 SIP - M36


FRONT VIEW

36-Pin FR-4 SIP - M37


## SINGLE IN-LINE PACKAGES (Continued)

36-Pin FR-4 SIP - M38

## MODULE DIMENSIONS FOR PACKAGE M38 ARE NOT YET AVAILABLE. PLEASE CONSULT THE FACTORY FOR FURTHER DETAILS.

40-Pin FR-4 SIP - M39


FRONT VIEW

40-Pin FR-4 SIP - M40


## SINGLE IN-LINE PACKAGES (Continued)

45-PIn FR-4 SIP - M41


## DUAL SINGLE IN-LINE PACKAGES

36-PIn Ceramic Sidebraze DSIP - M42


88-PIn Ceramic Sidebraze DSIP - M43


## ZIG-ZAG IN-LINE PACKAGES

42-PIn FR-4 ZIP - M44


FRONT VIEW


52-Pin FR-4 ZIP - M45


## ZIG-ZAG IN-LINE PACKAGES (Continued)

## 64-PIn FR-4 ZIP - M46



64-PIn FR-4 ZIP - M47


BACK VIEW

## SINGLE IN-LINE PACKAGES (Continued)

40-PIn FR-4 SIMM - M48

MODULE DIMENSIONS FOR PACKAGE M48 ARE NOT YET AVAILABLE. PLEASE CONSULT THE FACTORY FOR FURTHER DETAILS.

40-Pin FR-4 SIMM - M49



BACK VIEW

# GENEMAL HEORMATION 

TECHMOLOGY AND GAPASLITES

OUALITY AND RELABELITY

PAGRAOEDAGRAMOULLNES

## ECL PRODUCTS

FHIOPMODUCTS

SPECIALTY MEMORY PRODUCTS

SUBSYSTEHSPRODUCTS

APPLOATION AND TECHNICAL NOTES

## ECL PRODUCTS

The ECL Product Group is one of the newest product groups to be created at Integrated Device Technology, Inc. The charter of the group is to develop a leadership BiCMOS technology, create ECL-compatible products which drive and showcase that technology, and understand the needs of ECL users with the aim of creating products which more completely provide systems solutions.

The products offered by the ECL Products Group provide the designer of high-speed emitter-coupled logic (ECL) systems with a lower-power alternative to older bipolar ECL technologies. IDT BiCMOS ECL memory products allow the designer to achieve performance levels close to bipolar equivalents, yet with less engineering time and resources devoted to heat dissipation and thermal design. These products are ideal for cache, control-store, or main memory applications in minisupercomputer and high-end workstation, or pattern generation and data capture in test equipment.

This revolution in performance-density is achieved by IDT through the development of a technology which combines high-speed CMOS with limited use of bipolar structures. Called BiCEMOSTM, the technology provides greater performance in memory components by speeding up word-line drivers, sense amplifiers, and input-output buffers. Bipolar structures on-chip also allow the option of ECL-compatible interfaces.

To build components with ECL interfaces in the past required $100 \%$ bipolar circuit designs. Full bipolar designs were limited in density, however, by the high power dissipation of the chip: the level of integration available to the designer of ECL systems has thus been necessarily low when compared to CMOS. But in the past, designers looking for performance sacrificed density and solved power dissipation engineering problems in order to use bipolar ECL components. Today, BiCMOS provides the high-density and low cost of CMOS to ECL designers.

Integrated Device Technology has begun its family of BiCMOS ECL components with the most density-intensive elements: memory. Because memories benefit in speed from bipolar word-line drivers as mentioned above, larger (longer word-line) memories benefit most from BiCMOS. Thus, IDT has begun building BiCMOS ECL SRAMs at the 64 K -bit density, and will offer products with ever greater levels of integration. These density enhancements will include 256K-
bit memories and beyond, as well as memories including onchip logic to improve their use in computer architectures.

The speed of memories, measured as access time, is also improved with the development of BiCMOS. Bipolar structures speed up intemal elements of already fast CMOS memories. Because it is based on, and integrated into, standard IDT CMOS, BiCMOS will directly receive the benefits of enhancements made in future CMOS technology generations. Speed improvements will be achieved for both BiCMOS TTL and BiCMOS ECL memories, but the ECL output buffer is a clear speed leader over TTL, implying that ECL memories will in general out-perform TTL. In a system, ECL logic elements out-perform TTL by as much as a factor of three; IDT feels that ECL will win renewed interest as an interconnect standard for high-performance systems now that BiCMOS allows CMOS densities at ECL speeds.

Military applications will also benefit from BiCMOS ECL components. The low-power dissipation of BiCMOS allows ECL SRAMs to be offered as fully MIL-STD-883 compliant over the full $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range. The high density and low power will be ideal for high data rate applications such as RADAR, satellite communication, and graphics.

The lower power dissipation of BiCMOS ECL components makes the job of designing with ECL much easier than with bipolar ECL. System reliability goals are much easier to achieve because these components create less heat in a system. Heat dissipation techniques needed for system cooling benefit from a better starting point, reducing the amount of time and resources needed to prove a design. Power supply requirements are of course reduced. New packaging options are realized, such as plastic DIP and surface-mount packages.

Integrated Device Technology believes that BiCMOS will be a major technology for the coming years, and is dedicated to be the leader. To do this we have created memory products to drive the technology down the learning curve to provide our customers cost-effective high-performance. We offer standard and leadership ECL products implemented in highperformance BiCMOS. We intend to work closely with our customers to create new standard products which bring more of the advantages of BiCMOS speed, integration, and lower power to ECL systems.

## TABLE OF CONTENTS

PAGE
ECL PRODUCTS
IDT10484IDT100484
IDT101484
IDT10A484
IDT100A484
IDT101A484
IDT10490
IDT100490
IDT101490
IDT10494
IDT100494
IDT101494
IDT10496LL
IDT100496LL
IDT101496LL
IDT10496RL
IDT100496RL
IDT101496RL
IDT10497
IDT100497
IDT101497
IDT10498
IDT100498
IDT101498
IDT10504
IDT100504
IDT101504
IDT10506LL
IDT100506LL
IDT101506LL
IDT10506RL
IDT100506RL
IDT101506RLIDT10507
IDT100507
IDT101507
DT10508
IDT100508
IDT101508IDT10509IDT100509
4K x 4 ECL 10K SRAM (Corner Power) ..... 5.1
$4 \mathrm{~K} \times 4$ ECL 100K SRAM (Corner Power) ..... 5.1
4K x 4 ECL 101 K SRAM (Corner Power) ..... 5.1
4K x 4 ECL 10K SRAM (Center Power) ..... 5.2
$4 \mathrm{~K} \times 4$ ECL 100K SRAM (Center Power) ..... 5.2
$4 \mathrm{~K} \times 4$ ECL 101K SRAM (Center Power) ..... 5.2
64K x 1 ECL 10K SRAM ..... 5.3
$64 \mathrm{~K} \times 1$ ECL 100K SRAM ..... 5.3
64K x 1 ECL 101K SRAM ..... 5.3
16K x 4 ECL 10K SRAM ..... 5.4
16K x 4 ECL 100K SRAM ..... 5.4
16K x 4 ECL 101K SRAM ..... 5.4
16K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
16K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
16K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.5
16K x 4 Self-Timed Reg Input, Latch Output ..... 5.6
16K x 4 Self-Timed Reg Input, Latch Output ..... 5.6
16K x 4 Self-Timed Reg Input, Latch Output ..... 5.6
16K x 4 Synchronous Write, Latch Output ..... 5.7
16K x 4 Synchronous Write, Latch Output ..... 5.7
$16 \mathrm{~K} \times 4$ Synchronous Write, Latch Output ..... 5.7
16K $\times 4$ Conditional Write, Latch Output ..... 5.8
16K x 4 Conditional Write, Latch Output ..... 5.8
16K $\times 4$ Conditional Write, Latch Output ..... 5.8
64K x 4 ECL 10K SRAM ..... 5.9
64K x 4 ECL 100K SRAM ..... 5.9
$64 \mathrm{~K} \times 4$ ECL 100 K SRAM ..... 5.9
$64 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.10
$64 \mathrm{~K} \times 4$ Self-Timed Latch Input, Latch Output ..... 5.10
64K $\times 4$ Self-Timed Latch Input, Latch Output ..... 5.10
64K x 4 Self-Timed Reg Input, Latch Output ..... 5.11
64K x 4 Self-Timed Reg Input, Latch Output ..... 5.11
$64 \mathrm{~K} \times 4$ Self-Timed Reg Input, Latch Output ..... 5.11
64K x 4 Synchronous Write, Latch Output ..... 5.12
16K x 4 Synchronous Write, Latch Output ..... 5.12
16K x 4 Synchronous Write, Latch Output ..... 5.12
$64 \mathrm{~K} \times 4$ Conditional Write, Latch Output ..... 5.13
64K $\times 4$ Conditional Write, Latch Output ..... 5.13
$64 \mathrm{~K} \times 4$ Conditional Write, Latch Output ..... 5.13
32K x 9 ECL 10K SRAM ..... 5.14
32K x 9 ECL 100K SRAM ..... 5.14
32K x 9 ECL 101K SRAM ..... 5.14


## FEATURES:

- 4096-words x 4-bit organization
- Address access time: 7/8/10/15 ns
- Low power dissipation: 700 mW (typ.)
- Guaranteed Output Hold time
- Fully compatible with ECL logic levels
- Separate data input and output
- Traditional corner-power pin pinout
- Standard through-hole and surface mount packages


## DESCRIPTION:

The IDT10484, IDT100484 and IDT101484 are 16,384-bit high-speed BiCEMOS ${ }^{T M}$ ECL static random access memories organized as $4 \mathrm{~K} \times 4$, with separate data inputs and outputs. All I/Os are fully compatible with ECL levels.

These devices are part of a family of asynchronous four-bit-wide ECL SRAMs. This device have been configured to follow the traditional comer-voltage pinout. Because they are manufactured in BiCEMOS ${ }^{\text {TM }}$ technology, however, power dissipation is greatly reduced over equivalent bipolar devices.

The asynchronous SRAMs are the most straightorward to use because no additional clocks or controls are required: Dataout is available an access time after the last change of address. To write data into the device requires the creation of a Write Pulse, and the write cycle disables the output pins in conventional fashion. Two Write Enable inputs are supplied, so the write pulse is created as a logical-AND of these signals to allow write gating at the device for minimal skew.

The fast access time and guaranteed Output Hold time allow greater margin for systemtiming variation. Datain setup time specified with respect to the trailing edge of Write Pulse eases write timing allowing balanced Read and Write cycle times.

## FUNCTIONAL BLOCK DIAGRAM



BICEMOS is a tradernark of Integrated Device Technology, Inc.

## PIN CONFIGURATION



## PIN DESIGNATION

| Symbol | PIn Name |
| :--- | :--- |
| Ao through A11 | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| $\overline{\text { WE1, }} \overline{\text { WE2 }}$ | Write Enable Input |
| $\overline{\text { CS }}$ | Chip Select Input (Internal pull down) |
| VEE | More Negative Supply Voltage |
| Vcc | Less Negative Supply Voltage |

## AC OPERATING RANGES ${ }^{(1)}$

| I/O | VeE | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |

NOTE:

1. Referenced to Vcc

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter |  | DIP |  | Flatpack |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  | Typ. | Max. | Typ. | Max. | Unit |  |
| CIN | Input <br> Capacitance | 4 | - | TBD | - | pF |
| COUT | Output <br> Capacitance | 6 | - | TBD | - | pF |

## LOGIC SYMBOL



TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE1 }}$ | $\overline{\text { WE2 }}$ | Dataout | Function |
| :---: | :---: | :---: | :---: | :--- |
| H | X | X | L | Deselected |
| L | H | X | RAM Data | Read |
| L | X | H | RAM Data | Read |
| L | L | L | WRITE Data | Write |

## NOTE:

1. $\mathrm{H}=\mathrm{High}, \mathrm{L}=$ Low, $\mathrm{X}=$ Don't Care

ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.5 | W |
| IOUT | DC Output Current (Output High) |  | -50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-10K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | Ta |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vor | Output HIGH Voltage | V IN $=$ V ITHA or $\mathrm{V}_{\text {ILB }}$ |  | $\begin{gathered} -1000 \\ -960 \\ -900 \end{gathered}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vot | Output LOW Voltage | V IN $=$ Viha or V ILB |  | $\begin{array}{r} -1870 \\ -1850 \\ -1830 \\ \hline \end{array}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vohc | Output Threshold HIGH Voltage | V IN $=$ Vihb or $\mathrm{V}_{\text {ILA }}$ |  | $\begin{aligned} & -1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VoLc | Output Threshold LOW Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{array}{r} -840 \\ -810 \\ -720 \end{array}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL. | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| I IH | Input HIGH Cuirrent | $\mathrm{V} \mathbb{N}=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Outputs Open |  | -190 | -130 | - | mA | - |

NOTE:
2756 \$1 06

1. Typical parameters are specified at $\mathrm{VEE}_{\mathrm{EE}}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Tbias | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.5 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

NOTE:
2756 th 07

1. Stresses greater than those listedunder ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-100K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condition |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | VIN $=$ VIIHA or V IIB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | VIN $=$ VIHA or VIIB |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | $\mathrm{VIN}=\mathrm{V}_{\text {IHB }}$ or VILA |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | $\mathrm{VIN}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 H | Input HIGH Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHA }}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {ILB }}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open |  | -170 | -110 | - | mA |

NOTES:
2756 tbl 08

1. Typical parameters are specified at $\mathrm{V}_{\mathrm{EE}}=-5.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | Ceramic | -65 to +150 |${ }^{\circ} \mathrm{C}$.

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-101K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA | VILB | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ V V Ha | VILB | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V In $=$ V IHB | V lla | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | $\mathrm{V} \mathbb{I N}^{\text {= }}$ V $\mathrm{V}_{1+\mathrm{B}}$ | VILA | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| IIH | Input HIGH Current | $\mathrm{V}_{\mathbb{N}}=\mathrm{V}^{\text {IHA }}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| IIL | Input LOW Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {ILB }}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -190 | -130 | - | mA |

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION



2756 drw 06

## AC TEST INPUT PULSE



Note: All timing measurements are referenced to $50 \%$ input levels.

## RISE/FALL TIME

| Symbol | Parameter | Test Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tr | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10484, IDT100484 and IDT101484 BiCMOS ECL static RAMs (SRAM) provide high speed with low power dissipationtypical of BiCMOS ECL. These devices follow the traditional corner-power pinout and functionality for 4 Kx 4 ECL SRAMs. (Forcenter-powerpinouts, please see the IDT10A484, IDT100A494, and IDT101A484, respectively.)The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility ( -5.2 V ).

## READ TIMING

The read timing on these asynchronous devices is straightforward. Dataout is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}}$ ). Then Address (ADDR) settles and data appears onthe output aftertime tAA. Note that DataOUT is held for a short time ( tOH ) after the address begins to change for the next access, then ambiguous data is on the bus until a new time taA.

## WRITE TIMING

To write data to the device, a Write Pulse need be formed to control the write to the SRAM array. This Write Pulse, called $\overline{W E}$, is formed inside the device as the logical-AND of the WE1 and $\overline{W E 2}$ inputs; that is, when $\overline{W E 1}$ and $\overline{W E 2}$ both are driven low, WE goes low and the write cycle begins.

While $\overline{C S}$ and ADDR must be set-up when $\overline{W E}$ goes low, Datain can settle after the falling edge of $\bar{W} E$, giving the data path extra margin. Data is written to the memory cell at the end of the Write Pulse, and addresses and Chip Select must be held after the rising edge of the Write Pulse to ensure satisfactory completion of the cycle.

DataOUT is disabled (held low) during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the Dataout pins will output the written data after "Write Recovery Time" (tWR).

Because of the very short Write Pulse requirement, these devices can be cycled as quickly for Writes as for Reads. Balanced cycles mean simpler timing in cache applications.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 1048457 \\ 10048457 \\ 10148457 \end{gathered}$ |  | $\begin{aligned} & 1048458 \\ & 10048458 \\ & 10148458 \end{aligned}$ |  | $\begin{gathered} 10484 S 10 \\ 100484 S 10 \\ 101484 S 10 \end{gathered}$ |  | 10484 S15 100484S15 101484 S15 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle | ** |  |  |  |  |  |  |  |  |  |  |
| tacs | Chip Select Access Time | - | * | 3 | - | 5 | - | 5 | - | 5 | ns |
| tres | Chip Select Recovery Time | - | -* | 3 | - | 5 | - | 5 | - | 5 | ns |
| taA | Address Access Time | - | $\stackrel{\square}{*}$ | 7 | - | 8 | - | 10 | - | 15 | ns |
| tor | Data Hold from Address Change | - | 3 \% | - | 3 | - | 3 | - | 3 | - | ns |

1. Input and Output reference level is $50 \%$ point of waveform.

READ CYCLE GATED BY CHIP SELECT


READ CYCLE GATED BY ADDRESS


## AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10484 S 7 \\ 100484 S 7 \\ 10148457 \end{gathered}$ |  | $\begin{gathered} 10484 S 8 \\ 10048458 \\ 10148458 \end{gathered}$ |  | $\begin{gathered} 10484 S 10 \\ 100484 S 10 \\ 101484 S 10 \end{gathered}$ |  | $\begin{gathered} 10484 \mathrm{~S} 15 \\ 100484 \mathrm{~S} 15 \\ 101484 \mathrm{~S} 15 \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tw | Write Pulse Width | tWSA = minimum | 5 | - | 6 | - | 8 | - | 10 | - | ns |
| twSD | Data Set-up Time | - | 0 | \% | 0 | - | 0 | - | 2 | - | ns |
| tWSD2 ${ }^{(2)}$ | Data Set-up Time to WE High | - | 5 | \% | 5 | - | 5 | - | 5 | - | ns |
| tWSA | Address Set-up Time | tWSA $=$ minimum | 0 | \%- | 0 | - | 0 | - | 2 | - | ns |
| twscs | Chip Select Set-up Time | - | 0 \% | \% - | 0 | - | 0 | - | 2 | - | ns |
| tWHD | Data Hold Time | - | 1 \% | - | 1 | - | 1 | - | 2 | - | ns |
| tWHA | Address Hold Time | - | 1\% | - | 1 | - | 1 | - | 2 | - | ns |
| tWHCS | Chip Select Hold Time | - | 1. | - | 1 | - | 1 | - | 2 | - | ns |
| tws | Write Disable Time | - | - | 5 | - | 5 | - | 5 | - | 5 | ns |
| twR(3) | Write Recovery Time | - | - | 5 | - | 5 | - | 5 | - | 5 | ns |

## NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. TWSD is specified with respect to the falling edge of WE for compatibility with bipolar part specifications, but this device actually only requires twSD2 with respect to rising edge of WE .
3. twr is defined as the time to reflect the newly written data on the Data Outputs ( $C_{0} \mathrm{O}_{10} \mathrm{C}_{3}$ ) when no new Address Transition occurs.

WRITE CYCLE TIMING DIAGRAM


## ORDERING INFORMATION



HIGH-SPEED BiCMOS
ECL STATIC RAM 16 K (4K x 4-BIT) SRAM

## PRELIMINARY

 IDT10A484IDT100A484
IDT101A484

## FEATURES:

- 4096-words x 4-bit organization
- Address access time: $5 / 7 / 8 / 10 \mathrm{~ns}$
- Low power dissipation: 700 mW (typ.)
- Guaranteed Output Hold time
- Fully compatible with ECL logic levels
- Separate data input and output
- Center-power pinout for reduced noise
- Standard through-hole and surface mount packages


## DESCRIPTION:

The IDT10A484, IDT100A484 and IDT101A484 are 16,384bit high-speed BiCEMOSTM ECL static random access memories organized as $4 K \times 4$, with separate data inputs and outputs. All I/Os are fully compatible with ECL levels.

These devices are part of a family of asynchronous four-bit-wide ECL SRAMs. This device have been configured to follow the center-power pinout for reduced noise allowing higher speed operation. Because they are manufactured in BiCEMOS ${ }^{\text {TM }}$ technology, powerdissipation is greatly reduced over equivalent bipolar devices.

The asynchronous SRAMs are the most straightforward to use because no additional clocks or controls are required: Dataout is available an access time after the last change of address. To write data into the device requires the creation of a Write Pulse, and the write cycle disables the output pins in conventional fashion. Two Write Enable inputs are supplied, so the write pulse is created as a logical-AND of these signals to allow write gating at the device for minimal skew.

The fast access time and guaranteed Output Hold time allow greater margin for systemtiming variation. Datain setup time specified with respect to the trailing edge of Write Pulse eases write timing allowing balanced Read and Write cycle times.

## FUNCTIONAL BLOCK DIAGRAM



2811 drw 01

## PIN CONFIGURATION




400-Mil-Wide CERAMIC PACKAGE C28


400-Mil-Wide CERPACK E28


300-Mil-Wide PLASTIC SOJ PACKAGE Y28

## LOGIC SYMBOL



TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | WE1 | WE2 | Dataout | Function |
| :---: | :---: | :---: | :---: | :---: |
| H | X | X | L | Deselected |
| L | H | X | RAM Data | Read |
| L | X | H | RAM Data | Read |
| L | L | L | WRITE Data | Write |

## ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |  |  |  |
| TA | Operating Temperature |  | 0 to +75 |  |  |  |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |  |  |  |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TSTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 |  |  |  |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |  |  |  |
| PT | Power Dissipation |  |  |  | 1.5 | W |
| IOUT | DC Output Current <br> (Output High) | -50 | mA |  |  |  |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposuretoabsolutemaximum rating conditions for extended periods may affect reliability.
ECL-10K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | UnIt | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=\mathrm{V}$ IHA or V ILB |  | $\begin{aligned} & -1000 \\ & -960 \\ & -900 \end{aligned}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VoL | Output LOW Voltage | V IN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VOHC | Output Threshoid HIGH Voltage | V IN $=$ V IHB or $\mathrm{V}_{\text {ILA }}$ |  | $\begin{aligned} & -1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VOLC | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| IIH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| IIL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\text { CS }}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IeE | Supply Current | All Inputs and Outputs Open |  | -190 | -130 | - | mA | - |

NOTE:

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.5 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-100K DC ELECTRICAL CHARACTERISTICS
(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=\mathrm{V}$ IHA or V ILB |  | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=$ V Ifi or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| Vil | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| I IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -170 | -110 | - | mA |

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unlt |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |  |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.5 | W |
| IOUT | DC Output Current <br> (Output High) | -50 | mA |  |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-101K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condition |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=\mathrm{V}$ IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ VIHA or V ILB |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V IN $=\mathrm{V}$ IHB or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| VoLC | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | V IN $=$ V IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open |  | -190 | -130 | - | mA |

## AC TEST LOAD CONDITION



2811 drw 07

## AC TEST INPUT PULSE



Note: All timing measurements are referenced to $50 \%$ input levels.

2811 drw 08

RISE/FALL TIME

| Symbol | Parameter | Test Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tR | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10484, IDT100484, and IDT101484 BiCMOS ECL static RAMs (SRAM) provide high speed with low power dissipation typical of BiCMOS ECL. These devices follow the center-power pinout for 4 Kx 4 ECL SRAMs, reducing noise over corner-power versions allowing for improved system performance. (For corner-power pinouts, please see the IDT10484, IDT100494, and IDT101484, respectively.) The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility (-5.2V).

## READ TIMING

The read timing on these asynchronous devices is straightforward. Dataout is held low until the device is selected by Chip Select (CS). Then Address (ADDR) settles and data appears on the output aftertime tAA. Note that DataOUT is held for a short time (TOH) after the address begins to change for the next access, then ambiguous data is on the bus until a new time tAA.

## WRITE TIMING

To write data to the device, a Write Pulse need be formed to controlthe write to the SRAM array. This Write Pulse, called $\overline{W E}$, is formed inside the device as the logical-AND of the WE1 and $\overline{\mathrm{WE} 2}$ inputs; that is, when $\overline{\mathrm{WE} 1}$ and $\overline{\mathrm{WE}} 2$ both are driven low, WE goes low and the write cycle begins.

While CS and ADDR must be set-up when WE goes low, Datain can settle after the falling edge of $\overline{\mathrm{WE}}$, giving the data path extra margin. Data is writtento the memory cell at the end of the Write Pulse, and addresses and Chip Select must be held after the rising edge of the Write Pulse to ensure satisfactory completion of the cycle.

Dataout is disabled (heid low) during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the DataOUT pins will output the written data after "Write Recovery Time" (twR).

Because of the very short Write Pulse requirement, these devices can be cycled as quickly for Writes as for Reads. Balanced cycles mean simpler timing in cache applications.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10 \mathrm{~A} 484 \mathrm{S5} \\ 100 \mathrm{~A} 484 \mathrm{~S} 5 \\ 101 \mathrm{~A} 484 \mathrm{~S} 5 \\ \hline \end{gathered}$ |  | 10A484S7100A484S7101A484S7 |  | 10A484S8100A484S8101A484S8 |  | $\begin{aligned} & \text { 10A484S10 } \\ & \text { 100A484S10 } \\ & \text { 101A484S10 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tacs | Chip Select Access Time | - | - | $\% 2$ | - | 3 | - | 5 | - | 5 | ns |
| tres | Chip Select Recovery Time | - | - | \% 2 | - | 3 | - | 5 | - | 5 | ns |
| tas | Address Access Time | - | - | 5 | - | 7 | - | 8 | - | 10 | ns |
| toh | Data Hold from Address Change | - | 2\% | - | 3 | - | 3 | - | 3 | - | ns |

1. Input and Output reference level is $50 \%$ point of waveform.

## READ CYCLE GATED BY CHIP SELECT



READ CYCLE GATED BY ADDRESS


## AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | 10A484S5100A484S5101A484S5 |  | $\begin{aligned} & \text { 10A484S7 } \\ & \text { 100A484S7 } \\ & 101 A 484 S 7 \end{aligned}$ |  | 10A484S8 <br> 100A484S8 <br> 101A484S8 |  | $10 A 484 S 10$ <br> 100A484S10 <br> 101A484S10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mlin. | Max. | Miln. | Max. | Mlin. | Max. | Mlin. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tw | Write Pulse Width | twSA $=$ minimum | 3 | - | 5 | - | 6 | - | 8 | - | ns |
| tWSD | Data Set-up Time | - | 0 | $\bar{\square}$ | 0 | - | 0 | - | 0 | - | ns |
| tWSO2 ${ }^{(2)}$ | Data Set-up Time to WE High | - | 3 | \% | 5 | - | 5 | - | 5 | - | ns |
| tWSA | Address Set-up Time | tWSA $=$ minimum | 0 | \% | 0 | - | 0 | - | 0 | - | ns |
| twscs | Chip Select Set-up Time | - | 0 | \% | 0 | - | 0 | - | 0 | - | ns |
| tWHD | Data Hold Time | - | 1 * | - | 1 | - | 1 | - | 1 | - | ns |
| tWHA | Address Hold Time | - | 1** | - | 1 | - | 1 | - | 1 | - | ns |
| tWHCS | Chip Select Hold Time | - | 1.\% | - | 1 | - | 1 | - | 1 | - | ns |
| tws | Write Disable Time | - | $\cdots$ | 3 | - | 5 | - | 5 | - | 5 | ns |
| tWR ${ }^{(3)}$ | Write Recovery Time | - | - | 3 | - | 5 | - | 5 | - | 5 | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. twso is specified with respect to the falling edge of $\bar{W} E$ for compatibility with bipolar part specifications, but this device actually only requires twsDe with respect to rising edge of WE.
3. tw is defined as the time to reflect the newly written data on the Data Outputs ( $\mathrm{Q}_{0}$ to $Q_{3}$ ) when no new Address Transition occurs.

## WRITE CYCLE TIMING DIAGRAM



## ORDERING INFORMATION




## FEATURES:

- 65,536-words x 1 -bit organization
- Address access time: 8/10/12/15
- Low power dissipation: 420 mW (typ.)
- Guaranteed Output Hold time
- Fully compatible with ECL logic levels
- Separate data input and output
- JEDEC standard through-hole and surface mount packages


## DESCRIPTION:

The IDT10490, IDT100490 and IDT101490 are 65,536-bit high-speed BiCEMOS ${ }^{\text {M }}$ ECL static random access memories organized as $64 \mathrm{~K} \times 1$, with separate data inputs and outputs. All I/Os are fully compatible with ECL levels.

These devices are part of a family of asynchronous one-bit-wide ECL SRAMs. The devices have been configured to follow the standard ECL SRAM JEDEC pinout. Because they are manufactured inBiCEMOS ${ }^{\text {TM }}$ technology, however, power dissipation is greatly reduced over equivalent bipolar devices.

The asynchronous SRAMs are the most straightforward to use because no additional clocks or controls are required: Dataout is available an access time after the last change of address. To write data into the device requires the creation of a Write Pulse, and the write cycle disables the output pins in conventional fashion.

The fast access time and guaranteed Output Hold time allow greater margin for system timing variation. Dataln setup time specified with respect to the trailing edge of Write Pulse eases write timing allowing balanced Read and Write cycle times.

FUNCTIONAL BLOCK DIAGRAM


2759 dw 01

## PIN CONFIGURATION



SOJ TOP VIEW

PIN DESCRIPTIONS

| Symbol | Pln Name |
| :--- | :--- |
| Ao through A15 | Address Inputs |
| Do | Data Input |
| Q0 | Data Output |
| $\overline{W E}$ | Write Enable Input |
| $\overline{C S}$ | Chip Select Input (Internal pull down) |
| VEE | More Negative Supply Voltage |
| Vcc | Less Negative Supply Voltage |

2759 th 01

## AC OPERATING RANGES ${ }^{(1)}$

| UO | VEE | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sed}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sed}$ |
| 101 K | -4.75 V to -5.46 V | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sed}$ |

NOTE:

1. Referenced to Vcc


300-Mil-WIde CERDIP PACKAGE D22


2759 drw 05

300-Mil-Wide PLASTIC SOJ PACKAGE Y24

## LOGIC SYMBOL



CAPACITANCE ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unit |  |
| CIN | Input <br> Capacitance | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathrm{CS}}$ | $\overline{\text { WE }}$ | Data OUT | Function |
| :---: | :---: | :---: | :--- |
| H | X | L | Deselected |
| L | H | RAM Data | Read |
| L | L | L | Write |
| NOTE: <br> 1. H=High, L=Low, X=Don't Care |  |  |  |

NOTE:

1. $\mathrm{H}=\mathrm{High}, \mathrm{L}=$ Low, $\mathrm{X}=$ Don't Care

## ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TBIAS | Temperature Under Bias |  | -55 to +125 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TsTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| PT | Power Dissipation |  | 1.5 |
| lOUT | DC Output Current <br> (Output High) | -50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-10K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=\mathrm{V}$ IHA or V ILB |  | $\begin{aligned} & -1000 \\ & -960 \\ & -900 \end{aligned}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vol | Output LOW Voltage | V IN $=\mathrm{V}$ IHA or V ILB |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vohc | Output Threshold HIGH Voltage | $\mathrm{V}_{\mathbb{I}}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | $\begin{aligned} & \hline-1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $0^{\circ} \mathrm{C}$ $25^{\circ} \mathrm{C}$ $75^{\circ} \mathrm{C}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \\ & \hline \end{aligned}$ | mV | $0^{\circ} \mathrm{C}$ $25^{\circ} \mathrm{C}$ $75^{\circ} \mathrm{C}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| I IH | Input HIGH Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| 1 IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\text { CS }}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Outputs Open |  | -170 | -80 | - | mA | - |

## NOTES:

2759 tbol 06

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

# ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$ 

| Symbol | Rating |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 |
| -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |  |
| PT | Power Dissipation | 1.5 | W |
| IOUT | DC Out mput Current (Output <br> High) | -50 | mA |

## NOTE:

2759 ணы 07

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ V IHA or V ILB | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or V ILA | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs | -1810 | - | -1475 | mV |
| IIH | Input HIGH Current | $\mathrm{V} \mathbb{N}=\mathrm{V}_{1} \mathrm{HA}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | - | - | 110 |  |
| IIL | Input LOW Current | V IN $=\mathrm{V}_{\text {ILB }}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open | -150 | -70 | - | mA |

NOTE:

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | UnIt |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| Tbias | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.0 | W |
| lout | DC Out mput Current (Output High) |  | -50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-101K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ V IHA or V ILB |  | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | $\mathrm{V}_{\mathrm{N}}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {IIA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or V ILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | $\mathrm{V}_{1 \times}=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -170 | -80 | - | mA |

NOTE:
2759 th 10

1. Typical parameters are specified at $\mathrm{VEE}_{\mathrm{E}}=-5.2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION <br> Vcc (GND)



## AC TEST INPUT PULSE



Note: All timing measurements are referenced to $50 \%$ input levels.

RISE/FALL TIME

| Symbol | Parameter | Test Conditlon | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tR | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10490, IDT100490 and IDT101490 BiCMOS ECL static RAMs (SRAM) provide high speed with low power dissipation typical of BiCMOS ECL. These devices follow the conventional pinout and functionality for $64 \mathrm{~K} \times 1$ SRAMs. The ECL -101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility (-5.2V).

## READ TIMING

The read timing on these asynchronous devices is straightforward. Dataout is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}}$ ). Then Address (ADDR) settles and data appears on the output aftertime tAA. Note that DataOUT is held for a short time ( tOH ) after the address begins to change for the next access, then ambiguous data is on the bus until a new time taA.

## WRITE TIMING

To write data to the device, a Write Pulse need be formed on the Write Enable input ( $\overline{\mathrm{WE}}$ ) to control the write to the SRAM array. While $\overline{C S}$ and ADDR must be set-up when $\overline{W E}$ goes low, Datain can settle after the falling edge of $\overline{W E}$, giving the data path extra margin. Data is written to the memory cell at the end of the Write Pulse, and addresses and Chip Select must be held after the rising edge of the Write Pulse to ensure satisfactory completion of the cycle.

Dataout is disabled (held low) during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the Dataout pins will output the written data after "Write Recovery Time" (tWR).

Because of the very short Write Pulse requirement, these devices can be cycled as quickly for Writes as for Reads. Balanced cycles mean simpler timing in cache applications.

## AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{aligned} & 1049058 \\ & 10049058 \\ & 10149038 \end{aligned}$ |  | $\begin{gathered} 10490 S 10 \\ 100490 S 10 \\ 101490 S 10 \end{gathered}$ |  | $\begin{gathered} 10490 S 12 \\ 100490 S 12 \\ 101490 S 12 \end{gathered}$ |  | $\begin{gathered} 10490 \text { S15 } \\ 100490 \text { S15 } \\ 101490 S 15 \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tacs | Chip Select Access Time | - | - | 3 | - | 5 | - | 5 | - | 5 | ns |
| tRCS | Chip Select Recovery Time | - | - | 3 | - | 5 | - | 5 | - | 5 | ns |
| taA | Address Access Time | - | $\stackrel{\square}{*}$ | 8 | - | 10 | - | 12 | - | 15 | ns |
| tOH | Data Hold from Address Change | - | 3. | - | 3.5 | - | 3.5 | - | 3.5 | - | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.

## READ CYCLE GATED BY CHIP SELECT



## READ CYCLE GATED BY ADDRESS



## AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10490 S 8 \\ 100490 S 8 \\ 101490 S 8 \end{gathered}$ |  | $\begin{aligned} & 10490 \text { S10 } \\ & 100490 \text { S10 } \\ & 101490 \text { S10 } \end{aligned}$ |  | $\begin{gathered} 10490 \mathrm{~S} 12 \\ 100490 \mathrm{~S} 12 \\ 101490 \mathrm{~S} 12 \end{gathered}$ |  | $\begin{gathered} 10490 \text { S15 } \\ 100490 \text { S15 } \\ 101490 \text { S15 } \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tw | Write Pulse Width | tWSA $=$ minimum | 6 | - | 8 | - | 10 | - | 10 | - | ns |
| tWSD | Data Set-up Time | - | 0 | \% | 0 | - | 0 | - | 2 | - | ns |
| tWSD2 ${ }^{(2)}$ | Data Set-up Time to WE High | - | 5 | \%- | 5 | - | 5 | - | 5 | - | ns |
| tWSA | Address Set-up Time | tWSA $=$ minimum | 0 | \% | 0 | - | 0 | - | 2 | - | ns |
| twscs | Chip Select Set-up Time | - | 0 | $\stackrel{-}{*}$ | 0 | - | 0 | - | 2 | - | ns |
| tWHD | Data Hold Time | - | 2\% | - | 2 | - | 2 | - | 3 | - | ns |
| tWHA | Address Hold Time | - | ${ }^{2}$ | - | 2 | - | 2 | - | 3 | - | ns |
| twhes | Chip Select Hold Time | - | 2. | - | 2 | - | 2 | - | 3 | - | ns |
| tws | Write Disable Time | - | - | 5 | - | 5 | - | 5 | - | 10 | ns |
| twi ${ }^{(3)}$ | Write Recovery Time | - | - | 10 | - | 12 | - | 14 | - | 18 | ns |

## NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. twsD is specified with respect to the falling edge of WE for compatibility with bipolar part specifications, but this device actually only requires twSD2 with respect to rising edge of WE.
3. t W $=$ tWHA + tAA and thus can include a full access time if addresses change while Chip Select is still low.

WRITE CYCLE TIMING DIAGRAM


2759 drw 11

## ORDERING INFORMATION

| IDT | XXX | $X$ | XX | X | X |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { Device Type }}$ | $\frac{\text { Architecture }}{}$ | $\overline{\text { Speed }}$ | $\overline{\text { Package }}$ | Process/ Temp. Range |  | : |
|  |  |  |  |  | $\underline{L}$ | Blank | Commercial $0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ |
|  |  |  |  |  | -_\| | $\begin{aligned} & \mathrm{D} \\ & \mathrm{Y} \end{aligned}$ | CERDIP <br> Plastic SOJ |
|  |  |  |  |  |  | $\begin{aligned} & 8 \\ & 10 \\ & 12 \\ & 15 \end{aligned}$ | Speed in Nanoseconds |
|  |  |  |  |  | - 1 | S | Standard Architecture |
|  |  |  |  |  |  | 10490 | 64 K ( $64 \mathrm{~K} \times 1$-bit) BiCMOS ECL-10K Static RAM |
|  |  |  |  |  |  | 100490 | 64K (64K $\times 1$-bit) BiCMOS ECL-100K Static RAM |
|  |  |  |  |  |  | 101490 | 64K (64K x 1-bit) BiCMOS ECL-101K Static RAM |



## FEATURES:

- 16,384-words x 4-bit organization
- Address access time: 7/8/10/15
- Low power dissipation: 700 mW (typ.)
- Guaranteed Output Hold time
- Fully compatible with ECL logic levels
- Separate data input and output
- JEDEC standard through-hole and surface mount packages


## DESCRIPTION:

The IDT10494, IDT100494 and 101494 are 65,536-bit high-speed BiCEMOSTM ECL static random access memories organized as $16 \mathrm{~K} \times 4$, with separate data inputs and outputs. All I/Os are fully compatible with ECL levels.

These devices are part of a family of asynchronous four-bit-wide ECL SRAMs. The devices have been configured to follow the standard ECL SRAM JEDEC pinout. Because they are manufactured inBiCEMOS ${ }^{\text {TM }}$ technology, however, power dissipation is greatly reduced over equivalent bipolar devices.

The asynchronous SRAMs are the most straightforward to use because no additional clocks or controls are required: DataOUT is available an access time after the last change of address. To write data into the device requires the creation of a Write Pulse, and the write cycle disables the output pins in conventional fashion.

The fast access time and guaranteed Output Hold time allow greater margin for systemtiming variation. Datain setup time specified with respect to the trailing edge of Write Pulse eases write timing allowing balanced Read and Write cycle times.

## FUNCTIONAL BLOCK DIAGRAM



2764 drw 01

## PIN CONFIGURATION



## PIN DESCRIPTIONS

| Symbol | Pln Name |
| :--- | :--- |
| A0 through $A_{13}$ | Address Inputs |
| Do through D3 | Data Inputs |
| $Q_{0}$ through $\mathrm{C}_{3}$ | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{\mathrm{CS}}$ | Chip Select Input (Internal pull down) |
| VEE | More Negative Supply Voltage |
| VCC | Less Negative Supply Voltage |

AC OPERATING RANGES ${ }^{(1)}$

| IO | VEE | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | 0 TO $85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |

NOTE:

1. Referenced to Vcc

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unit |  |
| CIN | Input <br> Capacitance | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

LOGIC SYMBOL


TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | Dataout | Function |
| :---: | :---: | :---: | :--- |
| H | $\mathbf{X}$ | L | Deselected |
| L | H | RAM Data | Read |
| L | L | L | Write |

NOTE:

1. $\mathrm{H}=$ High, L=Low, $\mathrm{X}=$ Don't Care

ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |
| TSTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.5 | W |
| IOUT | DC Output Current (Output <br> High) | -50 | mA |  |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-10K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ VIIHA or VILB |  | $\begin{aligned} & \hline-1000 \\ & -960 \\ & -900 \end{aligned}$ | -885 | $\begin{array}{r} -840 \\ -810 \\ -720 \\ \hline \end{array}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VoL | Output LOW Voltage | $\mathrm{VIN}=\mathrm{VIHA}$ or VILB |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vohc | Output Threshold HIGH Voltage | V IN $=$ V IHB or V ILA |  | $\begin{aligned} & \hline-1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VOLC | Output Threshold LOW Voltage | V IN $=$ V IHB or $\mathrm{V}_{\text {ILA }}$ |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \\ & \hline \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| I IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\text { CS }}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I IL | Input LOW Current | V IN $=\mathrm{VILB}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Outputs Open |  | -190 | -130 | - | mA | - |

NOTE:

[^0]ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | RatIng |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| PT | Power Dissipation | 1.5 | W |
| lOUT | DC Out mput Current (Output <br> High) | -50 | mA |

NOTE:
2762 tbl 07

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | VIN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | Vin $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VII | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| I IH | Input HIGH Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ iHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 112 | Input LOW Current | V IN $=$ VILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open |  | -170 | -110 | - | mA |

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.5 | W |
| lOUT | DC Out mput Current (Output <br> High) | -50 | mA |  |

NOTE:
2763 bl 09

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-101K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| VOL | Output LOW Voltage | $V{ }^{\text {IN }}=\mathrm{V}$ IHA or V ILB |  | -1810 | -1715 | -1620 | mV |
| VOHC | Output Threshold HIGH Voltage | V IN $=\mathrm{V}$ IHB or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=$ V IHB or V ILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| I IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I II | Input LOW Current | V IN $=\mathrm{V}$ ILB | CS | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -190 | -130 | - | mA |

## NOTE:

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION



2764 drw 06

## AC TEST INPUT PULSE


$\mathrm{tR}=\mathrm{tF}=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.
 relerenced to $50 \%$ input levels.

RISE/FALL TIME

| Symbol | Parameter | Tost Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tR | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10494, IDT100494 and IDT101494 BiCMOS ECL static RAMs (SRAM) provide high speed with low power dissipation typical of BiCMOS ECL. These devices follow the conventional pinout and functionality for $16 \mathrm{~K} \times 4$ ECL SRAMs. The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility (-5.2V).

## READ TIMING

The read timing on these asynchronous devices is straightforward. Dataout is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}}$ ). Then Address (ADDR) settles and data appears on the output aftertime tAA. Note that DataOUT is held for a short time ( tOH ) after the address begins to change for the next access, then ambiguous data is on the bus until a new time taA.

## WRITE TIMING

To write data to the device, a Write Pulse need be formed on the Write Enable input ( $\overline{\mathrm{WE}}$ ) to control the write to the SRAM array. While $\overline{\mathrm{CS}}$ and ADDR must be set-up when $\bar{W} E$ goes low, Datain can settle afterthe falling edge of $\overline{W E}$, giving the datapath extra margin. Data is written to the memory cell at the end of the Write Pulse, and addresses and Chip Select must be held after the rising edge of the Write Pulse to ensure satisfactory completion of the cycle.

Dataout is disabled (held low) during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the DataOUT pins will output the written data after "Write Recovery Time" (twR).

Because of the very short Write Pulse requirement, these devices can be cycled as quickly for Writes as for Reads. Balanced cycles mean simpler timing in cache applications.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10494 S 7 \\ 100494 S 7 \\ 101494 S 7 \end{gathered}$ |  | $\begin{aligned} & 10494 S 8 \\ & 10049458 \\ & 10149458 \end{aligned}$ |  | $\begin{gathered} 10494 \mathrm{~S} 10 \\ 100494 \mathrm{~S} 10 \\ 101494 \mathrm{~S} 10 \end{gathered}$ |  | $\begin{gathered} 10494 \mathrm{~S} 15 \\ 100494 \mathrm{~S} 15 \\ 101494 \mathrm{~S} 15 \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tacs | Chip Select Access Time | - | - | 3 | - | 5 | - | 5 | - | 5 | ns |
| trcs | Chip Select Recovery Time | - | - | 3 | - | 5 | - | 5 | - | 5 | ns |
| tas | Address Access Time | - | - | 7 | - | 8 | - | 10 | - | 15 | ns |
| tor | Data Hold from Address Change | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |

NOTE:
2764 bid 12

1. Input and Output reference level is $\mathbf{5 0 \%}$ point of waveform.

## READ CYCLE GATED BY CHIP SELECT



2764 drw 08

## READ CYCLE GATED BY ADDRESS



## AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test <br> Condition | $\begin{gathered} 1049457 \\ 10049457 \\ 101494 S 7 \end{gathered}$ |  | $\begin{aligned} & 10494 S 8 \\ & 100494 S 8 \\ & 101494 S 8 \end{aligned}$ |  | $\begin{gathered} \text { 10494S10 } \\ \text { 100494S10 } \\ 101494 S 10 \end{gathered}$ |  | $\begin{gathered} 10494 \text { S15 } \\ 100494 \text { S15 } \\ 101494 \mathrm{~S} 15 \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tw | Write Pulse Width | tWSA $=$ minimum | 5 | - | 6 | - | 8 | - | 10 | - | ns |
| tWSD | Data Set-up Time | - | 0 | - | 0 | - | 0 | - | 2 | - | ns |
| tWSD2 ${ }^{(2)}$ | Data Set-up Time to WE High | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tWSA | Address Set-up Time | tWSA $=$ minimum | 0 | - | 0 | - | 0 | - | 2 | - | ns |
| twscs | Chip Select Set-up Time | - | 0 | - | 0 | - | 0 | - | 2 | - | ns |
| tWHD | Data Hold Time | - | 1 | - | 2 | - | 2 | - | 3 | - | ns |
| tWHA | Address Hold Time | - | 1 | - | 2 | - | 2 | - | 3 | - | ns |
| tWHCS | Chip Select Hold Time | - | 1 | - | 2 | - | 2 | - | 3 | - | ns |
| tws | Write Disable Time | - | - | 5 | - | 5 | - | 5 | - | 5 | ns |
| twr ${ }^{(3)}$ | Write Recovery Time | - | - | 5 | - | 5 | - | 5 | - | 5 | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. twSD is specified with respect to the falling edge of WE for compatibility with bipolar part specifications, but this device actually only requires twSO2 with respect to rising edge of WE.
3. twR is defined as the time to reflect the newly written data on the Data Outputs ( $Q_{0}$ to $Q_{3}$ ) when no new Address Transition occurs.

WRITE CYCLE TIMING DIAGRAM


## ORDERING INFORMATION



## SELF-TIMED BiCMOS ECL STATIC RAM 64K (16K x 4-BIT) STRAM

## PRELIMINARY <br> IDT10496LL IDT100496LL IDT101496LL

## FEATURES:

- 16,384-words x 4-bit organization
- Self-Timed Write, with latches on inputs and latches on outputs
- Balanced Read/Write cycle time: 13/15ns
- Access time: 10/12 ns (max.)
- Fully compatible with ECL logic levels
- Through-hole DIP and surface-mount packages


## DESCRIPTION:

The IDT10496LL, IDT100496LL and IDT101496LL are 65,536-bit high-speed BiCEMOS™ ECL static random access memories organized as $16 \mathrm{~K} \times 4$, with inputs and outputs fully compatible with ECL levels. Clocked level-sensitive
latches on inputs and outputs, and the self-timed write operation, provide enhanced system performance over conventional RAMs, providing easier design and improved system level cycle times.

Inputs can flow into the device and then are latched by the leading edge of an externally supplied differential clock. The small input valid window required means more margin for system skews. Logic-to-memory propagation delay is included in device cycle time calculation, allowing this device to deliverbetter systemperformance than asynchronous SRAMs and glue logic.

Write timing is controlled internally based on the clock. Write Enable has no special requirements. The device allows balanced read and write cycle times, and reads and writes can be inserted in any order.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION



## PIN DESCRIPTION

| Symbol | Pin Name |
| :--- | :--- |
| Ao through A13 | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{C S}$ | Chip Select Input (Internal pull <br> down) |
| CLK, $\overline{\text { CLK }}$ | Differential Clock Inputs |
| VBB | Reference Voltage Output ( $\approx 1.32 \mathrm{~V}$ ) |
| VEE | More Negative Supply Voltage |
| Vcc | Less Negative Supply Voltage |
| NC | No Connect - not internally bonded |

## AC OPERATING RANGES ${ }^{(1)}$

| IVO | Vee | Temperature |
| :---: | :--- | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |

NOTE:

1. Referenced to Vcc

CAPACITANCE ( $T A=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unit |  |
| CINCLK | Input <br> Capacitance <br> CLK/CLK | 6 | - | 3 | - | pF |
| CIN | Input <br> Capacitance <br> except CLK/CLK | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

LOGIC SYMBOL


16Kx4 STRAM

TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | CLK | Dataour(${ }^{(2)}$ | Function |
| :---: | :---: | :---: | :---: | :--- |
| H | X | $\uparrow$ | L | Deselected |
| L | H | $\uparrow$ | RAM Data | Read |
| L | L | $\uparrow$ | WRITE Data | Write |

## NOTES:

1. $\mathrm{H}=\mathrm{High}, \mathrm{L}=$ Low, $\mathrm{X}=$ Don't Care
2. DATAOUT changes when CLK returns high.

## ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-10K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$ for DIP, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\mathrm{V} \mathrm{IN}^{\text {= }}$ = $\mathrm{V}_{\mathrm{HA}}$ | V 1 LB | $\begin{aligned} & -1000 \\ & -960 \\ & -900 \end{aligned}$ | -885 | $\begin{array}{r} -840 \\ -810 \\ -720 \\ \hline \end{array}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vol | Output LOW Voltage | $\mathrm{V}_{\mathbb{N}}=\mathrm{V}_{\text {IHA }}$ | VILB | $\begin{array}{r} -1870 \\ -1850 \\ -1830 \\ \hline \end{array}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vorc | Output Threshold HIGH Voltage | $\mathrm{V} \mathbb{N}=\mathrm{V}_{\text {I }} \mathrm{HB}$ | VILA | $\begin{aligned} & -1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{\mathbb{N}}=\mathrm{V}_{1} \mathrm{HB}$ | VILA | - | - | $\begin{array}{r} -1645 \\ -1630 \\ -1605 \\ \hline \end{array}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed High for All | put Voltage uts ${ }^{(2)}$ | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Low for All | put Voltage $\text { uts }{ }^{(2)}$ | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| 1 H | Input HIGH Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| 1 ll | Input LOW Current | V IN $=\mathrm{VIILB}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Open ${ }^{(2)}$ | Outputs | -260 | -200 | - | mA | - |

## NOTES:

2788 tor 08

1. Typical parameters are specified at $\mathrm{V}_{\mathrm{EE}}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

## ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

## NOTE:

1. Stresses greater than thoselisted under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or VILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHA }}$ or $\mathrm{V}_{\text {ILB }}$ |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V IN $=$ VIHB or V ILA |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or $^{\text {V ILA }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs ${ }^{(2)}$ |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | $\mathrm{V} \mathbb{N}=\mathrm{V}_{1} \mathrm{HA}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | V IN $=$ VILB | $\overline{\mathrm{C}} \overline{\mathrm{S}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open ${ }^{(2)}$ |  | -240 | -180 | - | mA |

## NOTES:

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

## ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

NOTE:
2768 tb 09

1. Stresses greater than those listed under ABSOLUTEMAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-101K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ Vina or V Ilib |  | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | V IN $=$ VIHB or V ILA |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs ${ }^{(2)}$ |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}_{\text {IHA }}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open ${ }^{(2)}$ |  | -260 | -200 | - | mA |

NOTES:
2768 하 10

1. Typical parameters are specified at $\mathrm{VEE}_{\mathrm{E}}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

## LOAD CONDITION



2768 drw 06
Includes probe and
jig capacitance

## INPUT PULSE


$t R=t F=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

2768 drw 07

## RISE/FALL TIME

| Symbol | Parameter | Test Condition | Min. | Typ. | Max. | Unlt |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $t R$ | Output Rise Time | - | - | 2 | - | $n s$ |
| $t F$ | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10496LL, IDT100496LL, and IDT101496LL SelfTimed BiCMOS ECL static RAMs (STRAM) provide high speed with low power dissipation typical of BiCMOS ECL. On-chiplogic additionally helps improve system performance. The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility (-5.2V).

As can be seen in the Functional Block Diagram on the title page, this device contains level-sensitive latches to sample and hold addresses, input data, and control status, and hold output data. Inputs are transparent while the clock (CLK) input is low (and CLK is high), and then hold their contents when the
clock returns high. Inthe case of a write cycle, the memory cell is written during the clock-high time, and write data conducted to the outputs. Because the output latches are controlled by an inversion of the clock, output data flows out the output latch while clock is high and then is held into the next cycle during clock low.

The Latch-Latch architecture is most useful when read access data is needed within the same cycle that addresses settle. The input latch, when transparent, allows the access to begin as soon as addresses settle, allowing data to be ready somewhat sooner in the cycle than would be possible with a clocked-register implementation.

FUNCTIONAL DESCRIPTION TIMING EXAMPLE


## READ TIMING

In a typical read cycle, the read address flows into the device while clock is low, as at 1 below. Read access begins when the last address has settled. When clock returns high, the inputs are held so that addresses can begin to change for the next cycle.

Clock high also opens the output latches, so the read data for the read address clocked in at 1 is gated through the output latch to the output pins. There is a short delay from rising clock to output ready, called tDR (see Read Cycle Timing). If the clock-low time (tWL) is shorter than the inherent access-time of the cell, output is guaranteed valid after the specified tAA. But if tWL is longer than the cell access-time, output data will be valid tDR after clock goes high. Thus, the time it takes from address valid to data ready for any given address is
tAA = tAA or (tSA + tDR),
whichever is larger. A permutation of this equation holds for each read and write access modes.

Because addresses and control lines (Write Enable and Chip Select) all must be stable for access to commence, there are two other read access modes, described as follows.

If addresses and controls are all stable before input latches are opened by clock going low, as at 4 below, access begins on the low-going edge of clock. Data is available tacle later, provided the output latch is opened by clock returning high.

If address and Write Enable are valid after clock-low, but Chip Select is last to go low, as at $\mathbf{7}$ below, data is available tacs after the low-going edge of Chip Select.

The output latch takes some time to change state for the next cycle, but this time is very short. Therefore, data hold time from clock high (tDH) is specified as zero minimum hold time.

## DESELECT TIMING

Because the outputs are latched, they will continue to drive the output pins until a disable state is clocked through the device. The deselected state is achieved by de-asserting chip select ( $\overline{\mathrm{CS}}$ high) before clock returns high. This case occurs at 2 below. Outputs then attain the disable state (low) tDR later. Status of other inputs do not effect the disabling of the device when chip select is de-asserted with the proper relation to clock.

## WRITE TIMING

Write cycles are identical to read cycles, except that write enable and write data need also be supplied, with the appropriate setup and hold timing. The device has on-chip timing that handles all aspects of writing data into the addressed RAM cell without the need for external write-pulse generation. The timing logic uses the clock-high time as the write pulse, and thus determines the minimum clock-high time, tWH.

In addition to writing to the RAM cell, the write data is fed to the output register by a multiplexer, so that write data is available on the output pins after an access time. Thus the input data supplied at ${ }^{3}$ is available on the output tadrafter the input data has settled, while the input data supplied at 6 is available taW after Write Enable is asserted low. This function is sometimes called "Transparent Write," and is useful for write-through cache applications.

There are no restrictions on the order of read cycles and write cycles.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{aligned} & \text { 10496LL.13 } \\ & \text { 100496LL13 } \\ & \text { 101496LL13 } \end{aligned}$ |  | 10496 LL15$100496 L L 15$$101496 L L 15$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |
| tCYC | Cycle Time | - | 13 | - | 15 | - | ns |
| $\mathrm{tAA}^{(2)}$ | Address Access Time | - | - | \% $\% 10$ | - | \% * 12 | ns |
| tacs ${ }^{(3)}$ | Chip Select Access Time | - | - | \% 5 | - | $\stackrel{\square}{*}$ | ns |
| tACLK ${ }^{(4)}$ | Access Time from Clock Low | - | - | \% 10 | - | \% 12 | ns |
| twl | Clock Low Pulse Width | - | 3 | \% - | 3 | - | ns |
| tWH | Clock High Pulse Width | - | 10 \% | - | 12 | - | ns |
| tSCS | Setup Time for Chip Select | - | 1 \% | - | 1 \% | - | ns |
| tSA | Setup Time for Address | - | 1 \% | - | 1 者》 | - | ns |
| tHCS | Hold Time for Chip Select | - | 2 \% | - | 2 \% | - | ns |
| THA | Hold Time for Address | - | 2 | - | 2 | - | ns |
| tDH | Data Hold from Clock Low | - | 0 | - | 0 | - | ns |
| $\mathrm{tDR}^{(5)}$ | Data Ready from Clock Low | - | 0 | 4 | 0 | 4 | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. Read Cycle is gated by Address when tsA < TWL so that the access begins at the settling of Address. Access time is the larger of taA or tsA + tDR.
3. Read Cycle is gated by Chip Select when tscs < tWL so that access begins at the falling edge of Chip Select. Access time is the larger of tacs or tscs + tor.
4. Read Cycle is gated by Clock when tsA > twL so that access begins at the falling edge of Clock. Access time is the larger of taclk or twL + tDR.
5. $\operatorname{tDR}$ (max) is specified when all other gating conditions have been satisfied, specifically, for READ cycle: when tSA $>\operatorname{tAA}(\max )$-tDR(max) and tsCS $>\operatorname{tACs}$ (max)


READ CYCLE GATED BY ADDRESS (Assumes Chip Select and Clock stable before Address)


READ CYCLE GATED BY CHIP SELECT (Assumes Address and Clock stable before Chip Select)


READ CYCLE 'GATED B'Y CLOCK (Assumes Address and Chip Select stable before Clock Low)


AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{aligned} & \text { 10496LL13 } \\ & \text { 100496LL13 } \\ & \text { 101496LL13 } \end{aligned}$ |  | $\begin{gathered} \hline 10496 L L 15 \\ \text { 100496LL15 } \\ \text { 101496LL15 } \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Write Cycle ${ }^{(2)}$ |  |  |  |  |  |  |  |
| tAW ${ }^{(3)}$ | Write Enable Low to Data Valid | - | - | 5 | - | 5 | ns |
| TAD( ${ }^{(4)}$ | Data In Valid to Data Out Valid | - | - | 5 | - | 5 | ns |
| tswe | Setup Time for Write Enable | - | 1 | - | 1 | - | ns |
| tSD | Setup Time for Data In | - | 1 | - | 1 | - | ns |
| tHWE | Hold Time for Write Enable | - | 2 | - | 2 | - | ns |
| tHD | Hold Time for Data In | - | 2 | - | 2 | - | ns |

Notes.

1. Input and Output reference level is $50 \%$ point of waveform.
2. All Setup, Hold, and Access timing are the same as the Read Cycle with the addition of above requirements. Write Data appears on output pins after rising edge of clock.
3. Access time is the larger of taw or tswe + tDR.
4. Access time is the larger of tADI or tSD + tDR.

## WRITE CYCLE



## CLOCK INPUT

The clock input circult has been designed to accomodate both single-ended and differential mode operation. Differential mode exhibits better common-mode nolse rejection and is obtalned by driving both true and complement clock Ilnes with a differentlal driver, as shown In Figure (a). Single-ended operation is achleved as either falling-edge-active or rising-edge-active, as shown in Figures (b) and (c), respectively. VBB is designed to drive clock input only and is not intended to be used for any other purpose.

(a) Differential Mode

(b) Falling-Edge-Active Single-Ended Mode

(c) Rising-Edge-Active Single-Ended Mode

## ORDERING INFORMATION



## SELF-TIMED BiCMOS ECL STATIC RAM 64K (16K x 4-BIT) STRAM

## PRELIMINARY IDT10496RL IDT100496RL IDT101496RL

## FEATURES:

- 16,384 -words $\times 4$-bit organization
- Self-Timed, with registers on inputs and latches on outputs
- Balanced Read/Write cycle time: $10 / 12 / 15$ ns
- Access time: $10 / 12 / 15$ ns (max.)
- Fully compatible with ECL logic levels
- Through-hole DIP and surface-mount packages


## DESCRIPTION:

The IDT10496RL, IDT100496RL and IDT101496RL are 65,536 -bit high-speed BiCEMOS ${ }^{\text {TM }}$ ECL static random access memories organized as $16 \mathrm{~K} \times 4$, with inputs and outputs fully compatible with ECL levels. Clocked registers on inputs
and latches on outputs, and the self-timed write operation, provide enhanced system performance over conventional RAMs, providing easier design and improved system level cycle times.

Inputs are captured by the leading edge of an extemally supplied differential clock. The small input valid window required means more marginfor systemskews. Logic-to-memory propagation delay is included indevice cycle time calculation, allowing this device to deliver better system performance than asynchronous SRAMs and glue logic.

Write timing is controlled internally based on the clock. Write Enable has no special requirements. The device allows balanced read and write cycle times, and reads and writes can be inserted in any order.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION

| $\overline{\text { CS }} 1$ | 32 | $\square \overline{W E}$ |
| :---: | :---: | :---: |
| Do | 31 | VBb |
| D1 | 30 | $\square \mathrm{CLK}$ |
| $\mathrm{D}_{2}$ | 29 | $\square$ CLK |
| D3 | 28 | $\square \mathrm{NC}$ |
| Qo | 27 | $\square \mathrm{NC}$ |
| Q1 | 26 | - $\mathrm{A}_{13}$ |
| Vcc | 25 | $\square \mathrm{A} 12$ |
| Voc $\square^{9}$ | 24 | $\square \mathrm{Vee}$ |
| Q2 10 | 23 | ( ${ }^{111}$ |
| Q3 ${ }^{11}$ | 22 | P A10 |
| A0 12 | 21 | ค ${ }^{\text {a }}$ |
| ${ }^{\text {A } 1}{ }^{13}$ | 20 | $\square \mathrm{AB}^{\text {a }}$ |
| A2 14 | 19 | - A7 |
| ${ }^{\text {A }}{ }^{15}$ | 18 | ص $\mathrm{A}_{6}$ |
| $\mathrm{A}_{4}{ }^{16}$ | 17 | $\square \mathrm{As}$ |



400-MAI-Wide CERAMIC PACKAGE C32


300-MII-Wide PLASTIC SOJ PACKAGE Y32

## PIN DESCRIPTION

| Symbol | PIn Name |
| :--- | :--- |
| Ao through A13 | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{\text { CS }}$ | Chip Select Input (Internal pull down) |
| CLK, $\overline{\text { CLK }}$ | Differential Clock Inputs |
| VBB | Reference Voltage Output ( $\approx 1.32 \mathrm{~V})$ |
| VEE | More Negative Supply Voltage |
| VcC | Less Negative Supply Voltage |
| NC | No Connect - not internally bonded |

AC OPERATING RANGES ${ }^{(1)}$

| VO | VEE | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |

## NOTE:

1. Referenced to Vcc

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unit |  |
| CINCLK | Input <br> Capacitance <br> CLKKICLK | 6 | - | 3 | - | pF |
| CIN | Input <br> Capacitance <br> except CLKICLK | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

LOGIC SYMBOL


TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | CLK | DataouT ${ }^{(2)}$ | Function |
| :---: | :---: | :---: | :---: | :--- |
| $H$ | X | $\lrcorner$ | L | Deselected |
| L | H | $\pm$ | RAM Data | Read |
| L | L | $\lrcorner$ | WRITE Data | Write |

NOTES:

1. $\mathrm{H}=\mathrm{High}, \mathrm{L}=$ Low, $\mathrm{X}=$ Don't Care
2. DATÁOUT initiated by falling edge of CLK.

IDT10496RL, IDT100496RL, IDT101496RL
HIGH SPEED BICMOS ECL SELF-TIMED STATIC RAM 64 K ( $16 \mathrm{~K} \times 4$-BIT)

## ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND |  | +0.5 to -7.0 | V.

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-10K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}_{\mathrm{L}}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$ for DIP, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V $\mathrm{VIHA}^{\text {or }} \mathrm{V}$ ILB |  | $\begin{aligned} & -1000 \\ & -960 \\ & -900 \\ & \hline \end{aligned}$ | -885 | $\begin{array}{r} -840 \\ -810 \\ -720 \\ \hline \end{array}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vol | Output LOW Voltage | V IN $=$ VIHA or $\mathrm{V}_{\text {ILB }}$ |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \\ & \hline \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VOHC | Output Threshold HIGH Voltage | $\mathrm{VIN}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | $\begin{gathered} -1020 \\ -980 \\ -920 \end{gathered}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Votc | Output Threshold LOW Voltage | V IN $=$ VIHB or $\mathrm{V}_{\text {IIA }}$ |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs ${ }^{(2)}$ |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{array}{r} -840 \\ -810 \\ -720 \\ \hline \end{array}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| I IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I IL | Input LOW Current | V IN $=\mathrm{VILB}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Outputs Open(2) |  | -260 | -200 | - | mA | - |

## NOTES:

1. Typical parameters are specified at $\mathrm{VEE}_{\mathrm{E}}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one oí which is tied low and one is tied high.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | RatIng |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND |  | +0.5 to -7.0 | V.

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VoH | Output HIGH Voltage | V IN $=$ VIHA or $\mathrm{V}_{\text {ILB }}$ |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | Vin $=$ Vina or Vilb |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs ${ }^{(2)}$ |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | -1810 | - | -1475 | mV |
| 1 H | Input HIGH Current | V IN $=\mathrm{V}_{\text {IHA }}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {ILB }}$ | $\overline{\text { CS }}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open ${ }^{(2)}$ |  | -240 | -180 | - | mA |

## NOTES:

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

## ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unlt |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage <br> Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \\ & \hline \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| IOUT | DC Output Current (Output High) |  | -50 | mA |

NOTE:

1. Stresses greater than those listedunderABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-101K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$ for DIP, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condtions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vor | Output HIGH Voltage |  |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | VIN $=$ VIHA or VILB |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| ViH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs ${ }^{(2)}$ |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | V IN $=$ V IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | V IN $=$ V ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open ${ }^{(2)}$ |  | -260 | -200 | - | mA |

## NOTES:

2771 do 10

1. Typical parameters are specified at $\mathrm{V}_{\mathrm{EE}}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

## AC TEST LOAD CONDITION



2771 drw 06

## AC TEST INPUT PULSE


$t \mathrm{t}=\mathrm{tF}=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

2771 drw 07

RISE/FALL TIME

| Symbol | Parameter | Test Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tr | Output Rise Time | - | - | 2 | - | ns |
| t $F$ | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10496RL, IDT100496RL and IDT101496RL SelfTimed BiCMOS ECL static RAMs (STRAM) provide high speed with low power dissipation typical of BiCMOS ECL. On-chip logic additionally helps improve system performance. The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility (-5.2V).

As can be seen in the Functional Block Diagram on the title page, this device contains clocked input registers to sample and hold addresses, input data, and control status. Inputs are sampled on the rising edge of the clock (CLK) input (falling edge of CLK). In the case of a write cycle, the memory cell is written during the clock-high time, and write data conducted to
the outputs. Output data flows out the output latch and is held into the next cycle.

## READ TIMING

In a typical read cycle, the read address is captured by the rising edge of clock, as at $\mathbf{T}$ below. Then, when clock goes low, the read data for the read address clocked in at $\mathbf{0}$ is gated through the output latch to the output pins. There is a short delay from falling clock to output ready, called IDR (see Read Cycle Timing). If the clock-high time (tWH) is shorter than the inherent access-time of the cell, output is guaranteed valid after the specified tacc. But if twh is longer than the cell access-time, output data will be valid tDR after clock goes low. Thus, the time it takes from clock-to-output for any given

FUNCTIONAL DESCRIPTION TIMING EXAMPLE

address (the latency, or tACC) is

$$
t A C C=t A C C \text { or ( } t W H+t D R),
$$

whichever is larger.
The output latch takes some time to change state for the next cycle, but this time is very short. Therefore, data hold time from clock low (tDH) is specified as zero minimum hold time.

## DESELECT TIMING

Because the outputs are latched, they will continue to drive the output pins until a disable state is clocked through the device. The deselected state is achieved by de-asserting chip select ( $\overline{\mathrm{CS}}$ high) at rising edge of clock. This case occurs at (2) below. Outputs then attain the disable state (low) tacc later. Status of other inputs do not effect the disabling of the device when chip select is de-asserted with the proper relation to clock.

## WRITE TIMING

Write cycles are identical to read cycles, except that write enable and write data need also be supplied, with the appropriate setup and hold timing. The device has on-chip timing that handles all aspects of writing data into the addressed RAM cell without the need for external write-pulse generation. The timing logic uses the clock-high time as the write pulse, and thus determines the minimum clock-high time, twh.

In addition to writing to the RAM cell, the write data is fed to the output register by a multiplexer, so that write data is available on the output pins in the appropriate time slot (i.e. after tWH + tDR). This function is sometimes called "Transparent Write," and is useful for write-through cache applications. Thus the input data sampled at 3 is available on the output at the end of the cycle.

There are no restrictions on the order of read cycles and write cycles.

## AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} \text { 10496RL10 } \\ \text { 100496RL10 } \\ \text { 101496RL10 } \end{gathered}$ |  | 10496RL12 100496RL12 101496RL12 |  | $\begin{gathered} \text { 10496RL15 } \\ \text { 100496RL15 } \\ \text { 101496RL15 } \\ \hline \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |
| tcyc | Cycle Time | - | 10 | - | 12 | - | 15 | - | ns |
| tacc ${ }^{(2)}$ | Access Time from Clock High | - | - | 10 | - | 12 | - | 15 | ns |
| twL | Clock Low Pulse Width | - | 5 | - | 5 | - | 6 | - | ns |
| tWH | Clock High Pulse Width | - | 5 | - | 5 | - | 6 | - | ns |
| tscs | Setup Time for Chip Select | - | 1 | - | 1 | - | 1 | - | ns |
| tSA | Setup Time for Address | - | 1 | - | 1 | - | 1 | - | ns |
| thes | Hold Time for Chip Select | - | 2 | - | 2.5 | - | 2.5 | - | ns |
| tha | Hold Time for Address | - | 2 | - | 2.5 | - | 2.5 | - | ns |
| tDH | Data Hold from Clock Low | - | 2 | - | 2 | - | 2 | - | ns |
| tDR | Data Ready from Clock Low | - | 0 | 5 | 0 | 5 | 0 | 5 | ns |

## NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. Access time is the larger of tacc or twH + tor.

## READ CYCLE TIMING DIAGRAM



2771 drw 09

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} \text { 10496RL10 } \\ \text { 100496RL10 } \\ \text { 101496RL10 } \end{gathered}$ |  | $\begin{gathered} \text { 10496RL12 } \\ \text { 100496RL12 } \\ \text { 101496RL12 } \end{gathered}$ |  | $\begin{gathered} 10496 R L 15 \\ 100496 R L 15 \\ \text { 101496RL15 } \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle ${ }^{(2)}$ |  |  |  |  |  |  |  |  |  |
| tSWE | Setup Time for Write Enable | - | 1 | - | 1 | - | 1 | - | ns |
| tSD | Setup Time for Data In | - | 1 | - | 1 | - | 1 | - | ns |
| thWE | Hold Time for Write Enable | - | 2 | - | 2.5 | - | 2.5 | - | ns |
| tHD | Hold Time for Data In | - | 2 | - | 2.5 | - | 2.5 | - | ns |

## NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. All Setup, Hold, and Access timing are the same as the Read Cycle with the addition of above requirements. Write Data appears on output pins after falling edge of clock.

## WRITE CYCLE TIMING DIAGRAM



## CLOCK INPUT

The clock input circuit has been designed to accomodate both single-ended and differentlal mode operation. Differentlal mode exhibits better common-mode nolse rejection and is obtalned by driving both true and complement clock lines with a differential driver, as shown In Figure (a). Singie-ended operation is achleved as elther falling-edge-active or rising-edge-active, as shown In Figures (b) and (c), respectlvely. VBB ls designed to drive clock input only and is not intended to be used for any other purpose.

(a) Differential Mode

(b) Falling-Edge-Actlve Single-Ended Mode

(c) Rising-Edge-Actlve Single-Ended Mode

## ORDERING INFORMATION

IDT $\frac{X X X}{\text { Device Type }} \frac{X}{\text { Architecture }} \quad \frac{X X}{\text { Speed }} \frac{X}{\text { Package }} \quad \frac{X}{\text { Process/ }}$


Blank C
y

10
12
15
RL Registered Inputs, Latched Outputs
10496 64K (16K x 4-bits) BiCMOS ECL-10K Self-Timed Static RAM

64K (16K x 4-bits) BiCMOS ECL-100K
Self-Timed Static RAM
64 K (16K $\times 4$-bits) BiCMOS ECL-101K Self-Timed Static RAM


## FEATURES:

- 16,384-words $\times 4$-bit organization
- Address access time: $12 / 15$ ns
- Read Data output latch for extended hold time
- Short Write Cycle input data and address valid time
- Pin compatible with standard 16K $\times 4$
- Through-hole DIP and surface-mount packages


## DESCRIPTION:

The IDT10497, IDT100497 and IDT101497 are 65,536-bit high-speed BiCEMOSTM ECL static random access memories organized as $16 \mathrm{~K} \times 4$, with inputs and outputs fully compatible with ECL levels. Internal registers on inputs
provide enhanced Write Cycle performance over conventional RAMs, while output read data latch allows longer output data hold time providing easier design and improved system level cycle times.

In the read mode, this device is pinout and timing compatible with the standard asynchronous SRAMs (IDT10494), yet the addition of an output latch with separate enable control allow output data to be captured and held long into the next cycle. This minimizes noise on the data bus and provides better set-up time margin for the next logic stage in pipelined applications.

In the write mode, the device adds an invisible pipeline stage in the write address and data paths, allowing very short set-up and hold times for these inputs and less stringent requirements for the write pulse input.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION




400-MII-Wide
CERAMIC PACKAGE
C32


300-Mil-Wide PLASTIC SOJ PACKAGE 732

## PIN DESCRIPTIONS

| Symbol | Pin Name |
| :--- | :--- |
| Ao through A13 | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{\mathrm{CS}}$ | Chip Select Input (Internal pull down) |
| $\overline{\mathrm{OLE}}$ | Output Latch Enable |
| VEE | More Negative Supply Voltage |
| Vcc | Less Negative Supply Voltage |

## AC OPERATING RANGES ${ }^{(1)}$

| IO | Vee | Temperature |
| :---: | :---: | :---: |
| 10K | $-5.2 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100K | -4.5V $\pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101K | -4.75 V to -5.46V | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| NOTE: <br> 1. Referenced to Vcc |  |  |

## LOGIC SYMBOL



TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | $\overline{\text { OLE }}$ | Dataout $^{(2)}$ | Functlon |
| :---: | :---: | :---: | :---: | :--- |
| $H$ | $X$ | X | L | Deselected |
| L | H | L | RAM Data | Read |
| L | H | H | RAM Data | Output Held |
| L | L | X | L | Write |

## NOTES:

1. $\mathrm{H}=$ High, $\mathrm{L}=$ Low, $\mathrm{X}=$ Don't Care
2. DATAOUT initiated by falling edge of $\overline{O L E}$.

ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

NOTE:
XIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-10K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | $\begin{gathered} -1000 \\ -960 \\ -900 \end{gathered}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vol | Output LOW Voltage | VIN $=$ VIHA or $\mathrm{V}_{\text {ILB }}$ |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VOHC | Output Threshold HIGH Voltage | $\mathrm{V}_{\mathbb{N}}=\mathrm{V}_{\text {IHB }}$ or V ILA |  | $\begin{aligned} & \hline-1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{aligned} & 0^{\circ} \mathrm{C} \\ & 25^{\circ} \mathrm{C} \\ & 75^{\circ} \mathrm{C} \end{aligned}$ |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{aligned} & 0^{\circ} \mathrm{C} \\ & 25^{\circ} \mathrm{C} \\ & 75^{\circ} \mathrm{C} \end{aligned}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $0^{\circ} \mathrm{C}$ $25^{\circ} \mathrm{C}$ $75^{\circ} \mathrm{C}$ |
| I IH | Input HIGH Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| 1 LL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| lee | Supply Current | All Inputs and Outputs Open |  | -260 | -200 | - | mA | - |

NOTES:

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to $=7.0$ | V |
| TA | Operating Temperature |  | 0 to + 85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | Ceramic | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.0 | W |
| Iout | DC Output Current (Output High) |  | -50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | VIN $=$ V IHA or V IIB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | VIN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V IN $=$ V IHB or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| I IH | Input HIGH Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open |  | -240 | -180 | - | mA |

NOTE:

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |  |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |
| TsTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation | 2.0 | W |  |
| IOUT | DC Output Current <br> (Output High) | -50 | mA |  |

NOTE:
277409

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolutemaximumrating conditions for extended periods may affect reliability.

ECL-101K DC ELECTRICAL CHARACTERISTICS
( $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condition |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHA }}$ or $\mathrm{V}_{\text {ILB }}$ |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or V ILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\text { CS }}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| IIL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open |  | -260 | -200 | - | mA |

NOTE:

1. Typical parameters are specified at $V_{E E}=-5.2 \mathrm{~V}, T A=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION



AC TEST INPUT PULSE

$\mathrm{tR}=\mathrm{tF}=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

RISE/FALL TIME

| SYMBOL | PARAMETER | TEST CONDITION | MIN. | TYP. | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| th | Output Rise Time | - | - | 2 | - | ns |
| t | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10497. IDT100497, and IDT101497 BiCMOS ECL static RAMs (SRAM) with SYNCHRONOUS WRITE provide high speed with low power dissipation typical of BiCMOS ECL. On-chip logic additionally helps improve system performance, yet the device is pinout-compatible with asynchronous equivalents (i.e...IDT10494, IDT100494, and IDT101494 respectively). The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility ( -5.2 V ).

As can be seen in the Functional Block Diagram on the title page, this device contains clocked input registers to sample and hold addresses and input data, during a write cycle only. Inputs are sampled on the rising edge of the Write Enable (WE). The write cycle is pipelined: the memory cell is written during the $\overline{W E}$-low time in the next cycle.

Read cycles are not pipelined and operate identically to an asynchronous device, except that an output latch is provided to capture and hold Read data.

FUNCTIONAL DESCRIPTION TIMING EXAMPLE


## READ TIMING

The read timing on the device is asynchronous. Dataout is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}}$ ). Then Address (ADDR) settles and data appears on the output after time tas, as at $\mathbf{O}$ below.

DataOUt is held for a short time (toh) after the address begins to change for the next access, as can be seen at $\mathbf{0}$ allowing addresses to begin to change early for the next cycle - then ambiguous data is on the bus until a new time taA.

To avoid this noise on the bus and provide for longer output hold time, this device includes an output Read data latch which allows Read data to flow out while Output Latch Enable ( $\overline{\mathrm{OLE}}$ ) is low, and then hold when $\overline{\mathrm{OLE}}$ is high. Thus in the example below Read data at $\boldsymbol{0}$ is held until Read data at $\mathbf{8}$ is ready for output.

Note that Dataout is disabled (held low) by $\overline{\mathrm{CS}}$ high or $\overline{\mathrm{WE}}$ low, regardless of the state of the Output Latch.

## DESELECT TIMING

Deselect timing is identical to a standard asynchronous device. This case occurs at $\Theta$ below. Outputs attain the disable state (low) tras later Chip Select ( $\overline{\mathrm{CS}}$ ) is taken to a high logic state. Status of other inputs do not effect the disabling of the device when chip select is de-asserted.

## WRITE TIMING

Write cycles pipelined to allow easier design and higher system performance. The write pulse created on the $\overline{W E}$ input is used as a strobe to clock in the Write Address and Data into a register. This address and data are held in the register until the next write cycle, when they are used to write into the memory array through the Input Multiplexor.

Note the veryshort valid window required for Write Address and Data inputs. This is because these signals are captured by the input register. This means that input data may arrive late in the cycle, as at 3 below, or data and address may arrive late, as at $\mathbf{6}$ below.

Dataout is disabled during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the Dataout pins will output the written data after "Write Recovery Time" (tWR), as for a standard asynchronous device.

There is a special case when a Read cycle follows directly a Write Cycle to the same address. The memory array has not yet been updated with the Write data - it is still in the input register. This case is handled by including an address comparator and Output Multiplexor on the device: if the address being presented on the input pins is the same as the address stored in the input register, the data presented to the output pins is also from the input register.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10497 \mathrm{~S} 12 \\ 100497 \mathrm{~S} 12 \\ 101497 \mathrm{~S} 12 \end{gathered}$ |  | $\begin{gathered} 10497 S 15 \\ 100497 S 15 \\ 101497 S 15 \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |
| tAA ${ }^{(2)}$ | Address Access Time | - | - | \% 12 | - | 15 | ns |
| tacs | Chip Select Access Time | - | - | * 5 | - | * ${ }^{\circ}$ | ns |
| trcs | Chip Select Recovery Time | - | - | - 5 | - | * 5 | ns |
| toh | Data Hold from Address Change | - | 3 | 葢 | 3 | * - | ns |
| tolel | Latch Enable Low Pulse Width | - | 5 | - - | 5 | - | ns |
| taho | Address Valid to OLE High | - | 14 | - | 17 | - | ns |
| tor | Data Hold from Clock Low | - |  | - | 0 | - | ns |
| tDR | Data Ready from Clock Low | - | 0 | 4 | 0 | 4 | ns |

NOS.

1. Input and Output reference level is $50 \%$ point of waveform.
2. Read Data is valid at tAA or taHO - tolel + tDR, whichever is larger; that is, Read Data is valid at the access time unless Output Latch Enable is high, and then access is tor after OLE goes low.

## READ CYCLE GATED BY CHIP SELECT



## READ CYCLE GATED BY ADDRESS



## OUTPUT LATCH TIMING



AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} \text { 10497S12 } \\ 100497 \mathrm{~S} 12 \\ 101497 \mathrm{~S} 12 \end{gathered}$ |  | $\begin{gathered} 10497 \mathrm{~S} 15 \\ 100497 \mathrm{~S} 15 \\ 101497 \mathrm{~S} 15 \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |
| tw | Write Pulse Width | - | 10 | - | 12 | - | ns |
| twscs | Setup Time for Chip Select | - | 0 | - | 1 | \% | ns |
| twSA | Setup Time for Address | - | 1 | - | 1 | \% | ns |
| tWSD | Setup Time for Data In | - | 1 \% | - | 1 苓 | $\stackrel{-}{*}$ | ns |
| twhes | Hold Time for Chip Select | - | 2 | - | 2 | - | ns |
| tWHA | Hold Time for Address | - | 2 \% | - | $2 \%$ | - | ns |
| tWHD | Hold Time for Data In | - | 2 \% | - | 2 \% | - | ns |
| tws | Write Disable Time | - | - " ${ }^{\text {\% }}$ | 5 | - ** | 5 | ns |
| tWR | Write Recovery Time | - | - | 5 | - | 5 | ns |

1. Input and Output reference level is $50 \%$ point of waveform.

## WRITE CYCLE TIMING DIAGRAM



## ORDERING INFORMATION

IDT $\frac{X X X}{\text { Device Type }} \quad \frac{X}{\text { Architecture }} \quad \frac{X X}{\text { Speed }} \quad \frac{X}{\text { Package }} \quad \frac{X}{\text { Process/ }}$


2774 drw 11


## FEATURES:

- 16,384-words x 4-bit organization
- Address access time: $12 / 15 \mathrm{~ns}$
- Read Data output latch for extended hold time
- Short Write Cycle input data and address valid time
- Write Cycle may be terminated very late in the cycle
- Pin compatible with standard $16 \mathrm{~K} \times 4$
- Through-hole DIP and surface-mount packages


## DESCRIPTION:

The IDT10498, IDT100498 and IDT101498 are 65,536-bit high-speed BiCEMOSTM ECL static random access memories organized as $16 \mathrm{~K} \times 4$, with inputs and outputs fully compatible with ECL levels. Internal registers on inputs
provide enhanced Write Cycle performance over conventional RAMs, while output read data latch allows longer output data hold time providing easier design and improved system level cycle times.

In the read mode, this device is pinout and timing compatible with the standard asynchronous SRAMs (IDT10494), yet the addition of an output latch with separate enable control allow output data to be captured and held long into the next cycle. This minimizes noise on the data bus and provides better set-up time margin for the next logic stage in pipelined applications.

In the write mode, the device adds an invisible pipeline stage in the write address and data paths, allowing very short set-up and hold times for these inputs and less stringent requirements for the write pulse input. Additionally, the address and data paths to the input register are gated by the Conditional Write Multiplexor, which allows termination of a Write cycle late in the cycle.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION



## PIN DESCRIPTIONS

| Symbol | Pin Name |
| :---: | :---: |
| A0 through $\mathrm{A}_{13}$ | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| WE | Write Enable Input |
| $\overline{\mathrm{CS}}$ | Chip Select Input (Internal pull down) |
| $\overline{\text { OLE }}$ | Output Latch Enable |
| Vee | More Negative Supply Voltage |
| Vcc | Less Negative Supply Voltage |

## AC OPERATING RANGES ${ }^{(1)}$

| VO | VEE | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sed}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | 0 TO $85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sed}$ |
| 101 K | -4.75 V to -5.46 V | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sed}$ |

NOTE:

1. Referenced to Vcc

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unlt |  |
| CIN | Input <br> Capacitance | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

## LOGIC SYMBOL



TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | $\overline{\text { OLE }}$ | Data OUT |  |
| :---: | :---: | :---: | :---: | :--- |
| (2) | Function |  |  |  |
| L | X | X | L | Deselected |
| L | H | L | RAM Data | Read |
| L | L | X | RAM Data | Output Held |

NOTES:

1. $H=$ High, L=Low, $X=$ Don't Care
2. DATAOUT initiated by falling edge of $\overline{O L E}$.

## ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBias | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \\ & \hline \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| Iout | DC Output Current (Output High) |  | -50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions

## ECL-10K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | $\begin{gathered} -1000 \\ -960 \\ -900 \end{gathered}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Voi | Output LOW Voltage | V IN $=$ VIHA or VILB |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vohic | Output Threshold HIGH Voltage | V IN $=$ V IHB or $\mathrm{V}_{\text {ILA }}$ |  | $\begin{aligned} & -1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VoLC | Output Threshold LOW Voltage | $\mathrm{V}_{1 \times}=\mathrm{V}_{\text {IHB }}$ or V ILA |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| I IH | Input HIGH Current | V IN $=\mathrm{V}_{\text {IHA }}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I IL | Input LOW Current | V IN $=$ VILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Outputs Open |  | -260 | -200 | - | mA | - |

NOTE:

1. Typical parameters are specified at $\mathrm{V}_{\mathrm{EE}}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to + 85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

1. Stresses greater than those listedunder ABSOLUTEMAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condltions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHA }}$ or $\mathrm{V}^{\text {ILB }}$ |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | VIN $=$ VIHA or VILB |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | $\mathrm{V}_{\mathrm{N}}=\mathrm{V}_{\text {IHB }}$ or VILA |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 H | Input HIGH Current | $\mathrm{V}_{\mathbb{N}}=\mathrm{V}_{\text {IHA }}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL. | Input LOW Current | V IN $=\mathrm{V}_{\text {ILB }}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -240 | -180 | - | mA |

NOTE:

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 |
| -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |  |
| PT | Power Dissipation | 2.0 | W |
| IOUT | DC Output Current <br> (Output High) | -50 | mA |

## NOTE:

2778 tb 09

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-101K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condition |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | - 880 | mV |
| VOL | Output LOW Voltage | V In $=$ Vina or Vilib |  | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}_{1} \mathrm{HA}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 IL | Input LOW Current | V IN $=\mathrm{V}_{\text {ILB }}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -260 | -200 | - | mA |

## NOTE:

1. Typical parameters are specified at $\mathrm{V}_{\mathrm{EE}}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION



## AC TEST INPUT PULSE


$\mathrm{tR}=\mathrm{tF}=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

2779 drw 07

## RISE/FALL TIME

| SYMBOL | PARAMETER | TEST CONDITION | MIN. | TYP. | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| th | Output Rise Time | - | - | 2 | - | ns |
| 4 | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10498, IDT100498, and IDT101498 BiCMOS ECL static RAMs (SRAM) with CONDITIONAL WRITE provide high speed with low power dissipation typical of BiCMOS ECL. On-chip logic additionally helps improve system performance, yet the device is pinout-compatible with asynchronous equivalents (i.e...IDT10494, IDT100494, andIDT101494 respectively). The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility ( -5.2 V ).

As can be seen in the Functional Block Diagram on the title
page, this device contains clocked input registers to sample and hold addresses and input data, during a write cycle only. Inputs are sampled on the rising edge of the Write Enable ( $\overline{\mathrm{WE}}$ ). The write cycle is pipelined: the memory cell is written during the $\overline{W E}$-low time in the next cycle. Additionally, the address and data paths to the input register are gated by the Conditional Write Multiplexor, which allows termination of a Write cycle late in the cycle.

Read cycles are not pipelined and operate identically to an asynchronous device, except that an output latch is provided to capture and hold Read data.

FUNCTIONAL DESCRIPTION TIMING EXAMPLE


## READ TIMING

The read timing on the device is asynchronous. DataOut is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}}$ ). Then Address (ADDR) settles and data appears on the output after time tAA, as at 11 below.

Dataout is held for a short time ( tOH ) after the address begins to change for the next access, as can be seen at 7 allowing addresses to begin to change early for the next cycle - then ambiguous data is on the bus until a new time tAA.

To avoid this noise on the bus and provide for longer output hold time, this device includes an output Read data latch which allows Read data to flow out while Output Latch Enable ( $\overline{O L E}$ ) is low, and then hold when OLE is high. Thus in the example below Read data at $\mathbf{7}$ is held until Read data at 8 is ready for output.

Note that Dataoutis disabled (held low) by $\overline{\mathrm{CS}}$ high or $\overline{\mathrm{WE}}$ low, regardless of the state of the Output Latch.

## DESELECT TIMING

Deselect timing is identical to a standard asynchronous device. This case occurs at $(2$ below. Outputs attain the disable state (low) tras later Chip Select ( $\overline{\mathrm{CS}}$ ) is taken to a high logic state. Status of other inputs do not effect the disabling of the device when chip select is de-asserted.

## WRITE TIMING

Write cycles pipelined to allow easier design and higher systemperformance. The write pulse created on the WE input is used as a strobe to clock in the Write Address and Data into a register. This address and data are held in the register until the next write cycle, when they are used to write into the memory array through the Input Multiplexor.

Note the very short valid window required for Write Address and Data inputs. This is because these signals are captured by the input register. This means that input data may arrive
late in the cycle, as at $(3$ below, or data and address may arrive late, as at 6 below.

Dataout is disabled during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the Dataout pins will output the written data after "Write Recovery Time" (tWR), as for a standard asynchronous device.

There is a special case when a Read cycle follows directly a Write Cycle to the same address. The memory array has not yet been updated with the Write data - it is still in the input register. This case is handled by including an address comparator and Output Multiplexor on the device: if the address being presented on the input pins is the same as the address stored in the input register, the data presented to the output pins is also from the input register.

## CONDITIONAL WRITE

In certain system architectures, the decision whether to write data within a cycle occurs late in the cycle. An example might be cache hit logic taking time to decide if a cache line needs to be updated. This device allows a write to be initiated, yet terminated very late in the cycle by using Chip Select should a write not be required by the system.

The Conditional Write Multiplexor controlled by Chip Select makes this possible. In a normal Write cycle, $\overline{\mathrm{CS}}$ is low and the Multiplexor delivers the state of the addresses and data on the input pins to the Input Multiplexor and Input Register, respectively. Because $\overline{\mathrm{CS}}$ does not gate the Write Pulse logic, it has a short valid window requirement.

To terminate the Write cycle, as shown at 6 below, all that is required is to bring $\overline{\mathrm{CS}}$ to a high logic state. This switches the Conditional Write Multiplexor to circulate the previously written address and data (held in the Input Register) around to be clocked again into the Input Register. No Write cycle is apparent to the system.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{array}{r} 10498 \mathrm{~S} 12 \\ 100498 \mathrm{~S} 12 \\ 101498 \mathrm{~S} 12 \end{array}$ |  | $\begin{gathered} \text { 10498S15 } \\ \text { 100498S15 } \\ \text { 101498S15 } \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |
| $\mathrm{taA}^{(2)}$ | Address Access Time | - | - | \% 12 | - | \%. $\times 15$ | ns |
| tacs | Chip Select Access Time | - | - | 5 | - | $\stackrel{\square}{*}$ | ns |
| trcs | Chip Select Recovery Time | - | - | $\stackrel{\square}{*}$ | - | 5 | ns |
| tor | Data Hold from Address Change | - |  | - | $3 \quad$ | * - | ns |
| tolel | Latch Enable Low Pulse Width | - | 5 令 | - | 5 \% | - | ns |
| тано | Address Valid to OLE High | - | 14 \% | - | 17 \% | - | ns |
| tD ${ }^{\text {chen }}$ | Data Hold from Clock Low | - | 0 \% | - | 0 \% \% | - | ns |
| tor | Data Ready from Clock Low | - | 0 | 4 | 0 | 4 | ns |

1. Input and Output reference level is $50 \%$ point of waveform.
2. Read Data is valid at tAA or taho - tolel + tDR, whichever is larger; that is, Read Data is valid at the access time unless Output Latch Enable is high, and then access is tDR after OLE goes low.

## READ CYCLE GATED BY CHIP SELECT



## READ CYCLE GATED BY ADDRESS



AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10498 \mathrm{~S} 12 \\ 100498 \mathrm{~S} 12 \\ 101498 \mathrm{~S} 12 \end{gathered}$ |  | 10498515 100498S15 101498515 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |
| tw | Write Pulse Width | - | 10 | - | 12 | - | ns |
| twscs | Setup Time for Chip Select | - | 1 | - | 1 | - | ns |
| twTcs | $\overline{\text { CS Set-Up, Terminated Write }}$ | - | 2 | \% - | 2 | $\%$ | ns |
| tWSA | Setup Time for Address | - | 1 | - | 1 | - | ns |
| tWSD | Setup Time for Data In | - | 1 | * - | 1 | * | ns |
| tWHCS | Hold Time for Chip Select | - | 2 | - | 2 | - | ns |
| tWHA | Hold Time for Address | - | 2 | - |  | - | ns |
| tWHD | Hold Time for Data In | - |  | - |  | - | ns |
| tws | Write Disable Time | - | - | 5 | - | 5 | ns |
| twr | Write Recovery Time | - | - | 5 | - | 5 | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.

## WRITE CYCLE TIMING DIAGRAM



## ORDERING INFORMATION



## IDT10504

IDT100504

## FEATURES:

- 65,536-words x 4-bit organization
- Address access time: 8/10/12/15
- Low power dissipation: 800 mW (typ.)
- Guaranteed Output Hold time
- Fully compatible with ECL logic levels
- Separate data input and output
- JEDEC standard through-hole and surface mount packages


## DESCRIPTION:

The IDT10504, IDT100504 and IDT101504 are 262,144bit high-speed BiCEMOS ${ }^{\text {mM }}$ ECL static random access mernories organized as $64 \mathrm{~K} \times 4$, with separate data inputs and outputs. All I/Os are fully compatible with ECL levels.

These devices are part of a family of asynchronous four-bit-wide ECL SRAMs. The devices have been configured to follow the standard ECL SRAM family pinout. Because they are manufactured in BiCEMOS ${ }^{\text {TM }}$ technology, however, power dissipation is greatly reduced over equivalent bipolar devices.

The asynchronous SRAMs are the most straightforward to use because no additional clocks or controls are required: DataOUT is available an access time after the last change of address. To write data into the device requires the creation of a Write Pulse, and the write cycle disables the output pins in conventional fashion.

The fast access time and guaranteed Output Hold time allow greater margin for systemtiming variation. Dataln setup time specified with respect to the trailing edge of Write Pulse eases write timing allowing balanced Read and Write cycle times.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION



PIN DESCRIPTION

| Symbol | Pin Name |
| :--- | :--- |
| Ao through A15 | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{\text { CS }}$ | Chip Select Input (Internal pull <br> down) |
| VEE | More Negative Supply Voltage |
| Vcc | Less Negative Supply Voltage |
| NC | No Connect (Not Internally <br> Connected |

## AC OPERATING RANGES ${ }^{(1)}$

| IO | VEE | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |

NOTE:

1. Referenced to Vcc


| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unit |  |
| CIN | Input <br> Capacitance | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

1. Referenced to Vcc

2780 rbl 03


400-MII-WIde
CERAMIC PACKAGE C32


300-Mil-Wlde
PLASTIC SOJ PACKAGE Y32

LOGIC SYMBOL


TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | DATAOuT | Function |
| :---: | :---: | :---: | :--- |
| H | X | L | Deselected |
| L | H | RAM Data | Read |
| L | L | L | Write |

NOTE:
2780 bㅓ 04

1. $\mathrm{H}=\mathrm{High}, \mathrm{L}=$ Low, $\mathrm{X}=$ Don't Care

ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Unit <br> Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| PT | Power Dissipation |  | 1.5 |
| IOUT | DC Output Current <br> (Output High) | -50 | WA |

NOTE:
2782 tol 05

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-10K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unlt | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ Viha or V ilib |  | $\begin{aligned} & -1000 \\ & -960 \\ & -900 \end{aligned}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & .720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VoL | Output LOW Voltage | V IN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{aligned} & 0^{\circ} \mathrm{C} \\ & 25^{\circ} \mathrm{C} \\ & 75^{\circ} \mathrm{C} \end{aligned}$ |
| VOHC | Output Threshold HIGH Voltage | V : $=$ VIHB or V ILA |  | $\begin{aligned} & -1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{array}{r} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{array}$ |
| VOLC | Output Threshold LOW Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{aligned} & 0^{\circ} \mathrm{C} \\ & 25^{\circ} \mathrm{C} \\ & 75^{\circ} \mathrm{C} \end{aligned}$ |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I IL | Input LOW Current | V IN $=$ VILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| lee | Supply Current | All Inputs and Outputs Open |  | -220 | -150 | - | mA | - |

NOTE:

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.5 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V $\mathrm{IHA}^{\text {d }}$ | VILB | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ V IHA | VILB | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | VIN $=$ VihB | VILA | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed High for All | out Voltage uts | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed <br> Low for All | out Voltage uts | -1810 | - | -1475 | mV |
| IIH | Input HIGH Current | V IN $=$ V IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and | Outputs Open | -200 | -130 | - | mA |

NOTES:
2780 tbl 08

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | Ceramic Plastic | $\begin{array}{r} -65 \text { to }+150 \\ -55 \text { to }+125 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.5 | W |
| Iout | DC Out mput Current (Output High) |  | -50 | mA |

## NOTE:

1. Stresses greater than those listedunder ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-101K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condition |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHA }}$ or $\mathrm{V}_{\text {ILB }}$ |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ila }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}_{\text {I }} \mathrm{HA}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 IL | Input LOW Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {ILB }}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open |  | -220 | -150 | - | mA |

NOTES:
2781 tol 10

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION



2780 drw 06

## AC TEST INPUT PULSE


$\mathrm{tR}=\mathrm{tF}=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

2780 drw 07

RISE/FALL TIME

| Symbol | Parameter | Test Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| IR | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10504, IDT100504 and IDT101504 BiCMOS ECL static RAMs (SRAM) provide high speed with low power dissipation typical of BiCMOS ECL. These devices follow the conventional pinout and provide an upgrade path from 16Kx4 SRAMs.The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility $(-5: 2 \mathrm{~V})$.

## READ TIMING

The read timing on these asynchronous devices is straightforward. DataOUT is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}}$ ). Then Address (ADDR) settles and data appears on the output after time tAA. Note that DataOUT is held for a short time ( tOH ) after the address begins to change for the next access, then ambiguous data is on the bus until a new time tAA.

## WRITE TIMING

To write data to the device, a Write Pulse need be formed on the Write Enable input ( $\overline{W E}$ ) to control the write to the SRAM array. While $\overline{C S}$ and ADDR must be set-up when $\overline{W E}$ goes low, DataIN can settie after the falling edge of $\bar{W} E$, giving the data path extra margin. Data is written to the memory cell at the end of the Write Pulse, and addresses and Chip Select must be held after the rising edge of the Write Pulse to ensure satisfactory completion of the cycle.

DataOUT is disabled (held low) during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the DataOUT pins will output the written data after "Write Recovery Time" (tWR).

Because of the very short Write Pulse requirement, these devices can be cycled as quickly for Writes as for Reads. Balanced cycles mean simpler timing in cache applications.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{aligned} & \text { 10504S8 } \\ & \text { 100504S8 } \\ & 101504 S 8 \end{aligned}$ |  | $\begin{gathered} 10504 \mathrm{~S} 10 \\ 100504 \mathrm{~S} 10 \\ 101504 \mathrm{~S} 10 \end{gathered}$ |  | $\begin{gathered} 10504 \mathrm{~S} 12 \\ 100504 \mathrm{~S} 12 \\ 101504 \mathrm{~S} 12 \end{gathered}$ |  | $\begin{array}{r} 10504 \mathrm{~S} 15 \\ 100504 \mathrm{~S} 15 \\ 101504 \mathrm{~S} 15 \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tacs | Chip Select Access Time | - | - | \% ${ }^{\text {c }}$ | - | 5 | - | 5 | - | 5 | ns |
| tres | Chip Select Recovery Time | - | - | 8 | - | 5 | - | 5 | - | 5 | ns |
| taA | Address Access Time | - | - | $\times 8$ | - | 10 | - | 12 | - | 15 | ns |
| tor | Data Hold from Address Change | - | 3\% | - | 3 | - | 3 | - | 3 | - | ns |

NOTE:
2780 tol 12

1. Input and Output reference level is $50 \%$ point of waveform.

## READ CYCLE GATED BY CHIP SELECT



## READ CYCLE GATED BY ADDRESS



AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} \text { 10504S8 } \\ \text { 100504S8 } \\ \text { 101504S8 } \end{gathered}$ |  | $\begin{gathered} 10504 \text { S10 } \\ 100504 \text { S10 } \\ 101504 \text { S10 } \end{gathered}$ |  | $\begin{gathered} 10504 \mathrm{~S} 12 \\ 100504 \mathrm{~S} 12 \\ 101504 \mathrm{~S} 12 \end{gathered}$ |  | $\begin{array}{r} 10504 \text { S15 } \\ 100504 \text { S15 } \\ 101504 \text { S15 } \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tw | Write Pulse Width | tWSA $=$ minimum | 6 | - | 8 | - | 10 | - | 10 | - | ns |
| tWSD | Data Set-up Time | - | 0 | \% | 0 | - | 0 | - | 2 | - | ns |
| tWSD2 ${ }^{(2)}$ | Data Set-up Time to WE High | - | 5 | *- | 5 | - | 5 | - | 5 | - | ns |
| tWSA | Address Set-up Time | tWSA $=$ minimum | 0 | \% - | 0 | - | 0 | - | 2 | - | ns |
| twscs | Chip Select Set-up Time | - | 0 \% | \% - | 0 | - | 0 | - | 2 | - | ns |
| tWHD | Data Hold Time | - | 2, \% | - | 2 | - | 2 | - | 3 | - | ns |
| tWHA | Address Hold Time | - | 2** | - | 2 | - | 2 | - | 3 | - | ns |
| tWHCS | Chip Select Hold Time | - | 2. | - | 2 | - | 2 | - | 3 | - | ns |
| tws | Write Disable Time | - | - | 5 | - | 5 | - | 5 | - | 5 | ns |
| twR(3) | Write Recovery Time | - | - | 5 | - | 5 | - | 5 | - | 5 | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. twSD is specified with respect to the falling edge of WE for compatibility with bipolar part specifications, but this device actually only requires twsD2 with respect to rising edge of WE.
3. twR is defined as the time to reflect the newly written data on the Data Outputs ( $Q_{0}$ to $Q_{3}$ ) when no new Address Transition occurs.

## WRITE CYCLE TIMING DIAGRAM



## ORDERING INFORMATION

IDT



## SELF-TIMED BiCMOS ECL STATIC RAM 256K (64K x 4-BIT) STRAM

## PRELIMINARY <br> IDT10506LL IDT100506LL IDT101506LL

## FEATURES:

- 65,536-words x 4-bit organization
- Self-Timed Write, with latches on inputs and latches on outputs
- Balanced Read/Write cycle time: 15/18ns
- Access time: $12 / 15$ ns (max.)
- Fully compatible with ECL logic levels
- Through-hole DIP and surface-mount packages


## DESCRIPTION:

The IDT10506LL, IDT100506LL and IDT101506LL are 65,536 -bit high-speed BiCEMOS ${ }^{\text {TM }}$ ECL static random access memories organized as $64 \mathrm{~K} \times 4$, with inputs and outputs fully compatible with ECL levels. Clocked level-sensitive
latches on inputs and outputs, and the self-timed write operation, provide enhanced system performance over conventional RAMs, providing easier design and improved system level cycle times.

Inputs can flow into the device and then are latched by the leading edge of an externally supplied differential clock. The small input valid window required means more margin for system skews. Logic-to-memory propagation delay is included in device cycle time calculation, allowing this device to deliverbetter systemperformance than asynchronousSRAMs and glue logic.

Write timing is controlled internally based on the clock. Write Enable has no special requirements. The device allows balanced read and write cycle times, and reads and writes can be inserted in any order.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION




300-MII-Wlde
PLASTIC SOJ PACKAGE Y32

## PIN DESCRIPTIONS

| Symbol | Pin Name |
| :--- | :--- |
| Ao through A15 | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through $\mathrm{Q}_{3}$ | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{\text { CS }}$ | Chip Select Input (Internal pull down) |
| CLK, $\overline{\text { CLK }}$ | Differential Clock Inputs |
| VBB | Reference Voltage Output ( $\approx 1.32 \mathrm{~V}$ ) |
| VEE | More Negative Supply Voltage |
| VCC | Less Negative Supply Voltage |

AC OPERATING RANGES ${ }^{(1)}$

| VO | VEE | Temperature |
| :---: | :--- | :--- |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |

NOTE:

1. Referenced to Vcc

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | UnIt |  |
| CINCLK | Input <br> Capacitance <br> CLK/CLK | 6 | - | 3 | - | pF |
| CIN | Input <br> Capacitance <br> except CLK/CLK | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

LOGIC SYMBOL

$64 K \times 4$ STRAM

TRUTH TABLE ${ }^{(1)}$

| $\overline{\text { CS }}$ | $\overline{\text { WE }}$ | CLK | Dataour $^{(2)}$ | Function |
| :---: | :---: | :---: | :---: | :--- |
| H | X | $\mathbf{I}$ | L | Deselected |
| L | H | 1 | RAM Data | Read |
| L | L | 1 | WRITE Data | Write |

NOTES:

1. $\mathrm{H}=$ High, L=Low, $\mathrm{X}=$ Don't Care
2. DATAOUT changes when CLK retums high.

## ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to + 75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.0 | W |
| IOUT | DC Output Current (Output High) |  | -50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-10K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$ for DIP, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Voh | Output HIGH Voltage | $\mathrm{VIN}=$ Viha or VilB |  | $\begin{gathered} \hline-1000 \\ -960 \\ -900 \end{gathered}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VoL | Output LOW Voltage | V IN $=$ V IHA or V ILB |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{aligned} & 0^{\circ} \mathrm{C} \\ & 25^{\circ} \mathrm{C} \\ & 75^{\circ} \mathrm{C} \end{aligned}$ |
| VOHC | Output Threshold HIGH Voltage | V IN $=$ ViHB or $\mathrm{V}^{\text {ILA }}$ |  | $\begin{aligned} & \hline-1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All inputs ${ }^{(2)}$ |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | $\begin{array}{r} -1870 \\ -1850 \\ -1830 \\ \hline \end{array}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| 1 H | Input HIGH Current | V IN $=\mathrm{V}$ iHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| 1 L | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IeE | Supply Current | All Inputs and Outputs Open ${ }^{(2)}$ |  | -280 | -220 | - | mA | - |

## NOTES:

2783 bl 06

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK , one of which is tied low and one is tied high.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.0 | W |
| IOUT | DC Output Current (Output High) |  | -50 | mA |

NOTE:

1. Stresses greater than those listedunder ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ VIHA | VILB | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ VIHA Or | Vilb | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | V IN $=\mathrm{V}_{1} \mathrm{HB}$ | V12 | -1035 | - | - | mV |
| VoLC | Output Threshold LOW Voltage | V IN $=$ VIHB or | VILA | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed High for All In | put Voltage uts ${ }^{(2)}$ | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Low for All Inp | out Voltage $\text { uts }{ }^{(2)}$ | -1810 | - | -1475 | mV |
| IIH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 ll | Input LOW Current | V IN $=$ VILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Open ${ }^{(2)}$ | Outputs | -260 | -200 | - | mA |

## NOTES:

2783 w108

1. Typical parameters are specified at $\mathrm{V}_{\mathrm{EE}}=-4.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| VTERM | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 1.0 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

## NOTE:

2783 ы 09

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-101K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$ for DIP, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unlt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| VoL | Output LOW Voltage | V IN $=$ V IHA or V Lib |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V IN $=$ V IHB or V ILA |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or V IIA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs ${ }^{(2)}$ |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}_{1} \mathrm{HA}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 IL | Input LOW Current | V IN $=\mathrm{V}_{\text {LL }} \mathrm{B}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open ${ }^{(2)}$ |  | -280 | -220 | - | mA |

NOTES:

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

## AC TEST LOAD CONDITION



## AC TEST INPUT PULSE



Note: All timing measurements are referenced to $50 \%$ input levels.

2783 dw 07

## RISE/FALL TIME

| Symbol | Parameter | Test Condition | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tR | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10506LL, IDT100506LL, and IDT101506LL SelfTimed BiCMOS ECL static RAMs (STRAM) provide high speed with low power dissipation typical of BiCMOS ECL. On-chip logic additionally helps improve systemperformance. The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility (-5.2V).

As can be seen in the Functional Block Diagram on the title page, this device contains level-sensitive latches to sample and hold addresses, input data, and control status, and hold output data. Inputs are transparent while the clock (CLK) input is low (and CLK is high), and then hold their contents
when the clock returns high. In the case of a write cycle, the memory cell is written during the clock-high time, and write data conducted to the outputs. Because the output latches are controlled by an inversion of the clock, output data flows out the output latch while clock is high and then is held into the next cycle during clock low.

The Latch-Latch architecture is most useful when read access data is needed within the same cycle that addresses settle. The input latch, when transparent, allows the access to begin as soon as addresses settle, allowing data to be ready somewhat sooner in the cycle than would be possible with a clocked-register implementation.

FUNCTIONAL DESCRIPTION TIMING EXAMPLE


## READ TIMING

In a typical read cycle, the read address flows into the device while clock is low, as at $\mathbf{O}$ below. Read access begins when the last address has settled. When clock returns high, the inputs are held so that addresses can begin to change for the next cycle.

Clock high also opens the output latches, so the read data for the read address clocked in at $\mathbf{0}$ is gated through the output latch to the output pins. There is a short delay from rising clock to output ready, called tDR (see Read Cycle Timing). If the clock-low time (twL) is shorter than the inherent access-time of the cell, output is guaranteed valid after the specified tAA. But if twL is longer than the cell access-time, output data will be valid tDR after clock goes high. Thus, the time it takes from address valid to data ready for any given address is

$$
t A A=t A A \text { or }(t S A+t D R)
$$

whichever is larger. A permutation of this equation holds for each read and write access modes.

Because addresses and control lines (Write Enable and Chip Select) all must be stable for access to commence, there are two other read access modes, described as follows.

If addresses and controls are all stable before input latches are opened by clock going low, as at $\Theta$ below, access begins on the low-going edge of clock. Data is available tACLK later, provided the output latch is opened by clock returning high.

If address and Write Enable are valid after clock-low, but Chip Select is last to go low, as at $\boldsymbol{0}$ below, data is available tacs after the low-going edge of Chip Select.

The output latch takes some time to change state for the next cycle, but this time is very short. Therefore, data holdtime from clock high (tDH) is specified as zero minimum hold time.

## DESELECT TIMING

Because the outputs are latched, they will continue to drive the output pins until a disable state is clocked through the device. The deselected state is achieved by de-asserting chip select ( $\overline{\mathrm{CS}}$ high) before clock returns high. This case occurs at $(2$ below. Outputs then attain the disable state (low) tDR later. Status of other inputs do not effect the disabling of the device when chip select is de-asserted with the proper relation to clock.

## WRITE TIMING

Write cycles are identical to read cycles, except that write enable and write data need also be supplied, with the appropriate setup and hold timing. The device has on-chip timing that handles all aspects of writing data into the addressed RAM cell without the need for external write-pulse generation. The timing logic uses the clock-high time as the write pulse, and thus determines the minimum clock-high time, twh.

In addition to writing to the RAM cell, the write data is fed to the output register by a multiplexer, so that write data is available on the output pins after an access time. Thus the input data supplied at 3 is available on the outputtaDI after the input data has settled, while the input data supplied at 6 is available tAW after Write Enable is asserted low.This function is sometimes called "Transparent Write," and is useful for write-through cache applications.

There are no restrictions on the order of read cycles and write cycles.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} \text { 10506LL15 } \\ \text { 100506LL15 } \\ \text { 101506LL15 } \end{gathered}$ |  | $\begin{gathered} 10506 L L 18 \\ \text { 100506LL18 } \\ \text { 101506LL18 } \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |
| tcyc | Cycle Time | - | 15 | - | 18 | - | ns |
| tAA ${ }^{(2)}$ | Address Accass Time | - | - | 12 | - | 15 | ns |
| tacs ${ }^{(3)}$ | Chip Select Access Time | - | - | \% 5 | - | \% 5 | ns |
| tACLK ${ }^{(4)}$ | Access Time from Clock Low | - | - | \% $\% 12$ | - | \%* 15 | ns |
| twL | Clock Low Pulse Width | - | 3 | - | 3 | - - | ns |
| twh | Clock High Pulse Width | - | 12 | * | 15 | * | ns |
| tscs | Setup Time for Chip Select | - | 1 | - | 1 | - | ns |
| tSA | Setup Time for Address | - | 1 | - | 1 | - | ns |
| thes | Hold Time for Chip Select | - |  | - | 2 | - | ns |
| tha | Hold Time for Address | - | 2 | - | 2 | - | ns |
| tD | Data Hold from Clock Low | - | 0 | - | 0 | - | ns |
| tDR ${ }^{(5)}$ | Data Ready from Clock Low | - | 0 | 4 | 0 | 4 | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. Read Cyde is gated by Address when tSA < TWL so that the access begins at the setting of Address. Access time is the larger of tan or tsA + tor.
3. Read Cycle is gated by Chip Select when tscs < twL so that access begins at the falling edge of Chip Select. Access time is the larger of tacs or tscs + tDR.
4. Read Cycle is gated by Clock when tSA > twL so that access begins at the falling edge of Clock. Access time is the larger of taclk or twl + tDR.
5. tor(max) is specified when all other gating conditions have been satisfied, specifically, for READ cycle: when tsA >tAA(max)-tDR(max) and tscs >tacs(max) - tDR(max) and twL > tACLK(max) - tor(max); for WRITE cycle: when tSD > tADI (max) - tDR(max) and tsWE > taw(max) - tor(max).


READ CYCLE GATED BY CHIP SELECT (Assumes Address and Clock stable before Chip Select)


READ CYCLE GATED BY CLOCK (Assumes Address and Chip Select stable before Clock Low)
DATAOUT


AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)


NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. All Setup, Hold, and Access timing are the same as the Read Cycle with the addition of above requirements. Write Data appears on output pins after rising edge of clock.
3. Access time is the larger of tAW or tswe + tDR.
4. Access time is the larger of tADI or tSD + tDR.

## WRITE CYCLE



## CLOCK INPUT

The clock input clrcult has boen designed to accomodate both single-ended and differentlal mode operation. Differential mode exhibits better common-mode nolse rejection and is obtalned by driving both true and complement clock lines with a differentlal driver, as shown in Figure (a). Single-ended operation Is achleved as either falling-edge-active or rising-edge-active, as shown in Figures (b) and (c), respectlvely. VBB is designed to drive clock Input only and is not intended to be used for any other purpose.

(a) Differentlal Mode

(b) Falling-Edge-Actlve Single-Ended Mode

(c) Rising-Edge-Actlve Single-Ended Mode

## ORDERING INFORMATION



SELF-TIMED BiCMOS ECL STATIC RAM 256K (64K x 4-BIT) STRAM

## IDT10506RL IDT100506RL IDT101506RL

## FEATURES:

- 65,536-words x 4-bit organization
- Self-Timed Write, with registers on inputs and latches on outputs
- Balanced Read/Write cycle time: 12/15ns
- Access time: 12/15 ns (max.)
- Low power dissipation: 800 mW (typ.)
- Fully compatible with ECL logic levels
- Through-hole DIP and surface-mount packages


## DESCRIPTION:

The IDT10506RL, IDT100506RL and IDT101506RL are 262,144-bit high-speed BiCEMOSTM ECL static random ac-
cess memories organized as $16 \mathrm{~K} \times 4$, with inputs and outputs fully compatible with ECL levels. Clocked registers on inputs and latches on outputs, and the self-timed write operation, provide enhanced system performance over conventional RAMs, providing easier design and improved system level cycle times.

Inputs are captured by the leading edge of an extemaliy supplied differential clock. The small input valid window required means more marginfor systemskews. Logic-to-memory propagation delay is included in device cycle time calculation, allowing this device to deliver better system performance than asynchronous SRAMs and glue logic.

Write timing is controlled internally based on the clock. Write Enable has no special requirements. The device allows balanced read and write cycle times, and reads and writes can be inserted in any order.

## FUNCTIONAL BLOCK DIAGRAM



[^1]
## PIN CONFIGURATION




300-Mil-Wlde PLASTIC SOJ PACKAGE Y32

## PIN DESCRIPTION

| Symbol | Pin Name |
| :--- | :--- |
| Ao through A15 | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{\text { CS }}$ | Chip Select Input (Internal pull down) |
| CLK, $\overline{\text { CLK }}$ | Differential Clock Inputs |
| VBB | Reference Voltage Output ( $\approx 1.32 \mathrm{~V}$ ) |
| VEE | More Negative Supply Voltage |
| VCC | Less Negative Supply Voltage |
| NC | No Connect - not internally connected |

## AC OPERATING RANGES ${ }^{(1)}$

| VO | Vee | Temperature |
| :---: | :---: | :---: |
| 10K | $-5.2 \mathrm{~V} \pm 5 \%$ | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100K | -4.5V $\pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101K | -4.75 V to -5.46 V | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |

1. Referenced to Vcc

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unit |  |
| CINCLK | Input <br> Capacitance <br> CLK/CLK | 6 | - | 3 | - | pF |
| CIN | Input <br> Capacitance <br> except CLK/CLK | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

LOGIC SYMBOL


TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | CLK | Dataour $^{(2)}$ | Function |
| :---: | :---: | :---: | :---: | :--- |
| $H$ | X | $\uparrow$ | L | Deselected |
| L | H | $\ddagger$ | RAM Data | Read |
| L | L | $\ddagger$ | WRITE Data | Write |

NOTES:

1. $\mathrm{H}=\mathrm{High}, \mathrm{L}=$ Low, $\mathrm{X}=$ Don't Care
2. DATAOUT initiated by an internal timer and gated by falling edge of CLK.

## ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| Iout | DC Output Current (Output High) |  | -50 | mA |

## NOTE:

2788 tos

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-10K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unlt | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V $\mathrm{IHA}^{\text {ar }}$ | VILB | $\begin{aligned} & -1000 \\ & -960 \\ & -900 \\ & \hline \end{aligned}$ | -885 | $\begin{array}{r} -840 \\ -810 \\ -720 \\ \hline \end{array}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vol. | Output LOW Voltage | $\mathrm{V} \mathbb{N}^{\mathrm{N}}=\mathrm{V}$ IHA |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vohc | Output Threshold HIGH Voltage | V IN $=$ V IHB | VILA | $\begin{aligned} & \hline-1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Volc | Output Threshold LOW Voltage | V IN $=$ V $\mathrm{VIHB}^{\text {c }}$ | VILA | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed High for All | put Voltage uts ${ }^{(2)}$ | $\begin{array}{r} -1145 \\ -1105 \\ -1045 \\ \hline \end{array}$ | - | $\begin{array}{r} -840 \\ -810 \\ -720 \\ \hline \end{array}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \\ \hline \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Low for All | put Voltage uts ${ }^{(2)}$ | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{aligned} & 0^{\circ} \mathrm{C} \\ & 25^{\circ} \mathrm{C} \\ & 75^{\circ} \mathrm{C} \end{aligned}$ |
| 1 HH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\text { CS }}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Open ${ }^{(2)}$ | Outputs | -280 | -220 | - | mA | - |

## NOTES:

2788 カ 06

1. Typical parameters are specified at $\mathrm{V}_{E E}=-5.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Tbias | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| Iout | DC Output Current (Output High) |  | -50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, R \mathrm{~L}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | VIN $=$ VIHA or $\mathrm{V}_{\text {ILB }}$ |  | -1025 | -955 | -880 | mV |
| VoL | Output LOW Voltage | V IN $=$ ViHA or V ILB |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or V VILA |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | VIN $=$ VifB or VILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs ${ }^{(2)}$ |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | -1810 | - | -1475 | mV |
| I IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {ILB }}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open ${ }^{(2)}$ |  | -260 | -200 | - | mA |

## NOTES:

2788 d108

1. Typical parameters are specified at $V_{E E}=-4.5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| Iout | DC Output Current (Output High) |  | -50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-101K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=\mathrm{V}_{\text {IHA }}$ or $\mathrm{V}_{\text {ILIB }}$ |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=\mathrm{V}$ IHA or V ILB |  | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | V IN $=$ V IHB or V ILA |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=$ V IHB or V ILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs ${ }^{(2)}$ |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs ${ }^{(2)}$ |  | . 1810 | - | -1475 | mV |
| 11 H | Input HIGH Current | V IN $=$ V IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open ${ }^{(2)}$ |  | -280 | -220 | - | mA |

NOTES:

1. Typical parameters are specified at $\mathrm{V}_{\mathrm{EE}}=-5.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.
2. Except CLK and CLK, one of which is tied low and one is tied high.

## AC TEST LOAD CONDITION



## AC TEST INPUT PULSE


$t R=t F=2.0 n s$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

2788 dw 07

RISE/FALL TIME

| Symbol | Parameter | Test Condition | Min. | Typ. | Max. | Unlt |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $t \mathrm{R}$ | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10496RL, IDT100496RL and IDT101496RL SelfTimed BiCMOS ECL static RAMs (STRAM) provide high speed with low power dissipation typical of BiCMOS ECL. On-chip logic additionally helps improve system performance. The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility (-5.2V).

As can be seen in the Functional Block Diagram on the title page, this device contains clocked input registers to sample and hold addresses, input data, and control status. Inputs are sampled on the rising edge of the clock (CLK) input (falling edge of $\overline{C L K}$ ). In the case of a write cycle, the memory cell is written during the clock-high time, and write data conducted to
the outputs. Output data flows out the output latch and is held into the next cycle.

## READ TIMING

In a typical read cycle, the read address is captured by the rising edge of clock, as at 1 below. Then, when clock goes low, the read data for the read address clocked in at 1 is gated through the ouptut latch to the output pins. There is a delay from falling clock to output ready, called tDR (see Read Cycle Timing). If the clock-high time (tWH) is shorter than the inherent access-time of the cell, output is guaranteed valid after the specified tacc. But if twH is longer than the cell access-time, output data will be valid tDR after clock goes low. Thus, the time it takes from clock-to-output for any given address (the

## FUNCTIONAL DESCRIPTION TIMING EXAMPLE

CS
latency, or tacc) is
tACC = tACC or (twH + tDR), whichever is larger.
The output latch takes some time to change state for the next cycle, and this time is controlled by an internal timer. Therefore, data hold time from clock high at the beginning of the cycle (tDH) is specified. If the clock-high time (tWH) is longer than the IDH , then data will begin to switch immediately upon the clock-low transition and be steady at tacc.

## DESELECT TIMING

Because the outputs are latched, they will continue to drive the output pins until a disable state is clocked through the device. The deselected state is achieved by de-asserting chip select ( $\overline{\mathrm{CS}}$ high) at rising edge of clock. This case occurs at (2) below. Outputs then attain the disable state (low) tacc later. Status of other inputs do not effect the disabling of the device when chip select is de-asserted with the proper relation to clock.

## WRITE TIMING

Write cycles are identical to read cycles, except that write enable and write data need also be supplied, with the appropriate setup and hold timing. The device has on-chip timing that handles all aspects of writing data into the addressed RAM cell without the need for external write-pulse generation. The timing logic uses an internal timer to generate the write pulse, so the falling edge of clock is not critical.

In addition to writing to the RAM cell, the write data is fed to the output register by a multiplexer, so that write data is available on the output pins in the appropriate time slot (i.e. after tACC or tWH + tDR). This function is sometimes called "Transparent Write," and is useful for write-through cache applications. Thus the input data sampled at (3) is available on the output at the end of the cycle.

There are no restrictions on the order of read cycles and write cycles.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Ranges)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} \text { 10506RL12 } \\ \text { 100506RL12 } \\ \text { 101506RL12 } \end{gathered}$ |  | $\begin{gathered} \text { 10506RL15 } \\ \text { 100506RL15 } \\ \text { 101506RL15 } \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |
| tcyc | Cycle Time | - | 12 | - | 15 | - | ns |
| tacd ${ }^{(2)}$ | Access Time from Clock High | - | - | 12 | - | 15 | ns |
| twL | Clock Low Pulse Width | - | 5 | - | 6 | - | ns |
| twh | Clock High Pulse Width | - | 5 | - | 6 | - | ns |
| tscs | Setup Time for Chip Select | - | 1 | - | 1 | - | ns |
| tsa | Setup Time for Address | - | 1 | - | 1 | - | ns |
| thcs | Hold Time for Chip Select | - | 2.5 | - | 2.5 | - | ns |
| tha | Hold Time for Address | - | 2.5 | - | 2.5 | - | ns |
| tDH | Data Hold from Clock Low | - | 2 | - | 2 | - | ns |
| tDR | Data Ready from Clock Low | - | 0 | 5 | 0 | 5 | ns |

1. Input and Output reference level is $50 \%$ point of waveform.
2. Access time is the larger of tacc or twh + tDR.

READ CYCLE TIMING DIAGRAM


AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} \text { 10506RL12 } \\ \text { 100506RL12 } \\ \text { 101506RL12 } \end{gathered}$ |  | 10506RL15 100506RL15 101506RL15 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Write Cycle ${ }^{(2)}$ |  |  |  |  |  |  |  |
| tSWE | Setup Time for Write Enable | - | 1 | - | 1 | - | ns |
| tSD | Setup Time for Data In | - | 1 | - | 1 | - | ns |
| tHWE | Hold Time for Write Enable | - | 2.5 | - | 2.5 | - | ns |
| tHD | Hold Time for Data In | - | 2.5 | - | 2.5 | - | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. All Setup, Hold, and Access timing are the same as the Read Cycle with the addition of above requirements.

## WRITE CYCLE TIMING DIAGRAM



## CLOCK INPUT

The clock input clrcult has been designed to accomodate both single-ended and differential mode operation. Differential mode exhibits better common-mode nolse rejection and is obtained by driving both true and complement clock llnes with a differential driver, as shown In Figure (a). Single-ended operation is achieved as olther falling-edge-active or rising-edge-active, as shown In Flgures (b) and (c), respoctlvaly. VBB is designed to drive clock Input only and is not Intended to be used for any other purpose.

(a) Differentlal Mode

(b) Falling-Edge-Actlvo Single-Ended Mode

(c) Rising-Edge-Actlve Single-Ended Mode

## ORDERING INFORMATION



Commercial

Sidebraze DIP
Small-outline J-bend

Speed in Nanoseconds

Registered Inputs, Latched Outputs

256K (64K x 4-bits) BiCMOS ECL-10K Self-Timed Static RAM
256K (64K x 4-bits) BiCMOS ECL-100K Selif-Timed Static RAM
256K ( $64 \mathrm{~K} \times 4$-bits) BiCMOS ECL-101K Self-Timed Static RAM

|  | HIGH-SPEED BiCMOS ECL STATIC RAM 256 K ( $64 \mathrm{~K} \times 4$-BIT) with SYNCHRONOUS WRITE | ADVANCE INFORMATON IDT10507 IDT100507 IDT101507 |
| :---: | :---: | :---: |

## FEATURES:

- 65,535-words x 4-bit organization
- Address access time: $12 / 15$ ns
- Read Data output latch for extended hold time
- Short Write Cycle input data and address valid time
- Pin compatible with standard $64 \mathrm{~K} \times 4$
- Through-hole DIP and surface-mount packages


## DESCRIPTION:

The IDT10507, IDT100507 and IDT101507 are 262,144bit high-speed BiCEMOS ${ }^{\text {тм }}$ ECL static random access memories organized as $64 \mathrm{~K} \times 4$, with inputs and outputs fully compatible with ECL levels. Internal registers on inputs
provide enhanced Write Cycle performance over conventional RAMs, while output read data latch allows longer output data hold time providing easier design and improved system level cycle times.

In the read mode, this device is pinout and timing compatible with the standard asynchronous SRAMs (IDT10504), yet the addition of an output latch with separate enable control allow output data to be captured and held long into the next cycle. This minimizes noise on the data bus and provides better set-up time margin for the next logic stage in pipelined applications.

In the write mode, the device adds an invisible pipeline stage in the write address and data paths, allowing very short set-up and hold times for these inputs and less stringent requirements for the write pulse input.

## FUNCTIONAL BLOCK DIAGRAM



2789 dww 01

BICEMOS is a trademark of Integrated Device Technology, Inc.

## PIN CONFIGURATION



## PIN DESCRIPTIONS

| Symbol | Pin Name |
| :--- | :--- |
| Ao through A15 | Address inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{C S}$ | Chip Select Input (Internal pull down) |
| $\overline{\text { OLE }}$ | Output Latch Enable |
| VEE | More Negative Supply Voltage |
| Vcc | Less Negative Supply Voltage |

## AC OPERATING RANGES ${ }^{(1)}$

| VO | Vee | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |

## NOTE:

2789 tol 02

1. Referenced to Vcc

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unit |  |
|  | Input <br> Capacitance | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

## LOGIC SYMBOL



TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | $\overline{\text { OLE }}$ | Dataout $^{(2)}$ | Function |
| :---: | :---: | :---: | :---: | :--- |
| H | X | X | L | Deselected |
| L | H | L | RAM Data | Read |
| L | H | H | RAM Data | Output Held |
| L | L | X | L | Write |


| NOTES: |
| :--- |
| 1. H High, L=Low, X=Don't Care |
| 2. DATÅOUT initiated by falling edge of OLE. |

ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TStG | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| Iout | DC Output Current (Output High) |  | -50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-10K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V IIB |  | $\begin{gathered} \hline-1000 \\ -960 \\ -900 \end{gathered}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vol | Output LOW Voltage | VIN $=$ VIHA or VIIB |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VOHC | Output Threshold HIGH Voltage | V IN $=$ VIHB or V ILA |  | $\begin{aligned} & -1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}_{\text {I }} \mathrm{HA}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I. IL | Input LOW Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ ILB | $\overline{\text { CS }}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Outputs Open |  | -280 | -220 | - | mA | - |

## NOTE:

2789 tbl 06

1. Typical parameters are specified at $\mathrm{VEE}_{\mathrm{EE}}=-5.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

## ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| IOUT | DC Output Current (Output High) |  | -50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Paramoter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | VIN $=$ V IHA or $V$ ILB |  | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {IIA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V In $=\mathrm{V}_{\text {inb }}$ or Vila |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| I IH | Input HIGH Current | V IN $=\mathrm{V}_{\text {IHA }}$ | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\text { CS }}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -260 | -200 | - | mA |

## NOTE:

1. Typical parameters are specified at $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

## ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| PT | Power Dissipation |  | 2.0 |
| IOUT | DC Output Current <br> (Output High) | -50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions

## ECL-101K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condition |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Voh | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ V IHA or V ILB |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | -1035 | - | - | mV |
| VOLC | Output Threshold LOW Voltage | V IN $=$ V IHB or $\mathrm{V}^{\text {ILA }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL. | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| IIH | Input HIGH Current | V IN $=\mathrm{V}$ iHA | CS | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 LI | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -280 | -220 | - | mA |

NOTE:

1. Typical parameters are specified at $V_{E E}=-5.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION



## AC TEST INPUT PULSE


$\mathrm{tR}=\mathrm{tF}=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

2789 drw 07

RISE/FALL TIME

| Symbol | Parameter | Test Conditlon | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tR | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10507, IDT100507 and IDT101507 BiCMOS ECL static RAMs (SRAM) with SYNCHRONOUS WRITE provide high speed with low power dissipation typical of BiCMOS ECL. On-chip logic additionally helps improve system performance, yet the device is pinout-compatible with asynchronous equivalents (i.e...IDT10504, IDT100504, and IDT101504 respectively). The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility ( -5.2 V ).

As can be seen in the Functional Block Diagram on the title page, this device contains clocked input registers to sample and hold addresses and input data, during a write cycle only.

Inputs are sampled on the rising edge of the Write Enable ( $\overline{W E}$ ). The write cycle is pipelined: the memory cell is written during the $\overline{\mathrm{WE}}$-low time in the next cycle.

Read cycles are not pipelined and operate identically to an asynchronous device, except that an output latch is provided to capture and hold Read data.

## READ TIMING

The read timing on the device is asynchronous. DataOut is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}})$. Then Address (ADDR) settles and data appears on the output after time tAA, as at 10 below.

Dataout is held for a short time (tOH) after the address

FUNCTIONAL DESCRIPTION TIMING EXAMPLE

begins to change for the next access, as can be seen at 7 allowing addresses to begin to change early for the next cycle - then ambiguous data is on the bus until a new time taA.

To avoid this noise on the bus and provide for longer output hold time, this device includes an output Read data latch which allows Read data to flow out while Output Latch Enable ( $\overline{O L E}$ ) is low, and then hold when $\overline{O L E}$ is high. Thus in the example below Read data at $\boldsymbol{7}$ is held until Read data at 8 is ready for output.

Note that Dataour is disabled (held low) by $\overline{\mathrm{CS}}$ high or $\overline{\mathrm{WE}}$ low, regardless of the state of the Output Latch.

## DESELECT TIMING

Deselect timing is identical to a standard asynchronous device. This case occurs at $(9$ below. Outputs attain the disable state (low) tRCs later Chip Select ( $\overline{\mathrm{CS}}$ ) is taken to a high logic state. Status of other inputs do not effect the disabling of the device when chip select is de-asserted.

## WRITE TIMING

Write cycles pipelined to allow easier design and higher systemperformance. The write pulse created on the $\bar{W} E$ input
is used as a strobe to clock in the Write Address and Data into a register. This address and data are held in the register until the next write cycle, when they are used to write into the memory array through the Input Multiplexor.

Note the very short valid window required for Write Address and Data inputs. This is because these signals are captured by the input register. This means that input data may arrive late in the cycle, as at 3 below, or data and address may arrive late, as at 6 below.

Dataout is disabled during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the Dataout pins will output the written data after "Write Recovery Time" (tWR), as for a standard asynchronous device.

There is a special case when a Read cycle follows directly a Write Cycle to the same address. The memory array has not yet been updated with the Write data - it is still in the input register. This case is handled by including an address comparator and Output Multiplexor on the device: if the address being presented on the input pins is the same as the address stored in the input register, the data presented to the output pins is also from the input register.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10507 \mathrm{~S} 12 \\ 100507 \mathrm{~S} 12 \\ 101507 \mathrm{~S} 12 \end{gathered}$ |  | $\begin{gathered} \text { 10507S15 } \\ 100507 \mathrm{~S} 15 \\ 101507 \mathrm{~S} 15 \end{gathered}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. |  | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |
| $\mathrm{taA}^{(2)}$ | Address Access Time | - | - | \%. 12 | - |  | $\stackrel{\text { \% }}{\text { \% }}$, 15 | ns |
| tacs | Chip Select Access Time | - | - | + 5 | - |  | \% ${ }^{1}$ | ns |
| trcs | Chip Select Recovery Time | - | - | $\stackrel{\square}{*} 5$ | - |  | \% 5 | ns |
| tor | Data Hold from Address Change | - | 3 | * - | 3 |  | $\stackrel{\square}{*}$ | ns |
| tolel | Latch Enable Low Pulse Width | - | 5 | - | 5 | \% | - | ns |
| tАНО | Address Valid to OLE High | - | 14 | - | 17 |  | - | ns |
| tDH | Data Hold from Clock Low | - |  | - | 0 | \% | - | ns |
| tDR | Data Ready from Clock Low | - | 0 | 4 | 0 |  | 4 | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. Read Data is valid at tAA or tAHO - tOLEL + tDR, whichever is larger; that is, Read Data is valid at the access time unless Output Latch Enable is high, and then access is tDR after OLE goes low.

## READ CYCLE GATED BY CHIP SELECT



## READ CYCLE GATED BY ADDRESS



OUTPUT LATCH TIMING |


2789 drw 09

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)


NOTE

1. Input and Output reference level is $50 \%$ point of waveform.

## WRITE CYCLE TIMING DIAGRAM



## ORDERING INFORMATION

IDT


Commercial

Sidebraze DIP
Small-outline J-bend

Speed in Nanoseconds

Standard (Write Logic, Read Latch)

10507

100507

101507

# HIGH-SPEED BiCMOS ECL STATIC RAM 256 K ( $64 \mathrm{~K} \times 4$-BIT) with CONDITIONAL WRITE 

## ADVANCE INFORMATION IDT10508 IDT100508 IDT101508

## FEATURES:

- 65,535-words x 4-bit organization
- Address access time: $12 / 15$ ns
- Read Data output latch for extended hold time
- Short Write Cycle input data and address valid time
- Write Cycle may be terminated very late in the cycle
- Pin compatible with standard $64 \mathrm{~K} \times 4$
- Through-hole DIP and surface-mount packages


## DESCRIPTION:

The IDT10508, IDT100508 and IDT101508 are 262,144bit high-speed BiCEMOS ${ }^{\text {TM }}$ ECLstatic random access memories organized as $64 \mathrm{~K} \times 4$, with inputs and outputs fully compatible with ECL levels. Internal registers on inputs provide enhanced Write Cycle performance over conven-
tional RAMs, while output read data latch allows longer output data hold time providing easier design and improved system level cycle times.

In the read mode, this device is pinout and timing compatible with the standard asynchronous SRAMs (IDT10504), yet the addition of an output latch with separate enable control allow output data to be captured and held long into the next cycle. This minimizes noise on the data bus and provides better set-up time margin for the next logic stage in pipelined applications.

In the write mode, the device adds an invisible pipeline stage in the write address and data paths, allowing very short set-up and hold times for these inputs and less stringent requirements for the write pulse input. Additionally, the address and data paths to the input register are gated by the Conditional Write Multiplexor, which allows termination of a Write cycle late in the cycle.

## FUNCTIONAL BLOCK DIAGRAM



PIN CONFIGURATION



300-Mil-Wide
PLASTIC SOJ PACKAGE Y32

PIN DESCRIPTIONS

| Symbol | Pin Name |
| :--- | :--- |
| Ao through A15 | Address Inputs |
| Do through D3 | Data Inputs |
| Qo through Q3 | Data Outputs |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{\text { CS }}$ | Chip Select Input (Internal pull down) |
| $\overline{\text { OLE }}$ | Output Latch Enable |
| VEE | More Negative Supply Voltage |
| Vcc | Less Negative Supply Voltage |

## AC OPERATING RANGES ${ }^{(1)}$

| IO | VEE | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | $0 \mathrm{TO} 85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | $0 \mathrm{TO} 75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| NOTE: | 2782 trl 02 |  |

1. Referenced to Vcc

CAPACITANCE $\left(T A=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | DIP |  | SOJ |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Max. | Typ. | Max. | Unit |  |
| CIN | Input <br> Capacitance | 4 | - | 3 | - | pF |
| COUT | Output <br> Capacitance | 6 | - | 3 | - | pF |

## LOGIC SYMBOL



## TRUTH TABLE ${ }^{(1)}$

| $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | $\overline{\text { OLE }}$ | Data our $^{(2)}$ | Function |
| :---: | :---: | :---: | :---: | :--- |
| H | $\mathbf{X}$ | $\mathbf{X}$ | L | Deselected |
| L | H | L | RAM Data | Read |
| L | H | H | RAM Data | Output Held |
| L | L | X | L | Write |

## NOTES

## ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | RatIng |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| PT | Power Dissipation |  | 2.0 |
| IOUT | DC Output Current <br> (Output High) | -50 | WA |

NOTE:
2792 \$1 05

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationisnotimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-10K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | $\begin{aligned} & -1000 \\ & -960 \\ & -900 \end{aligned}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VoL | Output LOW Voltage | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IHA }}$ or VILB |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vohc | Output Threshold HIGH Voltage | V IN $=$ VIHB or V ILA |  | $\begin{aligned} & -1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Volc | Output Threshold LOW Voltage | V IN $=$ VIHB or V ILA |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{aligned} & 0^{\circ} \mathrm{C} \\ & 25^{\circ} \mathrm{C} \\ & 75^{\circ} \mathrm{C} \end{aligned}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \\ & \hline \end{aligned}$ | mV | $\begin{aligned} & 0^{\circ} \mathrm{C} \\ & 25^{\circ} \mathrm{C} \\ & 75^{\circ} \mathrm{C} \end{aligned}$ |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I IL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| IEE | Supply Current | All Inputs and Outputs Open |  | -280 | -220 | - | mA | - |

## NOTE:

2792 til 06

1. Typical parameters are specified at $\mathrm{VEE}_{\mathrm{E}}=-5.2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

## ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | Ceramic Plastic | $\begin{aligned} & -65 \text { to }+150 \\ & -55 \text { to }+125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| Pt | Power Dissipation |  | 2.0 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

(VEE $=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V IN $=$ V IHB or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| VOLC | Output Threshold LOW Voltage | V IN $=$ V IHB or V ILA |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 H | Input HIGH Current | $\mathrm{VIN}=\mathrm{V}$ IHA | $\overline{\text { CS }}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 ll | Input LOW Current | V IN $=\mathrm{V}_{\text {ILB }}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -260 | -200 | - | mA |

NOTE:

1. Typical parameters are specified at $V_{E E}=-4.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

## ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | Ceramic <br> Plastic | -65 to +150 <br> -55 to +125 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| PT | Power Dissipation |  | 2.0 |
| IOUT | DC Output Current <br> (Output High) | -50 | WA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-101K DC ELECTRICAL CHARACTERISTICS

(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condition |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vor | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ V IHA or V ILB |  | -1810 | -1715 | -1620 | mV |
| VoHc | Output Threshold HIGH Voltage | V IN $=$ V IHB or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| VOLC | Output Threshold LOW Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | - | - | -1610 | mV |
| ViH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| Vil | Input LOW Vottage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | . 1475 | mV |
| IIH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| I IL | Input LOW Current | V IN $=\mathrm{V}_{\text {ILB }}$ | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open |  | -280 | -220 | - | mA |

1. Typical parameters are specified at $V_{E E}=-5.2 \mathrm{~V}, \mathrm{TA}_{A}=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION



AC TEST INPUT PULSE

$t R=t F=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

2792 drw 07

RISE/FALL TIME

| SYMBOL | PARAMETER | TEST CONDITION | MIN. | TYP. | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 4P | Output Rise Time | - | - | 2 | - | ns |
| 4 | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10508, IDT100508, and IDT101508 BiCMOS ECL static RAMs (SRAM) with CONDITIONAL WRITE provide high speed with low power dissipation typical of BiCMOS ECL. On-chip logic additionally helps improve system performance, yet the device is pinout-compatible with asynchronous equivalents (i.e...IDT10504, IDT100504, and IDT101504 respectively). The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K Vee compatibility ( -5.2 V ).

As can be seen in the Functional Block Diagram on the title page, this device contains clocked input registers to sample and hold addresses and input data, during a write cycle only.

Inputs are sampled on the rising edge of the Write Enable (WE). The write cycle is pipelined: the memory cell is written during the WE-low time in the next cycle. Additionally, the address and data paths to the input register are gated by the Conditional Write Multiplexor, which allows termination of a Write cycle late in the cycle.

Read cycles are not pipelined and operate identically to an asynchronous device, except that an output latch is provided to capture and hold Read data.

## READ TIMING

The read timing on the device is asynchronous. Dataout is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}}$ ).

FUNCTIONAL DESCRIPTION TIMING EXAMPLE


Then Address (ADDR) settles and data appears on the output after time tAA, as at 11 below.

Dataout is held for a short time ( tOH ) after the address begins to change for the next access, as can be seen at 7 allowing addresses to begin to change early for the next cycle - then ambiguous data is on the bus until a new time taA.

To avoid this noise on the bus and provide for longer output hold time, this device includes an output Read data latch which allows Read data to flow out while Output Latch Enable ( $\overline{O L E}$ ) is low, and then hold when $\overline{\text { OLE }}$ is high. Thus in the example below Read data at 8 is held until Read data at 8 is ready for output.

Note that Dataoutis disabled (held low) by $\overline{\mathrm{CS}}$ high or $\overline{\mathrm{WE}}$ low, regardless of the state of the Output Latch.

## DESELECT TIMING

Deselect timing is identical to a standard asynchronous device. This case occurs at $(2$ below. Outputs attain the disable state (low) tRCs later Chip Select ( $\overline{\mathrm{CS}}$ ) is taken to a high logic state. Status of other inputs do not effect the disabling of the device when chip select is de-asserted.

## WRITE TIMING

Write cycles pipelined to allow easier design and higher system performance. The write pulse created on the WE input is used as a strobe to clock in the Write Address and Data into a register. This address and data are held in the register until the next write cycle, when they are used to write into the memory array through the Input Multiplexor.

Note the very short valid window required for Write Address and Data inputs. This is because these signals are captured by the input register. This means that input data may arrive late in the cycle, as at 3 below, or data and address may arrive late, as at 6 below.

DataOUT is disabled during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the Dataour pins will output the written data after "Write Recovery Time" (tWR), as for a standard asynchronous device.

There is a special case when a Read cycle follows directly a Write Cycle to the same address. The memory array has not yet been updated with the Write data - it is still in the input register. This case is handled by including an address comparator and Output Multiplexor on the device: if the address being presented on the input pins is the same as the address stored in the input register, the data presented to the output pins is also from the input register.

## CONDITIONAL WRITE

In certain system architectures, the decision whether to write data within a cycle occurs late in the cycle. An example might be cache hit logic taking time to decide if a cache line needs to be updated. This device allows a write to be initiated, yet terminated very late in the cycle by using Chip Select should a write not be required by the system.

The Conditional Write Multiplexor controlled by Chip Select makes this possible. In a normal Write cycle, $\overline{\mathrm{CS}}$ is low and the Multiplexordelivers the state of the addresses and data on the input pins to the Input Multiplexor and Input Register, respectively. Because $\overline{\mathrm{CS}}$ does not gate the Write Pulse logic, it has a short valid window requirement.

To terminate the Write cycle, as shown at $\mathbf{6}$ below, all that is required is to bring $\overline{\mathrm{CS}}$ to a high logic state. This switches the Conditional Write Multiplexor to circulate the previously written address and data (held in the Input Register) around to be clocked again into the Input Register. No Write cycle is apparent to the system.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10508 S 12 \\ 100508 S 12 \\ 101508 S 12 \end{gathered}$ |  | $\begin{gathered} 10508 \mathrm{~S} 15 \\ 100508 \mathrm{~S} 15 \\ 101508 \mathrm{~S} 15 \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |
| $\mathrm{tAA}^{(2)}$ | Address Access Time | - | - | \% 12 | - | \% 15 | ns |
| tacs | Chip Select Access Time | - | - | \% | - | \% \% 5 | ns |
| tres | Chip Select Recovery Time | - | - | $\stackrel{\square}{*}$ | - | $\stackrel{5}{4}$ | ns |
| tor | Data Hold from Address Change | - | 3 | * - | 3 | * | ns |
| tolel | Latch Enable Low Pulse Width | - | 5 | - | 5 | - | ns |
| taho | Address Valid to OLE High | - | 14 | - | 17 | - | ns |
| tDH | Data Hold from Clock Low | - |  | - | 0 | - | ns |
| tDR | Data Ready from Clock Low | - | 0 | 4 | 0 | 4 | ns |

NOTES:

1. Input and Output reference level is $50 \%$ point of waveform.
2. Read Data is valid at taA or taHo - tolel + tor, whichever is larger; that is, Read Data is valid at the access time unless Output Latch Enable is high, and then access is tDr after OLE goes low.

READ CYCLE GATED BY CHIP SELECT


## READ CYCLE GATED BY ADDRESS



OUTPUT LATCH TIMING


2792 drw 09

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} 10508 S 12 \\ 100508 S 12 \\ 101508 \mathrm{~S} 12 \end{gathered}$ |  | $\begin{gathered} \text { 10508S15 } \\ \text { 100508S15 } \\ \text { 101508S15 } \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |
| tw | Write Pulse Width | - | 10 | - | 12 | - | ns |
| twscs | Setup Time for Chip Select | - | 1 | - | 1 | - | ns |
| twTCs | $\overline{\text { CS }}$ Set-Up, Terminated Write | - | 2 | \% | 2 | \% - | ns |
| tWSA | Setup Time for Address | - | 1 | 苓 | 1 | \% - | ns |
| tWSD | Setup Time for Data In | - | 1 | \% - | 1 | * - | ns |
| twhes | Hold Time for Chip Select | - | 2 | - | 2 | - | ns |
| tWHA | Hold Time for Address | - | 2 | - | 2 | - | ns |
| tWHD | Hold Time for Data In | - | 2 | - | 2 | - | ns |
| tws | Write Disable Time | - |  | 5 | - | 5 | ns |
| iWR | Write Recovery Time | - | - | 5 | - | 5 | ns |

1. Input and Output reference level is $50 \%$ point of waveform.

## WRITE CYCLE TIMING DIAGRAM



ORDERING INFORMATION


## HIGH-SPEED BiCMOS ECL STATIC RAM 256K (32K x 9-BIT) SRAM

## PRELIMINARY <br> IDT10509D <br> IDT100509D <br> IDT101509D

## FEATURES:

- 32,768-words x 9-bit organization
- Address access time: 8/10/12/15
- Wide word for reduced address loading
- Guaranteed Output Hold time
- Differential Write Clock and Single-Ended Write Enable
- Fully compatible with ECL logic levels
- Separate data input and output
- Standard pinouts


## DESCRIPTION:

The IDT10509D, IDT100509D and IDT101509D are 294,912-bit high-speed BiCEMOS ${ }^{\text {M }}$ ECL static random access memories organized as $32 \mathrm{Kx9}$, with separate data inputs and outputs. All I/Os are fully compatible with ECL levels.

These devices are part of a family of nine-bit-wide ECL

SRAMs. The devices have been configured to follow the proposed ECL SRAM JEDEC pinout. Because they are manufactured in BiCEMOS ${ }^{\text {TM }}$ technology, however, power dissipation is similar to CMOS devices of equivalent density.

The asynchronous SRAMs are the most straightforward to use because no additional clocks or controls are required: Dataout is available an access time after the last change of address.

The fast access time and guaranteed Output Hold time allow greater margin for system timing variation.

To write data into this device requires the creation of a Write Pulse, which is the combination of the Write Enable and the Write Clock. The differential Write Clock ensures easy creation of a clean write pulse throughout the memory array, reducing requirements on the skew of Write Enable with respect to addresses. Write cycles can be operated in traditional manner by disabling the Write-Clock and using the Write Enable only. Write cycle disables the output pins in conventional fashion.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION



300-Mil-Wide Plastlc SSOP Package 48

LOGIC SYMBOL


32Kx9
SRAM

TRUTH TABLE ${ }^{(1)}$

| $\overline{\text { CS }}$ | $\overline{\text { WE }}$ | WCLK | WCLK | Data out | Functlon |
| :---: | :---: | :---: | :---: | :---: | :--- |
| H | X | X | X | L | Deselected |
| L | H | X | X | RAM Data | Read |
| L | X | L | H | RAM Data | Read |
| L | L | H | L | L | Write, Diff. Clock |
| L | L | VEE | L | L | Write, Low Clock |
| L | L | H | VEE | L | Write, High Clock |
| L | L | VEE | VEE | L | Write, Single <br> Enable |


| NOTE: |
| :--- |
| 1. H=High, L=Low, X=Don't Care |

## PIN DESCRIPTIONS

| Symbol | Pln Name |
| :--- | :--- |
| Ao through A14 | Address Inputs |
| Do through Da | Data Inputs |
| Qo through $\mathrm{CB}_{8}$ | Data Outputs |
| $\overline{\mathrm{CS}}$ | Chip Select Input (Internal pull down) |
| $\overline{\text { WE }}$ | Write Enable Input |
| $\overline{\text { WCLK, WCLK }}$ | Differential Write Clock Inputs |
| VEE | More Negative Supply Voltage |
| VCC | Less Negative Supply Voltage |
| NC | No Connect (Not internally bonded) |

## AC OPERATING RANGES ${ }^{(1)}$

| VO | VEE | Temperature |
| :---: | :---: | :---: |
| 10 K | $-5.2 \mathrm{~V} \pm 5 \%$ | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 100 K | $-4.5 \mathrm{~V} \pm 5 \%$ | 0 TO $85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| 101 K | -4.75 V to -5.46 V | 0 TO $75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ |
| NOTE: | 2810 *102 |  |

1. Referenced to Vcc

## CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | SSOP |  |  |
| :--- | :--- | :---: | :---: | :---: |
|  |  | Typ. | Max. | Unit |
| CIN | Input Capacitance | TBD | - | pF |
| COUT | Output Capacitance | TBD | - | pF |

ECL-10K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | RatIng | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | Ceramic | -65 to +150 |${ }^{\circ} \mathrm{C}$.

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this

ECL-10K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit | TA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or VILB |  | $\begin{aligned} & \hline-1000 \\ & -960 \\ & -900 \end{aligned}$ | -885 | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| Vol | Output LOW Voltage | V IN $=$ V IHA or V ILB |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1665 \\ & -1650 \\ & -1625 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VoHc | Output Threshold HIGH Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | $\begin{aligned} & -1020 \\ & -980 \\ & -920 \end{aligned}$ | - | - | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VOLC | Output Threshold LOW Voltage | $\mathrm{V}_{\mathbb{N}}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | $\begin{aligned} & -1645 \\ & -1630 \\ & -1605 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | $\begin{aligned} & -1145 \\ & -1105 \\ & -1045 \end{aligned}$ | - | $\begin{aligned} & -840 \\ & -810 \\ & -720 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| VIL. | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | $\begin{aligned} & -1870 \\ & -1850 \\ & -1830 \end{aligned}$ | - | $\begin{aligned} & -1490 \\ & -1475 \\ & -1450 \end{aligned}$ | mV | $\begin{gathered} 0^{\circ} \mathrm{C} \\ 25^{\circ} \mathrm{C} \\ 75^{\circ} \mathrm{C} \end{gathered}$ |
| 1 IH | Input HIGH Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ IHA | $\overline{\overline{C S}}$ | - | - | 220 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | - | - | 110 | $\mu \mathrm{A}$ | - |
| I IL | Input LOW Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ ILB | $\overline{\mathrm{CS}}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ | - |
|  |  |  | Others | -50 | - | 90 | $\mu \mathrm{A}$ | - |
| Iee | Supply Current | All Inputs and Outputs Open |  | -280 | -220 | - | mA | - |

## NOTE:

2810 tblo 0

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-100K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect to GND | +0.5 to -7.0 | V |
| TA | Operating Temperature | 0 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | Ceramic | -65 to +150 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| PT | Power Dissipation | 2.0 | W |
| IOUT | DC Output Current <br> (Output High) | -50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolutemaximum rating conditions for extended periods may affect reliability.

## ECL-100K DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VEE}=-4.5 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+85^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Conditions |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or $\mathrm{V}^{\text {ILB }}$ |  | -1025 | -955 | -880 | mV |
| VOL | Output LOW Voltage | V IN $=$ V IHA or V V ILB |  | -1810 | -1715 | -1620 | mV |
| Vohe | Output Threshold HIGH Voltage | V IN $=$ V IHB or $\mathrm{V}_{\text {ILA }}$ |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | $\mathrm{V}_{1 \times}=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| ViH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| I IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | $\overline{\mathrm{CS}}$ | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| 1 IL | Input LOW Current | $\mathrm{V} \mathbb{N}=\mathrm{V}$ ILB | $\overline{\text { CS }}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| Iee | Supply Current | All Inputs and Outputs Open |  | -260 | -200 | - | mA |

1. Typical parameters are specified at $V_{E E}=-4.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.

ECL-101K ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Vterm | Terminal Voltage With Respect to GND |  | +0.5 to -7.0 | V |
| TA | Operating Temperature |  | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias |  | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | Ceramic | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation |  | 2.0 | W |
| lout | DC Output Current (Output High) |  | -50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTEMAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

ECL-101K DC ELECTRICAL CHARACTERISTICS
(VEE $=-5.2 \mathrm{~V}, \mathrm{RL}=50 \Omega$ to $-2.0 \mathrm{~V}, \mathrm{TA}=0$ to $+75^{\circ} \mathrm{C}$, air flow exceeding $2 \mathrm{~m} / \mathrm{sec}$ )

| Symbol | Parameter | Test Condition |  | Min. (B) | Typ. ${ }^{(1)}$ | Max. (A) | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | V IN $=$ V IHA or V ILB |  | -1025 | -955 | -880 | mV |
| Vol | Output LOW Voltage | V IN $=$ V IHA or $\mathrm{V}_{\text {ILB }}$ |  | -1810 | -1715 | -1620 | mV |
| Vohc | Output Threshold HIGH Voltage | V IN $=\mathrm{V}$ IHB or V ILA |  | -1035 | - | - | mV |
| Volc | Output Threshold LOW Voltage | V IN $=\mathrm{V}_{\text {IHB }}$ or $\mathrm{V}_{\text {ILA }}$ |  | - | - | -1610 | mV |
| VIH | Input HIGH Voltage | Guaranteed Input Voltage High for All Inputs |  | -1165 | - | -880 | mV |
| VIL. | Input LOW Voltage | Guaranteed Input Voltage Low for All Inputs |  | -1810 | - | -1475 | mV |
| 1 IH | Input HIGH Current | V IN $=\mathrm{V}$ IHA | CS | - | - | 220 | $\mu \mathrm{A}$ |
|  |  |  | Others | - | - | 110 |  |
| IIL | Input LOW Current | V IN $=\mathrm{V}$ ILB | $\overline{\text { CS }}$ | 0.5 | - | 170 | $\mu \mathrm{A}$ |
|  |  |  | Others | -50 | - | 90 |  |
| IEE | Supply Current | All Inputs and Outputs Open |  | -280 | -220 | - | mA |

NOTE:

1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ and maximum loading.

## AC TEST LOAD CONDITION



2810 drw 05

## AC TEST INPUT PULSE


$\mathrm{tR}=\mathrm{tF}=2.0 \mathrm{~ns}$ typ.
Note: All timing measurements are referenced to $50 \%$ input levels.

2810 drw 06

RISE/FALL TIME

| Symbol | Parameter | Test Conditlon | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tr | Output Rise Time | - | - | 2 | - | ns |
| tF | Output Fall Time | - | - | 2 | - | ns |

## FUNCTIONAL DESCRIPTION

The IDT10509D, IDT100509D, and IDT101509D BiCMOS ECL static RAMs (SRAM) provide high speed with low power dissipation typical of BiCMOS ECL. These devices follow the proposed pinout and functionality for $32 \mathrm{Kx9}$ ECL SRAMs. The ECL-101K meets electrical specifications that combine the ECL-100K temperature and voltage compensated output levels with the high-speed of ECL-10K VEE compatibility (-5.2V).

## READ TIMING

The read timing on these asynchronous devices is straightforward. Dataout is held low until the device is selected by Chip Select ( $\overline{\mathrm{CS}}$ ). Then Address (ADDR) settles and data appears on the output after time tAA. Note that DataOUT is held for a short time (tOH) after the address begins to change for the next access, then ambiguous data is on the bus until a new time tAA.

## WRITE TIMING

To write data to the device, a Write Pulse need be formed to control the write to the SRAM array. This device includes on-board logic that provides an internal Write Pulse defined as the logical NOT-AND combination (i.e. NOR, see block diagram) of Write Clock ( $\overline{\text { WCLK }}$ ) asserted low and the Write Enable ( $\overline{\mathrm{WE}}$ ) asserted low. Note that the Write Clock is a differential input allowing for greater noise rejection and cleaner signal forming over the memory array. This combination of signals is useful for the development of the very short Write Pulse that asynchronous SRAMs need: Write Clock is a carefully formed free-running signal that is de-skewed over the memory array layout; Write Enable is a control signal that
can be generated and delivered with the same skew tolerance as address signals.

While $\overline{C S}$, ADDR, and Datain must be valid when Write Pulse (see definition above) goes low. Data is written to the memory cell at the end of the Write Pulse, and inputs must be held after the rising edge of the Write Pulse to ensure satisfactory completion of the cycle.

DataOUT is disabled (held low) during the Write Cycle. If $\overline{\mathrm{CS}}$ is held low (active) and addresses remain unchanged, the Dataout pins will output the written data after "Write Recovery Time" (twR).

Because of the very short Write Pulse requirement, these devices can be cycled as quickly for Writes as for Reads. Balanced cycles mean simpler timing in cache applications.

## ALTERNATIVE WRITE OPERATION

The device may also be used other Write Pulse modes, if preferred. The Write Clock input may be converted from differential to single-ended operation as described in the Truth Table. The Write Clock may be disabled altogether, and only the Write Enable used to form Write Pulse, by externally connecting both inputs of the differential Write Clock (WCLK and $\bar{W} C L K)$ to the VEE supply voltage.

Tying the positive side of the differential Write Clock (WCLK) to the VEE voltage will allow for two single-ended write enables, $\bar{W} E$ and WCLK. The internal Write Pulse is in Write mode when both are low.

Tying the negative side of the differential Write Clock ( $\overline{W C L K}$ ) to the VEE voltage will allow for two single-ended write enables, $\overline{W E}$ and WCLK. The internal Write Pulse is in Write mode when $\overline{W E}$ is low and WCLK is high.

AC ELECTRICAL CHARACTERISTICS (Over the AC Operating Range)

| Symbol | Parameter ${ }^{(1)}$ | Test Condition | $\begin{gathered} \text { 10509D8 } \\ \text { 100509D8 } \\ \text { 101509D8 } \end{gathered}$ |  | $\begin{aligned} & \text { 10509D10 } \\ & \text { 100509D10 } \\ & \text { 101509D10 } \end{aligned}$ |  | $\begin{gathered} \hline \text { 10509D12 } \\ \text { 100509D12 } \\ \text { 101509D12 } \end{gathered}$ |  | $\begin{aligned} & \hline \text { 10509D15 } \\ & \text { 100509D15 } \\ & \text { 101509D15 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tacs | Chip Select Access Time | - | - | $\stackrel{\%}{*}$ \% | - | $\stackrel{3}{3}$ | - | $\% 5$ | - | $\stackrel{5}{4}$ | ns |
| tRCS | Chip Select Recovery Time | - | - | \% 5 | - | $\bigcirc$ | - | \% 5 | - | $\cdots$ | ns |
| taA | Address Access Time | - | 二 | 8 | - | 10 | - \% | 12 | - \% | 15 | ns |
| toh | Data Hold from Address Change | - | 3** | - | 3* | - | 3* | - | 3** | - | ns |

NOTE:

1. Input and Output reference level is $50 \%$ point of waveform.

## READ CYCLE GATED BY CHIP SELECT



## READ CYCLE GATED BY ADDRESS



AC ELECTRICAL CHARACTERISTICS（Over the AC Operating Range）

| Symbol | Parameter（1） | Test Condition | 10509D8100509D8101509D8 |  | $\begin{gathered} \text { 10509D10 } \\ \text { 100509D10 } \\ \text { 101509D10 } \end{gathered}$ |  | $\begin{gathered} \hline \text { 10509D12 } \\ \text { 100509D12 } \\ \text { 101509D12 } \end{gathered}$ |  | $\begin{array}{r} 10509 \mathrm{D} 15 \\ 100509 \mathrm{D} 15 \\ 101509 \mathrm{D} 15 \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min． | Max． | Min． | Max． | MIn． | Max． | Min． | Max． |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |
| tcyc | Cycle Time | － | 8 | － | 10 | － | 12 | － | 15 | － | ns |
| tw | Write Enable Pulse Width | － | 6 | \％ | 8 | \％ | 10 | \％ | 13 | \％ | ns |
| tWL | $\overline{\text { WCLK Low Pulse Width }}$ | － | 6 | ＊ | 8 | 娄 | 10 | 令 | 13 | ＊ | ns |
| tWH | $\overline{\text { WCLK High Pulse Width }}$ | － | 2 | ，－ | 2 | － | 2 | ＊ | 2 | \％－ | ns |
| twscs | Chip Select Set－up Time | － | 0 | － | 0 | － | 0 | ＊－ | 0 | ＊－ | ns |
| tWSA | Address Set－up Time | － | 0 | $\stackrel{\text {＊}}{\text {＊}}$ | 0 | － | 0 | － | 0 | \％ | ns |
| tWSD2 | Data Set－up Time | － | 6 | － | 8 ＊ | 离－ | 10 荟 | － | 13 令 | － | ns |
| tWSWE | Write Enable Set－up Time | － | 0 \％ | － | 0 \％ | － | 0． | － | 0 | － | ns |
| tWHCs ${ }^{(2)}$ | Chip Select Hold Time | － | $1{ }^{1}$ | － | 1 1\％ | － | 1\％ | － | 2\％ | － | ns |
| TWHA ${ }^{(2)}$ | Address Hold Time | － | 1\％ | － | 1＊＊ | － | 1 1／＊ | － | 2＊＊ | － | ns |
| tWHD ${ }^{(2)}$ | Data Hold Time | － | \％ | － | ＊＊ | － | \％圌 | － | 2＊＊＊ | － | ns |
| tWHWE ${ }^{(2)}$ | Write Enable Hold Time | － | 90\％ | － | \％范 | － | 0\％ | － | \％\％ | － | ns |
| tws | Write Disable Time | － | － | 5 | －\％ | 5 | －＊ | 5 | －＊ | 5 | ns |
| twR ${ }^{(3)}$ | Write Recovery Time | － | － | 5 | － | 5 | － | 5 | － | 5 | ns |

NOTES：
1．Input and Output reference level is $50 \%$ point of waveform．
2．Write Pulse Width is the logical NOT－AND of $\bar{W} E 1$ and $\overline{W E 2}$ ，that is，when both are logical low．
3．twris defined as the time to reflect the newly written data on the Data Outputs（ $\mathcal{O}_{0}$ to $Q_{3}$ ）when no new Address Transition occurs．
WRITE CYCLE TIMING DIAGRAM


## ORDERING INFORMATION



#  <br>  

CHMEMTY ANU RELVABHUTY

PACHAGEDAGRAMI OUTHNES

ECLPHODUCTS

FIFO PRODUCTS

## SPEGATH MEMORY PRODUCTS

## sunswstemspmonucts

APPLIOATION AND TECHNICAL NOTES

## FIFO MEMORIES

Integration of IDT high-speed static RAM technology with internal support logic yields high-performance, high-density FIFO memories. A FIFO is used as a memory buffer between two asynchronous systems with simultaneous read/write access. The data rate between the two systems can be regulated by monitoring the status flags and throttling the read and write accesses. Since these FIFOs are built with an internal RAM pointer architecture, there is no fall-through time between a write to a memory location and a read from that memory location. System performance is significantly improved over the shift register-based architecture of previous FIFO designs which are handicapped with long fall-through times.

IDT offers the widest selection of monolithic FIFOs, ranging from shallows $64 \times 4$ and $64 \times 5$ to the high-density $16 \mathrm{~K} \times 9$. Shallow FIFOs regulate data flow in tightly couped computational engines. High-density FIFOs store large blocks in networking, telecommunication and data storage systems. The IDT7200 FIFO family ( $256 \times 9$ through the $16 \mathrm{Kx9}$ FIFOs) are all pin and function compatible, making density upgrades simple. AllIDTFIFOs can be cascaded to greater word depths and expanded to greater word widths with no external support logic.

IDT's high-speed SyncFIFO'M is ideal for multiprocessor systems, workstations and high-end graphics. The innovative architecture of the SyncFIFO (internal I/O registers with separate clock and enable inputs), along with wider data bus, simplifies design and reduces interface logic.

The Parallel-Serial FIFOs incorporate a serial input or a serial output shifter for serial-to-parallel or parallel-to-serial bus interface. The Parallel-Serial FIFOs also offer six status flags for flexible data throttling.

A variety of packages are available: standard plastic DIP and CERDIP, surface mount ceramic LCC, PLCC and SOIC, and high-reliability flatpack. Increasing board density is the overwhelming goal of IDT's package development efforts, as demonstrated by the introduction of the 300 mil ThinDIP.

FIFO modules, composed of four LCC devices mounted on a multi-layer co-fired ceramic substrate, increase densities to $32 \mathrm{Kx18}$ which are pin-compatible with current monolithic versions.

IDT is committed to offering FIFOs of increasing density, speed and enhanced architectural innovations, such as Flexishift ${ }^{T M}$ and the BiFIFO, for easier system interface.

## TABLE OF CONTENTS

PAGE

## FIFO PRODUCTS

IDT7200
IDT7201
IDT7202
IDT7203
IDT7204
IDT7205
IDT7206
IDT72021
IDT72031
IDT72041
IDT72103
IDT72104
IDT72105
IDT72115
IDT72125
IDT72131
IDT72141
IDT72132
IDT72142
IDT72200
IDT72210
IDT72420
IDT72201
IDT72211
IDT72421
IDT72215A
IDT72225A
IDT72220
IDT72230
IDT72240
IDT72221
IDT72231
IDT72241
IDT72235
IDT72245
IDT72401
IDT72402
IDT72403
IDT72404
IDT72413
IDT7251
IDT7252
IDT72510
IDT72520
IDT72511
IDT72521
IDT72605
$256 \times 9$-Bit ParalleI FIFO ..................................................................................... 6.1
$512 \times 9$-Bit Parallel FIFO ...................................................................................... 6.1
$1024 \times 9$-Bit Parallel FIFO .................................................................................... 6.2
2K x 9-Bit Parallel FIFO ....................................................................................... 6.3
4K x 9-Bit Parallel FIFO ....................................................................................... 6.3
8K x 9-Bit Parallel FIFO ....................................................................................... 6.4
16K x 9-Bit ParalleI FIFO ...................................................................................... 6.5
1K x 9-Bit Parallel FIFO w/ Flags and Output Enable ............................................. 6.6
$2 \mathrm{~K} \times 9$-Bit Parallel FIFO w/Flags and Output Enable .............................................. 6.6
4K $\times$ 9-Bit Parallel FIFO w/Flags and Output Enable .............................................. 6.6
2K x 9-Bit Configurable Parallel-Serial FIFO .......................................................... 6.7
$4 \mathrm{~K} \times 9$-Bit Configurable Parallel-Serial FIFO .......................................................... 6.7
$256 \times 16$-Bit Parallel-to-Serial FIFO....................................................................... 6.8
$512 \times 16$-Bit Parallel-to-Serial FIFO....................................................................... 6.8
$1024 \times 16$-Bit Parallel-to-Serial FIFO..................................................................... 6.8
$2048 \times 9$-Bit Parallel-to-Serial FIFO....................................................................... 6.9
$4096 \times 9$-Bit Parallel-to-Serial FIFO....................................................................... 6.9
$2048 \times 9$-Bit Serial-to-Parallel FIFO...................................................................... 6.10
$2048 \times 9$-Bit Serial-to-Parallel FIFO....................................................................... 6.10
$256 \times 8$-Bit Parallel SyncFIFO™ (Clocked FIFO) ................................................... 6.11
$512 \times 8$-Bit Parallel SyncFIFO™ (Clocked FIFO) ................................................... 6.11
$64 \times 8$-Bit Parallel SyncFIFO™ (Clocked FIFO) ..................................................... 6.11
$256 \times 9$-Bit Parallel SyncFIFO™ (Clocked FIFO) ................................................... 6.12
$512 \times 9$-Bit Parallel SyncFIFO ${ }^{\text {mM }}$ (Clocked FIFO) .................................................... 6.12
$64 \times 9$-Bit Parallel SyncFIFOTM (Clocked FIFO) ..................................................... 6.12
$512 \times 18$-Bit Parallel SyncFIFOTM (Clocked FIFO) ................................................. 6.13
$1024 \times 18$-Bit Parallel SyncFIFO™ (Clocked FIFO) ............................................... 6.13
1K $\times 8$-Bit ParalleI SyncFIFO™ (Clocked FIFO) ..................................................... 6.14
2K $\times 8$-Bit ParalleI SyncFIFOTM (Clocked FIFO) ..................................................... 6.14
4K x 8-Bit Parallel SyncFIFOrM (Clocked FIFO) ..................................................... 6.14
1K x 9-Bit Parallel SyncFIFO™ (Clocked FIFO)..................................................... 6.15
2K x 9-Bit Parallel SyncFIFOrM (Clocked FIFO)..................................................... 6.15
4K x 9-Bit Parallel SyncFIFO™ (Clocked FIFO) ..................................................... 6.15
2K x 18-Bit Parallel SyncFIFOTM (Clocked FIFO) ................................................... 6.16
4K x 18-Bit Parallel SyncFIFOrM (Clocked FIFO) ................................................... 6.16
$64 \times 4$ FIFO......................................................................................................... 6.17
$64 \times 5$ FIFO......................................................................................................... 6.17
$64 \times 4$ FIFO (w/Output Enable)............................................................................ 6.17
$64 \times 5$ FIFO (w/Output Enable)............................................................................. 6.17
$64 \times 5$ FIFO (w/Flags) ......................................................................................... 6.18
$512 \times 18$-Bit — 1 K $\times 9$-Bit BiFIFO .......................................................................... 6.19
1K x 18-Bit — $2 \mathrm{~K} \times 9$-Bit BiFIFO ........................................................................... 6.19
$512 \times 18$-Bit - $1 \mathrm{~K} \times 9$-Bit BiFIFO .......................................................................... 6.19
1K x 18-Bit — 2K x 9-Bit BiFIFO ........................................................................... 6.19
$512 \times 18$-Bit BiFIFO ............................................................................................. 6.20
1K x 18-Bit BiFIFO............................................................................................... 6.20
$256 \times 18$-Bit Synchronous BiFIFO (SyncBiFIFO™ )................................................ 6.21
IDT72615

## FEATURES:

- First-In/First-Out dual-port memory
- $256 \times 9$ organization (IDT7200)
- $512 \times 9$ organization (IDT7201A)
- Low power consumption
- Active: 770 mW (max.)
- Power-down: 27.5mW (max.)
- Ultra high speed-15ns access time
- Asynchronous and simultaneous read and write
- Fully expandable by both word depth and/or bit width
- Pin and functionally compatible with 720X family
- Status Flags: Empty, Half-Full, Full
- Auto-retransmit capability
- High-performance CEMOS ${ }^{\text {TM }}$ technology
- Military product compliant to MIL-STD-883, Class B
- Standard Military Drawing \#5962-87531, 5962-89666, and 5962-89863 are listed on this function.


## DESCRIPTION:

The IDT7200/7201A are dual-port memories that load and empty data on a first-in/first-out basis. The devices use Full and Empty flags to prevent data overilow and underflow and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the devices through the use of the Write ( W ) and Read ( $\overline{\mathrm{R}})$ pins. The devices have a read/write cycle time of $25 \mathrm{~ns}(40 \mathrm{MHz}$ ).

The devices utilizes a 9 -bit wide data array to allow for control and parity bits at the user's option. This feature is especially useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking. It also features a Retransmit ( $\overline{\mathrm{RT}}$ ) capability that allows for reset of the read pointer to its initial position when $\overline{\mathrm{RT}}$ is pulsed low to allow for retransmission from the beginning of data. A Half-Full Flag is available in the single device mode and width expansion modes.

The IDT7200/1A is fabricated using IDT's high-speed CEMOS technology. They are designed for those applications requiring asynchronous and simultaneous read/ writes in multiprocessing and rate buffer applications. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

FUNCTIONAL BLOCK DIAGRAM


CEMOS is a traderrark of Integrated Device Technology, Inc.

## PIN CONFIGURATIONS



DIP/SOIC/FLATPACK TOP VIEW


LCC/PLCC
TOP VIEW

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Mil. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2679 tы 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicatedin the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | Vin $=0 \mathrm{~V}$ | 8 | pF |
| COUT | Output Capacitance | Vour $=0 \mathrm{~V}$ | 8 | pF |

NOTE:
2679 202 02

1. This parameter is sampled and not $100 \%$ tested.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccm | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH $^{(1)}$ | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH $^{(1)}$ | Input High Voltage <br> Mlitary | 2.2 | - | - | V |
| VIL $^{(2)}$ | Input Low Voltage <br> Commercial and <br> Military | - | - | 0.8 | V |

NOTE:
2679 t103

1. $\mathrm{V}_{1 \mathrm{H}}=2.6 \mathrm{~V}$ for XT input (commercial).
$\mathrm{V}_{1 \mathrm{H}}=2.8 \mathrm{~V}$ for XI input (military).
2. 1.5 V undershoots are allowed for 10 ns once per cycle.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7200 IDT7201 Commerclal tA $=15,20 \mathrm{~ns}$ |  |  | IDT7200 <br> IDT7201 <br> Milltary $t A=20 \mathrm{~ns}$ |  |  | IDT7200 <br> IDT7201 <br> Commerclal $t_{A}=25,35 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $\mathrm{LLI}^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | -1 | - | 1 | $\mu \mathrm{A}$ |
| H20 ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | $\mu A$ |
| VOH | Output Logic "1" Voltage loh $=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | V |
| VoL | Output Logic " 0 " Voltage $\mathrm{IOH}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{icca}^{(3)}$ | Active Power Supply Current | - | - | $140^{(4)}$ | - | - | $160^{(4)}$ | - | - | $125^{(4)}$ | mA |
| Icce ${ }^{(3)}$ | Standby Current ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} / \overline{\mathrm{RT}}=\mathrm{VIH}$ ) | - | - | 15 | - | - | 20 | - | - | 15 | mA |
| $\operatorname{lcc3}(\mathrm{L})^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | - | 5 | - | - | 9 | - | - | 0.5 | mA |
| $\mathrm{lccs}(\mathrm{S})^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) |  |  |  |  |  |  | - | - | 5 | mA |

## DC ELECTRICAL CHARACTERISTICS (Continued)

(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { IDT7200 } \\ \text { IDT7201 } \\ \text { Milltary } \\ \mathbf{t A}=30,40 \mathrm{~ns} \\ \hline \end{gathered}$ |  |  | IDT7200IDT7201Commerclal$\mathbf{t A}=50,65,80,120 \mathrm{~ns}$ |  |  | IDT7200IDT7201MilltarytA $=50,65,80,120 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $\underline{\mathrm{LI}}{ }^{(1)}$ | Input Leakage Current (Any Input) | -10 | - | 10 | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{ILO}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage $\mathrm{IOH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | V |
| VOL | Output Logic "0" Voltage $\mathrm{IOH}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{lcC1}^{(3)}$ | Active Power Supply Current | - | - | $140^{(4)}$ | - | 50 | 80 | - | 70 | 100 | mA |
| $\mathrm{Icce}^{(3)}$ | Standby Current ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} \overline{\mathrm{RT}}=\mathrm{V} / \mathrm{H}$ ) | - | - | 20 | - | 5 | 8 | - | 8 | 15 | mA |
| $\operatorname{lcc3}(\mathrm{L})^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | - | 0.9 | - | - | 0.5 | - | - | 0.9 | mA |
| lcc3(S) ${ }^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | - | 9 | - | - | 5 | - | - | 9 | mA |

1. Measurements with $0.4 \leq \mathrm{V} / \mathrm{N} \leq \mathrm{Vcc}$.
2. $\overline{\mathrm{R}} \geq \mathrm{V}_{\mathrm{IH}}, 0.4 \leq$ Vout $\leq \mathrm{VCC}_{\text {. }}$
3. ICC measurements are made with outputs open (only capacitive loading).
4. Tested at $\mathrm{f}=20 \mathrm{MHz}$.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Com'l. |  | Com'l. \& Mil. |  | Com'l. |  | Mil. |  | Com'L. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{gathered} \text { 7200L15 } \\ \text { 7201LA15 } \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { 7200L20 } \\ \text { 7201LA20 } \\ \hline \end{gathered}$ |  | $\begin{array}{\|c\|} \hline \text { 7200S/L25 } \\ \text { 7201SA/LA25 } \\ \hline \end{array}$ |  | $\begin{gathered} \text { 7200S/L30 } \\ \text { 7201SA/LA30 } \end{gathered}$ |  | $\begin{array}{\|c\|} \hline \text { 7200S/L35 } \\ \text { 7201SA/LA35 } \end{array}$ |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ts | Shift Frequency | - | 40 | - | 33.3 | - | 28.5 | - | 25 | - | 22.2 | MHz |
| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| ts | Access Time | - | 15 | \% | 20 | - | 25 | - | 30 | - | 35 | ns |
| tRR | Read Recovery Time | 10 | - | 10. | - | 10 | - | 10 | - | 10 | - | ns |
| tRPW | Read Pulse Width ${ }^{(2)}$ | 15 | - | 20 | \% | 25 | - | 30 | - | 35 | - | ns |
| tRLZ | Read Pulse Low to Data Bus at Low $\mathrm{Z}^{(3)}$ | 5 | - | 5. | - | 5 | - | 5 | - | 5 | - | ns |
| twlz | Write Pulse High to Data Bus at Low ${ }^{(3,4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 10 | - | ns |
| tDV | Data Valid from Read Pulse High | 5 | - | 5. | $\stackrel{-}{-}$ | 5 | - | 5 | - | 5 | - | ns |
| triz | Read Pulse High to Data Bus at High Z ${ }^{(3)}$ | - | 15 | - | 15 | - | 18 | - | 20 | - | 20 | ns |
| twc | Write Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tWPW | Write Pulse Width ${ }^{(2)}$ | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tWR | Write Recovery Time | 10 | - | , 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tos | Data Set-up Time | 11 | - | 12 | - | 15 | - | 18 | - | 18 | - | ns |
| tor | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tRSC | Reset Cycle Time | 25 | -3 | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tRS | Reset Pulse Width ${ }^{(2)}$ | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tRSS | Reset Set-up Time ${ }^{(3)}$ | 15 | $\stackrel{*}{*}$ | 20. | - | 25 | - | 30 | - | 35 | - | ns |
| tRSR | Reset Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tRTC | Retransmit Cycle Time | 25 | \% | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tRT | Retransmit Pulse Width ${ }^{(2)}$ | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tris | Retransmit Set-up Time ${ }^{(3)}$ | 15 | $\stackrel{1}{*}$ | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tRTR | Retransmit Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tEFL | Reset to Empty Flag Low | - | 4 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tHFF,FFH | Reset to Hall-Full and Full Flag High | - | 25. | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tref | Read Low to Empty Flag Low | - | 15 | - | 20 | - | 25 | - | 30 | - | 30 | ns |
| tRFF | Read High to Full Flag High | - | 15 | - | 20 | - | 25 | - | 30 | - | 30 | ns |
| tRPE | Read Pulse Width after EFF High | 15 | $\cdots$ | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tWEF | Write High to Empty Flag High | 一 | 15 | - | 20 | - | 25 | - | 30 | - | 30 | ns |
| tWFF | Write Low to Full Flag Low | - | t5 | - | 20 | - | 25 | - | 30 | - | 30 | ns |
| tWHF | Write Low to Half-Full Flag Low | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| trhf | Read High to Halt-Full Flag High | $\cdots$ | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tWPF | Write Pulse Width atter FF High | \% ${ }^{1}$ | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| txOL | Read/Write to $\overline{\mathrm{XO}}$ Low | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tXOH | Read/Write to XO High | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tx | $\overline{\mathrm{XI}}$ Pulse Width ${ }^{(2)}$ | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tXIR | $\overline{\mathrm{XI}}$ Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| txis | $\overline{\text { XI Set-up Time }}$ | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |

## NOTES:

1. Timings referenced as in AC Test Conditions.
2. Pulse widths less than minimum value are not allowed
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

## AC ELECTRICAL CHARACTERISTICS（Continued）

（Commercial： $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ；Military： $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ）

| Symbol | Parameter |  | tary | Commmercial and Milltary |  |  |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{\|c\|} \hline \text { 7200S/L40 } \\ \text { 7201SA/LA40 } \end{array}$ |  | $\begin{array}{\|c\|} \hline \text { 7200S/L50 } \\ \text { 7201SA/LA50 } \end{array}$ |  | $\begin{array}{\|c\|} \hline \text { 7200S/L65 } \\ \text { 7201SA/LA65 } \end{array}$ |  | $\begin{array}{\|c\|} \hline \text { 7200S/L80 } \\ \text { 7201SA/LA80 } \end{array}$ |  | $\begin{gathered} \text { 7200S/L120 } \\ 7201 S A L A 120 \end{gathered}$ |  |  |
|  |  | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． |  |
| ts | Shift Frequency | － | 20 | － | 15 | － | 12.5 | － | 10 | － | 7 | MHz |
| tRC | Read Cycle Time | 50 | － | 65 | － | 80 | － | 100 | － | 140 | － | ns |
| ts | Access Time | － | 40 | － | 50 | － | 65 | － | 80 | － | 120 | ns |
| tRR | Read Recovery Time | 10 | － | 15 | － | 15 | － | 20 | － | 20 | － | ns |
| tRPW | Read Pulse Width ${ }^{(2)}$ | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| tRLZ | Read Pulse Low to Data Bus at Low ${ }^{(3)}$ | 5 | － | 10 | － | 10 | － | 10 | － | 10 | － | ns |
| twl | Write Pulse High to Data Bus at Low ${ }^{(3,4)}$ | 10 | － | 15 | － | 15 | － | 20 | － | 20 | － | ns |
| tDV | Data Valid from Read Pulse High | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| tRHZ | Read Pulse High to Data Bus at High Z ${ }^{(3)}$ | － | 25 | － | 30 | － | 30 | － | 30 | － | 35 | ns |
| twc | Write Cycle Time | 50 | － | 65 | － | 80 | － | 100 | － | 140 | － | ns |
| tWPW | Write Pulse Width ${ }^{(2)}$ | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| twR | Write Recovery Time | 10 | － | 15 | － | 15 | － | 20 | － | 20 | － | ns |
| tDS | Data Set－up Time | 20 | － | 30 | － | 30 | － | 40 | － | 40 | － | ns |
| tDH | Data Hold Time | 0 | － | 5 | － | 10 | － | 10 | － | 10 | － | ns |
| tRSC | Reset Cycle Time | 50 | － | 65 | － | 80 | － | 100 | － | 140 | － | ns |
| tRS | Reset Pulse Width ${ }^{(2)}$ | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| tRSS | Reset Set－up Time ${ }^{(3)}$ | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| tRSR | Reset Recovery Time | 10 | － | 15 | － | 15 | － | 20 | － | 20 | － | ns |
| tRTC | Retransmit Cycle Time | 50 | － | 65 | － | 80 | － | 100 | － | 140 | － | ns |
| tRT | Retransmit Pulse Width ${ }^{(2)}$ | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| tRTS | Retransmit Set－up Time ${ }^{(3)}$ | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| tRTR | Retransmit Recovery Time | 10 | － | 15 | － | 15 | － | 20 | － | 20 | － | ns |
| tEFL | Reset to Empty Flag Low | － | 50 | － | 65 | － | 80 | － | 100 | － | 140 | ns |
| thFH，FFH | Reset to Half－Full and Full Flag High | － | 50 | － | 65 | － | 80 | － | 100 | － | 140 | ns |
| tREF | Read Low to Empty Flag Low | － | 30 | － | 45 | － | 60 | － | 60 | － | 60 | ns |
| tRFF | Read High to Full Flag High | － | 35 | － | 45 | － | 60 | － | 60 | － | 60 | ns |
| trPE | Read Pulse Width atter EF High | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| tWEF | Write High to Empty Flag High | － | 35 | － | 45 | － | 60 | － | 60 | － | 60 | ns |
| tWFF | Write Low to Full Flag Low | － | 35 | － | 45 | － | 60 | － | 60 | － | 60 | ns |
| tWHF | Write Low to Half－Full Flag Low | － | 50 | － | 65 | － | 80 | － | 100 | － | 140 | ns |
| truF | Read High to Half－Full Flag High | － | 50 | － | 65 | － | 80 | － | 100 | － | 140 | ns |
| tWPF | Write Pulse Width after FF High | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| txal | Read／Write to XO Low | － | 40 | － | 50 | － | 65 | － | 80 | － | 120 | ns |
| tхOH | Read／Write to $\overline{\mathrm{XO}}$ High | － | 40 | － | 50 | － | 65 | － | 80 | － | 120 | ns |
| txt | XI Pulse Width ${ }^{(2)}$ | 40 | － | 50 | － | 65 | － | 80 | － | 120 | － | ns |
| tXIR | $\overline{\text { XI Recovery Time }}$ | 10 | － | 10 | － | 10 | － | 10 | － | 10 | － | ns |
| txis | $\overline{\text { XI Set－up Time }}$ | 10 | 二 | 15 | 二 | 15 | 二 | 15 | － | 15 | － | ns |

## NOTES：

2879 너 06
1．Timings referenced as in AC Test Conditions．
2．Pulse widths less than minimum value are not allowed．
3．Values guaranteed by design，not currently tested．
4．Only applies to read data flow－through mode．

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |

2679 tbl 08

## SIGNAL DESCRIPTIONS

## INPUTS:

DATA IN (D0 - D8)
Data inputs for 9 -bit wide data.

## CONTROLS:

## RESET ( $\overline{\mathrm{RS}}$ )

Reset is accomplished whenever the Reset ( $\overline{\mathrm{RS}}$ ) input is takento a low state. During reset, both internal read and write pointers are set to the first location. A reset is required after power up before a write operation can take place. Both the Read Enable ( $\overline{\mathrm{R}}$ ) and Write Enable $(\overline{\mathrm{W}}$ ) Inputs must be In the high state during the window shown in Figure 2, (i.e., trss before the rising edge of $\overline{\mathrm{RS}}$ ) and should not change until trsi after the rising edge of $\overline{\mathrm{RS}}$. Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be reset to high after Reset ( $\overline{\mathrm{RS}}$ ).

## WRITE ENABLE ( $\bar{W}$ )

A write cycle is initiated on the falling edge of this input if the Full Flag ( $\overline{\text { FF }}$ ) is not set. Data set-up and hold times must be adhered to with respect to the rising edge of the Write Enable $(\bar{W})$. Data is stored in the RAM array sequentially and independently of any on-going read operation.

After half of the memory is filled and at the falling edge of the next write operation, the Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be set to low and will remain set until the difference between the write pointer and read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag ( $\overline{\mathrm{HF}) \text { is then }}$ reset by the rising edge of the read operation.

To prevent data overflow, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operations. Upon the completion of a valid read operation, the Full Flag ( $\overline{\mathrm{FF}})$ will go high after tRFF, allowing a valid write to begin. When the FIFO is full, the internal write pointer is blocked from $\bar{W}$, so external changes in $\bar{W}$ will not affect the FIFO when it is full.

## READ ENABLE $(\overline{\mathrm{R}})$

A read cycle is initiated on the falling edge of the Read Enable ( $\overline{\mathrm{R}}$ ) provided the Empty Flag ( $\overline{\mathrm{EF}}$ ) is not set. The data is accessed on a First-In/First-Out basis, independent of any ongoing write operations. After Read Enable ( $\overline{\mathrm{R}}$ ) goes high,
or equivalent circuit
Flgure 1. Output Load

* Includes scope and jig capacitances.

the Data Outputs ( $Q_{0}-Q 8$ ) will return to a high impedance condition until the next Read operation. When all data has been read from the FIFO, the Empty Flag (EF) will go low, allowing the "final" read cycle but inhibiting further read operations with the data outputs remaining in a high impedance state. Once a valid write operation has been accomplished, the Empty Flag ( $\overline{\mathrm{EF}}$ ) will go high after tWEF and a valid Read can then begin. When the FIFO is empty, the internal read pointer is blocked from $\bar{R}$ so external changes in $\bar{R}$ will not affect the FIFO when it is empty.


## FIRST LOAD/RETRANSMIT ( $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ )

This is a dual-purpose input. Inthe Depth ExpansionMode, this pin is grounded to indicate that it is the first loaded (see Operating Modes). In the Single Device Mode, this pin acts as the restransmit input. The Single Device Mode is initiated by grounding the Expansion $\operatorname{In}(\overline{\mathrm{XI}})$.

The IDT7200/7201A can be made to retransmit data when the Retransmit Enable control ( $\overline{\mathrm{RT}}$ ) input is pulsed low. A retransmit operation will set the internal read pointer to the first location and will not affect the write pointer. Read Enable ( $\overline{\mathrm{R}}$ ) and Write Enable $(\bar{W})$ must be in the high state during retransmit. This feature is useful when less than 256/512 writes are performed between resets. The retransmit feature is not compatible with the Depth Expansion Mode and will affect the Half-Full Flag ( $\overline{\mathrm{HF}}$ ), depending on the relative locations of the read and write pointers.

## EXPANSION IN ( $\overline{\mathrm{X}}$ )

This input is a dual-purpose pin. Expansion $\ln (\overline{\mathrm{X}})$ is grounded to indicate an operation in the single device mode. Expansion $\ln (\overline{\mathrm{XI}})$ is connected to Expansion Out ( $\overline{\mathrm{XO}})$ of the previous device inthe Depth Expansion or Daisy Chain Mode.

## OUTPUTS:

## FULL FLAG ( $\overline{F F}$ )

The Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operation, when the write pointer is one location less than the read pointer, indicating that the device is full. If the read pointer is not moved after Reset ( $\overline{\mathrm{RS}}$ ), the Full-Flag ( $\overline{\mathrm{FF}}$ ) will go low after 256 writes for IDT7200 and 512 writes for the IDT7201A.

## EMPTY FLAG ( $\overline{E F}$ )

The Empty Flag ( $\overline{E F}$ ) will go low, inhibiting further read operations, when the read pointer is equal to the write pointer, indicating that the device is empty.

## EXPANSION OUT/HALF-FULL FLAG ( $\overline{\mathrm{XO}} / \overline{\mathrm{hF}}$ )

This is a dual-purpose output. In the single device mode, when Expansion $\ln (\overline{\mathrm{XI}})$ is grounded, this output acts as an indication of a half-full memory.

After half of the memory is filled and at the falling edge of the next write operation, the Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be set low and will remain set until the difference between the write
pointer and read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag ( $\overline{\mathrm{FF}}$ ) is then reset by using rising edge of the read operation.

In the Depth Expansion Mode, Expansion In $(\overline{\mathrm{XII}})$ is connected to Expansion Out ( $\overline{\mathrm{XO}}$ ) of the previous device. This output acts as a signal to the next device in the Daisy Chain by providing a pulse to the next device when the previous device reaches the last location of memory.

## DATA OUTPUTS ( $\mathrm{Q}_{0}-\mathrm{Q}_{8}$ )

Data outputs for 9 -bit wide data. This data is in a high impedance condition whenever Read $(\overline{\mathrm{R}}$ ) is in a high state.


NOTES:
Figure 2. Reset

1. $\overline{\mathrm{EF}}, \overline{\mathrm{FF}}, \overline{\mathrm{HF}}$ may change status during Reset, but flags will be valid at trsc.
2. $\bar{W}$ and $\overline{\mathrm{R}}=\mathrm{V}_{\mathbb{1}}$ around the rising edge of $\overline{\mathrm{RS}}$.


Figure 3. Asynchronous Write and Read Operation


Figure 4. Full Flag From Last Write to First Read


Figure 5. Empty Flag From Last Read to First Write


Figure 6. Retransmit


Figure 7. Empty Flag Timing


Figure 8. Full Fiag Timing


Figure 9. Half-Full Flag Tlming


Figure 10. Expansion Out


Flgure 11. Expansion In

## OPERATING MODES

## SINGLE DEVICE MODE

A single IDT7200/7201A may be used when the application requirements for 256/512 words or less. The IDT7200/7201A
is in a Single Device Configuration when the Expansion $\ln (\overline{\mathrm{XI}})$ control input is grounded (see Figure 12). In the mode the Half-Full Flag (HF), which is an active low output, is shared with Expansion Out $(\overline{\mathrm{XO}})$.


2679 dww 14

Figure 12. Block Diagram of Single 256/512 $\times 9$ FIFO

WIDTH EXPANSION MODE
Word width may be increased simply by connecting the corresponding input control of multiple devices. Status flags ( $\overline{\mathrm{EF}}, \overline{\mathrm{FF}}$ and $\overline{\mathrm{HF}}$ ) can be detected from any one device. Figure

13 demonstrates an 18-bit word width by usingtwo IDT7201As. Any word width can be attained by adding additional IDT7201As.


Figure 13. Block Dlagram of $256 / 512 \times 18$ FIFO Memory Used In WIdth Expansion Mode

## DEPTH EXPANSION (DASIY CHAIN) MODE

The IDT7200/7201 A can easily be adapted to applications where the requirements are for greater than 256/512 words. Figure 14 demonstrates Depth Expansionusingthree IDT7200/ 7201As. Any depth can be attained by adding additional IDT7200/7201As. The IDT7200/7201A operates in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designed by grounding the First Load (FL) control input.
2. All other devices must have $\overline{\mathrm{FL}}$ in the high state.
3. The Expansion Out $(\overline{\mathrm{XO}})$ pin of each device must be tied to the Expansion $\ln (\overline{\mathrm{XI}})$ pin of the next device. See Figure 14.
4. External logic is needed to generate a composite Full Flag ( $\overline{\mathrm{FF}}$ ) and Empty Flag ( $\overline{\mathrm{EF}}$ ). This requires the ORing of all EFs and ORing of all FFs (i.e. all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{\mathrm{EF}}$ ). See Figure 14.
5. The Retransmit ( $\overline{\mathrm{RT}}$ ) function and Half-Full Flag $(\overline{\mathrm{HF}})$ are not available in the Depth Expansion Mode.
For additional information refer to Tech Note 9: "Cascading FIFOs or FIFO Modules".

## COMPOUND EXPANSION MODE

The two expansion techniques described above can be applied together in a straight forward manner to achieve large FIFO arrays (see Figure 15).

## BIDIRECTIONAL MODE

Applications which require data buffering between two systems (each system capable of Read and Write operations) can be achieved by pairing IDT7200/7201As as shown in Figure 16. Care must be taken to assure that the appropri-
ate flag is monitored by each system (i.e., $\overline{\mathrm{FF}}$ is monitored on the device where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\overline{\mathrm{R}}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## DATA FLOW-THROUGH MODES

Two types of flow-through modes are permitted: a read flow-through and write flow-through mode. For the read flow-through mode (Figure 17), the FIFO permits the reading of a single word after writing one word of data into an empty FIFO. The data is enabled on the bus in ( $\mathrm{tWEF}+\mathrm{t}_{\mathrm{A}}$ ) ns after the rising edge of $\bar{W}$, called the first write edge, and it remains on the bus until the $\overline{\mathrm{R}}$ line is raised from low-to-high, after which the bus would go into a three-state mode after trhz ns. The EF line would have a pulse showing temporary de-assertion and then would be asserted. In the interval of time that $\overline{\mathrm{R}}$ is low, more words can be written to the FIFO (the subsequent writes after the first write edge will be de-assert the Empty Flag); however, the same word (written on the first write edge) presented to the output bus as the read pointer, would not be incremented when $\overline{\mathrm{R}}$ was low. On toggling $\overline{\mathrm{R}}$, the other words that are written to the FIFO will appear on the output bus as in the read cycle timings.

In the write flow-through mode (Figure 18), the FIFO permits the writing of a single word of data immediately after reading one word of data from a full FIFO. The $\overline{\mathrm{R}}$ line causes the $\overline{F F}$ to be de-asserted but the $\bar{W}$ line, being low, causes it to be asserted again in anticipation of a new data word. Onthe rising edge of $\bar{W}$, the new word is loaded in the FIFO. The $\bar{W}$ line must be toggled when $\overline{\mathrm{FF}}$ is not asserted to write new data in the FIFO and to increment the write pointer.

For additional information refer to Tech Note 8: "Operating FIFOs on Full and Empty Boundary Conditions" and Tech Note 6: "Designing with FIFOs".

TABLE -RESET AND RETRANSMIT
Single Device Configuration/Width Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS | $\overline{\text { RT }}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | EF | $\overline{\text { FF }}$ | $\overline{\mathrm{HF}}$ |
| Reset | 0 | X | 0 | Location Zero | Location Zero | 0 | 1 | 1 |
| Retransmit | 1 | 0 | 0 | Location Zero | Unchanged | X | X | X |
| Read/Write | 1 | 1 | 0 | Increment ${ }^{(1)}$ | Increment ${ }^{(1)}$ | X | X | X |

NOTE:
2679 tbl 09

1. Pointer will increment if flag is High.

## TABLE II—RESET AND FIRST LOAD TRUTH TABLE

Depth Expansion/Compound Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { RS }}$ | $\overline{\mathrm{FL}}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | $\overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ |
| Reset First Device | 0 | 0 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Reset All Other Devices | 0 | 1 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | $(1)$ | X | X | X | X |

NOTE:
2679 tol 10

1. $\overline{X I}$ is connected to $\overline{X O}$ of previous device. See Figure 15. $\overline{\mathrm{RS}}=$ Reset Input $\overline{\overline{X I}} \overline{R T}=$ First Load/Retransmit, $\overline{E F}=$ Empty Flag Output, $\overline{F F}=$ Flag Full Output, $\overline{X I}=$ Expansion Input, $\overline{\mathrm{HF}}=$ Hall-Full Flag Output


FIgure 14. Block Dlagram of $1538 \times 9$ FIFO Memory (Depth Expansion)


Figure 15. Compound FIFO Expansion

NOTES:

1. For depth expsansion block see section on Depth Expansion and Figure 14.
2. For Flag detection see section on Width Expansion and Figure 13.


Flgure 16. Bldirectlonal FIFO Mode


Flgure 17. Read Data Flow-Through Mode


Figure 18. Write Data Flow-Through Mode

## ORDERING INFORMATION



[^2]
## $1024 \times 9$-BIT

## FEATURES:

- First-In/First-Out dual-port memory
- $1024 \times 9$ organization
- Low power consumption
- Active: 770 mW (Max.)
- Power-down: 27.5mW(Max.)
- Ultra high-speed: 15 ns access time
- Asynchronous and simultaneous read and write
- Fully expandable by both work depth and/or bit width
- Pin and functionality compatible with 720X family
- Status Flags: Empty, Haff-Full, Full
- Auto retransmit capability
- High-performance CEMOS ${ }^{\text {TM }}$ technology
- Military product compliant to MIL-STD-883, Class B
- Standard Military Drawing \#5962-89536 is listed on this function

FUNCTIONAL BLOCK DIAGRAM


2678 drw 02

## DESCRIPTION:

The IDT7202A is a dual-port memory that loads and empties data on a first-in/first-out basis. The device uses Full and Empty flags to prevent data overilow and underibw and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the device through the use of the Write $(\bar{W})$ and Read ( $\overline{\mathrm{R}})$ pins. The device has a read/write cycle time of $25 \mathrm{~ns}(40 \mathrm{MHz})$.

The device utilizes a 9 -bit wide data array to allow for control and parity bits at the user's option. It also features a Retransmit ( $\overline{\mathrm{RT}}$ ) capability that allows for reset of the read pointer to its initial position when RT is pulsed low to allow for retransmission from the beginning of data. A Half-Full Flag is available in the single device mode and width expansion modes.

The IDT7202A is fabricatedusing IDT's high-speedCEMOS technology. It is designed for those applications requiring asynchronous and simultaneous read/writes in multiprocessing and rate buffer applications. The $1024 \times 9$ organization of the IDT7202A allows a 1024 deep word structure without the need for expansion.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## PIN CONFIGURATIONS

## CONSULT FACTORY FOR CERPACK PINOUT

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Mil. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBiAs | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| Tsta | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| OUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolute maximumrating conditions for extended periods may affect reliabilty.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Paramoter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vccc | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccm | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{VIH}^{(1)}$ | Input High Votage <br> Commercial | 2.0 | - | - | V |
| $\mathrm{VIH}^{(1)}$ | Input High Votage <br> Military | 2.2 | - | - | V |
| $\mathrm{V}_{\mathrm{IL}}{ }^{(2)}$ | Input Low Voltage | - | - | 0.8 | V |

## NOTE:

2678 か ©

1. $\mathrm{V} \mathrm{V}=2.6 \mathrm{~V}$ for XI input (commercial).
$\mathrm{V}_{\mathrm{IH}}=2.8 \mathrm{~V}$ for $\bar{X}$ input (military).
2. 1.5V undershoots are allowed for 10 ns one per cycle.

DC ELECTRICAL CHARACTERISTICS
(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%$, $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7202LA Commercial tA $=15,20 \mathrm{~ns}$ |  |  | IDT7202LA Military $\mathrm{tA}=20 \mathrm{~ns}$ |  |  | IDT7202SALA Commerclal tA $=25,35 \mathrm{~ns}$ |  |  | $\begin{gathered} \text { IDT7202SA/LA } \\ \text { Military } \\ \mathbf{u}=30,40 \mathrm{~ns} \\ \hline \end{gathered}$ |  |  | $\begin{aligned} & \text { IDT7202SALA } \\ & \text { Commerclal } \\ & u=50,65,80 \mathrm{~ns} \\ & \hline \end{aligned}$ |  |  | $\begin{gathered} \text { IDT7202SALA } \\ \text { MIIItary } \\ \mathbf{u}=50,65,80,120 \end{gathered}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. | Min. | Typ. | Max. | MIn. | Typ. | Max. | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| ILI' ${ }^{\text {IT }}$ | Input Leakage <br> Current <br> (Any Input) | -1 | - | 1 | -10 | - | 10 | -1 | - | 1 | -10 | - | 10 | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| 120 ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| Vor | Output Logic "1" Voltage $1 \mathrm{OH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | V |
| VoL | Output Logic " 0 " Voltage $\mathrm{IOH}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | V |
| $\operatorname{lcct}^{(3)}$ | Active Power Supply Current | - | - | $140^{(4)}$ | - | - | $160^{(4)}$ | - | - | $125{ }^{(4)}$ | - | - | $140^{(4)}$ | - | 50 | 80 | - | 70 | 100 | mA |
| $1 \mathrm{Cc} 2^{(3)}$ | Average Standby Current ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=$ $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}=\mathrm{V}(\mathrm{H})$ | - | - | 19 | - | - | 20 | - | - | 15 | - | - | 20 | - | 5 | 8 | - | 8 | 15 | mA |
| lccs $(\mathrm{L})^{(3)}$ | Power Down Current (All Input $=$ Vcc-0.2V) | - | - | 5 | - | - | 9 | - | - | 0.5 | - | - | 0.9 | - | - | 0.5 | - | - | 0.9 | mA |
| ICC3(S) ${ }^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) |  |  |  |  |  |  | - | - | 5 | - | - | 9 | - | - | 5 | - | - | 9 | mA |

## NOTES:

1. Measurements with $0.4 \leq \operatorname{ViN} \leq \operatorname{Vcc}$.
2. $\overline{\mathrm{R}} \geq \mathrm{VIH}_{\mathrm{H}}, 0.4 \leq$ Vout $\leq \mathrm{Vcc}$.
3. Icc measurements are made with outputs open.
4. Tested at $\mathfrak{f}=20 \mathrm{MHz}$.

## AC ELECTRICAL CHARACTERISTICS

（Commercial： $\mathrm{Vcc}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ；Military： $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | Com＇l． |  | Com＇l $\&$ MII． |  | Com＇1 |  | Mil． |  | Com＇I |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7202SALLA15 |  | 7202SA／LA20 |  | 7202SA／LA25 |  | 7202SALLA30 |  | 7202SALLA35 |  |  |
|  |  | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． |  |
| ts | Shitt Frequency | － | 40 | － | 33.3 | － | 28.5 | － | 25 | － | 22.2 | MHz |
| tRC | Read Cycle Time | 25 | － | 30 | － | 35 | － | 40 | － | 45 | － | ns |
| tA | Access Time | － | 15 | $\rightarrow$ | 20 | － | 25 | － | 30 | － | 35 | ns |
| trR | Read Recovery Time | 10 | － | $16{ }^{10}$ | － | 10 | － | 10 | － | 10 | － | ns |
| tRPW | Read Pulse Width ${ }^{(2)}$ | 15 | － | 20 \％ | － | 25 | － | 30 | － | 35 | － | ns |
| tRLZ | Read Pulse Low to Data Bus at Low $\mathbf{Z}^{(3)}$ | 5 | － | 5 | Kinn | 5 | － | 5 | － | 5 | － | ns |
| twiz | Write Pulse High to Data Bus at Low $Z^{(3,4)}$ | 5 | － | \％\％ | － | 5 | － | 5 | － | 10 | － | ns |
| tov | Data Valid from Read Pulse High | 5 | － | （\％） 5 | \％ | 5 | － | 5 | － | 5 | － | ns |
| trizz | Read Pulse High to Data Bus at High $\mathbf{Z}^{(3)}$ | － | 15 |  | §in | － | 18 | － | 20 | － | 20 | ns |
| twc | Write Cycle Time | 25 | － | 34\％ | － | 35 | － | 40 | － | 45 | － | ns |
| WWPW | Write Pulse Width ${ }^{(2)}$ | 15 | － |  | － | 25 | － | 30 | － | 35 | － | ns |
| twh | Write Recovery Time | 10 | － | 10 ${ }^{\text {\％}}$ | － | 10 | － | 10 | － | 10 | － | ns |
| DS | Data Set－up Time | 11 | － | 12． | － | 15 | － | 18 | － | 18 | － | ns |
| T0， | Data Hold Time | 0 | － | 0 | － | 0 | － | 0 | － | 0 | － | ns |
| trsc | Reset Cycle Time | 25 | － | $30^{\circ}$ | － | 35 | － | 40 | － | 45 | － | ns |
| ths | Reset Pulse Widt ${ }^{(2)}$ | 15 | 一＊ | 20\％＊ | － | 25 | － | 30 | － | 35 | － | ns |
| trss | Reset Set－up Time ${ }^{(3)}$ | 15 | 一＊ | \％ 20 ＂ | － | 25 | － | 30 | － | 35 | － | ns |
| trsR | Reset Recovery Time | 10 | － | ＂粦縎 | － | 10 | － | 10 | － | 10 | － | ns |
| tric | Retransmit Cycle Time | 25 | $\stackrel{\text { \％}}{ }$ | $30 \%$ | － | 35 | － | 40 | － | 45 | － | ns |
| trt | Retransmit Pulse Width ${ }^{(2)}$ | 15 | －\＄2． | 20 | － | 25 | － | 30 | － | 35 | － | ns |
| tris | Retransmit Set－up Time ${ }^{(3)}$ | 15 | \％\＃\＃， | \％${ }^{2}$ | － | 25 | － | 30 | － | 35 | － | ns |
| tRTR | Retransmit Recovery Time | 10 |  | $\begin{aligned} & \text { IG } \\ & \text { IN } \\ & \hline \end{aligned}$ | － | 10 | － | 10 | － | 10 | － | ns |
| tefl | Reset to Empty Flag Low | － |  | $\stackrel{-}{+}$ | 30 | － | 35 | － | 40 | － | 45 | ns |
| OHFH，FFL | Reset to Half－Full and Full Flag High | － | 25 ＊＊ | Kis | 30 | － | 35 | － | 40 | － | 45 | ns |
| tref | Read Low to Empty Flag Low | － | $15$ | 䔍 ${ }^{-}$ | 20 | － | 25 | － | 30 | － | 30 | ns |
| tRFF | Read High to Full Flag High | － |  |  | 20 | － | 25 | － | 30 | － | 30 | ns |
| tRPE | $\begin{aligned} & \text { Read Pulse Width } \\ & \text { after EF High } \end{aligned}$ | 15 \％ |  | ${ }^{20}$ | － | 25 | － | 30 | － | 35 | － | ns |
| twEF | $\begin{aligned} & \hline \text { Write High to } \\ & \text { Empty Flag High } \\ & \hline \end{aligned}$ |  |  | － | 20 | － | 25 | － | 30 | － | 30 | ns |
| twFF | Write Low to Empty Flag Low |  |  | － | 20 | － | 25 | － | 30 | － | 30 | ns |
| twhF | Write Low to Half－Full Flag Low |  |  | － | 30 | － | 35 | － | 40 | － | 45 | ns |
| tRHF | Read High to Half－Full Flag High |  | 没 | － | 30 | － | 35 | － | 40 | － | 45 | ns |
| twpa | Write Pulse Width after FF High | 15 | § | 20 | － | 25 | － | 30 | － | 35 | － | ns |
| bxal | Read／Write to XO Low | － | \％ 5 | － | 20 | － | 25 | － | 30 | － | 35 | ns |
| bxor | Read／Write to XO High | － | 15 | － | 20 | － | 25 | － | 30 | － | 35 | ns |
| txi | XI Pulse Width ${ }^{(2)}$ | 15 | － | 20 | － | 25 | － | 30 | － | 35 | － | ns |
| txin | XI Recovery Time | 10 | － | 10 | － | 10 | － | 10 | － | 10 | － | ns |
| txis | $\overline{\text { XI Set－up Time }}$ | 10 | － | 10 | － | 10 | － | 10 | － | 10 | － | ns |

1．Timings referenced as in AC Test Conditions．
2．Pulse widths less than minimum value are not allowed

3．Values guaranteed by design，not currently tested．
4．Only applies to read data flow－through mode．

## AC ELECTRICAL CHARACTERISTICS (Continued)

(Commercial: Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter |  |  | Mlilitary and Commercial |  |  |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7202SA/LA40 |  | 7202SA/LA50 |  | 7202SA/LA65 |  | 7202SALLA80 |  | 7202SA/LA120 |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ts | Shift Frequency | - | 20 | - | 15 | - | - | - | 10 | - | 7 | MHz |
| trc | Read Cycle Time | 50 | - | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| ta | Access Time | - | 40 | - | 50 | - | - | - | 80 | - | 120 | ns |
| tRR | Read Recovery Time | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tRPW | Read Pulse Width ${ }^{(2)}$ | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| triz | Read Pulse Low to Data Bus at Low $\mathrm{Z}^{(3)}$ | 5 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| twLz | Write Pulse High to Data Bus at Low $\mathbf{Z}^{(3,4)}$ | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| \% 0 | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| trinz | Read Pulse High to Data Bus at High $\mathbf{Z}^{(3)}$ | - | 25 | - | 30 | - | - | - | 30 | - | 35 | ns |
| twc | Write Cycle Time | 50 | - | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| tWPW | Write Pulse Width ${ }^{(2)}$ | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| TWR | Write Recovery Time | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tos | Data Set-up Time | 20 | - | 30 | - | 30 | - | 40 | - | 40 | - | ns |
| tor | Data Hold Time | 0 | - | 5 | - | 10 | - | 10 | - | 10 | - | ns |
| thSC | Reset Cycle Time | 50 | - | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| trs | Reset Pulse Width ${ }^{(2)}$ | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tass | Reset Set-up Time ${ }^{(3)}$ | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| trSR | Reset Recovery Time | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tric | Retransmit Cycle Time | 50 | - | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| trit | Retransmit Pulse Width ${ }^{(2)}$ | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tris | Retransmit Set-up Time ${ }^{(3)}$ | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tata | Retransmit Recovery Time | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tEFL | Reset to Empty Flag Low | - | 50 | - | 65 | - | - | - | 100 | - | 140 | ns |
| tHFH,FFL | Reset to Half-Full and Full Flag High | - | 50 | - | 65 | - | - | - | 100 | - | 140 | ns |
| tref | Read Low to Empty Flag Low | - | 30 | - | 45 | - | - | - | 60 | - | 60 | ns |
| tifF | Read High to Full Flag High | - | 35 | - | 45 | - | - | - | 60 | - | 60 | ns |
| tRPE | Read Pulse Width after EF High | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| twer | Write High to Empty Flag High | - | 35 | - | 45 | - | - | - | 60 | - | 60 | ns |
| twFF | Write Low to Empty Flag Low | - | 35 | - | 45 | - | - | - | 60 | - | 60 | ns |
| twhF | Write Low to Half-Full Flag Low | - | 50 | - | 65 | - | - | - | 100 | - | 140 | ns |
| trif | Read High to Halt-Full Flag High | - | 50 | - | 65 | - | - | - | 100 | - | 140 | ns |
| twp | Write Pulse Width after FF High | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| 0xOL | Read/Write to XOL Low | - | 40 | - | 50 | - | - | - | 80 | - | 120 | ns |
| ${ }^{\circ} \mathrm{OOH}$ | Read/Write to $\overline{\mathrm{XO}}$ High | - | 40 | - | 50 | - | - | - | 80 | - | 120 | ns |
| txi | $\overline{\text { XII Pulse Width }}{ }^{(2)}$ | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tx\| ${ }^{\text {a }}$ | $\overline{\text { XI Recovery Time }}$ | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| txis | $\overline{\mathrm{XI}}$ Set-up Time | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |

## NOTES:

1. Timings referenced as in AC Test Conditions.
2. Pulse widths less than minimum value are not allowed.
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |

2678 tbl 06
CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 8 | pF |
| CouT | Output Capacitance | VoUT $=0 \mathrm{~V}$ | 8 | pF |

NOTE:
2678 ا07 07

1. This parameter is sampled and not $100 \%$ testod.

## SIGNAL DESCRIPTIONS

## INPUTS:

DATA IN (Do-D8)
Data inputs for 9-bit wide data.

## CONTROLS:

## RESET ( $\overline{\mathrm{RS}}$ )

Reset is accomplished whenever the Reset ( $\overline{\mathrm{RS}})$ input is taken to a low state. During reset, both internal read and write pointers are set to the first location. A reset is required after power up before a write operation can take place. Both the Read Enable $(\bar{R})$ and Write Enable $(\bar{W})$ Inputs must be in the high state during the window shown in Figure 2, (l.e., triss before the rising edge of $\overline{\mathrm{RS}}$ ) and should not change untll trse after the rising edge of $\overline{R S}$. Half-Full Flag ( $\overline{\mathrm{HF}})$ will be reset to high after Reset ( $\overline{\mathrm{RS}}$ ).

## WRITE ENABLE (W)

A write cycle is initiated on the falling edge of this input if the Full Flag ( $\overline{\mathrm{FF}}$ ) is not set. Data set-up and hold times must be adhered to with respect to the rising edge of the Write Enable $(\bar{W})$. Data is stored in the RAM array sequentially and independently of any on-going read operation.

After half of the memory is filled and at the falling edge of the next write operation, the Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be set to low and will remain set until the difference between the write pointer and read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag ( $\overline{\mathrm{HF}})$ is then reset by the rising edge of the read operation.

To prevent data overflow, the Full Flag ( $\overline{F F}$ ) will go low, inhibiting further write operations. Upon the completion of a valid read operation, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go high after tRFF, allowing a valid write to begin. When the FIFO is full, the internal write pointer is blocked from $\bar{W}$, so external changes in $\bar{W}$ will not affect the FIFO when it is full.

or equivalent circuit
Figure 1. Output Load
Includes lig and scope capacitances.

## READ ENABLE ( $\overline{\mathrm{R}}$ )

A read cycle is initiated on the falling edge of the Read Enable ( $\overline{\mathrm{R}}$ ) provided the Empty Flag ( $\overline{\mathrm{EF}}$ ) is not set. The data is accessed on a First-In/First-Out basis, independent of any ongoing write operations. After Read Enable ( $\overline{\mathrm{R}}$ ) goes high, the Data Outputs ( $\mathrm{Q} 0-\mathrm{Q} 8$ ) will return to a high impedance condition until the next Read operation. When all data has been read from the FIFO, the Empty Flag ( $\overline{\mathrm{FF}}$ ) will go low, allowing the "final" read cycle by inhibiting further read operations with the data outputs remaining in a high impedance state. Once a valid write operation has been accomplished, the Empty Flag (EF) will go high after tWEF and a valid Read can then begin. When the FIFO is empty, the internal read pointer is blocked from $\overline{\mathrm{R}}$ so external changes in $\overline{\mathrm{R}}$ will not affect the FIFO when it is empty.

## FIRST LOAD/RETRANSMIT ( $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ )

This is a dual-purpose input. In the Depth Expansion Mode, this pin is grounded to indicate that it is the first loaded (see Operating Modes). In the Single Device Mode, this pin acts as the restransmit input. The Single Device Mode is initiated by grounding the Expansion $\operatorname{In}(\overline{\mathrm{XI}})$.

The IDT7202A can be made to retransmit data when the Retransmit Enable Control ( $\overline{\mathrm{RT}}$ ) input is pulsed low. A retransmit operation will set the internal read pointer to the first location and will not affect the write pointer. Read Enable ( $\overline{\mathrm{R}})$ and Write Enable $(\bar{W})$ must be in the high state during retransmit. This feature is useful when less than 1024 writes are performed between resets. The retransmit feature is not compatible with the Depth Expansion Mode and will affect the Half-Full Flag ( $\overline{\mathrm{HF}}$ ), depending on the relative locations of the read and write pointers.

## EXPANSION IN (可)

This input is a dual-purpose pin. Expansion In $\overline{\mathrm{XII}}$ ) is grounded to indicate an operation in the single device mode. Expansion $\ln (\overline{\mathrm{XII}})$ is connected to Expansion Out ( $\overline{\mathrm{XO}})$ of the previous device inthe Depth Expansion or Daisy Chain Mode.

## OUTPUTS:

## FULL FLAG ( $\overline{F F}$ )

The Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operation, when the write pointer is one location less than the read pointer, indicating that the device is full. If the read pointer is not moved after Reset ( $\overline{\mathrm{RS}}$ ), the Full-Flag ( $\overline{\mathrm{FF}}$ ) will go low after 1024 writes.

## EMPTY FLAG ( $\overline{\mathrm{EF}}$ )

The Empty Flag ( $\overline{\mathrm{EF}}$ ) will go low, inhibiting further read operations, when the read pointer is equal to the write pointer, indicating that the device is empty.

## EXPANSION OUT/HALF-FULL FLAG ( $\overline{\mathrm{XO}} / \overline{\mathrm{HF}}$ )

This is a dual-purpose output. In the single device mode, when Expansion in ( $\overline{\mathrm{XI}})$ is grounded, this output acts as an indication of a half-full memory.

After half of the memory is filled and at the falling edge of the next write operation, the Hali-Full Flag ( $\overline{\mathrm{HF}}$ ) will be set low and will remain set until the difference between the write pointer and read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag ( $\overline{\mathrm{HF})}$ is then reset by using rising edge of the read operation.

In the Depth Expansion Mode, Expansion In ( $\overline{\mathrm{XI}})$ is connected to Expansion Put ( $\overline{\mathrm{XO}}$ ) of the previous device. This output acts as a signal to the next device in the Daisy Chain by providing a pulse to the next device when the previous device reaches the last location of memory.

Data outputs for 9 -bit wide data. This data is in a high impedance condition whenever Read $(\overline{\mathrm{R}})$ is in a high state.


NOTE:

1. $\overline{\mathrm{EF}}, \overline{\mathrm{FF}}$ and $\overline{\mathrm{HF}}$ may change status during Reset, but flags will be valid at tRsc.
2. $\bar{W}$ and $\bar{R}=$ VIH around the rising edge of $\overline{R S}$.

Figure 2. Reset


Figure 3. Asynchronous Write and Read Operation


Figure 4. Full Flag From Last Write to First Read


Figure 5. Empty Flag From Last Read to First Write


## NOTE:

1. $\overline{\mathrm{EF}}, \overline{\mathrm{FF}}$ and $\overline{\mathrm{FF}}$ may change status during Retransmit, but flags will be valid at tRTC.

Figure 6. Retransmit


Figure 7. Empty Flag Timing
2678 dnw 09


Figure 8. Full Flag Tlming


Figure 9. Half-Full Flag Tlming


Figure 10. Expansion Out


Figure 11. Expansion In

## OPERATING MODES

## SINGLE DEVICE MODE

A single IDT7202A may be used when the application requirements for 1024 words or less. The IDT7202A is in a Single Device Configuration when the Expansion In (可)
control input is grounded (see Figure 12). In the mode the Half-Full Flag $(\overline{\mathrm{HF}})$, which is an active low output, is shared with Expansion Out ( $\overline{\mathrm{XO}}$ ).


Figure 12. Block Diagram of Single $1024 \times 9$ FIFO

## WIDTH EXPANSION MODE

Word width may be increased simply by connecting the corresponding input control of multiple devices. Status flags ( $\overline{E F}, \overline{F F}$ and $\overline{H F}$ ) can be detected from any one device.

Figure 13 demonstrates an 18 -bit word width by using two IDT7202As. Any word width can be attained by adding additional IDT7202As.


NOTE:

1. Flag detection is accomplished by monitoring the $\overline{F F}, \overline{E F}$ and the $\overline{\mathrm{HF}}$ signals on either (any) device used in the width expansion configuration. Do not connect any output control signals together.

Figure 13. Block Dlagram of $1024 \times 18$ FIFO Memory Used In Wldth Expansion Mode

## DEPTH EXPANSION (DAISY CHAIN) MODE

The IDT7202A can easily be adapted to applications where the requirements are for greater than 1024 words. Figure 14 demonstrates Depth Expansion using three IDT7202As. Any depth can be attained by adding additional IDT7202As. The IDT7202As operate in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designed by grounding the First Load (FL) control input.
2. All other devices must have $\overline{\mathrm{FL}}$ in the high state.
3. The Expansion Out ( $\overline{X O}$ ) pin of each device must be tied to the Expansion In ( $\overline{\mathrm{XI}})$ pin of the next device. See Figure 14.
4. External logic is needed to generate a composite Full Flag ( $\overline{\mathrm{FF}}$ ) and Empty Flag ( $\overline{\mathrm{EF}}$ ). This requires the ORing of all $\overline{E F}$ s and ORing of all $\overline{F F}$ s (i.e. all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{\mathrm{EF}}$ ). See Figure 14.
5. The Retransmit ( $\overline{\mathrm{RT}}$ ) function and Half-Full Flag $(\overline{\mathrm{HF}})$ are not available in the Depth Expansion Mode.
For additional information refer to Tech Note 9: "Cascading FIFOs or FIFO Modules".

## COMPOUND EXPANSION MODE

The two expansion techinques described above can be applied together in a straightforward manner to achieve large FIFO arrays (see Figure 15).

## BIDIRECTIONAL MODE

Applications which require data buffering between two systems (each system capable of Read and Write operations) can be achieved by pairing IDT7202As as shown in Figure 16. Care must be taken to assure that the appropriate flag is monitored by each system (i.e., $\overline{F F}$ is monitored on the device
where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\bar{R}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## DATA FLOW-THROUGH MODES

Two types of flow-through modes are permitted: a read flow-through and write flow-through mode. For the read flowthrough mode (Figure 17), the FIFO permits the reading of a single wors after writing one word of data into an empty FIFO. The data is enabled on the bus in ( $\mathrm{tWEF}+\mathrm{tA}$ ) ns after the rising edge of $\bar{W}$, called the first write edge, and it remains on the bus until the $\bar{R}$ line is raised from low-to-high, after which the bus would go into a three-state mode after trhz ns. The EF line would have a pulse showing temporary de-assertion and then would be asserted. In the interval of time that $\bar{R}$ is low, more words can be written to the FIFO (the subsequent writes after the first write edge will be de-assert the Empty Flag); however, the same word (written on the first write edge) presented to the output bus as the read pointer, would not be incremented when $\bar{R}$ was low. On toggling $\bar{R}$, the other words that are written to the FIFO will appear on the output bus as in the read cycle timings.

In the write flow-through mode (Figure 18), the FIFO permits the writing of a single word of data immediately after reading one word of data from a full FIFO. The $\overline{\mathrm{R}}$ line causes the $\overline{F F}$ to be de-asserted but the $\bar{W}$ line, being low, causes it to be asserted again in anticipation of a new data word. Onthe rising edge of $\bar{W}$, the new word is loaded in the FIFO. The $\bar{W}$ line must be toggled when $\overline{F F}$ is not asserted to write new data in the FIFO and to increment the write pointer.

For additional information refer to Tech Note 8: "Operating FIFOs on Full and Empty Boundary Conditions" and Tech Note 6: "Designing with FIFOs".

TABLE -RESET AND RETRANSMIT
Single Device Configuration/Width Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{RS}}$ | $\overline{\mathrm{RT}}$ | $\overline{\text { XI }}$ | Read Pointer | Write Pointer | $\overline{E F}$ | $\overline{\text { FF }}$ | $\overline{\mathrm{HF}}$ |
| Reset | 0 | X | 0 | Location Zero | Location Zero | 0 | 1 | 1 |
| Retransmit | 1 | 0 | 0 | Location Zero | Unchanged | X | X | X |
| Read/Write | 1 | 1 | 0 | Increment ${ }^{1}$ | Increment ${ }^{1}$ | X | X | X |

NOTE:

1. Pointer will increment if flag is High.

## TABLE II-RESET AND FIRST LOAD TRUTH TABLE

Depth Expansion/Compound Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :--- | :--- | :---: | :---: |
|  | $\overline{\mathbf{R S}}$ | $\overline{\mathbf{R T}}$ | $\overline{\mathbf{X I}}$ | Read PoInter | Write Polnter | $\overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ |
| Reset First Device | 0 | 0 | ${ }^{(1)}$ | Location Zero | Location Zero | 0 | 1 |
| Reset All Other Devices | 0 | 1 | (1) | Location Zero | Location Zero | 0 | 1 |
| Read Write | 1 | X | (1) | X | X | X | X |

## NOTE:

1. $\overline{X I}$ is connected to $\overline{X O}$ of previous device. See Figure 14. $\overline{\mathrm{RS}}=$ Reset Input $\bar{F} \overline{\mathrm{RI}}=$ First Load/Retransmit, $\overline{E F}=$ Empty Flag Output, $\overline{F F}=$ Flag Full Output, $\overline{X I}=$ Expansion Input, $\overline{\mathrm{XF}}=$ Half-Full Flag Output


2678 Drw 18
Figure 14. Block Diagram of $3072 \times 9$ FIFO Memory (Depth Expansion)


NOTE:
2678 dw 17

1. For depth expansion block see section on Depth Expansion and Figure 14.
2. For Flag detection see section on Width Expansion and Figure 13.

Figure 15. Compound FIFO Expansion


FIgure 16. Bldirectional FIFO Mode
2678 drw 18


Figure 17. Read Data Flow-Through Mode
2678 drw 19


Figure 18. Write Data Flow-Through Mode

## ORDERING INFORMATION

IDT


Blank
B
Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
Military ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )
Compliant to MIL-STD-883, Class B


Plastic DIP
Plastic THINDIP
CERDIP
Sidebraze THINDIP
Plastic Leaded Chip Carrier
Leadless Chip Carrier
SOJ
SOIC
Cerpack

| 15 |
| :--- |
| 20 |
| 25 |
| 30 |
| 35 |
| 40 |
| 50 |
| 65 |
| 80 |
| 120 |

$\begin{aligned} & \text { Commercial Only } \\ & \begin{array}{l}\text { Commercial Only } \\ \text { Military Only } \\ \text { Commercial Only } \\ \text { Military Only }\end{array} \\ & \\ & \text { (Access Time (tA) } \\ & \text { Speed in Nanoseconds }\end{aligned}$
$\begin{aligned} & \text { Standard Power } \\ & \text { Low Power }\end{aligned}$

7202
$1024 \times 9$-Bit FIFO


Integrated Device Technology, Inc.

## IDT7203S/L IDT7204S/L

## FEATURES:

- First-In/First-Out dual-port memory
- $2048 \times 9$ organization (IDT7203)
- $4096 \times 9$ organization (IDT7204)
- Ultra high-speed: 15 ns access time
- Low power consumption
- Active: 880 mW (max.)
- Power-down: 44mW (max.)
- Asynchronous and simultaneous read and write
- Fully expandable by both word depth and/or bit width
- Pin and functionally compatible with IDT720X family
- Status Flags: Empty, Half-Full, Full
- Auto retransmit capability
- High-performance CEMOS™ technology
- Military product compliant to MIL-STD-883, Class B
- Standard Military Drawing \#5962-88669, 5962-89567, and 5962-89568 are listed on this function.


## DESCRIPTION:

The IDT7203/7204 are dual-port memories that load and empty data on a first-in/first-out basis. The device uses Full and Empty flags to prevent data overilow and underflow and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the device through the use of the Write $(\bar{W})$ and Read $(\bar{R})$ pins. The device has a read/write cycle time of $25 \mathrm{~ns}(40 \mathrm{MHz})$.

The device utilizes a 9 -bit wide data array to allow for control and parity bits at the user's option. It also features a Retransmit ( $\overline{\mathrm{RT}}$ ) capability that allows for reset of the read pointer to its initial position when $\overline{\mathrm{RT}}$ is pulsed low. A Half-Full Flag is available in the single device and width expansion modes.

The IDT7203/7204 is fabricated using IDT's high-speed CEMOS technology. They are designed for those applications requiring asynchronous and simultaneous readwrites in multiprocessing and rate buffer applications.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATIONS



Consult Factory for CERPACK Pinout.

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2661 b 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.


PLCC/LCC TOP VIEW

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCcM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{VIH}^{(1)}$ | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| $\mathrm{VIH}^{(1)}$ | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL $^{(2 .)}$ | Input Low Voltage <br> Commercial and <br> Military | - | - | 0.8 | V |

NOTES:
2661 tb 02

1. $\mathrm{V} H \mathrm{H}=2.6 \mathrm{~V}$ for $\overline{\mathrm{XI}}$ input (commercial).
$\mathrm{V}: \mathrm{H}=2.8 \mathrm{~V}$ for $\overline{X I}$ input (military).
2. 1.5 V undershoots are allowed for 10 ns once per cycle.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $V C C=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7203, IDT7204 Commercial $t_{A}=15,20 \mathrm{~ns}$ |  |  | $\begin{gathered} \text { IDT7203, IDT7204 } \\ \text { Military } \\ \text { tA }=20 \mathrm{~ns} \\ \hline \end{gathered}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $1 \mathrm{LI}{ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| ILO ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, $1 \mathrm{IOH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage, $\mathrm{lOL}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| Icc, ${ }^{(3,4)}$ | Active Power Supply Current | - | - | 160 | - | - | 200 | mA |
| $1 \operatorname{lcc}^{(3)}$ | Average Standby Current, ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} \overline{\mathrm{RT}}=\mathrm{V} \mid \mathrm{H}$ ) | - | - | 14 | - | - | 19 | mA |
| Icce $(\mathrm{L})^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | - | 8 | - | - | 12 | mA |

NOTES:

1. Measurements with $0.4 \leq \operatorname{VIN} \leq \operatorname{Vcc}$
2. $\overline{\mathrm{R}} \geq \mathrm{VIH}, 0.4 \leq$ VouT $\leq \mathrm{Vcc}$.
3. Icc measurements are made with outputs open (only capacitive loading).
4. Tested at $\mathrm{f}=20 \mathrm{MHz}$

## DC ELECTRICAL CHARACTERISTICS (Continued)

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7203, IDT7204 Commercial$\begin{gathered} \mathrm{t}_{\mathrm{A}}=25,35,50,65 \\ 80,120 \mathrm{~ns} \end{gathered}$ |  |  | IDT7203, IDT7204 Military$\begin{gathered} t A=30,40,50,65 \\ 80,120 \mathrm{~ns} \end{gathered}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $1 \mathrm{LLI}{ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | -1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| ILO ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, $\mathrm{IOH}=2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| VOL | Output Logic "0" Voltage, $\mathrm{IOL}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| $\operatorname{lcc}^{(3,4)}$ | Active Power Supply Current | - | 75 | 120 | - | 100 | 150 | mA |
| $\mathrm{lcc}^{(3)}$ | Average Standby Current, ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} / \overline{\mathrm{RT}}=\mathrm{V} / \mathrm{H})$ | - | 8 | 12 | - | 12 | 25 | mA |
| $\operatorname{lcc3}(\mathrm{L})^{(3)}$ | Power Down Current (All Input $=\mathrm{Vcc}-0.2 \mathrm{~V}$ ) | - | - | 2 | - | - | 4 | mA |
| $\operatorname{lcc3}(\mathrm{S})^{(3)}$ | Power Down Current (All Input $=$ Vcc -0.2 V ) | - | - | 8 | - | - | 12 | mA |

NOTES:

1. Measurements with $0.4 \leq \operatorname{Vin} \leq \mathrm{Vcc}$
2. $\overline{\mathrm{R}} \geq \mathrm{VIH}, 0.4 \leq$ Vout $\leq \mathrm{Vcc}$.
3. Icc measurements are made with outputs open.
4. Tested at $\mathrm{f}=20 \mathrm{MHz}$.

## AC ELECTRICAL CHARACTERISTICS ${ }^{(1)}$

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commerclal |  | Com'l. \& MII. |  | Commerclal |  | Military |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7203/04L15 |  | 7203/04L20 |  | 7203/04L25 |  | 7203/04L30 |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| fs | Shift Frequency | - | 40 | - | 33.3 | - | 28.5 | 交 | 25 | MHz |
| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | 40. | - | ns |
| ta | Access Time | - | 15 | - | 20 | - | 25 | . | 30 | ns |
| tRR | Read Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tRPW | Read Pulse Width ${ }^{(2)}$ | 15 | - | 20 | - | 25 | - | 30 | - | ns |
| tRLZ | Read Low to Data Bus Low ${ }^{(3)}$ | 5 | - | 5 | - | 5 | \% | 5\% | - | ns |
| tWLZ | Write High to Data Bus Low $Z^{(3,4)}$ | 5 | - | 5 | - | 5 | \#. | 5 | - | ns |
| tDV | Data Valid from Read High | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tRHZ | Read High to Data Bus High Z ${ }^{(3)}$ | - | 15 | - | 15 | 二 | 18. | - | 20 | ns |
| twc | Write Cycle Time | 25 | - | 30 | - | 35 | $\stackrel{\square}{4}$ | 40 | - | ns |
| twPW | Write Pulse Width ${ }^{(2)}$ | 15 | - | 20 | - | 25 | $\cdots$ | 30 | - | ns |
| tWR | Write Recovery Time | 10 | - | 10 | - | 10 . | $\stackrel{\text { ¢ }}{4}$ | 10 | - | ns |
| tos | Data Set-up Time | 11 | - | 12 | - | 15. | - | 18 | - | ns |
| tor | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tRSC | Reset Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| trs | Reset Pulse Width ${ }^{(2)}$ | 15 | - | 20 | $\stackrel{3}{*}$ | 25. | - | 30 | - | ns |
| trss | Reset Set-up Time | 15 | - | 20 | $\rightarrow$ | 25 | - | 30 | - | ns |
| tRSR | Reset Recovery Time | 10 | - | 10 | . | 10 | - | 10 | - | ns |
| tRTC | Retransmit Cycle Time | 25 | - | 30 | $\cdots$ | 35 | - | 40 | - | ns |
| tRT | Retransmit Pulse Width ${ }^{(2)}$ | 15 | - | 20 | - | 25 | - | 30 | - | ns |
| tRTS | Retransmit Set-up Time | 15 | - | 20 | $\stackrel{4}{4}$ | 25 | - | 30 | - | ns |
| tRTR | Retransmit Recovery Time | 10 | - | 10 | $\cdots$ | 10 | - | 10 | - | ns |
| tEFL | Reset to Empty Flag Low | - | 25 | \%... | 380 | - | 35 | - | 40 | ns |
| tHFH, tFFH | Reset to $\overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$ High | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tref | Read Low to Empty Flag Low | - | 15 | $\stackrel{\square}{4}$ | 20 | - | 25 | - | 30 | ns |
| tRFF | Read High to Full Flag High | - | 18 | -- | 20 | - | 25 | - | 30 | ns |
| tRPE | Read Pulse Width after EF High | 15 | \% | 20\% | - | 25 | - | 30 | - | ns |
| tWEF | Write High to Empty Flag High | - | 18 | " | 20 | - | 25 | - | 30 | ns |
| tWFF | Write Low to Full Flag Low | - | 15. | - | 20 | - | 25 | - | 30 | ns |
| tWHF | Write Low to Half-Full Flag Low | - | . 25. | - | 30 | - | 35 | - | 40 | ns |
| tRHF | Read High to Half-Full Flag High | $\rightarrow$ | 25 | - | 30 | - | 35 | - | 40 | ns |
| tWPF | Write Pulse Width after $\overline{\text { FF }}$ High | 15. | - | 20 | - | 25 | - | 30 | - | ns |
| tXOL | Read/Write Low to XO Low | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| t $\times$ OH | Read Write High to XO High | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| txI | XI Pulse Width ${ }^{(2)}$ | 15 | - | 20 | - | 25 | - | 30 | - | ns |
| tx\|R | XI Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| txIS | XI Set-up Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |

1. Timings referenced as in AC Test Conditions.
2. Pulse widths less than minimum are not allowed.
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

AC ELECTRICAL CHARACTERISTICS ${ }^{(1)}$ (Continued)
(Commercial: $\mathrm{Vcc}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{Vcc}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Com'l. <br> 7203S/L35 <br> 7204S/L35 |  | $\begin{gathered} \hline \text { Military } \\ \hline 7203 \mathrm{~S} / \mathrm{L40} \\ 7204 \mathrm{~S} / \mathrm{L40} \end{gathered}$ |  | Commercial and Military |  |  |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{aligned} & 7203 \mathrm{~S} / L 50 \\ & 7204 \mathrm{~S} / \mathrm{L} 50 \end{aligned}$ | $\begin{aligned} & 7203 \mathrm{~S} / L 65 \\ & 7204 \mathrm{~S} / \mathrm{L} 65 \end{aligned}$ |  | $\begin{aligned} & 7203 S / L 80 \\ & 7204 S / L 80 \end{aligned}$ |  | $\begin{aligned} & 7203 \mathrm{~S} / \mathrm{L} 120 \\ & 7204 \mathrm{~S} / \mathrm{L} 120 \end{aligned}$ |  |  |
|  |  | Min. | Max. |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  | Min. | Max. |
| fs | Shift Frequency | - | 22.2 | - | 20 | - | 15 | - | 12.5 | - | 10 | - | 7 | MHz |
| tRC | Read Cycle Time | 45 | - | 50 | - | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| ta | Access Time | - | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | ns |
| tRR | Read Recovery Time | 10 | - | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tapw | Read Pulse Width ${ }^{(2)}$ | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| trLz | Read Low to Data Bus Low ${ }^{(3)}$ | 5 | - | 5 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| twL | Write High to Data Bus Low ${ }^{(3,4)}$ | 10 | - | 10 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tov | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| triz | Read High to Data Bus High ${ }^{(3)}$ | - | 20 | - | 25 | - | 30 | - | 30 | - | 30 | - | 35 | ns |
| twc | Write Cycle Time | 45 | - | 50 | - | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| twPW | Write Pulse Width ${ }^{(2)}$ | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| twr | Write Recovery Time | 10 | - | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tos | Data Set-up Time | 18 | - | 20 | - | 30 | - | 30 | - | 40 | - | 40 | - | ns |
| toh | Data Hold Time | 0 | - | 0 | - | 5 | - | 10 | - | 10 | - | 10 | - | ns |
| trsc | Reset Cycle Time | 45 | - | 50 | - | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| trs | Reset Pulse Width ${ }^{(2)}$ | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| trss | Reset Set-up Time | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| task | Reset Recovery Time | 10 | - | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tric | Retransmit Cycle Time | 45 | - | 50 | - | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| tat | Retransmit Pulse Width ${ }^{(2)}$ | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tris | Retransmit Set-up Time ${ }^{(3)}$ | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| trin | Retransmit Recovery Time | 10 | - | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tefl | Reset to Empty Flag Low | - | 45 | - | 50 | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| $\begin{aligned} & \text { thFH, } \\ & \text { tFFH } \end{aligned}$ | Reset to $\overline{\mathrm{FF}}$ and $\overline{\mathrm{FF}}$ High | - | 45 | - | 50 | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| tref | Read Low to Empty Flag Low | - | 30 | - | 35 | - | 45 | - | 60 | - | 60 | - | 60 | ns |
| taff | Read High to Full Flag High | - | 30 | - | 35 | - | 45 | - | 60 | - | 60 | - | 60 | ns |
| tRPE | Read Pulse Width atter EF High | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| twef | Write High to Empty Flag High | - | 30 | - | 35 | - | 45 | - | 60 | - | 60 | - | 60 | ns |
| twff | Write Low to Full Flag Low | - | 30 | - | 35 | - | 45 | - | 60 | - | 60 | - | 60 | ns |
| twhf | Write Low to Half-Full Flag Low | - | 45 | - | 50 | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| trif | Read High to Half-Full Flag High | - | 45 | - | 50 | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| twPF | Write Pulse Width after FF High | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| txol | Read/Write Low to XO Low | - | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | ns |
| tXOH | Read/Write High to XO High | - | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | ns |
| tx1 | XI Pulse Width ${ }^{(2)}$ | 35 | - | 40 | - | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| txir | XI Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| txis | Х $\overline{\text { Set-up Time }}$ | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | ns |

NOTES:

1. Timings referenced as in AC Test Conditions.
2. Pulse widths less than minimum are not allowed.
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHZ}\right.$ )

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 8 | pF |
| Coư( |  |  |  |  |
|  | Output <br> Capacitance | VoUT $=0 \mathrm{~V}$ | 12 | pF |

NOTES:
2661 tbl 09

1. This parameter is sampled and not $100 \%$ tested.
2. With output deselected.

## SIGNAL DESCRIPTIONS:

## Inputs:

DATA IN (Do-D8) - Data inputs for 9-bit wide data.

## Controls:

RESET ( $\overline{\mathrm{RS}}$ ) - Reset is accomplished whenever the Reset $(\overline{\mathrm{RS}})$ input is taken to a low state. During reset, both internal read and write pointers are set to the first location. A reset is required after power-up before a write operation can take place. Both the Read Enable ( $\overline{\mathrm{R}}$ ) and Write Enable ( $\overline{\mathrm{W}}$ ) Inputs must be in the high state during the window shown in Figure 2 (l.e. trSs before the rising edge of $\overline{R S}$ ) and should not change until tRSR after the rising edge of $\overline{\mathrm{RS}}$. Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be reset to high after master Reset ( $\overline{\mathrm{RS}}$ ).

WRITE ENABLE $(\bar{W})$ - A write cycle is initiated on the falling edge of this input if the Full Flag ( $\overline{\mathrm{FF}}$ ) is not set. Data set-up and hold times must be adhered to with respect to the rising edge of the Write Enable $(\bar{W})$. Data is stored in the RAM array sequentially and independently of any on-going read operation.

After half of the memory is filled, and at the falling edge of the next write operation, the Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be set to low and will remain set until the difference between the write pointer and read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag ( $\overline{\mathrm{FF}}$ ) is then reset by the rising edge of the read operation.

To prevent data overflow, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operations. Upon the completion of a valid read operation, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go high after tRFF, allowing a valid write to begin. When the FIFO is full, the internal write pointer is blocked from $\bar{W}$, so external changes in $\bar{W}$ will not affect the FIFO when it is full.

or equivalent circuit
Flgure 1. Output Load

* Includes jig and scope capacitances.

READ ENABLE $(\overline{\mathrm{R}})$ - A read cycle is initiated on the falling edge of the Read Enable ( $\overline{\mathrm{R}}$ ) provided the Empty Flag (EF) is not set. The data is accessed on a First-In/First-Out basis independent of any ongoing write operations. After Read Enable ( $\overline{\mathrm{R}}$ ) goes high, the Data Outputs (Oo through Q8) will return to a high impedance condition until the next Read operation. When all the data has been read from the FIFO, the Empty Flag ( $\overline{\mathrm{EF}}$ ) will go low, allowing the "tinal" read cycle but inhibiting further read operations, with the data outputs remaining in a high impedance state. Once a valid write operation has been accomplished, the Empty Flag ( $\overline{\mathrm{EF} \text { ) will go }}$ high after twef and a valid Read can then begin. When the FIFO is empty, the internal read pointer is blocked from $\overline{\mathrm{R}}$ so external changes will not affect the FIFO when it is empty.

FIRST LOAD/RETRANSMIT ( $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ ) - This is a dualpurpose input. In the Depth Expansion Mode, this pin is grounded to indicate that it is the first device loaded (see Operating Modes). In the Single Device Mode, this pin acts as the retransmit input. The Single Device Mode is initiated by grounding the Expansion $\ln (\overline{\mathrm{X}})$.

The IDT7203/7204 can be made to retransmit data when the Retransmit Enable Control ( $\overline{\mathrm{RT}}$ ) input is pulsed low. A retransmit operation will set the internal read pointer to the first location and will not affect the write pointer. Read Enable ( $\overline{\mathrm{R}})$ and Write Enable $(\overline{\mathrm{W}})$ must be in the high state during retransmit. This feature is useful when less than 2048/4096 writes are performed between resets. The retransmit feature is not compatible with the Depth Expansion Mode and will affect the status of the flags depending on the relative locations of the read and write pointers.

EXPANSION IN ( $\overline{\mathrm{XI}})$ - This input is a dual-purpose pin. Expansion $\ln (\overline{\mathrm{XI}})$ is grounded to indicate an operation in the Single Device Mode. Expansion In ( $\overline{\mathrm{XI}})$ is connected to Expansion Out ( $\overline{\mathrm{XO}}$ ) of the previous device in the Depth Expansion or Daisy Chain Mode.

## Outputs:

FULL FLAG ( $\overline{\mathrm{FF}}$ ) - The Full Flag ( $\overline{\mathrm{FF}) \text { will go low, }}$ inhibiting further write operations, when the write pointer is equal to the read pointer, indicating that the device is full. If the read pointer is not moved after Reset ( $\overline{\mathrm{RS}}$ ), the Full Flag (FF) will go low after 2048 writes for the IDT7203 and 4096 writes for the IDT7204.

EMPTY FLAG ( $\overline{E F}$ ) - The Empty Flag ( $\overline{\mathrm{EF}}$ ) will go low, inhibiting further read operations, when the read pointer is equal to the write pointer, indicating that the device is empty.

## Expansion Out/Half Full Flag ( $\overline{\mathrm{XO}} / \overline{\mathrm{HF}}$ )

This is a dual-purpose output. In the single device mode, when Expansion In $(\overline{\mathrm{XI}})$ is grounded, this output acts as an indication of a half-full memory.

After half of the memory is filled, and at the falling edge of the next write operation, the Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be set to
low and will remain set until the difference between the write pointer and read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag $(\overline{\mathrm{HF}})$ is then reset by the rising edge of the read operation.

In the Depth Expansion Mode, Expansion In $(\overline{\mathrm{XI}})$ is connected to Expansion Out ( $\overline{\mathrm{XO}}$ ) of the previous device. This output acts as a signal to the next device in the Daisy Chain by providing a pulse to the next device when the previous device reaches the last location of memory. There will be an XO pulse when the Write pointer reaches the last location of memory, and an additional $\overline{X O}$ pulse when the Read pointer reaches the last location of memory.

## Data Outputs (Q0-Q8)

Qo-Q8 are data outputs for 9-bit wide data. These outputs are in a high impedance condition whenever $\operatorname{Read}(\bar{R})$ is in a high state.


NOTES:

1. $\overline{E F}, \overline{F F}$ and $\overline{\mathrm{HF}}$ may change status during Reset, but flags will be valid at tRSO.
2. $\bar{W}$ and $\overline{\mathrm{R}}=\mathrm{VIH}$ around the rising edge of $\overline{\mathrm{RS}}$.

Figure 2. Reset


Figure 3. Asynchronous Write and Read Operation


Figure 4. Full Flag From Last Write to First Read


Figure 5. Empty Flag From Last Read to First Write


NOTE:

1. $\overline{E F}, \overline{F F}$ and $\overline{\mathrm{HF}}$ may change status during Retransmit, but flags will be valid at tRTC.

Figure 6. Retransmit


Figure 7. Empty Flag Timing


Figure 8. Full Flag Timing


Figure 9. Half-Full Flag Timing


Figure 10. Expansion Out


Figure 11. Expansion In

## OPERATING MODES:

## Single Device Mode

A single IDT7203/7204 may be used when the application requirements are for $2048 / 4096$ words or less. The IDT7203/7204 are in a Single Device Configuration when the Expansion $\ln (\overline{\mathrm{XI}})$ control input is grounded (see Figure 12).

## Width Expansion Mode

Word width may be increased simply by connecting the corresponding input control signals of multiple devices. Status flags ( $\overline{E F}, \overline{\mathrm{FF}}$ and $\overline{\mathrm{HF}}$ ) can be detected from any one device. Figure 13 demonstrates an 18 -bit word width by using two IDT7203/7204s. Any word width can be attained by adding additional IDT7203/7204s.

## Depth Expansion (Daisy Chain Mode)

The IDT7203/7204 can easily be adapted to applications when the requirements are for greater than 2048/4096 words. Figure 14 demonstrates Depth Expansion using three IDT7203/7204s. Any depth can be attained by adding additional IDT7203/7204s. The IDT7203/7204 operates in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the First Load (FL) control input.
2. All other devices must have $\overline{\mathrm{FL}}$ in the high state.
3. The Expansion Out ( $\overline{\mathrm{XO}}$ ) pin of each device must be tied to the Expansion $\operatorname{In}(\overline{\mathrm{XI}})$ pin of the next device. See Figure 14.
4. Externallogic is needed to generate a composite Full Flag ( $\overline{\mathrm{FF}}$ ) and Empty Flag ( $\overline{\mathrm{EF}}$ ). This requires the ORing of all $\overline{\mathrm{EF}}$ s and ORing of all $\overline{\mathrm{FFs}}$ (i.e. all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{\mathrm{EF}}$ ). See Figure 14.
5. The Retransmit ( $\overline{\mathrm{RT}}$ ) function and Half-Full Flag ( $\overline{\mathrm{HF}}$ ) are not available in the Depth Expansion Mode.

For additional information, refer to Tech Note 9: Cascading FIFOs or FIFO Modules.

## Compound Expansion Mode

The two expansion techniques described above can be applied together in a straightfonward manner to achieve large FIFO arrays (see Figure 15).

## Bidirectional Mode

Applications which require data buffering between two systems (each system capable of Read and Write operations) can be achieved by pairing IDT7203/7204s as shown in Figure 16. Care must be taken to assure that the appropriate flag is monitored by each system (i.e. $\overline{\mathrm{FF}}$ is monitored on the device where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\overline{\mathrm{R}}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## Data Flow-Through Modes

Two types of flow-through modes are permitted, a read flow-through and write flow-through mode. For the read flowthrough mode (Figure 17), the FIFO permits a reading of a single word after writing one word of data into an empty FIFO. The data is enabled on the bus in ( $\mathrm{tWEF}+\mathrm{tA}$ ) ns atter the rising edge of $\bar{W}$, called the first write edge, and it remains on the bus until the $\overline{\mathrm{R}}$ line is raised from low-to-high, after which the bus would go into a three-state mode after trhz ns. The $\overline{\mathrm{EF}}$ line would have a pulse showing temporary deassertion and then would be asserted. In the interval of time that $\overline{\mathrm{R}}$ was low, more words can be written to the FIFO (the subsequent writes after the first write edge will deassert the empty flag); however, the same word (written on the first write edge), presented to the output bus as the read pointer, would not be incremented when $\overline{\mathrm{R}}$ is low. Ontoggling $\overline{\mathrm{R}}$, the other words that were written to the FIFO will appear on the output bus as in the read cycle timings.

In the write flow-through mode (Figure 18), the FIFO permits the writing of a single word of data immediately after reading one word of data from a full FIFO. The $\overline{\mathrm{R}}$ line causes the $\overline{F F}$ to be deasserted but the $\bar{W}$ line being low causes it to be asserted again in anticipation of a new data word. On the rising edge of $\bar{W}$, the new word is loaded in the FIFO. The $\bar{W}$ line must be toggled when $\overline{F F}$ is not asserted to write new data in the FIFO and to increment the write pointer.

For additional information, refer to Tech Note 8: Operating FIFOs on Full and Empty Boundary Conditions and Tech Note 6: Designing with FIFOs.


Figure 12. Block Diagram of $2048 \times 9 / 4096 \times 9$ FIFO Used In Single Device Mode.


NOTE:
2661 drw 04

1. Flag detection is accomplished by monitoring the $\overline{\mathrm{FF}}, \overline{\mathrm{EF}}$ and $\overline{\mathrm{HF}}$ signals on either (any) device used in the width expansion configuration. Do not connect any output control signals together.

Figure 13. Block Diagram of $2048 \times 18 / 4096 \times 18$ FIFO Memory Used in Width Expansion Mode

## TRUTH TABLES

## TABLE I-RESET AND RETRANSMIT

SINGLE DEVICE CONFIGURATION/WIDTH EXPANSION MODE

| Mode |  | Inputs |  |  | Internal Status |  | Outputs |  |  |
| :--- | :---: | :---: | :---: | :---: | :--- | :---: | :---: | :---: | :---: |
|  |  | $\overline{R T}$ | $\overline{X I}$ | Read Pointer | Write Pointer | $\overline{E F}$ | $\overline{\mathrm{FF}}$ | HF |  |
| Reset | 0 | X | 0 | Location Zero | Location Zero | 0 | 1 | 1 |  |
| Retransmit | 1 | 0 | 0 | Location Zero | Unchanged | X | X | X |  |
| ReadWrite | 1 | 1 | 0 | Increment ${ }^{(1)}$ | Increment ${ }^{(1)}$ | X | X | X |  |

NOTE:

1. Pointer will Increment if flag is high.

TABLE II-RESET AND FIRST LOAD TRUTH TABLE
DEPTH EXPANSION/COMPOUND EXPANSION MODE

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{R S}$ | $\overline{R T}$ | $\overline{X I}$ | Read Pointer | Write Pointer | $\overline{E F}$ | $\overline{F F}$ |
| Reset First Device | 0 | 0 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Reset all Other Devices | 0 | 1 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| ReadWrite | 1 | X | $(1)$ | X | X | X | X |

NOTES:

1. $X$ is connected to $\overline{X O}$ of previous device. See Figure 12.
2. $\overline{\mathrm{RS}}=$ Reset Input, $\overline{\mathrm{FL}} \overline{\mathrm{RT}}=$ First Load/Retransmit, $\overline{\mathrm{EF}}=$ Empty Flag Output, $\overline{\mathrm{FF}}=$ Full Flag Output, $\overline{\mathrm{XI}}=$ Expansion Input, $\overline{\mathrm{KF}}=$ Half-Full Flag Output


Figure 14. Block Diagram of $6,144 \times 9 / 12,288 \times 9$ FIFO Memory (Depth Expansion)


2661 dww 16
NOTES:

1. For depth expansion block see section on Depth Expansion and Figure 14.
2. For Flag detection see section on Width Expansion and Figure 13.

Figure 15. Compound FIFO Expansion


Figure 16. Bidirectional FIFO Mode


2661 drw 18
Figure 17. Read Data Flow-Through Mode


Figure 18. Write Data Flow-Through Mode

## ORDERING INFORMATION



CMOS PARALLEL
IDT7205
FIRST-IN/FIRST-OUT FIFO
$8192 \times 9$-BIT

## FEATURES:

- First-In/First-Out dual-port memory
- $8192 \times 9$ organization
- Ulitra high-speed: 20ns access time
- Low power consumption
- Active: 770 mW (max.)
- Power-down: 27.5mW (max.)
- Asynchronous and simultaneous read and write
- Fully expandable by both word depth and/or bit width
- Pin and functionally compatible with IDT720X family
- Status Flag: Empty, Hali-Full, Full
- Auto retransmit capability
- High-performance CEMOS™ technology
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7205 is a dual-port memory that loads and empties data on a first-in/first-out basis. The device uses Full and Empty flags to prevent data overfiow and underflow and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the device through the use of the Write ( $\bar{W}$ ) and Read $(\bar{R})$ pins. The device has a read/write cycle time of 30 ns ( 33 MHz ).

The device utilizes a 9-bit wide data array to allow for control and parity bits at the user's option. It also features a Retransmit ( $\overline{\mathrm{RT}}$ ) capability that allows for reset of the read pointer to its initial position when $\overline{\mathrm{RT}}$ is pulsed low. A Half-Full Flag is available in the single device and width expansion modes.

The IDT7205 is fabricated using IDT's high-speed CEMOS technology. It is designed for those applications requiring asynchronous and simultaneous read/writes in multiprocessing and rate buffer applications.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATIONS



Consult Factory for CERPACK Pinout
ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal <br> Voltage with <br> Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Blas | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2662 tbl 04

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.


PLCC/LCC TOP VIEW

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unlt |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VccM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{~V}_{1 H^{(1)}}$ | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| $\mathrm{V}_{1 \mathrm{H}^{(1)}}$ | Input High Voltage <br> Military | 2.2 | - | - | V |
| $\mathrm{VIL}^{(2)}$ | Input Low Voltage <br> Commercial and <br> Military | - | - | 0.8 | V |

## NOTES:

2662 tbl 02

1. $\mathrm{VIH}=2.6 \mathrm{~V}$ for $\overline{X I}$ input (commercial).
$\mathrm{V}_{\mathrm{IH}}=2.8 \mathrm{~V}$ for $\overline{\mathrm{XI}}$ input (military).
2. 1.5 V undershoots are allowed for $10 n s$ once per cycle.

DC ELECTRICAL CHARACTERISTICS
(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

|  | Parameter | IDT7205LCommerclaltA $=20,25,35,50,80 \mathrm{~ns}$ |  |  | $\begin{gathered} \text { IDT7205L } \\ \text { Military } \\ \text { tA }=30,50,80 \mathrm{~ns} \end{gathered}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Mln. | Typ. | Max. | Min. | Typ. | Max. |  |
| Lis ${ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | 二 | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| Lo ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, $1 \mathrm{OH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| VoL | Output Logic " 0 " Voltage, $\mathrm{lOL}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| KCC1 ${ }^{(3,4)}$ | Active Power Supply Current | - | - | 140 | - | - | 180 | mA |
| lcce ${ }^{(3)}$ | Average Standby Current, ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} \overline{\mathrm{RT}}=\mathrm{VIH}$ ) | - | - | 15 | - | - | 20 | mA |
| icc3 ${ }^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | - | 8 | - | - | 12 | mA |

NOTES:
2662 tbl 03

1. Measurements with $0.4 \mathrm{~V} \leq \mathrm{ViN} \leq$ Vcc
2. $\overline{\mathrm{R}} \geq \mathrm{VIH}, 0.4 \leq$ VOUT $\leq$ VCC.
3. ICC measurements are made with outputs open (only capacitive loading).
4. Tested at $f=20 \mathrm{MHz}$.

## AC ELECTRICAL CHARACTERISTICS

（Commercial：Vcc $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ；Military： $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ）

| Symbol | Parameters | Commercial |  | Commerclal |  | Millitary |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7205L20 |  | 7205L25 |  | 7205L30 |  |  |
|  |  | Min． | Max． | Min． | Max． | Min． | Max． |  |
| fs | Shift Frequency | － | 33.3 | － | 28.5 | － | 25 | MHz |
| tRC | Read Cycle Time | 30 | \％ | 35 | － | 40 | － | ns |
| tA | Access Time | － | 20） | － | 25 | － | 30 | ns |
| tRR | Read Recovery Time | 10 | － | 10 | － | 10 | － | ns |
| tRPW | Read Pulse Width ${ }^{(2)}$ | 20 | － | 25 | － | 30 | － | ns |
| trLz | Read Low to Data Bus Low ${ }^{(3)}$ | 5 | \％ | 5 | － | 5 | － | ns |
| twLZ | Write High to Data Bus Low Z ${ }^{(3,4)}$ | 5 | － | 5 | － | 5 | － | ns |
| to | Data Valid from Read High | 5 | － | 5 | － | 5 | － | ns |
| triz | Read High to Data Bus High Z ${ }^{(3)}$ | － | \％15\％ | － | 18 | － | 20 | ns |
| twc | Write Cycle Time | 30 | ， | 35 | － | 40 | － | ns |
| tWPW | Write Pulse Width ${ }^{(2)}$ | 20 | － | 25 | － | 30 | － | ns |
| tWR | Write Recovery Time | 10 | \％ | 10 | － | 10 | － | ns |
| tos | Data Set－up Time | 12 | \％ | 15 | － | 18 | － | ns |
| DH | Data Hold Time | 0 | － | 0 | － | 0 | － | ns |
| tRSC | Reset Cycle Time | 30 | － | 35 | － | 40 | － | ns |
| tRS | Reset Pulse Width ${ }^{(2)}$ | 20 | $\stackrel{ }{*}$ | 25 | － | 30 | － | ns |
| tRSS | Reset Set－up Time ${ }^{(3)}$ | 20 | － | 25 | － | 30 | － | ns |
| tRSR | Reset Recovery Time | 10 | － | 10 | － | 10 | － | ns |
| tric | Retransmit Cycle Time | 30 | \％．${ }_{\text {\％}}$ | 35 | － | 40 | － | ns |
| tRT | Retransmit Pulse Width ${ }^{(2)}$ | 20 | － | 25 | － | 30 | － | ns |
| tris | Retransmit Set－up Time ${ }^{(3)}$ | 20 | － | 25 | － | 30 | － | ns |
| trin | Retransmit Recovery Time | 10 | － | 10 | － | 10 | － | ns |
| teFL | Reset to Empty Flag Low | － | 30 | － | 35 | － | 40 | ns |
| HFFH，tFFH | Reset to $\overline{\mathrm{HF}}$ and $\overline{\text { FF }}$ High | － | 30 | 一 | 35 | － | 40 | ns |
| tREF | Read Low to Empty Flag Low | － | \％ 20 | － | 25 | － | 30 | ns |
| tRFF | Read High to Full Flag High | － | 20 | － | 25 | － | 30 | ns |
| tRPE | Read Pulse Width after EFF High | 20 | － | 25 | － | 30 | － | ns |
| tWEF | Write High to Empty Flag High | 一 | ， 20 | － | 25 | － | 30 | ns |
| tWFF | Write Low to Full Flag Low | － | ， 20 | － | 25 | － | 30 | ns |
| tWHF | Write Low to Half－Full Flag Low | － | 30 | － | 35 | － | 40 | ns |
| tRHF | Read High to Half－Full Flag High | － | \％ 30 | － | 35 | － | 40 | ns |
| tWPF | Write Pulse Width after $\overline{\text { FF High }}$ | 20. | ※－ | 25 | － | 30 | － | ns |
| tXOL | Read／Write Low to $\overline{\mathrm{XO}}$ Low | － | 20 | － | 25 | － | 30 | ns |
| XXOH | Read／Write High to XO High | 二， | 20 | － | 25 | － | 30 | ns |
| txI | $\overline{\text { XI Pulse Width }}{ }^{(2)}$ | 20 | 二 | 25 | － | 30 | － | ns |
| tXIR | $\overline{\mathrm{XI}}$ Recovery Time | 10 | － | 10 | － | 10 | － | ns |
| tXIS | $\overline{\text { XI Set－up Time }}$ | 10 | － | 10 | － | 10 | － | ns |

## NOTES：

1．Timings referenced as in AC Test Conditions．
2．Pulse widths less than minimum are not allowed．
3．Values guaranteed by design，not currently tested．
4．Only applies to read data flow－through mode．

## AC ELECTRICAL CHARACTERISTICS (Continued)

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | Com | rclal | Commerclal and Military |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7205L35 |  | 7205L50 |  | 7205L80 |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| is | Shift Frequency | - | 22.2 | - | 15 | - | 10 | MHz |
| tre | Read Cycle Time | 45 | - | 65 | - | 100 | - | ns |
| ta | Access Time | - | 35 | - | 50 | - | 80 | ns |
| tRR | Read Recovery Time | 10 | - | 15 | - | 20 | - | ns |
| tRPW | Read Pulse Width ${ }^{(2)}$ | 35 | - | 50 | - | 80 | - | ns |
| triz | Read Low to Data Bus Low ${ }^{(3)}$ | 5 | - | 10 | - | 10 | - | ns |
| tWLZ | Write High to Data Bus Low Z ${ }^{(3,4)}$ | 10 | - | 15 | - | 20 | - | ns |
| tDV | Data Valid from Read High | 5 | - | 5 | - | 5 | - | ns |
| triz | Read High to Data Bus High Z ${ }^{(3)}$ | - | 20 | - | 30 | - | 30 | ns |
| twc | Write Cycle Time | 45 | - | 65 | - | 100 | - | ns |
| tWPW | Write Pulse Width ${ }^{(2)}$ | 35 | - | 50 | - | 80 | - | ns |
| twr | Write Recovery Time | 10 | - | 15 | - | 20 | - | ns |
| tos | Data Set-up Time | 18 | - | 30 | - | 40 | - | ns |
| tD H | Data Hold Time | 0 | - | 5 | - | 10 | - | ns |
| trsc | Reset Cycle Time | 45 | - | 65 | - | 100 | - | ns |
| tRS | Reset Pulse Width ${ }^{(2)}$ | 35 | - | 50 | - | 80 | - | ns |
| tRSS | Reset Set-up Time ${ }^{(3)}$ | 35 | - | 50 | - | 80 | - | ns |
| trsR | Reset Recovery Time | 10 | - | 15 | - | 20 | - | ns |
| tRTC | Retransmit Cycle Time | 45 | - | 65 | - | 100 | - | ns |
| tRT | Retransmit Pulse Width ${ }^{(2)}$ | 35 | - | 50 | - | 80 | - | ns |
| tris | Retransmit Set-up Time ${ }^{(3)}$ | 35 | - | 50 | - | 80 | - | ns |
| trip | Retransmit Recovery Time | 10 | - | 15 | - | 20 | - | ns |
| tEFL | Reset to Empty Flag Low | - | 45 | - | 65 | - | 100 | ns |
| thFH, tFFH | Reset to $\overline{\mathrm{FF}}$ and $\overline{\mathrm{FF}}$ High | - | 45 | - | 65 | - | 100 | ns |
| tREF | Read Low to Empty Flag Low | - | 30 | - | 45 | - | 60 | ns |
| trff | Read High to Full Flag High | - | 30 | - | 45 | - | 60 | ns |
| tRPE | Read Pulse Width after EF High | 35 | - | 50 | - | 80 | - | ns |
| tWEF | Write High to Empty Flag High | - | 30 | - | 45 | - | 60 | ns |
| tWFF | Write Low to Full Flag Low | - | 30 | - | 45 | - | 60 | ns |
| twhF | Write Low to Hall-Full Flag Low | - | 45 | - | 65 | - | 100 | ns |
| tRHF | Read High to Half-Full Flag High | - | 45 | - | 65 | - | 100 | ns |
| tWPF | Write Pulse Width after FFF High | 35 | - | 50 | - | 80 | - | ns |
| OXOL | Read/Write Low to $\overline{\mathrm{XO}}$ Low | - | 35 | - | 50 | - | 80 | ns |
| OXOH | Read/Write High to $\overline{\mathrm{XO}}$ High | - | 35 | - | 50 | - | 80 | ns |
| tx1 | XI Pulse Width ${ }^{(2)}$ | 35 | - | 50 | - | 80 | - | ns |
| tXIR | XI Recovery Time | 10 | - | 10 | - | 10 | - | ns |
| txis | $\overline{\text { XI Set-up Time }}$ | 15 | - | 15 | - | 15 | - | ns |

NOTES:

1. Timings referenced as in AC Test Conditions.
2. Pulse widths less than minimum are not allowed.
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |

2662 tbl 05

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| $\mathrm{CIN}^{(3)}$ | Input Capacitance | V IN $=\mathrm{OV}$ | 10 | pF |
| COUT $^{(2,3)}$ | Output Capacitance | Vout $=0 \mathrm{OV}$ | 10 | pF |
| NOTES: |  |  |  |  |

1. This parameter is sampled and not $100 \%$ tested.
2. With output deselected.
3. Characterized values, not currently tested.

## SIGNAL DESCRIPTIONS

## Inputs:

DATA IN (Do-D8) - Data inputs for 9-bit wide data.

## Controls:

RESET ( $\overline{\mathrm{RS}}$ ) - Reset is accomplished whenever the Reset $(\overline{\mathrm{RS}})$ input istakento a low state. During reset, both internal read and write pointers are set to the first location. A reset is required after power-up before a write operation can take place. Both the Read Enable ( $\overline{\mathrm{R}}$ ) and Write Enable $(\overline{\mathrm{W}})$ Inputs must be in the high state during the window shown In Figure 2 (I.e.tras before the rising edge of $\overline{\mathrm{RS}}$ ) and should not change untll trSR after the rising edge of $\overline{\mathrm{RS}}$. Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be reset to high after master Reset ( $\overline{\mathrm{RS}}$ ).

WRITE ENABLE $(\bar{W})$-A write cycle is initiated on the falling edge of this input if the Full Flag (FF) is not set. Data set-up and hold times must be adhered to with respect to the rising edge of the Write Enable $(\bar{W})$. Data is stored in the RAM array sequentially and independently of any on-going read operation.

After half of the memory is filled, and at the falling edge of the next write operation, the Half-Full Flag ( $\overline{\mathrm{FF}}$ ) will be set to low and will remain set until the difference between the write pointer and read pointer is less than or equal to one half of the total memory of the device. The Haff-Full Flag (MF) is then reset by the rising edge of the read operation.

To prevent data overflow, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting furtherwrite operations. Uponthe completion of avalid read operation, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go high after tRFF, allowing a valid write to begin. When the FIFO is full, the internal write pointer is blocked from $\bar{W}$, so external changes in $\bar{W}$ will not affect the FIFO when it is full.

or equivalent circuit
Flgure 1. Output Load
*Includes jig and scope capacitances.

READ ENABLE $(\overline{\mathrm{R}})$ - A readcycle is initiated on the falling edge of the Read Enable ( $\overline{\mathrm{R}}$ ) providedthe Empty Flag ( $\overline{\mathrm{EF}}$ ) is not set. The data is accessed on a First-In/First-Out basis independent of any ongoing write operations. After Read Enable ( $\overline{\mathrm{R}})$ goes high, the Data Outputs (Cothrough Qs) will returnto a high impedancecondition until the nextRead operation. When all the data has been read from the FIFO, the Empty Flag ( $\overline{E F}$ ) will go low, allowing the "tinal" read cycle but inhibiting further read operations, with the data outputs remaining in a high impedance state. Once a valid write operation has been accomplished, the Empty Flag ( $\overline{E F}$ ) will go high after twEF and a valid Read can then begin. When the FIFO is empty, the internal read pointer is blocked from $\bar{R}$ so extemal changes will not affect the FIFO when it is empty.

FIRST LOAD/RETRANSMIT ( $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ ) - This is a dualpurpose input. In the Depth Expansion Mode, this pin is grounded to indicate that it is the first device loaded (see Operating Modes). The Single Device Mode is initiated by grounding the Expansion $\ln (\overline{\mathrm{XII}})$.

The IDT7205 can be made to retransmit data when the Retransmit Enable Control( $\overline{\mathrm{RT}}$ ) input is pulsed low. A retransmit operation will set the intermal read pointer to the first location and will not affect the write pointer. Read Enable ( $\overline{\mathrm{R}}$ ) and Write Enable $(\bar{W})$ must be in the high state during retransmit. This feature is useful when less than 8192 writes are periormed between resets. The retransmit feature is not compatible with the Depth Expansion Mode and will affect the status of the Flags depending on the relative locations of the read and write pointers.

EXPANSION IN ( $\overline{\mathrm{XI}})$ - This input is a dual-purpose pin. Expansion $\ln (\overline{\mathrm{XI}})$ is grounded to indicate an operation in the single device mode. Expansion In ( $\overline{\mathrm{XI}})$ is connected to Expansion Out $(\overline{\mathrm{XO}})$ of the previous device in the Depth Expansion or Daisy Chain Mode.

## Outputs:

FULL FLAG ( $\overline{\mathrm{FF}}$ ) - The Full Flag $(\overline{\mathrm{FF}})$ will go low, inhibiting further write operations, when the device is full. If the read pointer is not moved after Reset ( $\overline{\mathrm{RS}}$ ), the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low after 8192 writes.

EMPTY FLAG ( $\overline{E F}$ ) - The Empty Flag ( $\overline{\mathrm{EF}}$ ) will go low, inhibiting further read operations, when the read pointer is equal to the write pointer, indicating that the device is empty.

EXPANSION OUT/HALF-FULLFLAG ( $\overline{X O} / \overline{\mathrm{HF}}$ ) - This is a dual-purpose output. In the single device mode, when Expansion $\ln (\overline{\mathrm{XI}})$ is grounded, this output acts as an indication of a halffull memory.

After half of the memory is filled, and at the falling edge of the next write operation, the Half-Full Flag ( $\overline{\mathrm{HF}}$ ) will be set to low and will remain set until the difference between the write pointer and
read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag $(\overline{H F})$ is then reset by the rising edge of the read operation.

In the Depth Expansion Mode, Expansion In ( $\overline{\mathrm{XI}})$ is connected to Expansion Out ( $\overline{\mathrm{XO}})$ of the previous device. This output acts as a signal to the next device in the Daisy Chain by providing a pulse to the next device when the previous device reaches the last location of memory. There will be an XO pulse when the Write pointer reaches the last location of memory, and an additional XO pulse when the Read pointer reaches the last location of memory.

DATA OUTPUTS (Q0-Q8) - Q0-Q8 are data outputs for 9bit wide data. These outputs are in a high impedance condition whenever Read $(\bar{R})$ is in a high state.


NOTES:
2662 drw 11

1. $\overline{E F}, \overline{F F}$ and $\overline{\mathrm{FF}}$ may change status during Reset, but flags will be valid at tRsc.
2. $\bar{W}$ and $\bar{R}=V I H$ around the rising edge of $\overline{R S}$.

Figure 2. Reset


Figure 3. Asynchronous Write and Read Operation


Flgure 4. Full Flag From Last Write to First Read


Flgure 5. Empty Flag From Last Read to First Write


NOTE:

1. $\overline{E F}, \overline{F F}$ and $\overline{A F}$ may change status during Retransmit, but flags will be valid at tRTC.

FIgure 6. Retransmit


Figure 7. Empty Fiag TIming


Figure 8. Full Flag Timing


Figure 9. Half-Full Flag Tlming


Figure 10. Expansion Out


Figure 11. Expansion In

## OPERATING MODES:

## Single Device Mode

A single IDT7205 may be used when the application requirements are for 8192 words or less. The IDT7205 is in a Single Device Configuration when the Expansion In (XI) control input is grounded (see Figure 12).

## Width Expansion Mode

Word width may be increased simply by connecting the corresponding input control signals of multiple devices. Status flags ( $\overline{E F}, \overline{\mathrm{FF}}$ and $\overline{\mathrm{HF}}$ ) can be detected from any one device. Figure 13 demonstrates an 18 -bit word width by using two IDT7205s. Any word width can be attained by adding additional IDT7205s.

## Depth Expansion (Dalsy Chain Mode)

The IDT7205 can easily be adapted to applications when the requirements are for greater than 8192 words. Figure 14 demonstrates Depth Expansion using three IDT7205s. Any depth can be attained by adding additional IDT7205s. The IDT7205 operates in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the First Load (FL) control input.
2. All other devices must have $\overline{\mathrm{FL}}$ in the high state.
3. The Expansion Out ( $\overline{\mathrm{XO}}$ ) pin of each device must be tied to the Expansion $\ln (\overline{\mathrm{XI}})$ pin of the next device. See Figure 14.
4. External logic is needed to generate a composite Full Flag ( $\overline{\mathrm{FF}}$ ) and Empty Flag ( $\overline{\mathrm{EF}}$ ). This requires the ORing of all $\overline{\mathrm{EFs}}$ and ORing of all $\overline{\mathrm{FFs}}$ (i.e. all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{\mathrm{EF}}$ ). See Figure 14.
5. The Retransmit ( $\overline{\mathrm{RT}}$ ) function and Half-Full Flag ( $\overline{\mathrm{HF}}$ ) are not available in the Depth Expansion Mode.
For additional information, referto Tech Note 9: Cascading FIFOs or FIFO Modules.

## Compound Expansion Mode

The two expansion techniques described above can be applied together in a straightforward manner to achieve large FIFO arrays (see Figure 15).

## Bidirectional Mode

Applications which require data buffering between two systems (each system capable of Read and Write operations) can be achieved by pairing IDT7205s as shown in Figure 16. Care must be taken to assure that the appropriate flag is monitored by each system (i.e. $\overline{\mathrm{FF}}$ is monitored on the device where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\bar{R}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## Data Flow-Through Modes

Two types of flow-through modes are permitted, a read flow-through and write flow-through mode. For the read flowthrough mode (Figure 17), the FIFO permits a reading of a single word after writing one word of data into an empty FIFO. The data is enabled on the bus in ( $\mathrm{tWEF}+\mathrm{tA}$ ) ns after the rising edge of $\bar{W}$, called the first write edge, and it remains on the bus until the $\overline{\mathrm{R}}$ line is raised from low-to-high, after which the bus would go into a three-state mode after trHz ns. The $\overline{\mathrm{EF}}$ line would have a pulse showing temporary deassertion and then would be asserted. In the interval of time that $\bar{R}$ was low, more words can be written to the FIFO (the subsequent writes after the first write edge will deassert the empty flag); however, the same word (written on the first write edge), presented to the output bus as the read pointer, would not be incremented when $\overline{\mathrm{R}}$ is low. Ontoggling $\overline{\mathrm{R}}$, the other words that were written to the FIFO will appear on the output bus as in the read cycle timings.

In the write flow-through mode (Figure 18), the FIFO permits the writing of a single word of data immediately after reading one word of data from a full FIFO. The $\overline{\mathrm{R}}$ line causes the $\overline{F F}$ to be deasserted but the $\bar{W}$ line being low causes it to be asserted again in anticipation of a new data word. On the rising edge of $\bar{W}$, the new word is loaded in the FIFO. The $\bar{W}$ line must be toggled when $\overline{F F}$ is not asserted to write new data in the FIFO and to increment the write pointer.

For additional information, refer to Tech Note 8: Operating FIFOs on Full and Empty Boundary Conditions and Tech Note 6: Designing with FIFOs.


Flgure 12. Block Dlagram of $8192 \times 9$ FIFO Used In Single Device Mode


NOTE:

1. Flag detection is accomplished by monitoring the $\overline{F F}, \overline{E F}$ and $\overline{H F}$ signals on either (any) device used in the width expansion configuration. Do not connect any output signals together.

Figure 13. Block Dlagram of $8192 \times 18$ FIFO Memory Used In Width Expansion Mode

## TRUTH TABLES

TABLEI-RESET AND RETRANSMIT
SINGLE DEVICE CONFIGURATION/WIDTH EXPANSION MODE

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |  |
| :--- | :---: | :---: | :---: | :--- | :--- | :--- | :---: | :---: |
|  | RS | RT | XI | Read Polnter | Write Polnter | EF | FF | HF |
| Reset | 0 | X | 0 | Location Zero | Location Zero | 0 | 1 | 1 |
| Retransmit | 1 | 0 | 0 | Location Zero | Unchanged | X | X | X |
| ReadWrite | 1 | 1 | 0 | Increment ${ }^{(1)}$ | Increment ${ }^{(1)}$ | X | X | X |

NOTE:
2662 bl 07

1. Pointer will Increment if flag is high.

TABLE II - RESET AND FIRST LOAD
DEPTH EXPANSION/COMPOUND EXPANSION MODE

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FR | RT | XI | Read Pointer | Write Pointer | EF | FF |
| Reset First Device | 0 | 0 | (1) | Location Zero | Location Zero | 0 | 1 |
| Reset all Other Devices | 0 | 1 | (1) | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | (1) | X | X | X | X |

NOTES:
2662 하 08

1. $\overline{\mathrm{XI}}$ is connected to $\overline{\mathrm{XO}}$ of previous device. See Figure 14.
2. $\overline{\mathrm{RS}}=$ Reset Input, $\overline{\mathrm{FL}} \overline{\mathrm{RT}}=$ First Load/Retransmit, $\overline{\mathrm{EF}}=$ Empty Flag Output, $\overline{\mathrm{FF}}=$ Full Flag Output, $\overline{\mathrm{XI}}=$ Expansion Input, $\overline{\mathrm{KF}}=$ Half-Full Flag Output


Figure 14. Block Diagram of $24,576 \times 9$ FIFO Memory (Depth Expansion)


NOTES:
2662 drw 16

1. For depth expansion block see section on Depth Expansion and Figure 14.
2. For Flag detection see section on Width Expansion and Figure 13.

Figure 15. Compound FIFO Expansion


Figure 16. Bldirectional FIFO Mode


Figure 17. Read Data Flow-Through Mode


Flgure 18. Write Data Flow-Through Mode

## ORDERING INFORMATION




## FEATURES:

- First-In/First-Out dual-port memory
- $16 \mathrm{~K} \times 9$-bit organization
- Low power consumption
- Ultra high speed: 25 ns access time
- Asynchronous and simultaneous read and write
- Fully expandable by both word depth and/or bit width
- Pin-compatible with IDT720X FIFO family
- Half-Full Flag capability in single device mode
- Status flags: Empty, Half-Full, Full
- Auto retransmit capability
- High-performance submicron CEMOS ${ }^{\text {TM }}$ technology
- Available in28-pin plastic DIP, CERDIP and 32-pin surface mount LCC and PLCC
- Military product is compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7206 is a dual-port memory that loads and empties data on a first-in/first-out basis. The device uses Full and Empty flags to prevent data overflow and underflow and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the device through the use of the WRITE (W) and READ ( $\bar{R}$ ) pins. The device has a read/write cycle time of 35ns (28MHz).

The device utilizes a 9-bit wide data array to allow for control and parity bits at the user's option. It also features a RETRANSMIT ( $\overline{\mathrm{RT}}$ ) capability that allows for reset of the read pointer to its initial position, when $\overline{R T}$ is pulsed low. A Half-Full Flag is available in the single device mode and width expansion modes.

The IDT7206 is fabricated using IDT's high-speed CEMOS submicron technology. They are designed for those applications requiring asynchronous and simultaneous read/ writes in multiprocessing and rate buffer applications. The 16K x 9 allows a 16384 word structure without the need for expansion.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATIONS




LCC/PLCC
TOP VIEW


## FEATURES:

- First-In/First-Out dual-port memory
- Bit organization
- IDT72021-1K x 9
- IDT72031-2K $\times 9$
- IDT72041-4K x 9
- Ultra high speed
- IDT72021-25ns access time, 35ns cycle time
- IDT72031-35ns access time, 45ns cycle time
- IDT72041-35ns access time, 45ns cycle time
- Easily expandable in word depth and/or width
- Asynchronous and simultaneous read and write
- Functionally equivalent to IDT7202/03/04 with Output Enable ( $\overline{\mathrm{OE}}$ ) and Almost Empty/Almost Full Flag ( $\overline{\mathrm{AEF}}$ )
- Four status flags: Full, Empty, Half-Full (single device mode), and Almost Empty/Almost Full (7/8 empty or $7 / 8$ full in single device mode)
- Output Enable controls the data output port
- Auto-retransmit capability
- Available in 32-pin DIP and surface mount 32-pin LCC and PLCC
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

IDT72021/031/041s are high-speed, low-power, dual-port memory devices commonly known as FIFOs (First-In/FirstOut). Data can be written into and read from the memory at independent rates. The order of information stored and extracted does not change, but the rate of data entering the FIFO might be different than the rate leaving the FIFO. Unlike a static RAM, no address information is required because the read and write pointers advance sequentially. The IDT72021/ 031/041s can perform asynchronous and simultaneous read and write operations. There are four status flags, ( $\overline{\mathrm{HF}}, \overline{\mathrm{FF}}, \overline{\mathrm{EF}}$, $\overline{\mathrm{AEF}}$ ) to monitor data overflow and underflow. Output Enable $(\overline{\mathrm{OE}})$ is provided to control the flow of data through the output port. Additional key features are Write ( $\overline{\mathrm{W}}$ ), Read ( $\overline{\mathrm{R}}$ ), Retransmit ( $\overline{\mathrm{RT}}$ ), First Load ( $\overline{\mathrm{FL}}$ ), Expansion In ( $\overline{\mathrm{XI})}$ ) and Expansion Out (XO). The IDT72021/031/041s are designed for those applications requiring data control flags and Output Enable ( $\overline{\mathrm{OE}}$ ) in multiprocessing and rate buffer applications.

The IDT72021/031/041s are fabricated using IDT's CEMOS ${ }^{\text {™ }}$ technology. Military grade product is manufactured in compliance with the latest version of MIL-STD-883, Class B, for high reliability systems.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATIONS



PIN DESCRIPTIONS

| Symbol | Name | VO | Description |
| :---: | :---: | :---: | :---: |
| Do-D8 | Inputs | 1 | Data inputs for 9-bit wide data. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal READ and WRITE pointers are set to the first location of the RAM array. $\overline{H F}$ and $\overline{F F}$ go high, and $\overline{A E F}$ and $\overline{E F}$ go low. A reset is required before an initial WRITE atter power-up. $\overline{\mathrm{R}}$ and $\overline{\mathrm{W}}$ must be high during $\overline{\mathrm{RS}}$ cycle. |
| $\bar{W}$ | Write | 1 | When WRITE is low, data can be written into the RAM array sequentially, independent of READ. In order for WRITE to be active, $\overline{\mathrm{FF}}$ must be high. When the FIFO is full ( $\overline{\mathrm{FF}}-\mathrm{low}$ ), the internal WRITE operation is blocked. |
| $\overline{\bar{R}}$ | Read | 1 | When READ is low, data can be read from the RAM array sequentially, independent of WRITE. In order for READ to be active, EF must be high. When the FIFO is empty (EF-low), the internal READ operation is blocked. The three-state output buffer is controlled by the read signal and the external output control ( $\overline{\mathrm{OE}})$. |
| $\overline{\text { FLI }} \overline{\mathrm{RT}}$ | First Load/ Retransmit | 1 | This is a dual purpose input. In the single device configuration ( $\overline{\mathrm{XI}}$ grounded), activating retransmit (FL/RT-low) will set the internal READ pointer to the first location. There is no effect on the WRITE pointer. $\overline{\mathrm{R}}$ and $\overline{\mathrm{W}}$ must be high before setting $\overline{\mathrm{FL}} \overline{\mathrm{RT}}$ low. Retransmit is not compatible with depth expansion. In the depth expansion configuration, $\overline{\mathrm{FL}} / \mathrm{RT}$-low indicates the first activated device. |
| $\overline{\text { XI }}$ | Expansion In | 1 | In the single device configuration, $\overline{\mathrm{X}}$ is grounded. In depth expansion or daisy chain expansion, $\overline{\mathrm{XI}}$ is connected to $\overline{\mathrm{XO}}$ (expansion out) of the previous device. |
| $\overline{\mathrm{OE}}$ | Output Enable | 1 | When $\overline{\mathrm{OE}}$ is set high, the data flow through the three-state output buffer is inhibited regardless of an active READ operation. A read operation does increment the read pointer in this situation. When $\overline{\mathrm{OE}}$ is set low, Qo-Q8 are still in a high impedance condition if no READ occurs. For a complete READ operation with data ppearing on Q0-Q8, both $\overline{\mathrm{R}}$ and $\overline{\mathrm{OE}}$ should be asserted low. |
| $\overline{\text { FF }}$ | Full Flag | 0 | When $\overline{\mathrm{FF}}$ goes low, the device is full and further WRITE operations are inhibited. When $\overline{\mathrm{FF}}$ is high, the device is not full. |
| EF | Empty Flag | 0 | When $\overline{\mathrm{EF}}$ goes low, the device is empty and further READ operations are inhibited. When $\overline{\mathrm{EF}}$ is high, the device is not empty. |
| $\overline{\text { AEF }}$ | Almost-Empty/ Almost-Full Flag | 0 | When $\overline{A E F}$ is low, the device is empty to $1 / 8$ full or $7 / 8$ to completely full. When $\overline{A E F}$ is high, the device is greater than $1 / 8$ full, but less than $7 / 8$ full. |
| $\overline{\mathrm{XO} / \overline{\mathrm{HF}}}$ | Expansion Out/ Half-Full Flag | 0 | This is a dual purpose output. In the single device configuration (险 grounded), the device is more than half full when $\overline{\mathrm{HF}}$ is low. In the depth expansion configuration ( $\overline{\mathrm{XO}}$ connected to $\overline{\mathrm{XI}}$ of the next device), a pulse is sent from $\overline{\mathrm{XO}}$ to $\overline{\mathrm{I}}$ when the last location in the RAM array is filled. |
| Qo-Q8 | Outputs | 0 | Data outputs for 9 -bit wide data. |

## STATUS FLAG

| Number of Words in FIFO |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{1 K}$ | $\mathbf{2 K}$ | $\mathbf{4 K}$ | FF | AEF | HF | EF |
| 0 | 0 | 0 | H | L | H | L |
| $1-127$ | $1-255$ | $1-511$ | H | L | H | H |
| $128-512$ | $256-1024$ | $512-2048$ | H | H | H | H |
| $513-896$ | $1025-1792$ | $2049-3584$ | H | H | L | H |
| $897-1023$ | $1793-2047$ | $3585-4095$ | H | L | L | H |
| 1024 | 2048 | 4096 | L | L | L | H |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Mil. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| OUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than thoselistedunder ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 10 | pF |
| Cour | Output Capacitance | VoUT $=\mathrm{OV}$ | 10 | pF |

NOTE:

1. These parameters are sampled and not $100 \%$ tested.

RECOMMENDED DC
OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unlt |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccm | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| VcCC | Commercial <br> Supply Vohtage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL $^{(1)}$ | Input Low Voltage <br> Commercial and <br> Military | - | - | 0.8 | V |

NOTE:

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

## DC ELECTRICAL CHARACTERISTICS—IDT72021

(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72021 Commerclal $t A=25,35 n s$ |  |  | $\begin{aligned} & \text { IDT72021 } \\ & \text { Military } \\ & \text { tA }=30,40 \mathrm{~ns} \end{aligned}$ |  |  | IDT72021 Commerclal $t A=50,65,80,120 \mathrm{~ns}$ |  |  | $\begin{gathered} \text { IDT72021 } \\ \text { Niltary } \\ \text { t }=50,65,80,120 \mathrm{~ns} \end{gathered}$ |  |  | Unl |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min | Typ. | Max | Min. | Typ. | Max. | Min. | Typ. | Max |  |
| $\mathrm{Kif}^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| L. $\mathrm{O}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic " 1 " Voltage $1 \mathrm{CH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | V |
| Va | Output Logic "0" Voltage $1 a=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | - | - | 0.4 | V |
| $1 \mathrm{COC}^{(3,4)}$ | Active Power Supply Current | - | - | 120 | - | - | 140 | - | 50 | 80 | - | 70 | 100 | mA |
| $\operatorname{lcc}^{(3)}$ | $\begin{aligned} & \text { Standby Current } \\ & \left(\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} \overline{\mathrm{RT}}=\mathrm{V}_{\mathrm{H}}\right) \end{aligned}$ | - | - | 12 | - | - | 20 | - | 5 | 8 | - | 8 | 15 | mA |
| $1 \operatorname{lcm}^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | - | 500 | - | - | 900 | - | - | 500 | - | - | 900 | $\mu \mathrm{A}$ |

DC ELECTRICAL CHARACTERISTICS — IDT72031, IDT72041
(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72031IDT72041CommerclaltA $=35,50,65,80,120 n s$ |  |  | IDT72031IDT72041MiltarytA $=40,50,65,80,120 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $\mathrm{lLI}^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{HO}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage lour $=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Va. | Output Logic "0" Vottage lout $=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| lec1 ${ }^{(3,5)}$ | Active Power Supply Current | - | 75 | 120 | - | 100 | 150 | mA |
| $\mathrm{KCC}^{(3)}$ | Standby Current ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RST}}=\overline{\mathrm{FL}} / \overline{\mathrm{RT}}=\mathrm{V} / \mathrm{H})$ | - | 8 | 12 | - | 12 | 25 | mA |
| $\mathrm{CCO}^{(3)}$ | Power Down Current (All input $=$ Vcc -0.2 V ) | - | - | 2 | - | - | 4 | mA |

NOTES:

1. Measurements with $0.4 \leq \operatorname{Vin} \leq V C C$.
2. $\overline{\mathrm{A}} \geq \mathrm{V}_{\mathrm{H}}, 0.4 \leq$ Vour $\leq \mathrm{Vcc}$.
3. Icc measurements are made with $\overline{\mathrm{OE}}=\mathrm{HIGH}$.
4. Tested at $f=20 \mathrm{MHz}$.
5. Tested at $f=15.3 \mathrm{MHz}$.

## AC ELECTRICAL CHARACTERISTICS - IDT72021 ${ }^{(1)}$

(Commercial: Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Com'l |  | Mil. |  | Com'l |  | Mil. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $72021 \times 25$ |  | $72021 \times 30$ |  | $72021 \times 35$ |  | $72021 \times 40$ |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| is | Shift Frequency | - | 28.5 | - | 25 | - | 22.2 | - | 20 | MHz |
| tRC | $\overline{\mathrm{R}}$ Cycle Time | 35 | - | 40 | - | 45 | - | 50 | - | ns |
| tA | Access Time | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tRR | $\overline{\mathrm{R}}$ Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tRPW | $\overline{\mathrm{R}}$ Pulse Width ${ }^{(2)}$ | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tRLZ | $\overline{\mathrm{R}}$ Pulse Low to Data Bus at Low $\mathbf{Z}^{(3)}$ | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tWLZ | $\widetilde{W}$ Pulse High to Data Bus at Low ${ }^{(3,4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tDV | Data Valid from $\overline{\mathrm{R}}$ Pulse High | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| trHz | $\overline{\mathrm{R}}$ Pulse High to Data Bus at High $\mathbf{Z}^{(3)}$ | - | 18 | - | 20 | - | 20 | - | 25 | ns |
| twC | W Cycle Time | 35 | - | 40 | - | 45 | - | 50 | - | ns |
| tWPW | $\overline{\text { W Pulse Width }}{ }^{(2)}$ | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tWR | $\bar{W}$ Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tos | Data Set-up Time | 15 | - | 18 | - | 18 | - | 20 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tRSC | $\overline{\mathrm{RS}}$ Cycle Time | 35 | - | 40 | - | 45 | - | 50 | - | ns |
| tRS | $\overline{\mathrm{RS}}$ Pulse Width ${ }^{(2)}$ | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tRSS | $\overline{\mathrm{RS}}$ Set-up Time | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tRSR | $\overline{\mathrm{RS}}$ Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tRTC | $\overline{\mathrm{RT}}$ Cycle Time | 35 | - | 40 | - | 45 | - | 50 | - | ns |
| tRT | $\overline{\mathrm{RT}}$ Pulse Width ${ }^{(2)}$ | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tRTR | $\overline{\text { RT Recovery Time }}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tRSF1 | $\overline{\mathrm{RS}}$ to $\overline{\mathrm{EF}}$ and $\overline{\mathrm{AEF}}$ Low | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| tRSF2 | $\overline{\mathrm{RS}}$ to $\overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$ High | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| tref | $\overline{\mathrm{R}}$ Low to EF Low | - | 25 | - | 30 | - | 30 | - | 35 | ns |
| tRFF | $\overline{\bar{R}}$ High to FF High | - | 25 | - | 30 | - | 30 | - | 35 | ns |
| tRPE | $\overline{\mathrm{R}}$ Pulse Width After $\overline{\mathrm{EF}}$ High | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tWEF | $\overline{\text { W High to EF High }}$ | - | 25 | - | 30 | - | 30 | - | 35 | ns |
| tWFF | $\bar{W}$ Low to EF Low | - | 25 | - | 30 | - | 30 | - | 35 | ns |
| tWHF | $\bar{W}$ Low to $\overline{\text { FF }}$ Low | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| tRMF | $\overline{\mathrm{R}}$ High to $\overline{\mathrm{HF}}$ High | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| tWPF | $\overline{\text { W Pulse Width after } \overline{\text { FF }} \text { High }}$ | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tRF | $\overline{\bar{R}}$ High to Transitioning $\overline{\text { AEF }}$ | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| twF | $\overline{\bar{W}}$ Low to Transitioning $\overline{\text { AEF }}$ | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| tOEHZ |  | 0 | 12 | 0 | 15 | 0 | 17 | 0 | 20 | ns |
| toelz | $\overline{\mathrm{OE}}$ Low to Low-Z (Enable) ${ }^{(3)}$ | 0 | 12 | 0 | 15 | 0 | 17 | 0 | 20 | ns |
| taoe | $\overline{\mathrm{OE}}$ Low Data Valid (Q0-Q8) | - | 15 | - | 18 | - | 20 | - | 25 | ns |

NOTES:
2877 to 08

1. Timings referenced as in AC Test Conditions.
2. Pulse widths less than minimum value are not allowed.
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

## AC ELECTRICAL CHARACTERISTICS - IDT72021 ${ }^{(1)}$ (Continued)

(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Military and Commerclal |  |  |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $72021 \times 50$ |  | $72021 \times 65$ |  | $72021 \times 80$ |  | $72021 \times 120$ |  |  |
|  |  | Min. | Max. | MIn. | Max. | Min. | Max. | Min. | Max. |  |
| fs | Shitt Frequency | - | 15 | - | 12.5 | - | 10 | - | 7 | M Hz |
| tre | $\overline{\mathrm{R}}$ Cycle Time | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| tA | Access Time | - | 50 | - | 65 | - | 80 | - | 120 | ns |
| tRR | $\overline{\mathrm{R}}$ Recovery Time | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tRPW | $\overline{\mathrm{R}}$ Pulse Width ${ }^{(2)}$ | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tRLZ | $\overline{\mathrm{R}}$ Pulse Low to Data Bus at Low Z ${ }^{(3)}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| twLz | $\bar{W}$ Pulse High to Data Bus at Low $\mathbf{Z}^{(3,4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tov | Data Valid from $\overline{\mathrm{R}}$ Pulse High | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| trhz | $\overline{\mathrm{R}}$ Pulse High to Data Bus at High $\mathbf{Z}^{(3)}$ | - | 30 | - | 30 | - | 30 | - | 35 | ns |
| twc | W Cycle Time | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| tWPW | $\overline{\text { W Pulse Width }}{ }^{(2)}$ | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| twr | $\bar{W}$ Recovery Time | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tos | Data Set-up Time | 30 | - | 30 | - | 40 | - | 40 | - | ns |
| tDH | Data Hold Time | 5 | - | 10 | - | 10 | - | 10 | - | ns |
| trsc | $\overline{\mathrm{RS}}$ Cycle Time | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| tRS | $\overline{\mathrm{RS}}$ Pulse Width ${ }^{(2)}$ | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tRSS | $\overline{\mathrm{RS}}$ Set-up Time | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tRSR | $\overline{\mathrm{RS}}$ Recovery Time | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tRTC | RT Cycle Time | 65 | - | 80 | - | 100 | - | 140 | - | ns |
| tRT | $\overline{\text { RT Pulse Width }}{ }^{(2)}$ | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tRTR | RT Recovery Time | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tRSF1 | $\overline{\mathrm{RS}}$ to $\overline{\mathrm{EF}}$ and $\overline{\mathrm{AEF}}$ Low | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| tRSF2 | $\overline{\mathrm{RS}}$ to $\overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$ High | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| tREF | $\overline{\mathrm{R}}$ Low to $\overline{\mathrm{EF}}$ Low | - | 45 | - | 60 | - | 60 | - | 60 | ns |
| trif | $\overline{\mathrm{R}}$ High to $\overline{\mathrm{FF}}$ High | - | 45 | - | 60 | - | 60 | - | 60 | ns |
| tRPE | $\overline{\mathrm{R}}$ Pulse Width After EF High | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tWEF | $\bar{W}$ High to EF High | - | 45 | - | 60 | - | 60 | - | 60 | ns |
| twFF | $\overline{\text { W }}$ Low to EF Low | - | 45 | - | 60 | - | 60 | - | 60 | ns |
| tWHF | $\bar{W}$ Low to $\overline{\text { HF }}$ Low | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| tRHF | $\overline{\mathrm{R}}$ High to $\overline{\mathrm{HF}} \mathrm{High}$ | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| tWPF | $\bar{W}$ Pulse Width after FF High | 50 | - | 65 | - | 80 | - | 120 | - | ns |
| tRF | $\overline{\mathrm{R}}$ High to Transitioning $\overline{\mathrm{AEF}}$ | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| twF |  | - | 65 | - | 80 | - | 100 | - | 140 | ns |
| toenz | $\overline{\mathrm{OE}}$ High to High-Z (Disable) ${ }^{(3)}$ | 0 | 25 | 0 | 30 | 0 | 30 | 0 | 30 | ns |
| toelz | $\overline{\mathrm{OE}}$ Low to Low-Z (Enable) ${ }^{(3)}$ | 0 | 25 | 0 | 30 | 0 | 30 | 0 | 30 | ns |
| taie | $\overline{\text { OE Low Data Valid (Q0-Q8) }}$ | - | 30 | - | 40 | - | 40 | - | 40 | $n s$ |

NOTES:

1. Timings referenced as in AC Test Conditions.
2. Pulse widths less than minimum value are not allowed.
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

AC ELECTRICAL CHARACTERISTICS - IDT72031, IDT72041 ${ }^{(1)}$
(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{array}{r} 72031 \times 35 \\ 72041 \times 35 \\ \hline \end{array}$ |  | $\begin{aligned} & 72031 \times 40 \\ & 72041 \times 40 \end{aligned}$ |  | $\begin{aligned} & 72031 \times 50 \\ & 72041 \times 50 \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| fs | Shift Frequency | - | 22.2 | - | 20 | - | 15 | MHz |
| tRC | $\overline{\mathrm{R}}$ Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| ta | Access Time | - | 35 | - | 40 | - | 50 | ns |
| tRR | $\overline{\bar{R}}$ Recovery Time | 10 | - | 10 | - | 15 | - | ns |
| tRPW | $\overline{\mathrm{R}}$ Pulse Width ${ }^{(2)}$ | 35 | - | 40 | - | 50 | - | ns |
| tRLZ | $\overline{\mathrm{R}}$ Pulse Low to Data Bus at Low $\mathrm{Z}^{(3)}$ | 5 | - | 5 | - | 10 | - | ns |
| twLZ | $\bar{W}$ Pulse High to Data Bus at Low $\mathrm{Z}^{(3,4)}$ | 5 | - | 5 | - | 5 | - | ns |
| tov | Data Valid from $\overline{\mathrm{R}}$ Pulse High | 5 | - | 5 | - | 5 | - | ns |
| tRHZ | $\overline{\mathrm{R}}$ Pulse High to Data Bus at High ${ }^{(3)}$ | - | 20 | - | 25 | - | 30 | ns |
| twc | W Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| tWPW | $\overline{\text { W Puise Width }}{ }^{(2)}$ | 35 | - | 40 | - | 50 | - | ns |
| tWR | $\bar{W}$ Recovery Time | 10 | - | 10 | - | 15 | - | ns |
| tDS | Data Set-up Time | 18 | - | 20 | - | 30 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 5 | - | ns |
| tRSC | $\overline{\mathrm{RS}}$ Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| tRS | $\overline{\mathrm{RS}}$ Pulse Width ${ }^{(2)}$ | 35 | - | 40 | - | 50 | - | ns |
| trss | $\overline{\mathrm{RS}}$ Set-up Time | 35 | - | 40 | - | 50 | - | ns |
| tRSR | $\overline{\mathrm{RS}}$ Recovery Time | 10 | - | 10 | - | 15 | - | ns |
| tRTC | RT Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| tRT | RT Pulse Width ${ }^{(2)}$ | 35 | - | 40 | - | 50 | - | ns |
| tRTR | $\overline{\text { RT Recovery Time }}$ | 10 | - | 10 | - | 15 | - | ns |
| tRSFt | $\overline{\mathrm{RS}}$ to $\overline{\mathrm{EF}}$ and $\overline{\mathrm{AEF}}$ Low | - | 45 | - | 50 | - | 65 | ns |
| tRSF2 | $\overline{\mathrm{RS}}$ to $\overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$ High | - | 45 | - | 50 | - | 65 | ns |
| tREF | $\overline{\mathrm{R}}$ Low to $\overline{\mathrm{EF}}$ Low | - | 30 | - | 35 | - | 45 | ns |
| tRFF | $\overline{\mathrm{R}}$ High to $\overline{\mathrm{FF}}$ High | - | 30 | - | 35 | - | 45 | ns |
| tRPE | $\overline{\mathrm{R}}$ Pulse Width After EF $\overline{\mathrm{F}}$ High | 35 | - | 40 | - | 50 | - | ns |
| tWEF | $\bar{W}$ High to EF High | - | 30 | - | 35 | - | 45 | ns |
| tWFF | $\bar{W}$ Low to EF Low | - | 30 | - | 35 | - | 45 | ns |
| tWHF | $\bar{W}$ Low to $\overline{\text { HF }}$ Low | - | 45 | - | 50 | - | 65 | ns |
| trhF | $\overline{\mathrm{R}}$ High to $\overline{\mathrm{HF}}$ High | - | 45 | - | 50 | - | 65 | ns |
| tWPF | $\overline{\text { W Pulse Width after } \overline{\text { FF }} \text { High }}$ | 35 | - | 40 | - | 50 | - | ns |
| tRF | $\overline{\mathrm{R}}$ High to Transitioning $\overline{\mathrm{AEF}}$ | - | 45 | - | 50 | - | 65 | ns |
| twf | $\bar{W}$ Low to Transitioning $\overline{\text { AEF }}$ | - | 45 | - | 50 | - | 65 | ns |
| toenz | $\overline{\mathrm{OE}}$ High to High-Z (Disable) ${ }^{(3)}$ | 0 | 17 | 0 | 20 | 0 | 25 | ns |
| toelz | $\overline{\mathrm{OE}}$ Low to Low-Z (Enable) ${ }^{(3)}$ | 0 | 17 | 0 | 20 | 0 | 25 | ns |
| taoe | $\overline{\mathrm{OE}}$ Low Data Valid (Q0-Q8) | - | 20 | - | 25 | - | 30 | ns |

## NOTES:

2. Pulse widths less than minimum value are not allowed.
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

## AC ELECTRICAL CHARACTERISTICS - IDT72031, IDT72041 ${ }^{(1)}$ (Continued)

(Commercial: $\mathrm{Vcc}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{Vcc}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Paramoter | $\begin{aligned} & 72031 \times 65 \\ & 72041 \times 65 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 72031 \times 80 \\ & 72041 \times 80 \end{aligned}$ |  | $\begin{aligned} & 72031 \times 120 \\ & 72041 \times 120 \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| is | Shitt Frequency | - | 12.5 | - | 10 | - | 7 | MHz |
| trc | $\overline{\bar{R}}$ Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| tA | Access Time | - | 65 | - | 80 | - | 120 | ns |
| trR | $\overline{\bar{R}}$ Recovery Time | 15 | - | 20 | - | 20 | - | ns |
| tRPW | $\overline{\mathrm{R}}$ Pulse Width ${ }^{(2)}$ | 65 | - | 80 | - | 120 | - | ns |
| trLz | $\overline{\mathrm{R}}$ Pulse Low to Data Bus at Low $\mathrm{Z}^{(3)}$ | 10 | - | 10 | - | 10 | - | ns |
| tWLZ | $\bar{W}$ Pulse High to Data Bus at Low $\mathbf{Z}^{(3,4)}$ | 5 | - | 5 | - | 5 | - | ns |
| tov | Data Valid from $\overline{\mathrm{R}}$ Pulse High | 5 | - | 5 | - | 5 | - | ns |
| trHz | $\overline{\mathrm{R}}$ Pulse High to Data Bus at High $\mathbf{Z}^{(3)}$ | - | 30 | - | 30 | - | 35 | ns |
| twc | W Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| tWPW | $\overline{\text { W Pulse Width }}{ }^{(2)}$ | 65 | - | 80 | - | 120 | - | ns |
| twr | $\bar{W}$ Recovery Time | 15 | - | 20 | - | 20 | - | ns |
| tDS | Data Set-up Time | 30 | - | 40 | - | 40 | - | ns |
| tDH | Data Hold Time | 10 | - | 10 | - | 10 | - | ns |
| tRSC | $\overline{\mathrm{RS}}$ Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| tRS | $\overline{\mathrm{RS}}$ Pulse Width ${ }^{(2)}$ | 65 | - | 80 | - | 120 | - | ns |
| trss | $\overline{\mathrm{RS}}$ Set-up Time | 65 | - | 80 | - | 120 | - | ns |
| trSR | $\overline{\mathrm{RS}}$ Recovery Time | 15 | - | 20 | - | 20 | - | ns |
| tric | RT Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| trt | $\overline{\text { RT Pulse Width }}{ }^{(2)}$ | 65 | - | 80 | - | 120 | - | ns |
| tRTR | $\overline{R T}$ Recovery Time | 15 | - | 20 | - | 20 | - | ns |
| tRSF1 | $\overline{\mathrm{RS}}$ to $\overline{\mathrm{EF}}$ and $\overline{\mathrm{AEF}}$ Low | - | 80 | - | 100 | - | 140 | ns |
| tRSF2 | $\overline{\mathrm{RS}}$ to $\overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$ High | - | 80 | - | 100 | - | 140 | ns |
| treF | $\overline{\mathrm{R}}$ Low to $\overline{\mathrm{EF}}$ Low | - | 60 | - | 60 | - | 60 | ns |
| tRFF | $\overline{\mathrm{R}}$ High to $\overline{\mathrm{FF}}$ High | - | 60 | - | 60 | - | 60 | ns |
| tRPE | $\overline{\mathrm{R}}$ Pulse Width After EF High | 65 | - | 80 | - | 120 | - | ns |
| tWEF | $\bar{W}$ High to EF High | - | 60 | - | 60 | - | 60 | ns |
| tWFF | $\bar{W}$ Low to EF Low | - | 60 | - | 60 | - | 60 | ns |
| tWHF | $\bar{W}$ Low to $\overline{\text { HF }}$ Low | - | 80 | - | 100 | - | 140 | ns |
| trif | $\overline{\mathrm{R}}$ High to $\overline{\mathrm{HF}}$ High | - | 80 | - | 100 | - | 140 | ns |
| tWPF | $\overline{\text { W Pulse Width after } \overline{\text { FF }} \text { High }}$ | 65 | - | 80 | - | 120 | - | ns |
| tRF | $\overline{\mathrm{R}}$ High to Transitioning $\overline{\mathrm{AEF}}$ | - | 80 | - | 100 | - | 140 | ns |
| twF | $\bar{W}$ Low to Transitioning $\overline{A E F}$ | - | 80 | - | 100 | - | 140 | ns |
| toenz | $\overline{\mathrm{OE}}$ High to High-Z (Disable) ${ }^{(3)}$ | 0 | 30 | 0 | 30 | 0 | 30 | ns |
| toelz | $\overline{\mathrm{OE}}$ Low to Low-Z (Enable) ${ }^{(3)}$ | 0 | 30 | 0 | 30 | 0 | 30 | ns |
| taoe | $\overline{\mathrm{OE}}$ Low Data Valid (Q0-Q8) | - | 40 | - | 40 | - | 40 | ns |

## NOTES:

1. Timings referenced as in AC Test Conditions.
2. Pulse widths less than minimum value are not allowed.
3. Values guaranteed by design, not currently tested.
4. Only applies to read data flow-through mode.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |

2677 to 12


Figure 1. Output Load

* Includes scope and jig capacitances.


Figure 2. Reset

## NOTES:

1. $\overline{E F}, \overline{F F}, \overline{H F}$, and $\overline{A E F}$ may change status during Reset, but flags will be valid at thsc.
2. $\bar{W}$ and $\overline{\mathrm{R}}=\mathrm{V}_{\mathrm{IH}}$ around the rising edge of $\overline{\mathrm{RS}}$.


Figure 3. Asynchronous Write and Read Operation
NOTE:

1. Assume $\overline{O E}$ is asserted low.


Figure 4. Full Flag From Last Write to First Read


Figure 5. Empty Flag From Last Read to First Write
NOTE:

1. Assume $\overline{O E}$ is asserted low.


Figure 6. Retransmit


Figure 7. Empty Flag Timing


Figure 8. Full Flag Timing


Figure 9. Almost-Empty/Almost-Full Flag and Half-Full Timings


Figure 10. Output Enable and Read Operation Timings


Flgure 11. Expansion Out


Figure 12. Expansion In

## OPERATING CONFIGURATIONS

SINGLE DEVICE CONFIGURATION
The IDT72021/031/041 is in the Single Device Configuration when the Expansion In ( $\overline{\mathrm{XI}})$ control input is grounded (see Figure 13).


Figure 13. Block Diagram of Single $1 \mathrm{~K} / 2 \mathrm{~K} / 4 \mathrm{~K} \times 9$ FiFO

## WIDTH EXPANSION CONFIGURATION

Word width may be increased simply by connecting the corresponding input control signals of multiple devices. Status flags ( $\overline{E F}, \overline{F F}, \overline{H F}$, and $\overline{A E F}$ ) can be detected from any one
device. Figure 14 demonstrates an 18-bit word width by using two IDT72021/031/041 devices. Any word width can be attained by adding additional IDT72021/031/041s.


Figure 14. Block Diagram of $1 \mathrm{~K} / 2 \mathrm{~K} / 4 \mathrm{~K} \times 18$ FIFO Memory Used in Width Expansion Conflguration
NOTE:

1. Flag detection is accomplished by monitoring the $\overline{F F}, \overline{E F}, \overline{\mathrm{HF}}$ and $\overline{\mathrm{AEF}}$ signals on either (any) device used in the width expansion configuration. Do not connect any output signals together.

## DEPTH EXPANSION (DAISY CHAIN) MODE

The IDT72021/031/041 can easily be adapted to applications when the requirements are for greater than $1 \mathrm{~K} / 2 \mathrm{~K} / 4 \mathrm{~K}$ words. Figure 15 demonstrates Depth Expansion using three IDT72021/031/041s. Any depth can be attained by adding additional devices. The IDT72021/031/041 operates in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designed by grounding the First Load (FL) control input.
2. All other devices must have $\overline{\mathrm{FL}}$ in the high state.
3. The Expansion Out $(\overline{\mathrm{XO}})$ pin of each device must be tied to the Expansion In ( $\overline{\mathrm{XI}})$ pin of the next device. See Figure 15.
4. External logic is needed to generate a composite Full Flag ( $\overline{\mathrm{FF}}$ ) and Empty Flag ( $\overline{\mathrm{EF}}$ ). This requires the ORing of all EFs and ORing of all FFs (i.e. all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{\mathrm{EF}}$ ). See Figure 15.
5. The Retransmit ( $\overline{\mathrm{RT}}$ ) function and Half-Full Flag $(\overline{\mathrm{HF}})$ are not available in the Depth Expansion Mode.
For additional information refer to Tech Note 9: "Cascading FIFOs or FIFO Modules".

## COMPOUND EXPANSION MODE

The two expansion techinques described above can be applied together in a straight forward manner to achieve large FIFO arrays (see Figure 16).

## BIDIRECTIONAL MODE

Applications which require data buffering between two systems (each system capable of Read and Write operations) can be achieved by pairing IDT72021/031/041s as shown in Figure 17. Care must be taken to assure that the appropriate flag is monitored by each system (i.e., $\overline{\mathrm{FF}}$ is monitored on the device where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\overline{\mathrm{R}}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## DATA FLOW-THROUGH MODES

Two types of flow-through modes are permitted: a read flow-through and write flow-through mode. For the read flowthrough mode (Figure 18), the FIFO permits the reading of a single word after writing one word of data into an empty FIFO. The data is enabled on the bus in ( $\mathrm{tWEF}+\mathrm{tA}$ ) ns after the rising edge of $\bar{W}$, called the first write edge. It remains on the bus until the $\overline{\mathrm{R}}$ line is raised from low-to-high, after which the bus would go into a three-state mode after tRHz ns. The $\overline{\overline{E F}}$ line would have a pulse showing temporary deassertion and then would be asserted. In the interval of time that $\bar{R}$ was low, more words can be written to the FIFO (the subsequent writes after the first write edge will be deassert the Empty Flag); however, the same word (written on the first write edge), presented to the output bus as the read pointer, would not be incremented when $\bar{R}$ was low. On toggling $\bar{R}$, the other words that are written to the FIFO will appear on the output bus as in the read cycle timings.

In the write flow-through mode (Figure 18), the FIFO permits the writing of a single word of data immediately after reading one word of data from a full FIFO. The $\overline{\mathrm{R}}$ line causes the $\overline{\mathrm{FF}}$ to be deasserted but the $\overline{\mathrm{W}}$ line, being low causes it to be asserted again in anticipation of a new data word. On the rising edge of $\bar{W}$, the new word is loaded in the FIFO. The $\bar{W}$
line must be toggled when $\overline{F F}$ is not asserted to write new data in the FIFO and to increment the write pointer.

For additional information refer to Tech Note 8: "Operating FIFOs on Full and Empty Boundary Conditions" and Tech Note 6: "Designing with FIFOs".

## TRUTH TABLES

TABLE -RESET AND RETRANSMIT
Single Device Configuration/Width Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{RS}}$ | $\overline{\text { RT }}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | $\overline{\text { EF }}$ | $\overline{F F}$ | $\overline{\mathrm{HF}}$ | $\overline{\text { AEF }}$ |
| Reset | 0 | X | 0 | Location Zero | Location Zero | 0 | 1 | 1 | 0 |
| Retransmit | 1 | 0 | 0 | Location Zero | Unchanged | X | X | X | X |
| Read/Write | 1 | 1 | 0 | Increment ${ }^{(1)}$ | Increment ${ }^{(1)}$ | X | X | X | X |

NOTE:
2677 tol 13
t. Pointer will increment if flag is High.

## TABLE II-RESET AND FIRST LOAD TRUTH TABLE

Depth Expansion/Compound Expansion Mode

| Mode | Input3 |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbf{R S}}$ | $\overline{\mathrm{FL}}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | $\overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ |
| Reset First Device | 0 | 0 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Reset All Other Devices | 0 | 1 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | $(1)$ | X | X | $\bar{X}$ | $\overline{\mathrm{X}}$ |

## NOTE:

1. $\overline{X I}$ is connected to $\overline{X O}$ of previous device. See Figure 15. $\overline{\mathrm{RS}}=$ Reset Input $\overline{\mathrm{FL}} \overline{\mathrm{RT}}=$ First Load/Retransmit, $\overline{E F}=$ Empty Flag Output, $\overline{F F}=$ Flag Full Output, $\overline{\mathrm{XI}}=$ Expansion Input, $\overline{\mathrm{HF}}=$ Half-Full Flag Output, $\overline{\mathrm{AEF}}=$ Almost Empry/Almost Full Flag.


Figure 15. Block Dlagram of $3 \mathrm{~K} / 6 \mathrm{~K} / 12 \mathrm{~K} \times 9$ FIFO Memory (Depth Expansion)
NOTE:

1. IDT only guarantees depth expansion with identical IDT part numbers and speed.


NOTES:
Figure 16. Compound FIFO Expansion

1. For depth expansion block see section od Depth Expansion and Figure 15.
2. For Flag detection see section on Width Expansion and Figure 14.


Figure 17. Bidirectional FIFO Mode


2677 d $w 21$
Figure 18. Read Data Flow-Through Mode

## NOTE:

1. Assume $\overline{\mathrm{OE}}$ is asserted low.


Figure 19. Write Data Flow-Through Mode

## NOTE:

1. Assume $\overline{Z E}$ is asserted low.

## ORDERING INFORMATION




Integrated Device Technology, Inc.

CMOS PARALLEL-SERIAL FIFO
$2048 \times 9$-BIT
\& $4096 \times 9$-BIT

## FEATURES:

- 35ns parallel port access time, 45ns cycle time
- 50 MHz serial input/output frequency
- Serial-to-parallel, parallel-to-serial, serial-to-serial, and parallel-to-parallel operations
- Expandable in both depth and width with no external components
- Flexishift ${ }^{T M}$ - Sets programmable serial word width from 4 bits to any width with no external components
- Multiple flags: Full, Almost-Full (Full-1/8),Full-MinusOne, Empty, Almost-Empty (Empty + 1/8), Empty-Plus One, and Half-Full
- Asynchronous and simultaneous read or write operations
- Dual-port, zero fall-through time architecture
- Retransmit capability in single-device mode
- Packaged in 40-pin ceramic and plastic DIP, 44-pin LCC and PLCC
- Military product compliant to MIL-STD-883, Class B


## APPLICATIONS:

- High-speed data acquisition systems
- Local area network (LAN) buffer
- High-speed modem data buffer
- Remote telemetry data buffer
- FAX raster video data buffer
- Laser printer engine data buffer
- High-speed parallel bus-to-bus communications
- Magnetic media controllers
- Serial link buffer


## DESCRIPTION:

The IDT72103/72104 are high-speed Parallel-Serial FIFOs to be used with high-performance systems for functions such as serial communications, laser printer engine control and local area networks.

A serial input, a serial output and two 9-bit parallel ports make four modes of data transfer possible: serial-to-parallel, parallel-to-serial, serial-to-serial, and parallel-to-parallel. The IDT72103/ 72104 are expandable in both depth and width for all of these operational configurations.

## FUNCTIONAL BLOCK DIAGRAM



## DESCRIPTION (CONTINUED)

The IDT72103/72104 may be configured to handle serial word widths of four or greater using IDT's unique Flexishift feature. Flexishift allows serial width and depth expansion without external components. For example, you may configure a $4 \mathrm{~K} \times 24$ FIFO using three IDT72104s in a serial width expansion contiguration.

Seven flags are provided to signal memory status of the FIFO. The flags are $\overline{\mathrm{FF}}$ (Full), $\overline{\mathrm{AF}}$ ( $7 / 8$ full), $\overline{\mathrm{FF}-1}$ (Full-minusone), $\overline{\mathrm{EF}}$ (Empty), $\overline{\mathrm{AE}}$ ( $1 / 8$ full), $\overline{\mathrm{EF}+1}$ (Empty-plus-one), and $\overline{\mathrm{HF}}$ (Half-full).

## PIN CONFIGURATIONS



Read ( $\overline{\mathrm{R}}$ ) and Write ( $\overline{\mathrm{W}}$ ) control pins are provided for asynchronous and simultaneous operations. An output enable ( $\overline{\mathrm{OE}}$ ) control pin is available on the paralleloutput port for high impedance control. The depth expansion control pins $\overline{\mathrm{XO}}$ and $\overline{\mathrm{XI}}$ are provided to allow cascading for deeper FIFOs.

The IDT72103/72104 are manufactured using IDT's CEMOSTM technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.


LCC/PLCC TOP VIEW

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2753 tol 03

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | VIN $=$ OV | 10 | pF |
| CoUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 12 | pF |
| NOTE: |  |  |  |  |

1. This parameter is sampled and not $100 \%$ tested.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccm | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| $\mathrm{VII}^{(1)}$ | Input Low Voltage | - | - | 0.8 | V |
| NOTE: |  |  |  |  |  |

NOTE:

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

## PIN DESCRIPTION

| Symbol | Name | VO | Description |
| :---: | :---: | :---: | :---: |
| Do-D8 | Data Inputs <br> Serial Input Word Width Select | 1/O | In a parallel input configuration - data inputs for 9-bit wide data. In a serial input configuration - one of the nine output pins is used to select the serial input word width. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal READ and WRITE pointers are set to the first location of the RAM array. $\overline{\mathrm{EF}}, \overline{\mathrm{EF}+1}, \overline{\mathrm{AEF}}$ are all LOW after a reset, while $\overline{\mathrm{FF}}, \overline{\mathrm{FF}}-1, \overline{\mathrm{HF}}$ are HIGH atter a reset. |
| $\bar{W}$ | Write | 1 | A parallel word write cycle is initiated on the falling edge of $\bar{W}$ if the $\overline{F F}$ is high. When the FIFO is full, FF will go low inhibiting further write operations to prevent data overflow. In a serial input configuration, databits are clocked into the input shift register and the write pointer does not advance until a full parallel word is assembled. One of the pins, Di , is connected to $\overline{\mathrm{W}}$ and advances the write pointer every i-th serial input clock. |
| $\overline{\mathbf{R}}$ | Read | 1 | A read cycle is initiated on the falling edge of $\overline{\mathrm{R}}$ if the $\overline{\mathrm{EF}}$ is high. After all the data from the FIFO has been read EF will go low Inhibiting further read operations. In a serial output configuration, a data word is read from memory into the output shift register. One of the pins, Qj , is connected to $\overline{\mathrm{R}}$ and advances the read pointer every j -th serial output clock. |
| $\overline{\text { FLRT }}$ | First Load/ Retransmit | 1 | This is a dual-purpose pin. In multiple-device mode, $\overline{F L} / \overline{\mathrm{RT}}$ is grounded to indicate the first device loaded. <br> In single-device mode, $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ acts as the retransmit input. Single-device mode is initiated by grounding the $\overline{\mathrm{XI}} \mathrm{pin}$. |
| $\overline{\mathrm{XI}}$ | Expansion In | 1 | In single-device mode, $\overline{X I}$ is grounded. In depth expansion or daisy chain mode, $\overline{\mathrm{XI}}$ is connected to the $\overline{\mathrm{XO}}$ pin of the previous device. |
| $\overline{\mathrm{OE}}$ | Output Enable | 1 | When $\overline{O E}$ is LOW, both parallel and serial outputs are enabled. When $\overline{\mathrm{OE}}$ is HIGH, the parallel output buffers are placed in a high-impedance state. |
| Q0-Q8 | Data Outputs / Serial Output Word Width Select | 0 | In a parallel output configuration - data outputs for 9-bit wide data. In a serial output configuration - one of nine output pins used to select the serial output word width. |
| $\overline{\mathrm{FF}}$ | Full Flag | 0 | $\overline{F F}$ is asserted LOW when the FIFO is full and further write operations are inhibited. When the FF is HIGH, the FIFO is not full and data can be written into the FIFO. |
| $\overline{\mathrm{FF}-1}$ | Full-1 Flag | 0 | $\overline{F F-1}$ goes LOW when the FIFO memory array is one word away from being full. It will remain LOW when every memory location is filled. |

## PIN DESCRIPTION

| Symbol | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{XO}} / \overline{\mathrm{HF}}$ | Expansion Out/ Half-Full Flag | 0 | $\overline{\mathrm{HF}}$ is LOW when the FIFO is more than half-full in the single device or width expansion modes. The $\overline{\mathrm{HF}}$ will remain LOW until the difference between the write and read pointers is less than or equal to one-half of the FIFO memory. <br> In depth expansion mode, a pulse is written from $\overline{X O}$ to $\overline{X 1}$ of the next device when the last location in the FIFO is filled. Another pulse is sent from $\overline{\mathrm{XO}}$ to $\overline{\mathrm{XI}}$ of the next device when the last FIFO location is read. |
| $\overline{\text { AEF }}$ | Almost-Empty/ Almost-Full Flag | 0 | When $\overline{\text { AEF }}$ is LOW, the FIFO is empty to $1 / 8$ full or $7 / 8$ full to completely full. I $\overline{A E F}$ is HIGH, then the FIFO is greater than $1 / 8$ full, but less than $7 / 8$ full. |
| EF+1 | Empty+1 Flag | 0 | $\overline{\mathrm{EF}+1}$ is LOW when there is zero or one word word in the FIFO memory array. |
| $\overline{\mathrm{EF}}$ | Empty Flag | 0 | $\overline{\mathrm{EF}}$ goes LOW when the FIFO is empty and further read operations are inhibited. $\overline{\mathrm{FF}}$ is HIGH when the FIFO is not empty and data reads are permitted. |
| SI | Serial Input | 1 | Data input for serial data. |
| SO | Serial Output | 0 | Data output for serial data. |
| SICP | Serial Input Clock | 1 | This pin is the serial input clock. On the rising edge of the SICP signal, new serial data bits are read into the serial input shift register. |
| SOCP | Serial Output Clock | I | This pin is the serial output clock. On the rising edge of the SOCP signal, new serial data bits are read from the serial output shift register. |
| SIX | Serial Input Expansion | 1 | SIX controls the serial input expansion for word widths greater than 9 bits. In a serial input configuration, the SIX pin of the least significant device is tied HIGH. The SIX pin of all other devices is connected to the De pin of the previous device. In parallel input configurations or serial input configurations of 9 bits or less, SIX is tied HIGH. |
| SOX | Serial Output Expansion | I | SOX controls the serial output expansion for word widths greater than 9 bits. In a serial output configuration, the SOX pin of the least significant device is tied HIGH. The SOX pin of all other devices is connected to the Qs pin of the previous device. In parallel output configurations or serial output configurations of 9 bits or less, SOX is tied HIGH. |
| $\overline{\text { SI/ PI }}$ | Serial/Parallel Input | 1 | When this pin is HIGH, the FIFO is in a parallel input configuration and accepts input data through Do-D8. When $\overline{\mathrm{SI}} / \mathrm{PI}$ is LOW, the FIFO is in a serial input configuration and data is input through SI . |
| $\overline{\mathrm{SO}} / \mathrm{PO}$ | Serial/Parallel Output | I | When this pin is HIGH, the FIFO is in a parallel output configuration and sends output data through Q0-Q8. When $\overline{\mathrm{SO}} / \mathrm{PO}$ is LOW the FIFO is in a serial output configuration and data is input through SO. |
| GND | Ground |  | One ground pin for the DIP package and five ground pins for the LCC/PLCC packages. |
| Vcc | Power |  | One + 5V power pin. |

DC ELECTRICAL CHARACTERISTICS
(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { IDT72103/72104 } \\ \text { Commercial } \\ \mathrm{tA}=35,50,65,80,120 \mathrm{~ns} \end{gathered}$ |  |  | $\begin{gathered} \text { IDT72103/72104 } \\ \text { Milltary } \\ \text { tA }=40,50,65,80,120 \mathrm{~ns} \end{gathered}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| IIL ${ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{lax}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, lout $=-2 m A^{(4)}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage, lout $=8 \mathrm{~mA}^{(5)}$ | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{ICCl}^{(3)}$ | Average Vcc Power Supply Current | - | 90 | 140 | - | 100 | 160 | mA |
| $\mathrm{lcC2}^{(3)}$ | $\begin{aligned} & \text { Average Standby Current } \\ & (\bar{R}=\bar{W}=\overline{R S}=\overline{F L} / \overline{R T}=V I H) \\ & (S O C P=S I C P=V I L) \end{aligned}$ | - | 8 | 12 | - | 12 | 25 | mA |
| $\operatorname{ICCO}(\mathrm{L})^{(3,6)}$ | Power Down Current | - | - | 2 | - | - | 4 | mA |
| $\operatorname{Iccs}(\mathrm{S})^{(3,6)}$ | Power Down Current | - | - | 8 | - | - | 12 | mA |

NOTES:

1. Measurements with $0.4 \leq \mathrm{Vin} \leq \mathrm{Vcc}$.
2. $\overline{\mathrm{R}} \geq \mathrm{VIH}, \mathrm{SOCP} \leq \mathrm{VIL}, 0.4 \leq$ Vout $\leq \mathrm{Vcc}$.
3. ICC measurements are made with outputs open.
4. For SO, Iout $=-8 \mathrm{~mA}$.
5. For SO, lout $=16 \mathrm{~mA}$.
6. $\operatorname{SOCP}=\mathrm{SICP} \leq 0.2 \mathrm{~V}$; other Inputs $=\mathrm{V} C C-0.2 \mathrm{~V}$.

AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 3ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |


or equivalent circuit
Flgure 1. Ouput Load
*Includins jig and scope capacitances

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Com | erclal |  |  | Mil. and | Com'l. | Unit | Tlming <br> Flgure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { IDT72103×35 } \\ & \text { IDT72104×35 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72103×40 } \\ & \text { IDT72104×40 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT } 72103 \times 50 \\ & \text { IDT } 72104 \times 50 \\ & \hline \end{aligned}$ |  |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| fs | Parallel Shift Frequency | - | 22.2 | - | 20 | - | 15 | MHz | - |
| fSOCP | Serial-Out Shift Frequency | - | 50 | - | 50 | - | 40 | MHz | - |
| fSICP | Serial-In Shift Frequency | - | 50 | - | 50 | - | 40 | MHz | - |

PARALLEL-OUTPUT MODE TIMINGS

| tA | Access Time | - | 35 | - | 40 | - | 50 | ns | 4 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRR | Read Recovery Time | 10 | - | 10 | - | 15 | - | ns | 4 |
| tRPW | Read Pulse Width | 35 | - | 40 | - | 50 | - | ns | 4 |
| trC | Read Cycle Time | 45 | - | 50 | - | 65 | - | ns | 4 |
| twLZ | Write Pulse Low to Data Bus at Low Z |  |  |  |  |  |  |  |  |
| tRLZ | Read Pulse Low to Data Bus at Low Z |  |  |  |  |  |  |  |  |
| (RHZ | Read Pulse High to Data Bus at High Z |  |  |  |  |  |  |  |  |
| $(1)$ | 5 | - | 5 | - | 15 | - | ns | 15 |  |
| tDV | Data Valid from Read Pulse High | 5 | - | 5 | - | 10 | - | ns | 4 |

PARALLEL-INPUT MODE TIMINGS

| tDS | Data Set-up Time | 18 | - | 20 | - | 30 | - | ns | 3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tDH | Data Hold Time | 0 | - | 0 | - | 5 | - | ns | 3 |
| twc | Write Cycle Time | 45 | - | 50 | - | 65 | - | ns | 3 |
| twPW | Write Pulse Width | 35 | - | 40 | - | 50 | - | ns | 3 |
| twR | Write Recovery Time | 10 | - | 10 | - | 15 | - | ns | 3 |
| RESET TIMINGS |  |  |  |  |  |  |  |  |  |
| tRSC | Reset Cycle Time | 45 | - | 50 | - | 65 | - | ns | 2,18 |
| tRS | Reset Pulse Width | 35 | - | 40 | - | 50 | - | ns | 2,18 |
| tRSS | Reset Set-up Time | 35 | - | 40 | - | 50 | - | ns | 2,18 |
| tRSR | Reset Recovery Time | 10 | - | 10 | - | 15 | - | ns | 2,17,18 |

## RESET TO FLAG TIMINGS

| trSF1 | Reset to $\overline{\mathrm{EF}}, \overline{\mathrm{AEFF}}$, and $\overline{\mathrm{EF}+1}$ Low | - | 45 | - | 50 | - | 65 | ns | 2 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: | :---: |
| trSF2 | Reset to $\overline{\mathrm{HF}}, \overline{\mathrm{FF}}$, and $\overline{\mathrm{FF}-1}$ Low | - | 45 | - | 50 | - | 65 | ns | 2 |

RESET TO OUTPUT TIMINGS - SERIAL MODE ONLY

| trSQ | Reset Going Low to Q0-8 Low | 20 | - | 20 | - | 35 | - | ns | 18 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRSOH | Reset Going High to Q0-8 High | 20 | - | 20 | - | 35 | - | ns | 18 |
| tRSDL | Reset Going Low to D0-8 Low | 20 | - | 20 | - | 35 | - | ns | 17 |

## RETRANSMIT TIMINGS

| tRTC | Retransmit Cycle Time | 45 | - | 50 | - | 65 | - | ns | 5 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRT | Retransmit Pulse Width | 35 | - | 40 | - | 50 | - | ns | 5 |
| tRTS | Retransmit Set-up Time | 35 | - | 40 | - | 50 | - | ns | 5 |
| tRTR | Retransmit Recovery Time | 10 | - | 10 | - | 15 | - | ns | 5 |

PARALLEL MODE FLAG TIMINGS

| tref | Read Low to EF Low | - | 30 | - | 35 | - | 45 | ns | 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRFF | Read High to $\overline{\text { FF High }}$ | - | 30 | - | 35 | - | 45 | ns | 7 |
| tRF | Read High to Transitioning $\overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$ and $\overline{\mathrm{FF}}-1$ | - | 45 | - | 50 | - | 65 | ns | 8,9,10 |
| tRE | Read Low to Transitioning $\overline{\mathrm{AEF}}$ and $\overline{\mathrm{EF}+1}$ | - | 45 | - | 45 | - | 65 | ns | 11 |
| tRPE | Read Pulse Width after EF High | 35 | - | 40 | - | 50 | - | ns | 15 |
| tWEF | Write High to EF High | - | 30 | - | 35 | - | 45 | ns | 6 |
| tWFF | Write Low to FF Low | - | 30 | - | 35 | - | 45 | ns | 7 |
| tWF | Write Low to Transitioning $\overline{\mathrm{HF}}, \overline{\mathrm{AEFF}}$ and $\overline{\mathrm{FF}-1}$ | - | 45 | - | 50 | - | 65 | ns | 8,9,10 |
| tWE | Write High to Transitioning $\overline{\mathrm{AEF}}$ and $\overline{\mathrm{EF}+1}$ | - | 45 | - | 50 | - | 65 | ns | 11 |
| tWPF | Write Pulse Width after FF High | 35 | - | 40 | - | 50 | - | ns | 16 |

NOTE:

1. Values guaranteed by design, not tested.

## AC ELECTRICAL CHARACTERISTICS (Continued)

(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commercial and Military |  |  |  |  |  | Unit | Tlming Flgure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IDT72103x65 IDT72104x65 |  | $\begin{aligned} & \text { IDT72103×80 } \\ & \text { IDT72104×80 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72103×120 } \\ & \text { IDT72104×120 } \end{aligned}$ |  |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| fs | Parallel Shift Frequency | - | 12.5 | - | 10 | - | 7 | MHz | - |
| fSOCP | Serial-Out Shift Frequency | - | 33 | - | 28 | - | 25 | MHz | - |
| fsicP | Serial-In Shift Frequency | - | 33 | - | 28 | - | 25 | MHz | - |
| PARALLEL-OUTPUT MODE TIMINGS |  |  |  |  |  |  |  |  |  |
| tA | Access Time | - | 65 | - | 80 | - | 120 | ns | 4 |
| tRR | Read Recovery Time | 15 | - | 20 | - | 20 | - | ns | 4 |
| tRPW | Read Pulse Width | 65 | - | 80 | - | 120 | - | ns | 4 |
| tRC | Read Cycle Time | 80 | - | 100 | - | 140 | - | ns | 4 |
| twLz | Write Pulse Low to Data Bus at Low ${ }^{\text {(1) }}$ | 15 | - | 20 | - | 20 | - | ns | 15 |
| tRLZ | Read Pulse Low to Data Bus at Low ${ }^{(1)}$ | 10 | - | 10 | - | 10 | - | ns | 4 |
| tRHZ | Read Pulse High to Data Bus at High $\mathbf{Z}^{(1)}$ | - | 30 | - | 35 | - | 35 | ns | 4 |
| tov | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | ns | 4 |
| PARALLEL-INPUT MODE TIMINGS |  |  |  |  |  |  |  |  |  |
| tDS | Data Set-up Time | 30 | - | 40 | - | 40 | - | ns | 3 |
| tDH | Data Hold Time | 10 | - | 10 | - | 10 | - | ns | 3 |
| twC | Write Cycle Time | 80 | - | 100 | - | 140 | - | ns | 3 |
| twPW | Write Pulse Width | 65 | - | 80 | - | 120 | - | ns | 3 |
| tWR | Write Recovery Time | 15 | - | 20 | - | 20 | - | ns | 3 |
| RESET TIMINGS |  |  |  |  |  |  |  |  |  |
| tRSC | Reset Cycle Time | 80 | - | 100 | - | 140 | - | ns | 2,18 |
| thS | Reset Pulse Width | 65 | - | 80 | - | 120 | - | ns | 2,18 |
| tRSS | Reset Set-up Time | 65 | - | 80 | - | 120 | - | ns | 2,18 |
| tRSR | Reset Recovery Time | 15 | - | 20 | - | 20 | - | ns | 2,17,18 |

RESET TO FLAG TIMINGS

| tRSF1 | Reset to $\overline{\mathrm{EF}}, \overline{\mathrm{AEF}}$, and $\overline{\mathrm{EF}+1}$ Low | - | 80 | - | 100 | - | 140 | ns | 2 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| trSF2 | Reset to $\overline{\mathrm{HF}}, \overline{\mathrm{FF}}$, and $\overline{\mathrm{FF}}-1 \mathrm{Low}$ | - | 80 | - | 100 | - | 140 | ns | 2 |

RESET TO OUTPUT TIMINGS - SERIAL MODE ONLY

| trsal | Reset Going Low to Q0-8 Low | 50 | - | 65 | - | 105 | - | ns | 18 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRSOH | Reset Going High to Q0.8 High | 50 | - | 65 | - | 105 | - | ns | 18 |
| tRSDL | Reset Going Low to Do-8 Low | 50 | - | 65 | - | 105 | - | ns | 17 |
| RETRANSMIT TIMINGS |  |  |  |  |  |  |  |  |  |
| tRTC | Retransmit Cycle Time | 80 | - | 100 | - | 140 | - | ns | 5 |
| trT | Retransmit Pulse Width | 65 | - | 80 | - | 120 | - | ns | 5 |
| tRTS | Retransmit Set-up Time | 65 | - | 80 | - | 120 | - | ns | 5 |
| tRTR | Retransmit Recovery Time | 15 | - | 20 | - | 20 | - | ns | 5 |

PARALLEL MODE FLAG TIMINGS

| tREF | Read Low to EF Low | - | 60 | - | 60 | - | 60 | ns | 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRFF | Read High to FF High | - | 60 | - | 60 | - | 60 | ns | 7 |
| tRF | Read High to Transitioning $\overline{\text { HF, }} \overline{\text { AEF }}$ and $\overline{\mathrm{FF}-1}$ | - | 80 | - | 100 | - | 140 | ns | 8,9,10 |
| tre | Read Low to Transitioning $\overline{\mathrm{AEF}}$ and $\overline{\mathrm{EF}+1}$ | - | 80 | - | 100 | - | 140 | ns | 11 |
| tRPE | Read Pulse Width after EF High | 65 | - | 80 | - | 120 | - | ns | 15 |
| twef | Write High to EF High | - | 60 | - | 60 | - | 60 | ns | 6 |
| tWFF | Write Low to FF Low | - | 60 | - | 60 | - | 60 | ns | 7 |
| tWF | Write Low to Transitioning $\overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$ and $\overline{\mathrm{FF}}$-1 | - | 80 | - | 100 | - | 140 | ns | 8,9,10 |
| twe | Write High to Transitioning $\overline{\text { AEF }}$ and $\overline{\mathrm{EF}+1}$ | - | 80 | - | 100 | - | 140 | ns | 11 |
| tWPF | Write Pulse Width after FF High | 65 | - | 80 | - | 120 | - | ns | 16 |

NOTE:

1. Values guaranteed by design, not tested.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{aligned} & \hline \text { Commerclal } \\ & \hline \text { IDT72103×35 } \\ & \text { IDT72104×35 } \\ & \hline \end{aligned}$ |  | Milltary <br> IDT72103×40 <br> IDT72104×40 |  | $\begin{aligned} & \hline \text { Mil. and Com'I. } \\ & \hline \text { IDT72103×50 } \\ & \text { IDT } 72104 \times 50 \\ & \hline \end{aligned}$ |  | Unit | Timing Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |

## DEPTH EXPANSION MODE TIMINGS

| txol. | Read/Write to XO Low | - | 35 | - | 40 | - | 50 | ns | 13 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tXOH | Read/Write to XO High | - | 35 | - | 40 | - | 50 | ns | 13 |
| tx | $\overline{\mathrm{XI}}$ Pulse Width | 35 | - | 40 | - | 50 | - | ns | 14 |
| tXIR | $\overline{\text { XI Recovery Time }}$ | 10 | - | 10 | - | 10 | - | ns | 14 |
| txIS | $\overline{\text { XI Set-up Time }}$ | 15 | - | 15 | - | 15 | - | ns | 14 |

SERIAL-INPUT MODE TIMINGS

| ts2 | Serial Data In Set-up Time to SICP Rising Edge | 12 | - | 12 | - | 15 | - | ns | 19 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tH2 | Serial Data In Hold Time to SICP Rising Edge | 0 | - | 0 | - | 0 | - | ns | 19 |
| ts3 | SIX Set-up Time to SICP Rising Edge | 5 | - | 5 | - | 5 | - | ns | 19 |
| ts4 | $\bar{W}$ Set-up Time to SICP Rising Edge | 5 | - | 5 | - | 5 | - | ns | 19 |
| tH4 | $\bar{W}$ Hold Time to SICP Rising Edge | 7 | - | 7 | - | 7 | - | ns | 19 |
| tsicw | Serial In Clock Width High/Low | 8 | - | 8 | - | 10 | - | ns | 19 |
| ts5 | SUPI Set-up Time to SICP Rising Edge | 35 | - | 40 | - | 50 | - | ns | 19 |

SERIAL-OUTPUT MODE TIMINGS

| tS6 | SO/PO Set-up Time to SOCP Rising Edge | 35 | - | 40 | - | 50 | - | ns | 20 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tS7 | SOX Set-up Time to SOCP Rising Edge | 5 | - | 5 | - | 5 | - | ns | 20 |
| ts8 | $\bar{R}$ Set-up Time to SOCP Rising Edge | 5 | - | 5 | - | 5 | - | ns | 20 |
| th8 | $\bar{R}$ Hold Time to SOCP Rising Edge | 7 | - | 7 | - | 7 | - | ns | 20 |
| tsocw | Serial Out Clock Width High/Low | 8 | - | 8 | - | 10 | - | ns | 20 |

SERIAL MODE RECOVERY TIMINGS

| tREFSO | Recovery Time SOCP after EF Goes High | 35 | - | 40 | - | 80 | - | ns | 22 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRFFSI | Recovery Time SICP after FF Goes High | 15 | - | 15 | - | 15 | - | ns | 23 |

SERIAL MODE FLAG TIMINGS

| tSOCEF | SOCP Rising Edge (Bit 0-Last Word) to EFF Low | - | 20 | - | 25 | - | 25 | ns | 22 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tSOCFF | SOCP Rising Edge (Bit 0-First Word) to FFF High | - | 30 | - | 35 | - | 40 | ns | 24 |
| tSOCF | SOCP Rising Edge to $\overline{F F-1}, \overline{H F}, \overline{\text { AEF }}$ High | - | 30 | - | 35 | - | 40 | ns | 24,26 |
| tSOCF | SOCP Rising Edge to $\overline{A E F}, \overline{\mathrm{EF}}, \mathrm{EF}+1$ Low | - | 30 | - | 35 | - | 40 | ns | 22,26 |
| tSICEF | SICP Rising Edge (Last Bit-First Word) to EF High | - | 45 | - | 50 | - | 65 | ns | 21 |
| tSICFF | SICP Rising Edge (Bit 1-Last Word) to FF Low | - | 30 | - | 35 | - | 40 | ns | 23 |
| tsicF | SICP Rising Edge to $\overline{E F+1}, \overline{A E F}$ High | - | 45 | - | 50 | - | 65 | ns | 21,25 |
| tsicF | SICP Rising Edge to $\overline{\mathrm{FF}-1}, \overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$ High | - | 45 | - | 50 | - | 65 | ns | 23,25 |

SERIAL-INPUT MODE TIMINGS

| tPD1 | SICP Rising Edge to $\mathrm{D}^{(1)}$ | 5 | 17 | 5 | 17 | 5 | 20 | ns | 17,19 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SERIAL-OUTPUT MODE TIMINGS |  |  |  |  |  |  |  |  |  |
| tPD2 | SOCP Rising Edge to Q ${ }^{(1)}$ | 5 | 17 | 5 | 17 | 5 | 20 | ns | 20 |
| tSOHZ | SOCP Rising Edge to SO at High-Z ${ }^{(1)}$ | 5 | 16 | 5 | 16 | 5 | 16 | ns | 20 |
| tSOLZ | SOCP Rising Edge to SO at Low-Z ${ }^{(1)}$ | 5 | 22 | 5 | 22 | 5 | 22 | ns | 20 |
| tSOPD | SOCP Rising Edge to Valid Data on SO | - | 18 | - | 18 | - | 18 | ns | 20 |

## OUTPUT ENABLE/DISABLE TIMINGS

| tOEHZ | Output Enable to High-Z (Disable) ${ }^{(1)}$ | - | 16 | - | 16 | - | 16 | ns | 12 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| toeLZ | Output Enable to Low-Z (Enable) $)^{(1)}$ | 5 | - | 5 | - | 5 | - | ns | 12 |
| tAOE | Output Enable to Data Valid (CO-8) | - | 20 | - | 20 | - | 22 | ns | 12 |

NOTE:

1. Values guaranteed by design, not tested.

## AC ELECTRICAL CHARACTERISTICS (Continued)

(Commercial: Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commerclal and Military |  |  |  |  |  | Unit | Timing Flgure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { IDT72103×65 } \\ & \text { iDT72104×65 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { IDT } 72103 \times 80 \\ & \text { IDT72104×80 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72103×120 } \\ & \text { IDT72104×120 } \end{aligned}$ |  |  |  |
|  |  | Min. | Max. | Min. | Miax. | Min. | Max. |  |  |
| DEPTH EXPANSION MODE TIMINGS |  |  |  |  |  |  |  |  |  |
| txOL | Read/Write to XO Low | - | 65 | - | 80 | - | 120 | ns | 13 |
| +XOH | Read/Write to $\overline{\mathrm{XO}}$ High | - | 65 | - | 80 | - | 120 | ns | 13 |
| t×1 | $\overline{\text { XI Pulse Width }}$ | 65 | - | 80 | - | 120 | - | ns | 14 |
| +XIR | $\overline{\text { XI Recovery Time }}$ | 10 | - | 10 | - | 10 | - | ns | 14 |
| txIS | $\overline{\text { XI Set-up Time }}$ | 15 | - | 15 | - | 15 | - | ns | 14 |

SERIAL-INPUT MODE TIMINGS

| tS2 | Serial Data In Set-up Time to SICP Rising Edge | 15 | - | 20 | - | 20 | - | ns | 19 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{tH2}$ | Serial Data In Hold Time to SICP Rising Edge | 0 | - | 5 | - | 5 | - | ns | 19 |
| tS3 | SIX Set-up Time to SICP Rising Edge | 5 | - | 5 | - | 5 | - | ns | 19 |
| tS4 | $\bar{W}$ Set-up Time to SICP Rising Edge | 5 | - | 5 | - | 5 | - | ns | 19 |
| tH4 | $\bar{W}$ Hold Time to SICP Rising Edge | 10 | - | 12 | - | 15 | - | ns | 19 |
| tSICW | Serial In Clock Width High/Low | 10 | - | 15 | - | 15 | - | ns | 19 |
| tS5 | SUPI Set-up Time to SICP Rising Edge | 65 | - | 80 | - | 120 | - | ns | 19 |

SERIAL-OUTPUT MODE TIMINGS

| ts6 | SO/PO Set-up Time to SOCP Rising Edge | 65 | - | 80 | - | 120 | - | ns | 20 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{ts7}$ | SOX Set-up Time to SOCP Rising Edge | 5 | - | 5 | - | 5 | - | ns | 20 |
| $\mathrm{ts8}$ | $\overline{\mathrm{R}}$ Set-up Time to SOCP Rising Edge | 5 | - | 5 | - | 5 | - | ns | 20 |
| tH8 | $\overline{\mathrm{R}}$ Hold Time to SOCP Rising Edge | 10 | - | 12 | - | 15 | - | ns | 20 |
| tsocw | Serial Out Clock Width High/Low | 10 | - | 15 | - | 15 | - | ns | 20 |

SERIAL MODE RECOVERY TIMINGS

| tREFSO | Recovery Time SOCP after EF Goes High | 65 | - | 80 | - | 120 | - | ns | 22 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRFFSI | Recovery Time SICP after FF Goes High | 15 | - | 20 | - | 20 | - | ns | 23 |

SERIAL. MODE FLAG TIMINGS

| tSOCEF | SOCP Rising Edge (Bit 0-Last Word) to EF Low | - | 30 | - | 30 | - | 30 | ns | 22 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tSOCFF | SOCP Rising Edge (Bit 0- First Word) to FFF High | - | 50 | - | 60 | - | 60 | ns | 24 |
| tSOCF | SOCP Rising Edge to $\overline{F F-1}, \overline{H F}, \overline{\text { AEF }}$ High | - | 50 | - | 60 | - | 60 | ns | 24,26 |
| tSOCF | SOCP Rising Edge to $\overline{A E F}, \overline{\mathrm{EF}}, \overline{\mathrm{E}} \overline{+1}$ Low | - | 50 | - | 60 | - | 60 | ns | 22,26 |
| tsicef | SICP Rising Edge (Last Bit-First Word) to EF High | - | 80 | - | 80 | - | 80 | ns | 21 |
| tSICFF | SICP Rising Edge (Bit 1-Last Word) to FF Low | - | 50 | - | 60 | - | 60 | ns | 23 |
| tSICF | SICP Rising Edge to $\overline{\mathrm{EF}+1}, \overline{\mathrm{AEF}}$ High | - | 80 | - | 80 | - | 80 | ns | 21,25 |
| tSICF | SICP Rising Edge to $\overline{\mathrm{FF}-1}, \overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$ High | - | 80 | - | 80 | - | 80 | ns | 23,25 |

SERIAL-INPUT MODE TIMINGS

| tPD1 | SICP Rising Edge to $D^{(1)}$ | 5 | 25 | 5 | 30 | 5 | 35 | ns | 17,19 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

SERIAL-OUTPUT MODE TIMINGS

| tPD2 | SOCP Rising Edge to Q |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| (1) | 5 | 25 | 5 | 30 | 5 | 35 | ns | 20 |  |
| tSOHZ | SOCP Rising Edge to SO at High-Z | $(1)$ | 5 | 20 | 5 | 25 | 5 | 30 | ns |
| tSOLZ | SOCP Rising Edge to SO at Low- Z $^{(1)}$ | 5 | 22 | 5 | 30 | 5 | 35 | ns | 20 |
| tSOPD | SOCP Rising Edge to Valid Data on SO | - | 22 | 5 | 30 | 5 | 35 | ns | 20 |

## OUTPUT ENABLEIDISABLE TIMINGS

| toenz | Output Enable to High-Z (Disable) ${ }^{(1)}$ | - | 20 | - | 25 | - | 30 | ns | 12 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| toelz | Output Enable to Low-Z (Enable) ${ }^{(1)}$ | 5 | - | 5 | - | 5 | - | ns | 12 |
| taOE | Output Enable to Data Valid (Q0-8) | - | 25 | - | 30 | - | 35 | ns | 12 |

NOTE:
2753 drw 1

1. Values guaranteed by design, not tested.

## GENERAL SIGNAL DESCRIPTION

## INPUTS:

Data Inputs (D0-D8)
The parallel-in mode is selected by connecting the $\overline{\mathrm{SI}} / \mathrm{Pl}$ pin to Vcc. Do-Ds are the data input lines.

The serial-input mode is selected by grounding the $\overline{\mathrm{Sl}} / \mathrm{PI}$ pin. The Do-Ds lines are control output pins used to program the serial word width.

## Reset ( $\overline{\mathrm{RS}}$ )

Reset is accomplished whenever the $\overline{\mathrm{RS}}$ input is taken to a low state. Both internal read and write pointers are set to the first location during reset. A reset is required after power up before a write operation can take place. Both Read $(\bar{R})$ and Write $(\bar{W})$ inputs must be high during reset.

## Write ( $\bar{W}$ )

A write cycle is initiated on the falling edge of $\bar{W}$ provided the Full Flag ( $\overline{\mathrm{FF}}$ ) is not asserted. Data set-up and hold times must be met with respect to the rising edge of $\bar{W}$. Data is stored in the RAM array sequentially and independently of any on going read operation.

When the FIFO is full, the $\overline{\mathrm{FF}}$ will go low inhibiting further write operations to prevent data overflow. After a valid read operation is completed, the $\overline{F F}$ will go high after tRFF allowing a valid write to begin.

## Read ( $\overline{\mathrm{R}}$ )

A read cycle is initiated on the falling edge of $\vec{R}$, provided the $\overline{E F}$ is not set. Data is accessed on a first-in/first out basis independent of any on going write operations. After $\overline{\mathrm{R}}$ goes high, the Data Outputs ( $\mathrm{Q}_{0}-\mathrm{Q}_{8}$ ) go to a high impedance condition until the next read operation. When all the data has been read from the FIFO, the EF will go low, and Qo-Qs will go to a high impedance state inhibiting further read operations. After the completion of a valid write operation, the EF will go high after tWEF allowing a valid read to begin.

## Flrst Load/Retransmit ( $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ )

In the depth-expansion mode, the $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ pin is grounded to indicate that it is the first device loaded. In the single-device mode, the $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ pin acts as the retransmit input. The singledevice mode is initiated by grounding the Expansion-In ( $\overline{\mathrm{XI}})$ pin.

The IDT72103/72104 can be made to retransmit data when the $\overline{\mathrm{RT}}$ input is pulsed low. A retransmit operation will set the internal read pointer to the first location and will not affect the write pointer. During retransmit, $\overline{\mathrm{R}}$ and $\overline{\mathrm{W}}$ must be set high and the $\overline{\mathrm{FF}}$ will be affected depending on the relative locations of the read and write pointers. This feature is useful when less than 2048/4096 writes are performed between resets. The retransmit feature is not available in the depth expansion mode.

## Expansion In ( $\overline{\mathrm{XI}})$

The $\overline{\mathrm{XI}}$ pin is grounded to indicate an operation in the the single-device mode. In the depth expansion or daisy-chain mode, the $\overline{\mathrm{XI}}$ pin is connected to the $\overline{\mathrm{XO}}$ pin of the previous device.

## Output Enable ( $\overline{\mathrm{OE}}$ )

When $\overline{O E}$ is high, the parallel output buffers are tristated. When $\overline{O E}$ is low, both parallel and serial outputs are enabled.

## Serial Input (SI)

Serial data is read into the serial input register via the SI pin. In both depth and serial width expansion modes, the serialinput signals of the different FIFOs in the expansion array are connected together.

## Serlal Input Clock (SICP)

Serial data is read into the serial input register on the rising edge of the SICP signal. In both depth and serial width expansion modes, the SICP signals of the different FIFOs in the expansion array are connected together.

## Serial Output Clock (SOCP)

New serial data bits are read from the serial output register on the rising edge of the SOCP signal. In both depth and serial width expansion modes, the SOCP signals of the different FIFOs in the expansion array are connected together.

## Serial Input Expansion (SIX)

The SIX pin is tied high for single-device serial or parallel input operation. In a serial input configuration, the SIX pin of the least significant device is tied HIGH. The SIX pin of all other devices is connected to the Ds pin of the previous device.

## Serlal Output Expansion (SOX)

The SOX pin is tied high for single-device serial or parallel output operation. In a serial output configuration, the SOX pin of the least significant device is tied HIGH. The SOX pin of all other devices is connected to the Q8 pin of the previous device.

## Serial/Parallel Input ( $\overline{\mathrm{SI}} / \mathrm{PI}$ )

The $\overline{\mathrm{SI}} / \mathrm{PI}$ pin programs whether the IDT72103/72104 accepts parallel or serial data as input. When this pin is low, the FIFO expects serial data and the Do-D8 pins become output pins used to program the write signal and the serial input word width. For instance, connecting D8 to $\bar{W}$ will program a serial word width of 7 bits; connecting D7 to $\bar{W}$ will program a serial word width of 8 bits and so on.

## Serial/Parallel Output ( $\overline{\mathrm{SO}} / \mathrm{PO}$ )

The $\overline{\mathrm{SO}} / \mathrm{PO}$ pin programs whether the IDT72103/72104 outputs parallel or serial data. When this pin is low, the FIFO expects serial data and the Q0-Q8 pins output signals used to program the read signal and the serial output word width.

## OUTPUTS:

## Data Outputs (Q0-Q8)

Data outputs for 9-bit wide data. These output lines are in a high impedance condition whenever $\bar{R}$ is in a high state. The serial output mode is selected by grounding the $\overline{\mathrm{SO}} / \mathrm{PO}$ pin. The Qo-Q8 lines are control pins used to program the serial word width.

## Serial Output (SO)

Serial data is output on the SO pin. In both depth and serial width expansion modes the serial output signals of the different FIFOs in the expansion array are connected together. Following reset, SO is tristated until the first rising edge of the Serial Out Clock (SOCP) signal. Data is clocked out least significant bit first. In the serial width expansion mode, SO is tristated again after the ninth bit is output.

## Full Flag ( $\overline{\mathrm{FF}}$ )

$\overline{\mathrm{FF}}$ is asserted low when the FIFO is full. When the FIFO is full, the internal write pointer will not be incremented by any additional write pulses.

## Full Flag - Serial In Mode

Whenthe FIFO is loaded serially, the Serial In Clock (SICP) asserts the $\overline{F F}$. On the second rising edge of the SICP for the last word in the FIFO, the $\overline{\text { FF }}$ will assert low, and it will remain asserted until the next read operation. Note that when the FF is asserted, the last SICP for that word will have to be stretched as shown in Figure 23.

## Full Flag - Parallel-In Mode

When the FIFO is in the Parallel-In mode, the falling edge of $\bar{W}$ asserts the $\overline{\mathrm{FF}}$ (low). The $\overline{\mathrm{FF}}$ is then de-assented (high) by subsequent read operations - either serial or parallel.

## Full-Minus-One Flag ( $\overline{F F-1}$ )

The $\overline{F F-1}$ flag is asserted low when the FIFO is one word away from being full. It will remain asserted when the FIFO is full.

## Expansion Out/Half-Full Flag ( $\overline{\mathrm{XO}} / \overline{\mathrm{HF}}$ )

In the single-device mode, the $\overline{X O} / \overline{\mathrm{HF}}$ pin operates as a $\overline{\mathrm{HF}}$ pin when the $\overline{\mathrm{XI}}$ pin is grounded. After half of the memory is filled, the $\overline{H F}$ will be set to low at the falling edge of the next write operation. It will remain set until the difference between the write pointer and read pointer is less than or equal to onehalf of the FIFO total memory. The $\overline{\mathrm{HF}}$ is then reset by the rising edge of the read operation.

In the multiple-device mode, the $\overline{X I}$ pin is connected to the $\overline{X O}$ pin of the previous device. The $\overline{X O}$ pin signals a pulse to the next device when the previous device reaches the best location of memory in the daisy chain configuration.

## Almost-Empty or Almost-Full Flag ( $\overline{\mathrm{AEF}}$ )

The $\overline{A E F}$ asserts low if there are 0-255 or 1793-2048 bytes in the IDT72103, $2 \mathrm{~K} \times 9$ FIFO. The $\overline{\text { AEF }}$ asserts low if there are 0-511 or 3585-4096 bytes in the IDT72104, $4 \mathrm{~K} \times 9$ FIFO.

## Empty-Plus-One Flag ( $\overline{\mathrm{EF}+1}$ )

In the parallel-output mode, the $\overline{E F+1}$ flag is asserted low when there is one word or less in the FIFO. It will remain low when the FIFO is empty.

In the serial-output mode, the $\overline{E F+1}$ flag operates as an $\overline{\mathrm{EF}+2}$ flag. It goes low when the second to the last word is read from the RAM array and is ready to be shifted out.

## Empty Flag ( $\overline{E F}$ ) - Parallel-Out Mode

When the FIFO is in the parallel out mode and there is only one word in the FIFO, the falling edge of the $\overline{\mathrm{R}}$ line will cause the $\overline{E F}$ line to be asserted low. This is shown in Figure 6. The $\overline{E F}$ is then de-asserted high by either the rising edge of $\bar{W}$ or the rising edge of SICP, as shown in Figure 6.

## Empty Flag - Serlal-Out Mode

The use of the EF is important for proper serial-out operation when the FIFO is almost empty. The EF flag is asserted low after the first bit of the last word is shifted out. This is shown in Figure 22.

## TABLE 1 - STATUS FLAGS

| $\begin{array}{r} \text { Nun } \\ \text { Word } \\ \text { IDT72132 } \end{array}$ | er of <br> In FIFO IDT72142 | $\overline{\text { FF }}$ | $\overline{\text { FF-1 }}$ | $\overline{\text { AEF }}$ | $\overline{H F}$ | $\left\lvert\, \frac{(1)}{E F+1}\right.$ | EF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | H | H | L | H | L | L |
| 1 | 1 | H | H | L | H | L | H |
| 2-255 | 2-511 | H | H | L | H | H | H |
| 256-1024 | 512-2048 | H | H | H | H | H | H |
| 1025-1792 | 2049-3584 | H | H | H | L | H | H |
| 1793-2046 | 3585-4094 | H | H | L | L | H | H |
| 2047 | 4095 | H | L | L | L | H | H |
| 2048 | 4096 | L | L | L | L | H | H |

## NOTE:

2753 bl 12

1. $\overline{E F+1}$ acts as $E F+2$ in the serial out mode.

## PARALLEL TIMINGS:



## NOTE:

2753 drw 05

1. All flags may change status during Reset, but flags will be valid at trsc.

Figure 2. Reset



NOTE:

1. All flags may change status during Retransmit, but flags will be valid at trtc.

Figure 5. Retransmit


NOTES:

1. Data is valid on this edge.
2. The Empty Flag is asserted by $\bar{R}$ in the Parallel-Out mode and is specified by tref. The $E F$ flag is deassoted by the rising edge of $W$.
3. First rising edge of Write after EF is set.

Figure 6. Empty Flag Timings in Parallel Out Mode


## NOTE:

1. For the assertion time, twFF is used when data is written in the Parallel mode. The $\overline{F F}$ is de-asserted by the rising edge of $\overline{\mathrm{R}}$.

Figure 7. Full Flag Timings In Paralle-In Mode


Figure 8. Almost-Empty Flag Region


Figure 9. Almost-Full Flag Region


Figure 10. Half-Full and Full-minus-1 Flag Timings


Figure 11. Empty +1 Flag Timings


Figure 12. Output Enable Timings


FIgure 13. Expansion-Out


Figure 14. Expansion-In


Figure 15. Read Data Flow-Through Mode


Figure 16. Write Data Flow-Through Mode

## SERIAL TIMINGS:



NOTE:

1. SICP should be in the steady low or high during tass. The first low-high (or high-low) transition can begin after tRSR.

Flgure 17. Reset Tlmings for Serlal-In Mode


NOTE:

1. SOCP should be in the steady low or high during tass. The first low-high (or high-low) transition can begin after trse.

Figure 18. Reset Timings for Serlal-Out Mode


NOTES:

1. For the stand alone mode, $\mathrm{N} \geq 4$ and the input bits are numbered 0 to $\mathrm{N}-1$.
2. For the recommended interconnections, $D i$ is to be directly tied to $\bar{W}$ and the tS4 and th4 requirements will be satisfied. For users that modity $\bar{W}$ externally, tS4 and th4 requirements have to be met.
3. After $\overline{\mathrm{S} I} / \mathrm{PI}$ has been set up, it cannot be dynamically changed; it can only be changed after a reset operation.

Figure 19. Write Operation In Serial-In Mode


NOTES:

1. After $\overline{\mathrm{SO}} / \mathrm{PO}$ has been set up, it cannot be dynamically changed; it can only be changed after a reset operation.
2. For single device: Read out the last bit before $\overline{E F}$ is asserted.

For Serial Width Expansion mode: Read out the last bit of the current memory location from the active device.
3. For single device: The operation starts after Reset.

For Serial Width Expansion mode: Read the first bit of the current memory location from the active device.

Figure 20. Read Operation In Serlal-Out Mode


## NOTES:

1. Parallel Read shown for reference only. Can also use serial output mode.
2. The Empty Flag is de-asserted after the $\mathrm{N}-1$ rising edge of SICP of the first serial-in word. In the Serial-Out mode, a new read operation can begin trefso atter EF goes HIGH. In the Parallel-Out mode, a new read operation can occur immedately after FF goes HIGH.
3. The $\mathrm{EF}+1$ Flag is de-asserted after the $\mathrm{N}-1$ rising edge of SICP of the second serial-in word.

Figure 21. Empty Flag and Empty+1 Flag De-assertion In the Serial-In Mode


NOTES:

1. Parallel write shown for reference only. Can also use serial input mode.
2. The Empty Flag (EF) is asserted in Serial-Out mode by using the tsccef parameter. This parameter is measured in the worst case condition from the rising edge of the SOCP used to clock data bit 0 . Whenever EF goes LOW, there is only one word to be shifted out. In the Parallel-In mode, the $\overline{E F}$ flag is de-asserted by the rising edge of $\bar{W}$. In the Serial-In mode, the $\overline{E F}$ flag is de-asserted by the rising edge of $\bar{W}$.
3. First Write rising edge after EF is set.
4. SOCP should not be clocked until EF goes HIGH.

Figure 22. Empty Flag and Empty+1 Flag Assertion in the Serial-Out Mode (FIFO Being Emptied)


1. The Full Flag is asserted in the Serial-In mode by using the tsicFF parameter. This parameter is measured in the worst case condition from the rising edge of SICP followed by a (tPD1+tWFF) delay from the first rising edge of SICP of the last word.
2. First Read rising edge atter $\overline{\mathrm{FF}}$ is set.
3. SICP should not be clocked until FF goes HIGH.

Figure 23. Full Flag and Full-1 Flag Assertion In the Serial-In Mode (FIFO Being Filled)


## NOTES:

1. The FIFO is full and a new read sequence is started.
2. On the first rising edge of SOCP, the $\overline{F F}$ is de-asserted. In the Serial-In mode, a new write operation can begin following tRFFS1 after FF, goes HIGH. In the Parallel-In mode, a new write operation can occur immediately after FF goes HIGH.
3. The FF-1 flag is de-asserted after the first SOCP of the second serial word.

Figure 24. Full Flag and Full-1 Flag De-assertion in the Serlal-Out Mode


Figure 25. Half-Full, Almost-Full and Almost-Empty Timings for Serial-In Mode


Flgure 26. Half-Full, Almost-Full and Almost-Empty TImings for Serlal-Out Mode

## OPERATING DESCRIPTION

## PARALLEL OPERATING MODES:

## Parallel Data Input

By setting SI/PI high, data is written into the FIFO in parallel through the Do-Ds input data lines.

## Parallel Data Output

By setting $\overline{\mathrm{SO}} / \mathrm{PO}$ high, the parallel-out mode is chosen. In the parallel-out mode, as shown in Figure 4, data is available tA after the falling edge of $\bar{R}$ and the output bus $Q$ goes into high impedance after $\overline{\mathrm{R}}$ goes high.

Alternately, the user can access the FIFO by keeping $\overline{\mathrm{R}}$ low and enabling data on the bus by asserting $\overline{O E}$. When $\stackrel{\rightharpoonup}{R}$ is low, the $\overline{\mathrm{OE}}$ is high and the output bus is tri-stated. When $\overline{\mathrm{R}}$ is high, the output bus is disabled irrespective of $\overline{\mathrm{OE}}$. The enable and disable timings for $\overline{\mathrm{OE}}$ are shown in Figure 12.

## Single Device Mode

A single ID172103/72104 may be used when application requirements are for 2048/4096 words orless. The IDT72103/ 72104 is in the Single Device Configuration when the Expansion $\ln (\overline{\mathrm{XI}})$ control input is grounded (See Figure 27). In this mode, the $\overline{\mathrm{HF}} / \mathrm{XO}$ is used as an Half-Full flag.

## WIdth Expansion Mode

Word width may be increased simply by connecting the corresponding inputcontrol signals of multiple devices. Status flags can be detected from any one of the connected devices. Figure 28 demonstrates an 18 -bit word width by using two IDT72103/72104s. Any word width can be attained by adding additional IDT72103/72104.


Figure 27. Block Dlagram of Single $2048 \times 9 / 4096 \times 9$ FIFO in Parallel Mode

## INPUT CONFIGURATION TABLE

| Pln | Parallal Input | Serlal Input |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Single Device | WIdth Expansion |  |  |
|  |  |  | Lsast Significant Device | All Other Devices | Most Significant Device |
| $\overline{\mathrm{S} /} / \mathrm{Pl}$ | HIGH | LOW | LOW | LOW | LOW |
| St | HIGH | Input Data | Input Data | Input Data | Input Data |
| SICP | HIGH | Input Clock | Input Clock | Input Clock | Input Clock |
| SIX | HIGH | HIGH | HIGH | Ds of next least significant device | D8 of next least significant device |
| $\bar{W}$ | Write Control | Di | Di of most significant device | Di of most significant device | Di of most significant device |
| Do-D8 | Input Data | No connect except Di | No connect except D8 | No connect except D8 | No connect except Di |
| Di ${ }^{(1)}$ | - | W | - | - | $\bar{W}$ of all devices |
| D8 | - | - | - | SIX of next most significant device | SIX of next most significant device |

## NOTE:

1. Di refers to the most significant bit of the serial word. If multiple devices are width cascaded, Di is the most significant bit from the most significant device.

## OUTPUT CONFIGURATION TABLE

| Pin | Parallel Input | Serial Input |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Single Device | Wldth Expansion |  |  |
|  |  |  | Least Significant Device | All Other Devices | Most Significant Device |
| $\overline{\text { SO/PO }}$ | HIGH | LOW | LOW | LOW | LOW |
| SO | HIGH | Output Data | Output Data | Output Data | Output Data |
| SOCP | HIGH | Output Clock | Output Clock | Output Clock | Output Clock |
| SOX | HIGH | HIGH | HIGH | Q8 of next least significant device | Q8 of next least significant device |
| $\overline{\mathrm{R}}$ | Read Control | Qi | Qi of most significant device | Qi of most significant device | Di of most significant device |
| Q0-Q8 | Output Data | No connect except Di | No connect except Q8 | No connect except Q8 | No connect except Qi |
| $\mathrm{Qi}^{(1)}$ | - | $\bar{R}$ | - | - | $\bar{W}$ of all devices |
| Q8 | - | - | SOX of next most significant device | SOX of next most significant device | - |

## NOTE:

1. Qi refers to the most significant bit of the serial word. If multiple devices are width cascaded, Qi is the most significant bit from the most significant device.


NOTE:

1. Flag detection is accomplished by monitoring all the flag signals of either (any) device used in the width expansion configuration. Do not connect any flag signals together.

FIgure 28. Block Dlagram of $2048 \times 18 / 4096 \times 18$ FIFO Memory Used in Width Expansion In Parallet Mode

## TRUTH TABLES

TABLE 2: RESET AND RETRANSMIT -
SINGLE DEVICE CONFIGURATION/WIDTH EXPANSION IN PARALLEL MODE

| Mode | Inputs $^{(2)}$ |  |  | Internal Status ${ }^{(1)}$ |  | Outputs |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbf{R S}}$ | $\overline{\mathrm{FL}}$ | $\overline{\mathbf{X I}}$ | Read PoInter | Wrte PoInter | $\overline{\mathrm{AEF}}, \overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ | $\overline{\mathrm{HF}}$ |
| Reset | 0 | X | 0 | Location Zero | Location Zero | 0 | 1 | 1 |
| Retransmit | 1 | 0 | 0 | Location Zero | Unchanged | X | X | X |
| Read/Write | 1 | 1 | 0 | Increment ${ }^{(1)}$ | Increment ${ }^{(1)}$ | X | X | X |

NOTES:

1. Pointer will increment if appropriate flag is HIGH.
2. $\overline{\mathrm{RS}}=$ Reset Input, $\overline{\mathrm{FL}} \overline{\mathrm{RT}}=$ First Load/Retransmit, $\overline{E F}=$ Empty Flag Output, $\overline{\mathrm{FF}}=$ Full Fiag Output, $\overline{\mathrm{XI}}=$ Expansion Input.

## Depth Expansion (Dalsy Chain) Mode

The IDT72103/4 can be easily adapted to applications where the requirements are forgreater than2048/4096 words. Figure 29 demonstrates Depth Expansion using three IDT72103/4s. Any memory depth can be attained by adding additional IDT72103/4s. The IDT72103/4 operates in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the First Load (FL) control input pin.
2. All other devices must have the $\overline{\mathrm{FL}}$ pin in the high state.
3. The Expansion Out ( $\overline{\mathrm{XO}}$ ) pin of each device must be tied to the Expansion In (XI) pin of the next device. See Figure 29.
4. External logic is needed to generate a composite Full Flag (FF) and Empty Flag (EF). This requires the ORing of all $\overline{E F s}$ and OR-ing of all $\overline{\text { FFs }}$ (i.e., all must be set to generate the correct composite FF or E F). See Figure 29.
5. The Retransmit ( $\overline{\mathrm{RT}}$ ) function and Half-Full Flag ( $\overline{\mathrm{HF}) \text { are }}$ not available in the Depth Expansion mode.


NOTE:

Figure 29. Block Diagram of $6,144 \times 9 / 12,288 \times 9$-FIFO Memory, Depth Expansion In Parallel Mode

Bldirectional Mode
Applications requiring data buffering between two systems (each system capable of Read and Write operations) can be
achieved by pairing IDT72103/4 as shown in Figure 30. Both Depth Expansion and Width Expansion may be used in this mode.


NOTE:

1. $\overline{\mathrm{S}} / \mathrm{PI}$ and $\overline{\mathrm{SO}} / \mathrm{PO}$ pins are tied to Vcc.

Figure 30. Bldirectional FIFO Mode

## Compound Expansion Mode

The two expansion techniques described above can be applied together in a straightforward manner to achieve large FIFO arrays (see Figure 31).


2753 dw 34
NOTE:

1. $\overline{\mathrm{SI} / \mathrm{PI}}$ and $\overline{\mathrm{SO} / \mathrm{PO}}$ pins are tied to Vcc.
2. For depth expansion block see DEPTH EXPANSION Section and Figure 29.
3. For Flag Detection see WIDTH EXPANSION SECTION and Figure 28.

Figure 31. Compound FIFO Expansion

TABLE 3: RESET AND FIRST LOAD TRUTH TABLE -
DEPTH EXPANSION/COMPOUND EXPANSION MODE

| Mode | Inputs ${ }^{(2)}$ |  |  | Internal Status |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { RS }}$ | $\overline{\mathrm{FL}}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Polnter | $\overline{E F}$ | $\overline{\text { FF }}$ |
| Reset-First Device | 0 | 0 | (1) | Location Zero | Location Zero | 0 | 1 |
| Retransmit all Other Devices | 0 | 1 | (1) | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | (1) | X | X | X | X |

NOTES:
2753 tol 16

1. $\overline{X I}$ is connected to $\overline{X O}$ of previous device.
2. $\overline{\mathrm{RS}}=$ Reset Input, $\overline{\mathrm{FL}} \overline{\mathrm{RT}}=$ First Load/Retransmit, $\overline{\mathrm{EF}}=$ Empty Flag Ouput, $\overline{\mathrm{FF}}=$ Full Flag Output, $\overline{\mathrm{XII}}=$ Expansion Input.

## SERIAL OPERATING MODES:

## Serial Data Input

The Serial Input mode is selected by grounding the $\overline{S I} / P I$ line. The Do-8 lines are then outputs which are used to program the width of the serial word. They are taps off a digital delay line which, are meant for connection to the $\bar{W}$ input. For instance, connecting D6 to $\bar{W}$ will program a serial word width of 7 bits, connecting $D 7$ to $\bar{W}$ will program a serial word width of 8 bits and so on.

By programming the serial word width, an economy of clock cycles is achieved. As an example, if the word width is 6 bits, then on every 6th clock cycle the serial data register is written in parallel into the FIFO RAM array. Thus, the possible clock cycles for an extra 3 bits of width in the RAM array are not required.

The SIX signal is used for Serial-In Expansion. When the serial word width is 9 or less, the SIX input must be tied HIGH. When more than 9 bits of serial word width is required, more than one device is required. The SIX input of the least significant device must be tied HIGH. The D8 pin of the least significant device must be tied to SIX of the next significant device. In other words, the SIX input of the most significant and intermediate devices must always be connected to the D8 of the next least significant device.

Figure 32 shows the relationship of the SIX, SICP and Do-8 lines. In the stand alone case (Figure 32), on the first LOW-to-HIGH of SICP, the D1-7 lines go LOW and the D0 line remains HIGH. On the next SICP clock edge, the D1 goes

HIGH, then D2 and so on. This continues until the D line, which is connected to $\bar{W}$, goes HIGH. On the next clock cycle, after $\bar{W}$ is HIGH, all of the D lines go LOW again and a new serial word input starts.

In the cascaded case, the first LOW-to-HIGH SICP clock. edge for a serial word will cause all timed outputs (D) to go LOW except for Do of the least significant device. The D outputs of the least significant device will go high on consecutive clock cycles until D8. When D8 goes HIGH, the SIX of the next device goes HIGH. On the next cycle after the SIX input is brought HIGH, the Do goes HIGH; then on the next cycle Di and so on. A D1 output from the most significant device is issued to create the $\bar{W}$ for all cascaded devices.

The minimum serial word width is 4 bits and the maximum is virtually unlimited.

When in the Serial mode, the Least Significant Bit of a serial stream is shifted in first. If the FIFO output is in the Parallel mode, the first serial bit will come out on Qo. The second bit shifted in is on Q1 and so on.

In the Serial Cascade mode, the serial input (SI) pins must be connected together. Each of the devices then receives serial information together and uses the SIX and Do-8 lines to determine whether to store it or not.

The example shown in Figure 34 shows the interconnections for a serializing FIFO that transfers data to the internal RAM in 16-bit quantities (i.e. every 16 SICP cycles). This corresponds to incrementing the write pointer every 16 SICP cycles.

## SINGLE DEVICE SERIAL INPUT CONFIGURATION




Do $=1$

$\mathrm{D}_{2} \longrightarrow \square$


Figure 32. Serial-In Mode Where 8-Bit Parallel Output Data Is Read


Figure 33. Serlal-Input Circuitry

SERIAL INPUT WIDTH EXPANSION


FIgure 34. Serial-In Configuration for Serial-In to Parallet-Out Data of 16 blts

## SERIAL INPUT WITH DEPTH EXPANSION



## NOTE:

1. All $\overline{S I} / P I$ pins are tied to GND and $\overline{S O} / P O$ pins are tied to Vcc. $\overline{O E}$ is tied LOW. For $\overline{F F}$ and $E F$ connections see Figure 17.

Figure 35. An 8K $\times 8$ Serial-In, Parallel-Out FIFO

## SERIAL INPUT WITH WIDTH AND DEPTH EXPANSION



NOTE:

1. All SI/PI pins are tied to GND. $\overline{\text { SO} / P O ~ p i n s ~ a r e ~ t i e d ~ t o ~ V c c . ~ F o r ~} \overline{F F}$ and $\overline{E F}$ connections see Figure 17.

Figure 36. An $8 \mathrm{~K} \times 24$ Serlal-In, Parallel-Out FIFO Using Six IDT72104s

## Serial Data Output

The Serial Output mode is selected by setting the $\overline{\mathrm{SO}} / \mathrm{PO}$ line low. When in the Serial-Out mode, one of the $\mathrm{Q} 0-2$ lines should be used to control the $\bar{R}$ signal. In the Serial-Out mode, the Q0-8 are taps off a digital delay line. By selecting one of these taps andconnecting nto the input, the widthof the serial word to be read and shifted is programmed. For instance, if the Q5 line is connected to the $\overline{\mathrm{R}}$ input, on every sixth clock cycle a new word is read from the FIFO RAM array and begins to be shifted out. The serial word is shifted out Least Significant Bit First. If the input mode of the FIFO is parallel, the information that was written into the Do bit will come out as the first bit of the serial word. The second bit of the serial stream will be the D1 bit and so on.

In the stand alone case, the SOX line is tied HIGH and not used. On the first LOW-to-HIGH of the SOCP clock, all of the Q outputs except for Qo go LOW and a new serial word is started. On the next clock cycle, Q1 will go HIGH, Q2 on the next clock cycle and so on, as shown in Figure 37. This continues until the Q line, shich is connected to $\overline{\mathrm{R}}$, goes HGIH at which point all of the Q lines go LOW on the next clock and a new word is started.

In the cascaded case, word width of more than 9 bits can be achieved by using more than one device. Bytieing the SOX line of the least significant device HIGH and the SOX of the subsequent deviced to Q8 of the previous devices, a cascaded serial word is achieved. On the first LOW-to-HIGH clock edge of SOCP, all the lines except for Qo. Just as in the stand alone case, on each consecutive clock cycle, each Q line goes HIGH in the order of least to most significant. When Q8 (which is connected to the SOX input of the next device) goes HIGH, the Do of that device goes HIGH, thus cascading from one device to the next. The Q line of the most significant device, which programs the serial word width, is connected to all $\bar{R}$ inputs.

The Serial Data Output (SO) of each device in the serial word must be tied together. Since the SO pin is tri-stated, only the device which is currently shifting out is enabled and driving the 1 -bit bus.

Figure 39 shows an example of the interconnections for a 16 -bit serialized FIFO.

## SINGLE DEVICE SERIAL OUTPUT CONFIGURATION



Q $0=1$




Q7


NOTE:

1. Input data is loaded in 8 -bit quantities and read out serially.

Flgure 37. Serlal-Out Configuration


PARALLEL-OUT DATA TIMED OUTPUT Q0-8

Figure 38. Serial-Output CIrcultry


NOTE:

1. The parallel Data In is tied to Do-s of FIFO \#1 and Do- of FIFO \#2.

Flgure 39. Serial-Output for 16-Bit Parallel Data in

SERIAL OUTPUT WITH DEPTH EXPANSION


NOTE:

1. All ST/PI pins are tied to Vcc and SO/PO pins are tied to GND. $\bar{O} E$ is tied LOW. For $F F$ and $E F$ connections see Figure 17.

Figure 40. An $8 \mathrm{~K} \times 8$ Paralled-In Serial-Out FIFO

## SERIAL IN AND SERIAL OUT WITH WIDTH AND DEPTH EXPANSION



NOTE:

1. All $\overline{\mathrm{RS}}$ pins are connected together. All $\overline{\mathrm{OE}}$ pins are connected LOW. All $\overline{\mathrm{S}} / \mathrm{PI}$ and $\overline{\mathrm{SO}} / \mathrm{PO}$ pins are grounded.

Flgure 41. $128 \mathrm{~K} \times 1$ Serial-In Serlal-Out FIFO

## ORDERING INFORMATION



CMOS PARALLEL-TO-SERIAL FIFO
IDT72105
$256 \times 16,512 \times 16,1024 \times 16$
IDT72115
IDT72125

## FEATURES:

- 15ns parallel port access time, 25ns cycle time
- 50 MHz serial output shift rate
- Wide $\times 16$ organization offering easy expansion
- Low power consumption (50mA typical)
- Least/Most Significant Bit first read selected by asserting the FL/DIR pin
- Featuring five memory status flags: Empty, Full, Half-Full, Almost-Empty and Almost-Full
- Dual-port zero fall-through architecture
- Available in 28-pin 300 mil plastic and ceramic DIP, 28pin SOIC and 32-pin PLCC
- Military product compliant to Mil-STD-883, Class B


## DESCRIPTION:

The IDT72105/72115/72125s are very high speed, low power dedicated parallel-to-serial FIFOs. These FIFOs possess a 16-bit parallel input port and a serial output port offering 256, 512 and 1 K word depths, respectively.

The ability to buffer wide word widths (x16) make these FIFOs ideal for laser printers, FAX machines, local area networks (LANs), video storage and disk/tape controller applications.

Expansion in width and depth can be achieved using multiple chips. IDT's unique serial expansion logic (RSIX, RSOX, $\overline{\mathrm{FL}} / \mathrm{DIR}$ ) makes this possible using a minimum of pins.

The unique serial output port is driven by one data pin (SO) and one clock pin (SOCP). The Least Significant or Most Significant Bit can be read first by programming the DIR pin after a reset.

Monitoring the FIFO is eased by the availability of five status flags: Empty, Full, Half-Full, Almost-Empty and Almost-Full. The Full and Empty flags prevent any FIFO data overtlow or underflow conditions. The Half-Full Flag is available in both single and expansion mode configurations. The Almost-Empty and Almost-Full Flags are available only in a single device mode.

The IDT72105/15/25 are fabricated using IDT's leading edge, submicron CEMOS ${ }^{\text {TM }}$ technology. Military grade product is manufactured in compliance with the latest revision of Mil-STD-883, Class B.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATIONS




PLCC
TOP VIEW

## PIN DESCRIPTIONS

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| D0-D15 | Inputs | 1 | Data inputs for 16-bit wide data. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When RSis set low, internal READ and WRITE pointers are set to the first location of the RAM array. $\overline{\mathrm{FF}}$ and HF go HIGH . $\overline{E F}$ and $\overline{A E F}$ go LOW. A reset is required before an initial WRITE atter power-up. Wmust be high during the RScycle. Also the First Load pin (FL) is programmed only during Reset. |
| $\bar{W}$ | Write | 1 | A write cycle is initiated on the falling edge of WRITE if the Full Flag (伊) is not set. Data set-up and hold times must be adhered to with respect to the rising edge of WRITE. Data is stored in the RAM array sequentially and independently of any ongoing read operation. |
| SOCP | Serial Output Clock | 1 | A serial bit read cycle is initiated on the rising edge of SOCP if the Empty Flag (EF) is not set. In both Depth and Serial Word Width Expansion modes, all of the SOCP pins are tied together. |
| $\overline{\text { FU/IR }}$ | First Load/ Direction | 1 | This is a dual purpose input used in the width and depth expansion configurations. The First Load (F) function is programmed only during Reset ( $\overline{\mathrm{RS}}$ ) and a LOW on Findicates the first device to be loaded with a byte of data. All other devices should be programmed HIGH. The Direction (DIR) function is programmed during operation after Reset and tells the device whether to read out the Least Significant or Most Significant bit first. |
| RSIX | Read Serial in Expansion | I | In the single device configuration, RSIX is set HIGH. In depth expansion or daisy chain expansion, RSIX is connected to RSOX (expansion out) of the previous device. |
| SO | Serial Output | 0 | Serial data is output on the Serial Output (SO) pin: Data is clocked out LSB or MSB depending on the Direction pin programming. During Expansion the SO pins are tied together. |
| $\overline{F F}$ | Full Flag | 0 | When FF goes LOW, the device is full and further WRITE operations are inhibited. When FF is HIGH, the device is not full. |
| EF | Empty Flag | 0 | When $\overline{E F}$ goes LOW, the device is empty and further READ operations are inhibited. When $\overline{\mathrm{FF}}$ is HIGH, the device is not empty. |
| $\overline{\mathrm{HF}}$ | Half-Full Flag | 0 | When $\overline{\mathrm{HF}}$ is LOW, the device is more than half-full. When HF is HIGH, the device is empty to half-full. |
| RSOX/AEF | Read Serial Out Expansion Almost-Empty, Almost-Full Flag | 0 | This is a dual purpose output. In the single device configuration (RSIX HIGH), this is an $\overline{A E F}$ output pin. When AEF is LOW, the device is empty-to- $(1 / 8$ full -1$)$ or $(7 / 8$ full +1$)$-to-full. When $\overline{\mathrm{AEF}}$ is HIGH , the device is $1 / 8$-full up to $7 / 8$-full. In the Expansion configuration (RSOX connected to RSIX of the next device) a pulse is sent from RSOX to RSIX to coordinate the width, depth or daisy chain expansion. |
| Vcc | Power Supply |  | Single power supply of 5V. |
| GND | Ground |  | Single ground of OV. |

## STATUS FLAGS

| Number of Words in FIFO |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IDT72105 | IDT72115 | IDT72125 | FF | AEF | HF | EF |
| 0 | 0 | 0 | H | L | H | L |
| $1-31$ | $1-63$ | $1-127$ | H | L | H | H |
| $32-128$ | $64-256$ | $128-512$ | H | H | H | H |
| $129-224$ | $257-448$ | $513-896$ | H | H | L | H |
| $225-255$ | $449-511$ | $897-1023$ | H | L | L | H |
| 256 | 512 | 1024 | L | L | L | H |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Millitary | Unlt |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal <br> Voltage with <br> Respect to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBiAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTA | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| OUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| VCCM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL ${ }^{(1)}$ | Input Low Voltage <br>  <br> Military | - | - | 0.8 | V |

NOTE:
2665 하 04

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

DC ELECTRICAL CHARACTERISTICS
(Commercial Vcc $=5.0 \mathrm{~V} \pm 10 \%$, $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military Vcc $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

|  | Parametor | IDT72105/DT72115/ IDT72125 <br> Commerclal |  |  | $\begin{gathered} \text { IDT72105/IDT72115/ } \\ \text { IDT72125 } \\ \text { Military } \end{gathered}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $1 \mathrm{ll}{ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $1 \mathrm{OL}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage Iout $=-2 m A^{(5)}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage lout $=8 \mathrm{~mA} A^{(6)}$ | - | - | 0.4 | - | - | 0.4 | $V$ |
| Icc1 ${ }^{(3)}$ | Power Supply Current | - | 50 | 100 | - | 75 | 125 | mA |
| $\mathrm{ICC2}^{(3)}$ | Average Standby Current $(\bar{W}=\overline{\mathrm{RS}}=\overline{\mathrm{F}} / D I R=V I H)(S O C P=V I L)$ |  | 4 | 8 | - | 4 | 12 | mA |
| Icc3 ${ }^{(3,4,7)}$ | Power Down Current | - | 1 | 6 | - | 1 | 8 | mA |

## NOTES:

1. Measurements with $0.4 \leq$ Vin $\leq$ Vout.
2. SOCP $\leq$ VIL, $0.4 \leq$ Vout $\leq$ Vcc.
3. loc measurements are made with outputs open.
4. $\overline{R S}=\bar{F} / D I R=\bar{W}=\mathrm{Vcc}-0.2 \mathrm{~V} ; \mathrm{SOCP} \leq 0.2 \mathrm{~V}$; all other inputs $\geq \mathrm{Vcc}-0.2 \mathrm{or} \leq 0.2 \mathrm{~V}$.
5. For SO, IOUT $=-4 \mathrm{~mA}$.
6. For SO, IOUT $=16 \mathrm{~mA}$.
7. Measurements are made after reset.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{Vcc}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Figure | COM'L <br> $72105 L 15$ <br> $72115 L 15$ <br> $72125 L 15$ |  | COMMERCIAL AND MILTARY |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{aligned} & 72105 \times 25 \\ & 72115 \times 25 \\ & 72125 \times 25 \end{aligned}$ |  | $\begin{aligned} & 72105 \times 50 \\ & 72115 \times 50 \\ & 72125 \times 50 \end{aligned}$ |  | $\begin{aligned} & 72105 \times 80 \\ & 72115 \times 80 \\ & 72125 \times 80 \end{aligned}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ts | Parallel Shift Frequency | - | - | 40 | - | 28.5 | - | 15 | - | 10 | MHz |
| tsocp | Serial Shift Frequency | - | - | 50 | - | 50 | - | 40 | - | 28 | MHz |

PARALLEL INPUT TIMINGS

| twc | Write Cycle Time | 2 | 25 | - | 35 | - | 65 | - | 100 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twPW | Write Pulse Width | 2 | 15 | - | 25 | - | 50 | - | 80 | - | ns |
| tWR | Write Recovery Time | 2 | 10 | - | 10 | - | 15 | - | 20 | - | ns |
| tos | Data Set-up Time | 2 | 10 | - | 12 | - | 15 | - | 15 | - | ns |
| tDH | Data Hold Time | 2 | 0 | - | 0 | - | 2 | - | 5 | - | ns |
| tWEF | Write High to EF High | 5,6 | - | 30 | - | 35 | - | 45 | - | 50 | ns |
| tWFF | Write Low to FF Low | 4,7 | - | 30 | - | 35 | - | 45 | - | 50 | ns |
| tWF | Write Low to Transitioning $\overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$ | 8 | - | 30 | - | 35 | - | 45 | - | 50 | ns |
| tWPF | Write Pulse Width After FFF High | 7 | 15 | - | 25 | - | 50 | - | 80 | - | ns |

SERIAL OUTPUT TIMINGS

| tsocp | Serial Clock Cycle Time | 3 | 20 | - | 20 | - | 25 | - | 35 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tsocw | Serial Clock Width High/Low | 3 | 8 | - | 8 | - | 10 | - | 15 | - | ns |
| tSOPD | SOCP Rising Edge to SO Valid Data | 3 | - | 14 | - | 14 | - | 15 | - | 17 | ns |
| tSOHZ | SOCP Rising Edge to SO at High $\mathbf{Z}^{(1)}$ | 3 | 3 | 14 | 3 | 14 | 3 | 15 | 3 | 17 | ns |
| tsolz | SOCP Rising Edge to SO at Low $\mathrm{Z}^{(1)}$ | 3 | 3 | 14 | 3 | 14 | 3 | 15 | 3 | 17 | ns |
| tsocef | SOCP Rising Edge to EF Low | 5,6 | - | 35 | - | 35 | - | 45 | - | 50 | ns |
| tSOCFF | SOCP Rising Edge to FF High | 4,7 | - | 35 | - | 35 | - | 45 | - | 50 | ns |
| tSOCF | SOCP Rising Edge to Transitioning HF, $\overline{A E F}$ | 8 | - | 35 | - | 35 | - | 45 | - | 50 | ns |
| trefso | SOCP Delay After EF High | 6 | 35 | - | 35 | - | 65 | - | 100 | - | ns |

## RESET TIMINGS

| trsc | Reset Cycle Time | 1 | 25 | - | 35 | - | 65 | - | 100 | - |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| ns |  |  |  |  |  |  |  |  |  |  |
| tRS | Reset Pulse Width | 1 | 15 | - | 25 | - | 50 | - | 80 | - |
| tRss | Reset Set-up Time | 1 | 15 | - | 25 | - | 50 | - | 80 | - |
| ntrsR | Reset Recovery Time | 1 | 10 | - | 10 | - | 15 | - | 20 | - |

EXPANSION MODE TIMINGS

| tFLS | $\overline{\text { FL Set-up Time to } \overline{\text { RS }} \text { Rising Edge }}$ | 9 | 7 | - | 7 | - | 8 | - | 10 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tFLH | $\overline{\text { FL Hold Time to } \overline{R S} \text { Rising Edge }}$ | 9 | 0 | - | 0 | - | 2 | - | 5 | - | ns |
| tDIRS | DIR Set-up Time to SOCP Rising Edge | 9 | 10 | - | 10 | - | 12 | - | 10 | - | ns |
| toIRH | DIR Hold Time from SOCP Rising Edge | 9 | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tSOXD1 | SOCP Rising Edge to RSOX Rising Edge | 9 | - | 15 | - | 15 | - | 17 | - | 20 | ns |
| tSOXD2 | SOCP Rising Edge to RSOX Falling Edge | 9 | - | 15 | - | 15 | - | 17 | - | 20 | ns |
| tsixs | RSIX Set-up Time to SOCP Rising Edge | 9 | 5 | - | 5 | - | 8 | - | 15 | - | ns |
| tsIXPW | RSIX Pulse Width | 9 | 10 | - | 10 | - | 15 | 一 | 20 | - | ns |

NOTE:
2665 th 06

1. Guaranteed by design minimum times, not tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure A |
| 266507 |  |

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter( ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| Cin | Input Capacitance | Vin = OV | 10 | pF |
| COUT | Output <br> Capacitance | VoUT = OV | 12 | pF |

NOTE:
2665 tbl 06

1. This parameter is sampled and not $100 \%$ tested.

## FUNCTIONAL DESCRIPTION

## Parallel Data Input

The device must be reset before beginning operation so that allflags are set to initial state. In width or depth expansion the First Load pin ( $\overline{\mathrm{FL}}$ ) must be programmed to indicate the first device.

The data is written into the FIFO in parallel through the Do-15 input data lines. A write cycle is initiated on the falling edge of the Write $(\bar{W})$ signal provided the Full Flag $(\overline{\mathrm{FF}})$ is not asserted. If the $\bar{W}$ signal changes from HIGH-to-LOW and the Full Flag ( $\overline{\mathrm{FF}}$ ) is already set, the write line is inhibited internally from incrementing the write pointer and no write operation occurs.

Data set-up and hold times must be met with respect to the rising edge of Write. On the rising edge of $\bar{W}$, the write pointer is incremented. Write operations can occur simultaneously or asynchronously with read operations.

or equivalent circuit
Figure A. Output Load
-Includes jig and scope capacitances.

## Serial Data Output

The serial data is output on the SO pin. The data is clocked out on the rising edge of SOCP providing the Empty Flag (EF) is not asserted. If the Empty Flag is asserted then the next data word is inhibited from moving to the output register and being clocked out by SOCP.

The serial word is shifted out Least Significant Bit or Most Significant Bit first, depending on the FL/DIR level during operation. A LOW on DIR will cause the Least Significant Bit to be read out first. A HIGH on DIR will cause the Most Significant Bit to be read out first.


## NOTE:

1. $\overline{E F}, \overline{F F}, \overline{M F}$ and $\overline{A E F}$ may change status during Reset, but flags will be valid at trsc.
2. SOCP should be in the steady low or high during tRSS. The first low-high (or high-low) transition can begin after tRSR.

Figure 1. Reset


Flgure 2. Write Operation


1. In Single Device Mode, SO will not tri-state except after reset.

Figure 3. Read Operation


Figure 4. Full Flag from Last Write to First Read

NOTE:


1. SOCP should not be clocked until EF goes high.

Flgure 5. Empty Flag from Last Read to First Write

DATA IN


1. SOCP should not be clocked until EF goes high.
2. In Single Device Mode, SO will not tri-state except after Reset. It will retain the last valid data.

Figure 6. Empty Boundary Condition Timing


NOTE:

1. Single Device Mode will not tri-state but will retain the last valid data.

Figure 7. Full Boundary Condition Timing


Figure 8. Half-Full, Almost-Full and Almost-Empty Timings


Flgure 9. Serlal Read Expansion

## OPERATING CONFIGURATIONS

## Single Device Mode

The device must be reset before beginning operation so that all flags are set to location zero. In the standalone case, the RSIX line is tied HIGH and indicates single device operation to the device. The RSOX $\overline{A E F}$ pin defaults to $\overline{A E F}$ and outputs the Almost-Empty and Almost-Full Flag.

## WIdth Expansion Mode

In the cascaded case, word widths of more than 16 bits can be achieved by using more than one device. By tying the RSOX and RSIX pins together, as shown in Figure 11, and programming which is the Least Significant Device, a cascaded serial word is achieved. The Least Significant Device


Figure 10. Single Device Configuration

| Modo | Inputs |  |  | Internal Status |  | Outputs |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS | FL | DIR | Read Pointer | Write Polnter | AEF, EF | FF | HF |
| Reset | 0 | X | X | Location Zero | Location Zero | 0 | 1 | 1 |
| Read/Write | 1 | X | 0,1 | Increment ${ }^{(1)}$ | Increment ${ }^{(1)}$ | X | X | X |

## NOTE:

2665 tbl 09

1. Pointer will increment if appropriate flag is HIGH.

Table 1. Reset and First Load Truth Table-Single Device Conflguration
is programmed by a LOW on the Fป/DIR pin during reset. All other devices should be programmed HIGH on the FI/DIR pin at reset.

The Serial Data Output (SO) of each device in the serial word must be tied together. Since the SO pin is three stated, only the device which is currently shifting out is enabled and driving the 1 -bit bus. NOTE: After reset, the level on the

FL/DIR pin decides if the Least Significant or Most Significant Bit is read first out of each device.

The three flag outputs, Empty ( $\overline{\mathrm{EF}}$ ), Haff-Full ( $\overline{\mathrm{FF}}$ ) and Full ( $\overline{F F}$ ), should be taken from the Most Significant Device (in the example, FIFO \#2). The Almost-Empty and Almost-Full Flags are not available due to using the RSOX pin for expansion.


## Depth Expansion (Dalsy Chain) Mode

The IDT72105/15/25 can easily be adapted to applications where the requirements are for greater than 1024 words. Figure 12 demonstrates Depth Expansion using three IDT72105/15/25s and an IDT74FCT138 Address Decoder. Any depth can be attained by adding additional devices. The Address Decoder is necessary to determine which FIFO to write data into. A byte of data should be written sequentially into each FIFO so that the RSOX/RSIX handshake can control reading out the data in the correct sequence. The IDT72105/15/25 operates in the Depth Expansion Mode when the following conditions are met:

1. The first device must be designated by programming $\overline{\mathrm{FL}}$ LOW at Reset. All other devices to be programmed HIGH.
2. The Read Serial Out Expansion (RSOX) of each device must be tied to the Read Serial In Expansion (RSIX of the next device in the manner shown).
3. External logic is needed to generate composite Empty, Haff-Full and Full Flags. This requires the OR-ing of all EF , $\overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$ Flags.
4. The Almost-Empty and Almost-Full Flag is not available due to using the RSOX pin for expansion.

## Compound Expansion (Dalsy Chain) Mode

The IDT72105/15/25 can be expanded in both depth and width as Figure 13 indicates:

1. The RSOX-to-RSIX expansion signals are wrapped around sequentially.
2. The write ( $\bar{W}$ ) signal is expanded in width.
3. Flag signals are only taken from the Most Significant Devices.
4. The Least Significant Device in the array must be programmed with a LOW on FL/DIR during reset.


2685 dw 15
Figure 12. A $3 \mathrm{~K} \times 16$ Paralled-to-Serial FIFO using the IDT72125

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FS | F[ | DIR | Read Pointer | Write Pointer | EF | HF, FF |
| Reset-First Device | 0 | 0 | X | Location Zero | Location Zero | 0 | 1 |
| Reset All Other Devices | 0 | 1 | X | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | 0,1 | X | X | X | X |

NOTE:
2665 bl 10

1. $\overline{\mathrm{RS}}=$ Reset Input, FL/FIR $=$ First Load/Direction, $\mathrm{EF}=$ Empty Flag Output, $\mathrm{HF}=$ Half- Full Flag Output, FF $=$ Full Flag Ouput.

Table 2. Reset and First Load Truth Table-Width/Depth Compound Expansion Mode


Figure 13. A $3 \mathrm{~K} \times 32$ Parallel-to-Serial FIFO using the IDT72125

## ORDERING INFORMATION



## CMOS PARALLEL-TO-SERIAL FIFO $2048 \times$ 9-BIT \& $4096 \times 9$-BIT

## IDT72131

IDT72141

## FEATURES:

- 35 ns parallel port access time, 45 ns cycle time
- 50 MHz serial port shift rate
- Expandable in depth and width with no external components
- Programmable word lengths including 7-9, 16-18, 32-36 bit using Flexishift ${ }^{\text {TM }}$ serial output without using any additional components
- Multiple status flags: Full, Almost-Full ( $1 / 8$ from full), Half-Full, Almost Empty ( $1 / 8$ from empty), and Empty
- Asynchronous and simultaneous read and write operations
- Dual-port zero fall-through architecture
- Retransmit capability in single device mode
- Produced with high-performance, low power CEMOS ${ }^{\text {TM }}$ technology
- Available in 28 -pin ceramic and plastic DIP packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT72131/72141 are high-speed, low power parallel-to-serial FIFOs. These FIFOs are ideally suited to serial communications applications, tape/disk controllers, and local area networks (LANs). The IDT72131/72141 can be configured with the IDTs serial-to-parallel FIFOs (IDT72132/ 72142) for bidirectional serial data buffering.

The FIFO has a 9-bit parallel input port and a serial output port. Wider and deeper parallel-to-serial data buffers can be built using multiple IDT72131/72141 chips. IDTs unique Flexishift serial expansion logic (SOX, NR) makes width expansion possible with no additional components. These FIFOs willexpand to a variety of word widths including $8,9,16$, and 32 bits. The IDT72131/141 can also be directly connected for depth expansion.

Five flags are provided to monitor the FIFO. The full and empty flags prevent any FIFO data overilow or underflow conditions. The almost-full (7/8), half-full, and almost empty $(1 / 8)$ flags signal memory utilization within the FIFO.

The IDT72131/72141 is fabricated using IDTs high-speed submicron CEMOS technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



PIN DESCRIPTIONS

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| Do-D8 | Inputs | 1 | Data inputs for 9-bit wide data. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal READ and WRITE pointers are set to the first location of the RAM array. $\overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$ go high, and $\overline{\mathrm{AEF}}$ and $\overline{\mathrm{EF}}$ go low. A reset is required before an initial WRITE after power-up. $\bar{W}$ must be high and SOCP must be bw during $\overline{\mathrm{RS}}$ cycle. |
| $\bar{W}$ | Write | I | A write cycle is initiated on the falling edge of WRITE if the Full Flag ( $\overline{F F}$ ) is not set. Data setup and hold times must be adhered to with respect to the rising edge of WRITE. Data is stored in the RAM array sequentially and independently of any ongoing read operation. |
| SOCP | Serial Output Clock | I | A serial bit read cycle is initiated on the rising edge of SOCP if the Empty Flag ( $\overline{\mathrm{EF}}$ ) is not set. In both Depth and Serial Word Width Expansion modes, all of the SOCP pins are tied together. |
| NR | Next Read | 1 | To program the Serial Out data word width, connect $\overline{N R}$ with one of the Data Set pins ( $Q_{4}, Q_{6}$, $\mathrm{Q}_{7}$ and Q8). For example, $\overline{\mathrm{NR}}$ - Q7 programs for a 8-bit Serial Out word width. |
| FL/तT | First Load/ <br> Retransmit | 1 | This is a dual purpose input. In the single device configuration ( $\overline{\mathrm{XI}}$ grounded), activating retransmit ( $\overline{\mathrm{FL}} \overline{\mathrm{RT}}$-low) will set the internal READ pointer to the first location. There is no effect on the WRITE pointer. $\bar{W}$ must be high and SOCP must be low before setting FL/ $\overline{R T}$ bw. Retransmit is not compatible with depth expansion. Inthe depth expansion configuration, FI/ grounded indicates the first activated device. |
| $\overline{\mathrm{XI}}$ | Expansion In | I | In the single device configuration, $\overline{\mathrm{XI}}$ is grounded. In depth expansion or daisy chain expansion, $\overline{\mathrm{XI}}$ is connected to $\overline{\mathrm{XO}}$ (expansion out) of the previous device. |
| SOX | Serial Output Expansion | 1 | In the Serial Output Expansion mode, the SOX pin of the least significant device is tied high. The SOX pin of all other devices is connected to the Qe pin of the previous device. Data is then clocked out least significant bit first. For single device operation, SOX is tied high. |
| SO | Serial Output | 0 | Serial data is output on the Serial Output (SO) pin. Data is clocked out Least Significant Bit first. In the Serial Width Expansion mode the SO pins are tied together and each SO pin is tristated at the end of the byte. |
| $\overline{\mathrm{FF}}$ | Full Flag | 0 | When $\overline{F F}$ goes low, the device is full and further WRITE operations are inhibited. When $\overline{F F}$ is high, the device is not full. |
| $\overline{\mathrm{EF}}$ | Empty Flag | 0 | When $\overline{E F}$ goes low, the device is empty and further READ operations are inhibited. When $\overline{E F}$ is high, the device is not empty. |
| $\overline{\text { AEF }}$ | Almost-Empty/ Almost-Full Flag | 0 | When $\overline{A E F}$ is low, the device is empty to $1 / 8$ full or $7 / 8$ to completely full. When $\overline{A E F}$ is high, the device is greater than $1 / 8$ full, but less than $7 / 8$ full. |
| $\overline{\mathrm{XO}} / \overline{\mathrm{HF}}$ | Expansion Out/ Half-Full Flag | 0 | This is a dual-purpose output. In the single device configuration (XI grounded), the device is more than hall full when HF is low. In the depth expansion configuration (XO connected to $\overline{\mathrm{XI}}$ of the next device), a pulse is sent from $\overline{X O}$ to $\overline{X I}$ when the last location in the RAM array is filled. |
| Q4, $\mathbf{Q}_{6}$, Q7 and Q8 | Data Set | 0 | The appropriate Data Set pin ( $\mathrm{Q}_{4}, \mathrm{Q}_{6,} \mathrm{Q}_{7}$ and $\mathrm{Q}_{8}$ ) is connected to $\overline{\mathrm{NR}}$ to program the Serial Out data word width. For example: $Q_{6}-\overline{\mathrm{NR}}$ programs a 7-bit word width, $\mathrm{Q}_{8}$ - $\overline{\mathrm{NR}}$ programs a 9-bit word width, etc. |
| Vcc | Power Supply |  | Single Power Supply of 5V. |
| GND | Ground |  | Single ground at OV. |

## STATUS FLAGS

| Number of Words In FIFO |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IDT72131 | IDT72141 | FF | AEF | HF | $\overline{\text { EF }}$ |
| 0 | O | H | L | H | L |
| $1-255$ | $1-511$ | H | L | H | H |
| $256-1024$ | $512-2048$ | H | H | H | H |
| $1025-1792$ | $2049-3584$ | H | H | L | H |
| $1793-2047$ | $3585-4095$ | H | L | L | H |
| 2048 | 4096 | L | L | L | H |

## PIN CONFIGURATION



RECOMMENDED OPERATING CONDITIONS

| Symbol | Parameter | MIn. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VccM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vcc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL ${ }^{(1)}$ | Input Low Voltage | - | - | 0.8 | V |
| NOTE: |  |  |  |  |  |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | RatIng | Commerclal | Mliltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2751 tol 03

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditlons | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 10 | pF |
| Cour | Output Capacitance | Vour $=\mathrm{OV}$ | 12 | pF |

NOTE:
2751 tol 04

1. This parameter is sampled and not $100 \%$ tested.
2. 1.5 V undershoots are allowed for 10 ns once per cycle.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{Vcc}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72131/IDT72141 Commercial |  |  | IDT72131/IDT72141 Military |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| IIL ${ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{laL}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$. |
| Vor | Output Logic "1" Voltage, $\text { lout }=-8 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage lout $=16 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{lcCl}^{(3)}$ | Power Supply Current | - | 90 | 140 | - | 100 | 160 | mA |
| ICC2 ${ }^{(3)}$ | Average Standby Current $(\bar{W}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} / \overline{\mathrm{RT}}=\mathrm{VIH})$ (SOCP $=\mathrm{VIL})$ | - | 8 | 12 | - | 12 | 25 | mA |
| $\operatorname{lccs}(\mathrm{L})^{(3,4)}$ | Power Down Current | - | - | 2 | - | - | 4 | mA |
| $\operatorname{lcc3}(\mathrm{S})^{(3,4)}$ | Power Down Current | - | - | 8 | - | - | 12 | mA |

NOTES:

1. Measurements with $0.4 \leq \mathrm{Vin} \leq$ Vout.
2. SOCP $\leq$ VIL, $^{2} 0.4 \leq$ Vout $\leq$ Vcc.
3. Icc measurements are made with outputs open.
4. $\overline{\mathrm{RS}}=\overline{\mathrm{FL}} / \overline{\mathrm{RT}}=\overline{\mathrm{W}}=\mathrm{Vcc}-0.2 \mathrm{~V}$; SOCP $\leq 0.2 \mathrm{~V}$; all other inputs $2 \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\leq 0.2 \mathrm{~V}$.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commercial <br> IDT72131×35 <br> IDT72141×35 |  | Military |  | Mil. and Com'l. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{aligned} & \text { IDT72131×40 } \\ & \text { IDT72141×40 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72131×50 } \\ & \text { IDT72141×50 } \end{aligned}$ |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ts | Parallel Shift Frequency | - | 22.2 | - | 20 | - | 15 | MHz |
| tsocp | Serial-Out Shift Frequency | - | 50 | - | 50 | - | 40 | MHz |
| PARALLEL INPUT TIMINGS |  |  |  |  |  |  |  |  |
| tDS | Data Set-up Time | 18 | - | 20 | - | 30 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 5 | - | ns |
| twc | Write Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| tWPW | Write Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| twn | Write Recovery Time | 10 | - | 10 | - | 15 | - | ns |
| tWEF | Write High to EF High | - | 30 | - | 35 | - | 45 | ns |
| tWFF | Write Low to FF Low | - | 30 | - | 35 | - | 45 | ns |
| tWF | Write Low to Transitioning $\overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$ | - | 45 | - | 50 | - | 65 | ns |
| tWPF | Write Pulse Width After FF High | 35 | - | 40 | - | 50 | - | ns |

SERIAL OUTPUT TIMINGS

| tSOHz | SOCP Rising Edge to SO at High $Z^{(1)}$ | 5 | 16 | 5 | 16 | 5 | 26 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tSOLZ | SOCP Rising Edge to SO at Low ${ }^{(1)}$ | 5 | 22 | 5 | 22 | 5 | 22 | ns |
| tSOPD | SOCP Rising Edge to Valid Data on SO | - | 18 | - | 18 | - | 18 | ns |
| tsox | SOX Set-up Time to SOCP Rising Edge | 5 | - | 5 | - | 5 | - | ns |
| tsocw | Serial In Clock Width High/Low | 8 | - | 8 | - | 10 | - | ns |
| tSOCEF | SOCP Rising Edge (Bit 0 - Last Word) to EF Low | - | 20 | - | 25 | - | 25 | ns |
| tSOCFF | SOCP Rising Edge to FFF High | - | 30 | - | 35 | - | 40 | ns |
| tSOCF | SOCP Rising Edge to $\overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$, High | - | 30 | - | 35 | - | 40 | ns |
| trefso | Recovery Time SOCP After $\overline{\mathrm{EF}}$ High | 35 | - | 40 | - | 50 | - | ns |

RESET TIMINGS

| trsc | Reset Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| trs | Reset Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| trss | Reset Set-up Time | 35 | - | 40 | - | 50 | - | ns |
| trsR | Reset Recovery Time | 10 | - | 10 | - | 15 | - | ns |
| trsF1 | Reset to $\overline{\mathrm{EF}}$ and $\overline{\text { AEF Low }}$ | - | 45 | - | 50 | - | 65 | ns |
| trSF2 | Reset to $\overline{\text { HF }}$ and $\overline{\text { FF }}$ High | - | 45 | - | 50 | - | 65 | ns |
| trsa | Reset to Q Low | 20 | - | 20 | - | 35 | - | ns |
| trsaH | Reset to Q High | 20 | - | 20 | - | 35 | - | ns |

## RETRANSMIT TIMINGS

| tRTC | Retransmit Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRT | Retransmit Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| tris | Retransmit Set-up Time | 35 | - | 40 | - | 50 | - | ns |
| tRTR | Retransmit Recovery Time | 10 | - | 10 | - | 15 | - | ns |

DEPTH EXPANSION MODE TIMINGS

| tXOL | Read/Write to $\overline{X O}$ Low | - | 35 | - | 40 | - | 50 | ns |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: | :---: |
| t $\times O H$ | Read/Write to $\overline{X O}$ High | - | 35 | - | 40 | - | 50 | ns |
| tXI | $\overline{X I}$ Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| tXIR | $\overline{X I}$ Recovery Time | 10 | - | 10 | - | 10 | - | ns |
| tXIS | $\overline{X I}$ Set-up Time | 15 | - | 15 | - | 15 | - | ns |

NOTE:
2751 bl 07

1. Guaranteed by design minimum times, not tested.

## AC ELECTRICAL CHARACTERISTICS (Continued)

(Commercial: VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Military and Commercial |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { IDT72131×65 } \\ & \text { IDT72141×65 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72131×80 } \\ & \text { IDT72141×80 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72131×120 } \\ & \text { IDT72141×120 } \end{aligned}$ |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ts | Parallel Shift Frequency | - | 12.5 | - | 10 | - | 7 | M Hz |
| tsocp | Serial-Out Shift Frequency | - | 33 | - | 28 | - | 25 | MHz |

PARALLEL INPUT TIMINGS

| tDS | Data Set-up Time | 30 | - | 40 | - | 40 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tDH | Data Hold Time | 10 | - | 10 | - | 10 | - | ns |
| twc | Write Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| tWPW | Write Pulse Width | 65 | - | 80 | - | 120 | - | ns |
| twr | Write Recovery Time | 15 | - | 20 | - | 20 | - | ns |
| tWEF | Write High to EF High | - | 60 | - | 60 | - | 60 | ns |
| tWFF | Write Low to FF Low | - | 60 | - | 60 | - | 60 | ns |
| twF | Write Low to Transitioning $\overline{\text { HF }}, \overline{\text { AEF }}$ | - | 80 | - | 100 | - | 140 | ns |
| tWPF | Write Pulse Width After FF High | 65 | - | 80 | - | 120 | - | ns |

SERIAL OUTPUT TIMINGS

| tSOHz | SOCP Rising Edge to SO at High $\mathbf{Z}^{(1)}$ | 5 | 20 | 5 | 25 | 5 | 35 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tSOLZ | SOCP Rising Edge to SO at Low ${ }^{(1)}$ | 5 | 22 | 5 | 30 | 5 | 35 | ns |
| tSOPD | SOCP Rising Edge to Valid Data on SO | - | 22 | - | 30 | - | 35 | ns |
| tsox | SOX Set-up Time to SOCP Rising Edge | 5 | - | 5 | - | 5 | - | ns |
| tsocw | Serial In Clock Width High/Low | 10 | - | 15 | - | 15 | - | ns |
| tSOCEF | SOCP Rising Edge (Bit 0-Last Word) to EF Low | - | 30 | - | 30 | - | 30 | ns |
| tSOCFF | SOCP Rising Edge to FF High | - | 50 | - | 60 | - | 65 | ns |
| tSOCF | SOCP Rising Edge to $\overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$, High | - | 50 | - | 60 | - | 65 | ns |
| tREFSO | Recovery Time SOCP Atter EF High | 65 | - | 80 | - | 120 | - | ns |

## RESET TIMINGS

| tRsc | Reset Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRS | Reset Pulse Width | 65 | - | 80 | - | 120 | - | ns |
| tRss | Reset Set-up Time | 65 | - | 80 | - | 120 | - | ns |
| tRSR | Reset Recovery Time | 15 | - | 20 | - | 20 | - | ns |
| tRsF1 | Reset to $\overline{\text { EF }}$ and $\overline{\text { AEF Low }}$ | - | 80 | - | 100 | - | 140 | ns |
| tRSF2 | Reset to $\overline{\text { FF }}$ and $\overline{\text { FF High }}$ | - | 80 | - | 100 | - | 140 | ns |
| tRSQ | Reset to Q Low | 50 | - | 65 | - | 105 | - | ns |
| trsaH | Reset to Q High | 50 | - | 65 | - | 105 | - | ns |

## RETRANSMIT TIMINGS

| tRTC | Retransmit Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRT | Retransmit Pulse Width | 65 | - | 80 | - | 120 | - | ns |
| tRTS | Retransmit Set-up Time | 65 | - | 80 | - | 120 | - | ns |
| tRTR | Retransmit Recovery Time | 15 | - | 20 | - | 20 | - | ns |

## DEPTH EXPANSION MODE TIMINGS

| tXOL | Read/Write to $\overline{X O}$ Low | - | 65 | - | 80 | - | 120 | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tXOH | Read/Write to $\overline{X O}$ High | - | 65 | - | 80 | - | 120 | ns |
| tXI | $\overline{X I}$ Pulse Width | 65 | - | 80 | - | 120 | - | ns |
| UXIR | $\overline{X I}$ Recovery Time | 10 | - | 10 | - | 10 | - | ns |
| UXIS | $\overline{X I}$ Set-up Time | 15 | - | 15 | - | 15 | - | ns |

NOTE:

1. Guaranteed by design minimum times, not tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure A |

## FUNCTIONAL DESCRIPTION

## Parallel Data Input

The data is written into the FIFO in parallel through the Do-s input data lines. A write cycle is initiated on the falling edge of the Write $(\bar{W})$ signal provided the Full Flag ( $\overline{\mathrm{FF}}$ ) is not asserted. If the $\bar{W}$ signal changes from HIGH-to-LOW and the Full-Flag( $\overline{\mathrm{FF}}$ ) is already set, the write line is inhibited internally from incrementing the write pointer and no write operation occurs.

Data set-up and hold times must be met with respect to the rising edge of Write. The data is written to the RAM at the write pointer. On the rising edge of $\bar{W}$, the write pointer is incremented. Write operations can occur simultaneously or asynchronously with read operations.


Figure A. Ouput Load
-Including jig and scope capacitances

## Serial Data Output

The serial data is output on the SO pin. The data is clocked out on the rising edge of SOCP providing the Empty Flag (EF) is not asserted. If the Empty Flag is asserted then the next data word is inhibited from moving to the output register and being clocked out by SOCP. NOTE: SOCP should not be clocked while the Empty Flag is low. If it is, then two things will occur. One, invalid data will be read by SOCP and two, SOCP will be out of sync with Next Read (NR).

The serial word is shifted out Least Significant Bit first, that is the first bit will be D0, then D1 and so on up to the serial word width. The serial word width must be programmed by connecting the appropriate Data Set line (Q4, Q6, Q7 or Q8) to the $\overline{\mathrm{NR}}$ input. The Data Set lines are taps off a digital delay line. Selecting one of these taps, programs the width of the serial word to be read and shifted out.


NOTE:
2751 dmw 11

1. $E F, F F$ and $H F$ may change status during Reset, but flags will be valid at trisc.

Figure 1. Reset


Flgure 2. Write Operation


Figure 3. Read Operation
NOTES:

1. This timing applies to the Active Device in Width Expansion Mode.
2. This timing applies to Single Device Mode at Empty Boundary ( $\overline{E F}=l o w$ ) and the Next Active Device in Width Expansion Mode.


Figure 4. Full Flag from Last Write to First Read


## NOTE:

1. SOCP should not be clocked until EF goes high.

Figure 5. Empty Flag from Last Read to FIrst Write


NOTE:

1. SOCP should not be clocked until $\overline{E F}$ goes high.

Figure 6. Empty Boundary Condition Timing


Flgure 7. Full Boundry Condition TIming


Figure 8. Half Full, Almost Full and Almost Empty Timings


NOTE:

1. $E F, \overline{A E F}, \mathrm{HF}$ and $\overline{F F}$ may change status during Retransmit, but flags will be valid at tric.

Flgure 9. Retransmit


Figure 10. Expansion-Out


FIgure 11. Expansion-In

## OPERATING CONFIGURATIONS

## Single Device Configuration

In the standalone case, the SOX line is tied HIGH and not used. On the first LOW-to-HIGH of the SOCP clock, all of the

Data Set lines (Q4, Q8) go low and a new serialword is started. The Data Set lines then go high on the equivalent SOCP clock pulse. This continues until the Q line connected to $\overline{\mathrm{NR}}$ goes high completing the serial word. The cycle is then repeated with the next LOW-to-HIGH transition of SOCP.


SOCP


Q4


Q6


Q7

$\overline{N R}$


Figure 12. Eight-Bit Word Single Device Configuration

## TRUTH TABLES

TABLE 1: RESET AND RETRANSMIT -
SINGLE DEVICE CONFIGURATION/WIDTH EXPANSION MODE

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbf{R S}}$ | $\overline{\mathrm{FL}}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | $\overline{\mathrm{AEFF}}, \overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ | $\overline{\mathrm{HF}}$ |
| Reset | 0 | X | 0 | Location Zero | Location Zero | 0 | 1 | 1 |
| Retransmit | 1 | 0 | 0 | Location Zero | Unchanged | X | X | X |
| ReadWrite | 1 | 1 | 0 | Increment $^{(1)}$ | Increment $^{(1)}$ | X | X | X |

NOTE:

1. Pointer will increment if appropriate flag is HIGH.

## Width Expansion Configuration

In the cascaded case, word widths of more than 9 bits can be achieved by using more than one device. Bytying the SOX line of the least significant device HIGH and the SOX of the subsequent devices to the appropriate Data Set lines of the previous devices, a cascaded serial word is achieved.

On the first LOW-to-HIGH clock edge of SOCP, all lines go LOW. Just as in the standalone case, on each corresponding clock cycle, the equivalent Data Set line goes HIGH in order of least to most significant. When the Data Set line which is
connected to the SOX input of the next device goes HIGH, the Do of that device goes HIGH, the cascading from one device to the next. The Data Set line of the most significant bit programs the serial word width by being connected to all NR inputs.

The Serial Data Output (SO) of each device in the serial word must be tied together. Since the SO pin is three stated, only the device which is currently shifting out is enabled and driving the 1 -bit-bus.


Figure 13. Width Wxpansion for 16-bit Parallel Data In. The Parallel Data In is tled to Dos of FIFO \#1 and Do-s of FIFO \#2.

## Depth Expansion (Daisy Chain) Mode

The IDT72131/41 can be easily adapted to applications where the requirements are forgreater than2048/4096 words. Figure 14 demonstrates Depth Expansion using three IDT72131/41. Any depth can be attained by adding additional IDT72131/41 operates in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the First Load ( $\overline{\mathrm{FL}}$ ) control input.
2. All other devices must have $\overline{\mathrm{FL}}$ in the high state.
3. The Expansion Out ( $\overline{\mathrm{XO}})$ pin of each device must be tied to the Expansion $\ln (\overline{X I})$ pin of the next device.
4. External logic is needed to generate a composite Full Flag (FF) and Empty Flag (EF). This requires the OR-ing of all EFs and OR-ing of all FFs (i.e., all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{\mathrm{EF}}$ ).
5. The Retransmit ( $\overline{\mathrm{RT}}$ ) function and Half-Full Flag ( $\overline{\mathrm{HF}}$ ) are not available in the Depth Expansion mode.


Figure 14. A 12K $\times 8$ Parallel-In Serial-Out FIFO

TABLE 2: RESET AND FIRST LOAD TRUTH TABLE DEPTH EXPANSION/COMPOUND EXPANSION MODE

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbf{R S}}$ | $\overline{\text { FL }}$ | $\overline{\overline{X I}}$ | Read Pointer | Write Polnter | $\overline{E F}$ | $\overline{F F}$ |
| Reset-First Device | 0 | 0 | (1) | Location Zero | Location Zero | 0 | 1 |
| Retransmit all Other Devices | 0 | 1 | (1) | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | (1) | X | X | X | X |

## NOTES:

1. $\overline{\mathrm{XI}}$ is connected to $\overline{\mathrm{XO}}$ of previous device.
2. $\overline{\mathrm{RS}}=$ Reset Input, $\overline{\mathrm{FL}} / \overline{\mathrm{TT}}=$ First Load/Retransmit, $\overline{\mathrm{EF}}=$ Empty Flag Ouput, $\overline{\mathrm{FF}}=$ Full Flag Output, $\overline{\mathrm{XI}}=$ Expansion Input.

## ORDERING INFORMATION




## FEATURES:

- 35 ns parallel port access time, 45 ns cycle time
- 50 MHz serial port shift rate
- Expandable in depth and width with no external components
- Programmable word lengths including 8, 9, 16-18, and 32-36 bit using Flexshift ${ }^{T M}$ serial input without using any additional components
- Multiple status flags: Full, Almost-Full ( $1 / 8$ from full), Halt-Full, Almost Empty ( $1 / 8$ from empty), and Empty
- Asynchronous and simultaneous read and write operations
- Dual-port zero fall-through architecture
- Retransmit capability in single device mode
- Produced with high-performance, low-power CEMOS ${ }^{\text {TM }}$ technology
- Available in a 28 -pin ceramic and plastic DIP packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT72132/72142 are high-speed, low-power serial-toparallel FIFOs. These FIFOs are ideally suited to serial communications applications, tape/disk controllers, and local area networks (LANs). The IDT72132/72142 can be configured with the IDTs parallel-to-serial FIFOs (IDT72131/72141) for bidirectional serial data buffering.

The FIFO has a serial input port and a 9-bit parallel output port. Wider and deeper serial-to-parallel data buffers can be built using multiple IDT72132/72142 chips. IDTs unique Flexshift serial expansion logic (SIX, NW) makes width expansion possible with no additional components. These FIFOs will expand to a variety of word widths including $8,9,16$, and 32 bits. The IDT72132/142 can also be directly connected for depth expansion.

Five flags are provided to monitor the FIFO. The full and empty flags prevent any FIFO data overilow or underifow conditions. The Almost-Full (7/8), Half-Full, and Almost Empty ( $1 / 8$ ) flags signal memory utilization within the FIFO.

The IDT72132/72142 is fabricated using IDTs high-speed submicron CEMOS technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



PIN DESCRIPTIONS

| Symbol | Name | vo | Description |
| :---: | :---: | :---: | :---: |
| SI | Serial Input | I | Serial data is shifted in least significant bit first. In the serial cascade mode, the Serial Input (SI) pins are tied together and SIX plus D7, D8 determine which device stores the data. |
| $\overline{\mathrm{RS}}$ | Reset | I | When $\overline{R S}$ is set low, internal READ and WRITE pointers are set to the first location of the RAM array. $\overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$ go high, and $\overline{\mathrm{AEF}}$, and $\overline{\mathrm{EF}}$ go low. A reset is required before an initial WRITE after power-up. $\overline{\mathrm{R}}$ must be high during an $\overline{\mathrm{RS}}$ cycle. |
| $\overline{N W}$ | Next Write | 1 | To program the Serial In word width, connect $\overline{\text { NW }}$ with one of the Data Set pins (D7, D8). |
| SICP | Serial Input Clock | 1 | Serial data is read into the serial input register on the rising edge of SICP. In both Depth and Serial Word Width Expansion modes, all of the SICP pins are tied together. |
| $\overline{\mathrm{R}}$ | Read | 1 | When READ is low, data can be read from the RAM array sequentially, independent of SICP. In order for READ to be active, EF must be high. When the FIFO is empty (EF-low), the internal READ operation is blocked and Q0-Q8 are in a high impedance condition. |
| $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ | First Load/ Retransmit | 1 | This is a dual purpose input. In the single device configuration ( $\overline{\mathrm{XI}}$ grounded), activating retransmit ( $\overline{\mathrm{FL} / \mathrm{RT}}$-low) will set the internal READ pointer to the first location. There is no effect on the WRITE pointer. $\overline{\bar{R}}$ must be high and SICP must be low before setting FL/तIT low. Retransmit is not possible in depth expansion. In the depth expansion configuration, FL/RT grounded indicates the first activated device. |
| $\overline{\text { XI }}$ | Expansion In | 1 | In the single device configuration, $\overline{\mathrm{XI}}$ is grounded. In depth expansion or daisy chain expansion, $\overline{\mathrm{XI}}$ is connected to $\overline{\mathrm{XO}}$ (expansion out) of the previous device. |
| SIX | Serial Input Expansion | 1 | In the Expansion mode, the SIX pin of the least significant device is tied high. The SIX pin of all other devices is connected to the D8 pin of the previous device. For single device operation, SIX is tied high. |
| $\overline{\text { OE }}$ | Output Enable | 1 | When $\overline{O E}$ is set low, the parallel output buffers receive data from the RAM array. When $\overline{O E}$ is set high, parallel three state buffers inhibit data flow. |
| Q0-Q8 | Output Data | 0 | Data outputs for 9-bit wide data. |
| $\overline{\mathrm{FF}}$ | Full Flag | 0 | When $\overline{F F}$ goes low, the device is full and data must not be clocked by SICP. When $\overline{F F}$ is high, the device is not full. |
| $\overline{\mathrm{EF}}$ | Empty Flag <br> Almost-Full Flag | 0 | When $\overline{E F}$ goes low, the device is empty and further READ operations are inhibited. When $\overline{E F}$ is high, the device is not empty. |
| $\overline{\text { AEF }}$ | Almost-Empty/ Half-Full Flag | 0 | When $\overline{A E F}$ is low, the device is empty to $1 / 8$ full or $7 / 8$ to completely full. When $\overline{A E F}$ is high, the device is greater than $1 / 8$ full, but less than $7 / 8$ full. |
| $\overline{\mathrm{XO}} / \overline{\mathrm{HF}}$ | Expansion Out/ | 0 | This is a dual purpose output. In the single device configuration (気 grounded), the device is more than half full when $\overline{\mathrm{HF}}$ is low. In the depth expansion configuration ( $\overline{\mathrm{XO}}$ connected to $\overline{\mathrm{XI}}$ of the next device), a pulse is sent from $\overline{\mathrm{XO}}$ to $\overline{\mathrm{XI}}$ when the last location in the RAM array is filled. |
| D7, D8 | Data Set | 0 | The appropriate Data Set pin (D7, D8) is connected to $\overline{\mathrm{NW}}$ to program the Serial In data word width. For example: $\mathrm{D}_{7}$ - $\overline{\text { NW }}$ programs a 8 -bit word width, D8 - $\overline{\mathrm{NW}}$ programs a 9 -bit word width, etc. |
| Vcc | Power Supply |  | Single Power Supply of 5V. |
| GND | Ground |  | Three grounds at OV. |

## STATUS FLAGS

| Number of Words in FIFO |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | IDT72132 | IDT72142 | FF | AEF | HF |
| EF |  |  |  |  |  |
| 0 | 0 | H | L | H | L |
| $1-255$ | $1-511$ | H | L | H | H |
| $256-1024$ | $512-2048$ | H | H | H | H |
| $1025-1792$ | $2049-3584$ | H | H | L | H |
| $1793-2047$ | $3585-4095$ | H | L | L | H |
| 2048 | 4096 | L | L | L | H |

## PIN CONFIGURATIONS



RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccm | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vcc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL $^{(1)}$ | Input Low Voltage | - | - | 0.8 | V |

## NOTE:

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

DC ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 10 | pF |
| CouT | Output Capacitance | Vout $=\mathrm{OV}$ | 12 | pF |

NOTE:
2752 t) 04

1. This parameter is sampled and not $100 \%$ tested.
(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72132/IDT72142 <br> Commercial |  |  | IDT72132/IDT72142 <br> Military |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| IIL ${ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{lOL}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| Vor | Output Logic "1" Voltage, lout $=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vot | Output Logic "0" Voltage, lout $=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{lcCa}^{(3)}$ | Power Supply Current | - | 90 | 140 | - | 100 | 160 | mA |
| $1 \mathrm{CCO}^{(3)}$ | Average Standby Current $(\overline{\mathrm{R}}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} \overline{\mathrm{RT}}=\mathrm{VIH})$ (SICP = VIL) | - | 8 | 12 | - | 12 | 25 | mA |
| $\operatorname{lcc3}(\mathrm{L})^{(3,4)}$ | Power Down Current | - | - | 2 | - | - | 4 | mA |
| lcca(S) ${ }^{(3,4)}$ | Power Down Current | - | - | 8 | - | - | 12 | mA |

NOTES:

1. Measurements with $0.4 \leq \mathrm{ViN}_{\text {IN }} \leq$ Vout.
2. $R \geq V_{I H}, 0.4 \leq$ VOUT $\leq V \subset C$.
3. Icc measurements are made with outputs open.
4. $\overline{\mathrm{RS}}=\overline{\mathrm{FL}} / \mathrm{RT}=\overline{\mathrm{R}}=\mathrm{Vcc}-0.2 \mathrm{~V}$; SICP $\leq 0.2 \mathrm{~V}$; all other inputs $\geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\leq 0.2 \mathrm{~V}$

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{aligned} & \text { Commerclal } \\ & \hline \text { IDT72132×35 } \\ & \text { IDT72142×35 } \\ & \hline \end{aligned}$ |  | Military |  | Mil. and Com'l. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{aligned} & \text { IDT72132x40 } \\ & \text { IDT72142x40 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72132×50 } \\ & \text { IDT72142x50 } \\ & \hline \end{aligned}$ |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ts | Parallel Shift Frequency | - | 22.2 | - | 20 | - | 15 | MHz |
| tSICP | Serial-InShitt Frequency | - | 50 | - | 50 | - | 40 | MHz |
| PARALLEL OUTPUT TIMINGS |  |  |  |  |  |  |  |  |
| ta | Access Time | - | 35 | - | 40 | - | 50 | ns |
| tRR | Read Recovery Time | 10 | - | 10 | - | 15 | - | ns |
| tRPW | Read Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| IRC | Read Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| tRLZ | Read Pulse Low to Data Bus at Low ${ }^{(1)}$ | 5 | - | 5 | - | 10 | - | ns |
| tRHZ | Read Pulse High to Data Bus at High Z ${ }^{(1)}$ | - | 20 | - | 25 | - | 30 | ns |
| tov | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | ns |
| toenz | Output Enable to High-Z (Disable) ${ }^{(1)}$ | - | 15 | - | 15 | - | 15 | ns |
| toelz | Output Enable to Low-Z (Enable) ${ }^{(1)}$ | 5 | - | 5 | - | 5 | - | ns |
| taie | Output Enable to Data Valid (00-8) | - | 20 | - | 20 | - | 22 | ns |

## SERIAL INPUT TIMINGS

| tSIS | Serial Data in Set-Up Time to SICP Rising Edge | 12 | - | 12 | - | 15 | 二 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tSIH | Serial Data in Hold Time to SICP Rising Edge | 0 | - | 0 | - | 0 | - | ns |
| tSIX | SIX Set-Up Time to SICP Rising Edge | 5 | - | 5 | - | 5 | - | ns |
| tsicw | Serial-In Clock Width High/Low | 8 | - | 8 | - | 10 | - | ns |
| FLAG TIMINGS |  |  |  |  |  |  |  |  |
| tSICEF | SICP Rising Edge (Last Bit - First Word) to ĒF High | - | 45 | - | 50 | - | 65 | ns |
| tSICFF | SICP Rising Edge (Bit 1 - Last Word) to FF Low | - | 30 | - | 35 | - | 40 | ns |
| tsicF | SICP Rising Edge to $\overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$ | - | 45 | - | 50 | - | 65 | ns |
| tRFFSI | Recovery Time SICP After $\overline{\mathrm{FF}}$ Goes High | 15 | - | 15 | - | 15 | - | ns |
| tREF | Read Low to EFF Low | - | 30 | - | 35 | - | 45 | ns |
| tRFF | Read High to FF High | - | 30 | - | 35 | - | 45 | ns |
| tRF | Read High to Transitioning $\overline{\text { HF }}$ and $\overline{\text { AEF }}$ | - | 45 | - | 50 | - | 65 | ns |
| tRPE | Read Pulse Width After EF High | 35 | - | 40 | - | 50 | - | ns |

## RESET TIMINGS

| tRSC | Reset Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRS | Reset Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| tRSS | Reset Set-up Time | 35 | - | 40 | - | 50 | - | ns |
| tRSR | Reset Recovery Time | 10 | - | 10 | - | 15 | - | ns |
| tRSF1 | Reset to $\overline{\mathrm{EF}}$ and $\overline{\text { AEF Low }}$ | - | 45 | - | 50 | - | 65 | ns |
| tRSF2 | Reset to $\overline{\mathrm{HF}}$ and $\overline{\text { FF High }}$ | - | 45 | - | 50 | - | 65 | ns |
| tRSDL | Reset to D Low | 20 | - | 20 | - | 35 | - | ns |
| tPOI | SICP Rising Edge to D | 5 | 17 | 5 | 17 | 5 | 20 | ns |

## RETRANSMIT TIMINGS

| tRTC | Retransmit Cycle Time | 45 | - | 50 | - | 65 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRT | Retransmit Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| tRTs | Retransmit Set-up Time | 35 | - | 40 | - | 50 | - | ns |
| tRTR | Retransmit Recovery Time | 10 | - | 10 | - | 15 | - | ns |

DEPTH EXPANSION MODE TIMINGS

| tXOL | Read/Write to $\overline{\text { XO }}$ Low | - | 40 | - | 45 | - | 50 | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tXOH | Read/Write to $\overline{\mathrm{XO}}$ High | - | 40 | - | 45 | - | 50 | ns |
| tXI | $\overline{\text { XI Pulse Width }}$ | 35 | - | 40 | - | 50 | - | ns |
| tXIR | $\overline{\text { XI Recovery Time }}$ | 10 | - | 10 | - | 10 | - | ns |
| tXIS | $\overline{\text { XISet-up Time }}$ | 16 | - | 15 | - | 15 | - | ns |

NOTE:

1. Guaranteed by design minimum times, not tested

## AC ELECTRICAL CHARACTERISTICS (Continued)

(Commercial: Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Military and Commercial |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { IDT72132×65 } \\ & \text { IDT72142x65 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72132×80 } \\ & \text { IDT72142x80 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { IDT72132×120 } \\ & \text { IDT72142×120 } \end{aligned}$ |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ts | Parallel Shift Frequency | - | 12.5 | - | 10 | - | 7 | MHz |
| TSOCP | Serial-Out Shift Frequency | - | 33 | - | 28 | - | 25 | MHz |
| PARALLEL OUTPUT TIMINGS |  |  |  |  |  |  |  |  |
| tA | Access Time | - | 65 | - | 80 | - | 120 | ns |
| tRR | Read Recovery Time | 15 | - | 20 | - | 20 | - | ns |
| tRPW | Read Pulse Width | 65 | - | 80 | - | 120 | - | ns |
| tRC | Read Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| tRLZ | Read Pulse Low to Data Bus at Low Z $^{(1)}$ | 10 | - | 10 | - | 10 | - | ns |
| tRHZ | Read Pulse Highto Data Bus at High Z ${ }^{(1)}$ | - | 30 | - | 35 | - | 35 | ns |
| tDV | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | ns |
| toekz | Output Enable to High-Z (Disable) ${ }^{(1)}$ | - | 20 | - | 25 | - | 30 | ns |
| toelz | Output Enable to Low-Z (Enable) ${ }^{(1)}$ | 5 | - | 5 | - | 5 | - | ns |
| tate | Output Enable to Data Valid (Q0-8) | - | 25 | - | 30 | - | 35 | ns |
| SERIAL INPUT TIMINGS |  |  |  |  |  |  |  |  |
| tSIS | Serial Data in Set-Up Time to SICP Rising Edge | 15 | - | 20 | - | 20 | - | ns |
| tSIH | Serial Data in Hold Time to SICP Rising Edge | 0 | - | 5 | - | 5 | - | ns |
| tSIX | SIX Set-Up Time to SICP Rising Edge | 5 | - | 5 | - | 5 | - | ns |
| tsICW | Serial-In Clock Width High/Low | 10 | - | 15 | - | 15 | - | ns |
| FLAG TIMINGS |  |  |  |  |  |  |  |  |
| tSICEF | SICP Rising Edge (Last Bit - First Word) to EF High | - | 80 | - | 80 | - | 80 | ns |
| tSICFF | SICP Rising Edge (Bit 1 - Last Word) to $\widehat{\mathrm{FF}}$ Low | - | 50 | - | 60 | - | 60 | ns |
| tSICF | SICP Rising Edge to $\overline{\mathrm{HF}}, \overline{\mathrm{AEF}}$ | - | 80 | - | 80 | - | 80 | ns |
| tRFFSI | Recovery Time SICP After FF Goes High | 15 | - | 20 | - | 20 | - | ns |
| tREF | Read Low to EF Low | - | 60 | - | 60 | - | 60 | ns |
| tRFF | Read High to FF High | - | 60 | - | 60 | - | 60 | ns |
| tRF | Read High to Transitioning $\overline{\mathrm{HF}}$ and $\overline{\text { AEF }}$ | - | 80 | - | 100 | - | 140 | ns |
| tRPE | Read Pulse Width After EF High | 65 | - | 80 | - | 120 | - | ns |

## RESET TIMINGS

| trsc | Reset Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| trs | Reset Pulse Width | 65 | - | 80 | - | 120 | - | ns |
| trss | Reset Set-up Time | 65 | - | 80 | - | 120 | - | ns |
| trse | Reset Recovery Time | 15 | - | 20 | - | 20 | - | ns |
| tRSF1 | Reset to $\overline{E F}$ and $\overline{\text { EEF }}$ Low | - | 80 | - | 100 | - | 140 | ns |
| tRSF2 | Reset to $\overline{\mathrm{FF}}$ and $\overline{\mathrm{FF}} \mathrm{High}$ | - | 80 | - | 100 | - | 140 | ns |
| thSDL | Reset to D Low | 50 | - | 65 | - | 105 | - | ns |
| POI | SICP Rising Edge to D | 5 | 25 | 5 | 30 | 5 | 35 | ns |

## RETRANSMIT TIMINGS

| tRTC | Retransmit Cycle Time | 80 | - | 100 | - | 140 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRT | Retransmit Pulse Width | 65 | - | 80 | - | 120 | - | ns |
| tRTS | Retransmit Set-up Time | 65 | - | 80 | - | 120 | - | ns |
| tRTR | Retransmit Recovery Time | 15 | - | 20 | - | 20 | - | ns |

## DEPTH EXPANSION MODE TIMINGS

| tXOL | Read/Write to $\overline{\mathrm{XO}}$ Low | - | 65 | - | 80 | - | 120 | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tXOH | Read/Write to $\overline{\mathrm{XO}}$ High | - | 65 | - | 80 | - | 120 | ns |
| $\mathrm{t} \times \mathrm{I}$ | $\overline{\mathrm{XI}}$ Pulse Widh | 65 | - | 80 | - | 120 | - | ns |
| $\mathrm{t} \times 1 \mathrm{R}$ | $\overline{\mathrm{XI}}$ Recovery Time | 10 | - | 10 | - | 10 | - | ns |
| $\mathrm{t} \times 1 \mathrm{~S}$ | $\overline{\mathrm{XI}}$ Set-up Time | 15 | - | 15 | - | 15 | - | ns |

## NOTE:

1. Guaranteed by design minimum times, not tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |  |  |
| :--- | :---: | :---: | :---: |
| Input Rise/Fall Times | 5 ns |  |  |
| Input Timing Reference Levels | 1.5 V |  |  |
| Output Reference Levels | 1.5 V |  |  |
| Output Load | See Figure A |  |  |
| 2752 to 09 |  |  |  |

## FUNCTIONAL DESCRIPTION

## Serial Data Input

The serial data is input on the SI pin. The data is clocked in on the rising edge of SICP providing the Full Flag $(\overline{F F})$ is not asserted. If the Full Flag is asserted then the next data word is inhibited from moving into the RAM array. NOTE: SICP should not be clocked while the Full Flag is low. If it is, then then the input data will be lost.

The serial word is shifted in Least Significant Bit first. Thus, when the FIFO is read, the Least Significant Bit will come ouf on Q0 and the second bit is on Q1 and so on. The serial word width must be programmed by connecting the appropriate Data Set line (D7, D8) to the NW input. The data set lines are taps, programs the width of the serial word to be read in.


Flgure A. Output Load
*Includies jig and scope capacitances

## Parallel Data Output

A read cycle is initiated on the falling edge of Read ( $\overline{\mathrm{R}})$ provided the Empty Flag is not set. The output data is accessed on a first-in/first-out basis, independent of the ongoing write operations. The data is available ta after the falling edge of $\bar{R}$ and the output bus $Q$ goes into high impedance after $\overline{\mathrm{R}}$ goes HIGH.

Alternately, the user can access the FIFO by keeping $\overline{\mathrm{R}}$ LOW and enabling data on the bus by asserting Output Enable ( $\overline{\mathrm{OE}}$ ). When $\overline{\mathrm{R}}$ is LOW, the $\overline{\mathrm{OE}}$ signal enables data on the output bus. When $\overline{\mathrm{R}}$ is LOW and $\overline{\mathrm{OE}}$ is HIGH, the output bus is three-stated. When $\overline{\mathrm{R}}$ is HIGH, the output bus is disabled irrespective of $\overline{\mathrm{OE}}$.


NOTE:

1. $\overline{E F}, \overline{F F}$ and $\overline{\mathrm{FF}}$ may change status during Reset, but flags will be valid at trse.

Figure 1. Reset


Figure 2. Write Operation


Figure 3. Read Operation


Figure 4. Output Enable Timings


NOTE:
2752 dnw 07

1. SICP should not be clocked until FF goes high.

Figure 5. Full Flag from Last Write to First Read


Figure 6. Empty Flag from Last Read to First Write


Figure 7. Empty Boundry Condition Timing


NOTE:

1. SICP should remain low unti after $\overline{F F}$ goes high.

Figure 8. Full Boundry Condition Timing


2752 drw 11

Figure 9. Half Full, Almost Full and Almost Empty Timings


2752 drw 13
NOTE:

1. $\overline{E F}, \overline{A E F}, \overline{H F}$ and $\overline{F F}$ may change status during Retransmit, but flags will be valid at trTc.

Figure 10. Retransmit


Figure 11. Expansion-Out


Figure 12. Expansion-In

## OPERATING CONFIGURATIONS

## Single Device Conflguration

In the standalone case, the SIX line is tied HIGH and not used. On the first LOW-to-HIGH of the SICP clock, both of the

Data Set lines (D7, D8) go low and a new serial word is started. The Data Set lines then go high on the equivalent SICP clock pulse. This continues until the Dline connected to $\overline{\mathrm{NW}}$ goes high completing the serial word. The cycle is then repeated with the next LOW-to-HIGH transition of SICP.


Figure 13. Nine-Bit Word Single Device Conflguration

## TRUTH TABLES

TABLE 1: RESET AND RETRANSMIT -
SINGLE DEVICE CONFIGURATION/WIDTH EXPANSION MODE

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS | FL | $\overline{\mathrm{X}}$ | Read Pointer | Write Polnter | $\overline{\text { AEF, }} \mathbf{E F}$ | FF | $\overline{\text { HF }}$ |
| Reset | 0 | X | 0 | Location Zero | Location Zero | 0 | 1 | 1 |
| Retransmit | 1 | 0 | 0 | Location Zero | Unchanged | X | X | X |
| Read/Write | 1 | 1 | 0 | Increment ${ }^{(1)}$ | Increment ${ }^{(1)}$ | X | X | X |

## NOTE:

1. Pointer will increment if appropriate flag is HIGH.

## Width Expansion Conflguration

In the cascaded case, word widths of more than 9 bits can be achieved by using more than one device. By tying the SIX line of the least significant device HIGH and the SIX of the subsequent devices to the appropriate Data Set lines of the previous devices, a cascaded serial word is achieved.

On the first LOW-to-HIGH clock edge of SICP, both the Data Set lines go LOW. Just as in the standalone case, on each corresponding clock cycle, the equivalent Data Set line goes HIGH in order of least to most significant.


Figure 14. Serlal-In to Parallel-Out Data of 16 Bite

## Depth Expansion (Dalsy Chaln) Mode

The IDT72132/42 can be easily adapted to applications where the requirements are for greater than2048/4096 words. Figure 15 demonstrates Depth Expansion using three IDT72132/42. Any depth can be attained by adding additional IDT72132/42 operates in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the First Load ( $\overline{\mathrm{FL}}$ ) control input.
2. All other devices must have $\overline{\text { FL }}$ in the high state.
3. The Expansion Out ( $\overline{\mathrm{XO}})$ pin and Expansion In $(\overline{\mathrm{XI}})$ pin of each device must be tied together.
4. External logic is needed to generate a composite Full Flag ( $\overline{\mathrm{FF}}$ ) and Empty Flag (EF). This requires the OR-ing of all EFs and OR-ing of all FFs (i.e., all must be set to generate the correct composite ( $\overline{\mathrm{FF}}$ ) or (EF).
5. The Retransmit $(\overline{\mathrm{RT}})$ function and Half-Full Flag ( $\overline{\mathrm{HF}}$ ) are not available in the Depth Expansion mode.


Figure 15. An $8 \mathrm{~K} \times 8$ Serlal-In Paralle-Out FIFO

TABLE 2: RESET AND FIRST LOAD TRUTH TABLE DEPTH EXPANSION/COMPOUND EXPANSION MODE

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbf{R S}}$ | $\overline{\mathrm{FL}}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write PoInter | $\overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ |
| Reset-First <br> Device | $\mathbf{0}$ | $\mathbf{0}$ | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Retransmit all <br> Other Devices | 0 | 1 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| ReadWrite | $\mathbf{1}$ | X | $(1)$ | X | X | X | X |

NOTES:

1. $\overline{X I}$ is connected to $\overline{X O}$ of the previous device.
2. $\overline{R S}=$ Reset Input, $\overline{F L} / \overline{R T}=$ First Load/Retransmit, $\overline{E F}=$ Empty Flag Ouput, $\overline{F F}=$ Full Flag Output, $\overline{X I}=$ Expansion Input.

SERIAL INPUT WITH WIDTH AND DEPTH EXPANSION


Flgure 16. An $8 \mathrm{~K} \times 24$ Serlal-In, Paralled-Out FIFO Using Six IDT72142s

## ORDERING INFORMATION



## CMOS PARALLEL

## FEATURES:

- 64,256 , and $512 \times 8$-bit memory array structures
- 15ns read/write cycle time
- Read and write clocks can be asynchronous or coincident
- Dual-ported zero fall-through time architecture
- Empty and Full flags signal FIFO status
- Almost-empty and almost-full flags set to Empty+7 and Full-7, respectively
- Output enable puts output data bus in high impedance state
- Produced with advanced submicron CEMOS ${ }^{\text {™ }}$ technology
- Available in 28-pin 300 mil plastic DIP and 300 mil ceramic DIP
- For surface mount product please see the IDT72201/ 72211/72421 data sheet
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT72200/72210/72420 SyncFIFO ${ }^{\text {¹ }}$ are very high speed, low-power first-in, first-out (FIFO) memories with clocked read and write controls. The IDT72200/72210/ 72420 have a 256,512 , and $64 \times 8$-bit memory array, respectively. These FIFOs are applicable for a wide variety of data buffering needs, such as graphics, local area networks (LANs), and interprocessor communication.

These FIFOs have 8-bit input and output ports. The input port is controlled by a free-running clock (WCLK), and a write enable pin (WEN). Data is read into the Synchronous FIFO on every clock when WEN is asserted. The output port is controlled by another clock pin (RCLK) and a read enable pin ( $\overline{\mathrm{REN}}$ ). The read clock can be tied to the write clock for single clock operation or the two clocks can run asynchronous of one another for dual clock operation. An output enable pin ( $\overline{\mathrm{OE})}$ is provided on the read port for three-state control of the output.

These Synchronous FIFOs have two end-point flags, Empty $(\overline{\mathrm{EF}})$ and Full $(\overline{\mathrm{FF}})$. Two partial flags, Almost-Empty ( $\overline{\mathrm{AE}})$ and Almost-Full $(\overline{\mathrm{AF}})$, are provided for improved system control. The partial ( $\overline{\mathrm{AE}}$ ) flags are set to Empty +7 and Full- 7 for $\overline{\mathrm{AE}}$ and $\overline{\mathrm{AF}}$ respectively.

The IDT72200/72210/72420 are fabricated using IDT's high speed submicron CEMOS ${ }^{\text {mM }}$ technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## PIN CONFIGURATION



PIN DESCRIPTIONS

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| Do - D7 | Data Inputs | 1 | Data inputs for a 8-bit bus. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal read and write pointers are set to the first location of the RAM array, $\overline{F F}$ and $\overline{P A F}$ go high, and $\overline{\mathrm{PAE}}$ and $\overline{\mathrm{EF}}$ go low. A reset is required before an initial WRITE after power-up. |
| WCLK | Write Clock | 1 | Data is written into the FIFO on a LOW-to-HIGH transition of WCLK when WEN is asserted. |
| WEN | Write Enable | 1 | When WEN is LOW, data is written into the FIFO on every LOW-to-HIGH transition of WCLK. Data will not be written into the FIFO if the $\overline{\mathrm{FF}}$ is LOW. |
| Q0-Q7 | Data Outputs | 0 | Data outputs for a 8-bit bus. |
| RCLK | Read Clock | 1 | Data is read from the FIFO on a LOW-to-HIGH transition of RCLK when $\overline{\text { REN }}$ is asserted. |
| $\overline{R E N}$ | Read Enable | 1 | When $\overline{\text { REN }}$ is LOW, data is read from the FIFO on every LOW-to-HIGH transition of RCLK. Data will not be read from the FIFO if the $\overline{\mathrm{EF}}$ is LOW. |
| $\overline{O E}$ | Output Enable | 1 | When $\overline{\mathrm{OE}}$ is LOW, the data output bus is active. If $\overline{\mathrm{OE}}$ is HIGH, the output data bus will be in a high impedance state. |
| $\overline{\mathrm{EF}}$ | Empty Flag | 0 | When $\overline{E F}$ is LOW, the FIFO is empty and further data reads from the output are inhibited. When $\overline{E F}$ is HIGH, the FIFO is not empty. $\overline{\mathrm{EF}}$ is synchronized to RCLK. |
| $\overline{\mathrm{A} E}$ | Almost-Empty Flag | 0 | When $\overline{\mathrm{AE}}$ is LOW, the FIFO is almost empty based on the offset Empty+7. $\overline{\mathrm{AE}}$ is synchronized to RCLK. |
| $\overline{\mathrm{AF}}$ | Almost-Full Flag | 0 | When $\overline{\mathrm{AF}}$ is LOW, the FIFO is almost full based on the offset Full-7. $\overline{\mathrm{AF}}$ is synchronized to WCLK. |
| $\overline{\mathrm{FF}}$ | Full Flag | 0 | When $\overline{\mathrm{FF}}$ is LOW, the FIFO is full and further data writes into the input are inhibited. When $\overline{\mathrm{FF}}$ is HIGH, the FIFO is not full. $\overline{F F}$ is synchronized to WCLK. |
| Vcc | Power |  | One +5 volt power supply pin. |
| GND | Ground |  | One 0 volt ground pin. |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than thoselistedunderABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccm | Military Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL | Input Low Voltage <br> Commercial \& Military | - | - | 0.8 | V |

2680 tbil 03

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72200IDT72210IDT72420CommerclaltCLK $=15,20,25,50 \mathrm{~ns}$ |  |  | IDT72200 <br> IDT72210 <br> IDT72420 Milltary $\text { tCLK }=20,25,50 \mathrm{~ns}$ |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $1 \mathrm{LI}^{(1)}$ | Input Leakage Current (any input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| ILO ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, $\mathrm{IOH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| VoL | Output Logic "0" Voltage, loL = 8 mA | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{ICC1}^{(3)}$ | Active Power Supply Current | - | - | 140 | - | - | 160 | mA |

## NOTES:

1. Measurements with $0.4 \leq$ Vin $\leq$ Vout.
2. $\overline{\mathrm{OE}} \geq \mathrm{V}_{\mathrm{H}}, 0.4 \leq \mathrm{VOUT} \leq \mathrm{VCC}$
3. Measurements are made with outputs open. Tested at fcLk $=20 \mathrm{MHz}$.

Typical IcC1 $=65+$ (fclk* $1.1 / \mathrm{MHz}$ ) $+\left(\right.$ fcle ${ }^{*} \mathrm{CL}^{*} 0.03 / \mathrm{MHz}-\mathrm{pF}$ ) mA
fCLK $=1 /$ tCLK
$C L=$ external capacitive load ( 30 pF typical)

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN $^{(2)}$ | Input Capacitance | VIN $=0 \mathrm{~V}$ | 10 | pF |
| COUT(1,2) | Output Capacitance | VouT $=0 \mathrm{~V}$ | 10 | pF |
| NOTES: |  |  |  |  |

## NOTES:

2680 tbl 05

1. With output deselected. ( $\overline{\mathrm{OE}}=$ high)
2. Characterized values, not currently tested.

## AC ELECTRICAL CHARACTERISTICS

（Commercial：VCc $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ；Military： $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | Com＇l． <br> IDT72200L15 <br> IDT72210L15 <br> IDT72420L15 <br> Min．Max． | $\begin{array}{\|l} \hline \text { IDT7220 } \\ \text { IDT7221 } \\ \text { IDT7242 } \\ \text { Min. } \end{array}$ | Com 200L20 10L20 Max． | $\begin{aligned} & \hline \text { merclal } \\ & \text { IDT7220 } \\ & \text { IDT721 } \\ & \text { IDT7242 } \\ & \text { Min. } \\ & \hline \end{aligned}$ | 18 MIII 200L25 10 L 25 $20 L 25$ Max． | $\begin{aligned} & \text { Itary } \\ & \text { IDT7220 } \\ & \text { IDT722 } \\ & \text { IDT7242 } \\ & \text { Min. } \end{aligned}$ | $\begin{aligned} & \text { 200L50 } 50 \\ & 120 L 50 \\ & \text { 120L50 } \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| fs | Clock Cycle Frequency | － 66.7 | － | 50 | － | 40 | － | 20 | MHz |
| tA | Data Access Time | 2 \％． 10 | 2 | 12 | 3 | 15 | 3 | 25 | ns |
| tCLK | Clock Cycle Time | 15 － | 20 | － | 25 | － | 50 | － | ns |
| tCLKH | Clock High Time | 6 \％ | 8 | － | 10 | － | 20 | － | ns |
| tCLKL | Clock Low Time | 6 － | 8 | － | 10 | － | 20 | － | ns |
| tDs | Data Set－up Time | 4 \％毋． | 5 | － | 6 | － | 10 | － | ns |
| tDH | Data Hold Time | 1 － | 1 | － | 1 | － | 2 | － | ns |
| tens | Enable Set－up Time | 4 ， | 5 | － | 6 | － | 10 | － | ns |
| tenh | Enable Hold Time | $1^{\text {Na ．．．}{ }^{\text {a }} \text {－}}$ | 1 | － | 1 | － | 2 | － | ns |
| tRS | Reset Pulse Width ${ }^{(1)}$ | 15\％\％\％ | 20 | － | 25 | － | 50 | － | ns |
| tRSS | Reset Set－up Time | 15 | 20 | － | 25 | － | 50 | － | ns |
| tRSF | Reset to Flag and Output Time | － | － | 20 | － | 25 | － | 50 | ns |
| tolz | Output Enable to Output in Low Z ${ }^{(2)}$ | $0 \times 1$ | 0 | － | 0 | － | 0 | － | ns |
| toe | Output Enable to Output Valid | － 3 \％．．．ा 8 | 3 | 10 | 3 | 13 | 3 | 28 | ns |
| tohz | Output Enable to Output in High Z ${ }^{(2)}$ | $3 \%$ | 3 | 10 | 3 | 13 | 3 | 28 | ns |
| tWFF | Write Clock to Full Flag |  | － | 12 | － | 15 | － | 30 | ns |
| tREF | Read Clock to Empty Flag | 一莐： 10 | － | 12 | － | 15 | － | 30 | ns |
| tAF | Write Clock to Almost－Full Flag | －$\times$ \％ 10 | － | 12 | － | 15 | － | 30 | ns |
| taE | Read Clock to Almost－Empty Flag | 一毋．．．10 | － | 12 | － | 15 | － | 30 | ns |
| tSKEW1 | Skew time between Read Clock \＆Write Clock for Empty Flag \＆Full Flag |  | 8 | － | 10 | － | 15 | － | ns |
| tSKEW2 | Skew time between Read Clock \＆Write Clock for Almost－Empty Flag \＆Almost－Full Flag |  | 18 | － | 20 | － | 30 | － | ns |

## NOTES：

2680 tb 06
1．Pulse widths less than minimum values are not allowed．
2．Values guaranteed by design，not currently tested．

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3．0V |
| :--- | :---: |
| Input Rise／Fall Times | 3ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |
| $2680 \pm 107$ |  |


or equivalent circuit
2680 drw 03
Figure 1．Output Load
＊Indudes jig and scope capacitances．

## SIGNAL DESCRIPTIONS

## INPUTS:

Data In (D0 - D7) - Data inputs for 8-bit wide data.

## CONTROLS:

Reset ( $\overline{\mathrm{RS}})$ - Reset is accomplished wheneverthe Reset ( $\overline{\mathrm{RS}}$ ) input is taken to a low state. During reset, both internal read and write pointers are set to the first location. A reset is required after power up before a write operation can take place. The Full Flag ( $\overline{\mathrm{FF}}$ ) and Almost Full Flag ( $\overline{\mathrm{AF}}$ ) will be reset to high after tRSF. The Empty Flag ( $\overline{\mathrm{EF}})$ and Almost Empty Flag $(\overline{\mathrm{AE}})$ will be reset to low after tRSF. During reset, the output register is initialized to all zeros.

Write Clock (WCLK) - A write cycle is initiated on the low-tohightransition of the write clock (WCLK). Data set-up and hold times must be met in respect to the low-to-hightransition of the write clock (WCLK). The Full Flag ( $\overline{\mathrm{FF}}$ ) and Almost Full Flag $(\overline{\mathrm{AF}})$ are synchronized with respect to the low-to-high transition of the write clock (WCLK).

The write and read clocks can be asynchronous or coincident.

Write Enable ( $\overline{W E N}$ ) - When Write Enable ( $\overline{\text { WEN }}$ ) is low, data can be loaded into the input register and RAM array on the low-to-high transition of every write clock (WCLK). Data is stored in the RAM array sequentially and independently of any ongoing read operation.

When Write Enable (WEN) is high, the input register holds the previous data and no new data is allowed to be loaded into the register.

To prevent data overflow, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operations. Upon the completion of a valid read cycle, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go high after twFF, allowing a valid write to begin. Write Enable (WEN) is ignored when the FIFO is full.

Read Clock (RCLK) - Data can be read on the outputs on the low-to-high transition of the read clock (RCLK). The Empty Flag ( $\overline{\mathrm{EF}}$ ) and Almost-Empty Flag ( $\overline{\mathrm{AE}}$ ) are synchronized with respect to the low-to-high transition of the read clock (RCLK).

The write and read clocks can be asynchronous or coincident.

Read Enable ( $\overline{\operatorname{REN}}$ ) - When Read Enable ( $\overline{\mathrm{REN}}$ ) is low, data is read from the RAM array to the output register on the low-to-high transition of the read clock (RCLK).

When Read Enable ( $\overline{\operatorname{REN}}$ ) is high, the output register holds the previous data and no new data is allowed to be loaded into the register.

When all the data has been read from the FIFO, the Empty Flag ( $\overline{\mathrm{EF}}$ ) will go low, inhibiting further read operations. Once a valid write operation has been accomplished, the Empty Flag ( $\overline{E F}$ ) will go high after tREF and a valid read can begin. Read Enable (REN) is ignored when the FIFO is empty.

Output Enable ( $\overline{\mathrm{OE}})$ - When Output Enable ( $\overline{\mathrm{OE}}$ ) is enabled (low), the parallel output buffers receive data from the output register. When Output Enable ( $\overline{\mathrm{OE}}$ ) is disabled (high), the Q output data bus is in a high impedance state.

## OUTPUTS:

Full Flag ( $\overline{\mathrm{FF}}$ ) - The Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operation, when the device is full. If no reads are performed after Reset ( $\overline{\mathrm{RS}}$ ), the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low after 256 writes for the IDT72200, 512 writes for the IDT72210, and 64 writes for the IDT72420.

The Full Flag ( $\overline{\mathrm{FF}}$ ) is synchronized with respect to the low-to-high transition of the write clock (WCLK).

Empty Flag ( $\overline{\mathrm{EF}}$ ) - The Empty Flag ( $\overline{\mathrm{EF}}$ ) will go low, inhibiting further read operations, when the read pointer is equal to the write pointer, indicating the device is empty.

The Empty Flag ( $\overline{\mathrm{EF}}$ ) is synchronized with respect to the low-to-high transition of the read clock (RCLK).

Almost Full Flag ( $\overline{\mathrm{AF}})$ - The Almost Full Flag $(\overline{\mathrm{AF}})$ will go low when the FIFO reaches the Almost-Full condition. If no reads are performed after Reset ( $\overline{\mathrm{RS}})$, the Almost Full Flag $(\overline{\mathrm{AF}})$ will go low after 249 writes for the IDT72200, 505 writes for the IDT72210, and 57 writes for the IDT72420.

The Almost Full Flag ( $\overline{\mathrm{AF}}$ ) is synchronized with respect to the low-to-high transition of the write clock (WCLK).

Almost Empty Flag ( $\overline{\mathrm{AE}})$ - The Almost Empty Flag ( $\overline{\mathrm{AE}})$ will go low when the FIFO reaches the Almost-Empty condition. If no reads are performed after Reset ( $\overline{\mathrm{RS}}$ ), the Almost Empty Flag ( $\overline{\mathrm{AE}})$ will go high after8 writes for the IDT72200, IDT72210, and IDT72420.

The Almost Empty Flag ( $\overline{\mathrm{AE}})$ is synchronized with respect to the low-to-high transition of the read clock (RCLK)

Data Outputs (Qo - Q7) - Data outputs for a 8-bit wide data.

TABLE 1: STATUS FLAGS

| Number of Words in FIFO |  |  | FF | $\overline{\text { AF }}$ | $\overline{\text { AE }}$ | EF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IDT72200 | IDT72210 | IDT72420 |  |  |  |  |
| 0 | 0 | 0 | H | H | L | L |
| 1 to 7 | 1 to 7 | 1 to 7 | H | H | L | H |
| 8 to 248 | 8 to 504 | 8 to 56 | H | H | H | H |
| 249 to 255 | 505 to 511 | 57 to 63 | H | L | H | H |
| 256 | 512 | 64 | L | L | H | H |



NOTE:

1. After reset, the outputs will be low if $\overline{O E}=0$ and tri-state if $\overline{O E}=1$.
2. The clocks (RCLK, WCLK) can be free-running during reset.

Figure 2. Reset Timing

$\overline{\text { REN }}$


## NOTE:

1. tSKEW1 is the minimum time between a rising RCLK edge and a rising WCLK edge for $\overline{F F}$ to change during the curent clock cycle. If the time betwoen the rising edge of RCLK and the rising edge of WCLK is less than tskEWi, then FF may not change state until the next WCLK edge.

Figure 3. Write Cycle Timing


2680 drw 06
NOTE:

1. IskEW1 is the minimum time between a rising WCLK edge and a rising RCLK edge for $\overline{E F}$ to change during the curent clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than tsKEWi, then EF may not change state until the next RCLK edge.

Figure 4. Read Cycle TIming


## NOTE:

1. When tskew $\geq$ minimum specification, $t$ FRL maximum $=$ tCLK + tSKEW tsKEW < minimum specification, trRL maximum $=2$ tcLK + tskEw 1 The Latency Timing apply only at the Empty Boundry ( $\overline{\mathrm{EF}}=\mathrm{LOW}$ ).

Figure 5. First Data Word Latency Timing


NEXT DATA READ

Figure 6. Full Flag Timing


NOTE:
2680 drw 09

1. When tSKEW $\geq$ minimum specification, tFRL maximum $=$ tCLK + tSKEW 1 tSKEW < minimum specification, tFRL maximum $=2$ tCLK + tSKEW 1 The Latency Timing apply only at the Empty Boundry ( $\overline{E F}=$ LOW).

Figure 7. Empty Flag Timing


2680 drw 10
NOTES:

1. tsKEW2 is the minimum time between a rising RCLK edge and a rising WCLK edge for $\overline{A F}$ to change during the curent clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than tskEW2, then $\overline{A F}$ may not change state until the next WCLK edge.
2. If a write is performed on this rising edge of the write clock, there will be a Full -6 words in the FIFO when $\overline{A F}$ goes low.

Figure 8. Almost Full Flag Timing


NOTES:

1. tsKEW2 is the minimum time between a rising WCLK edge and a rising RCLK edge for $\overline{A E}$ to change during the curent clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than tskEWz, then $\overline{A E}$ may not change state until the next RCLK edge.
2. If a read is performed on this rising edge of the read clock, there will be a Empty -6 words in the FIFO when $\overline{A E}$ goes tow.

Figure 9. Almost Empty Flag Timing

## OPERATING CONFIGURATIONS

SINGLE DEVICE CONFIGURATION - A single IDT72200/ $72210 / 72420$ may be used when the application requirements are for 256/512/64 words or less. See Figure 10.


2680 dm 12
Flgure 10. Block Dlagram of Single $256 \times 8 / 512 \times 8 / 64 \times 8$ Synchronous FIFO

WIDTH EXPANSION CONFIGURATION - Word width may be increased simply by connecting the corresponding input control signals of multiple devices. Status flags ( $\overline{\mathrm{EF}}, \overline{\mathrm{AE}}, \overline{\mathrm{AF}}$ and $\overline{F F}$ ) can be detected from any one device. Figure 11
demonstrates a 16-bit word width by using two IDT72200/ $72210 / 72420 \mathrm{~s}$. Any word width can be attained by adding additional IDT72200/72210/72420s.


2680 drw 13
Figure 11. Block Dlagram of $256 \times 16 / 512 \times 16 / 64 \times 16$ Synchronous FIFO Used In a Width Expansion Conflguration

DEPTH EXPANSION - The IDT72200/72210/72420 can be adapted to applications when the requirements are for greater than 256/512/64 words. Depth expansion is possible by using expansion logic to direct the flow of data. A typical application
would have the expansion logic alternate data accesses from one device to the next in a sequential manner.

Please see the Application Note "DEPTH EXPANSION USING 72211 SYNCHRONOUS FIFOs" for details of this configuration.

## ORDERING INFORMATION



| Integrated Device Technology, Inc. | CMOS PARALLEL <br> SyncFIFO ${ }^{\text {TM }}$ (CLOCKED FIFO) <br> $256 \times 9$-BIT, $512 \times 9$-BIT AND $64 \times 9$-BIT | IDT72201 IDT72211 IDT72421 |
| :---: | :---: | :---: |

## FEATURES:

- 64, 256, and $512 \times 9$-bit memory array structures
- 15ns read/write cycle time
- Read and write clocks can be asynchronous or coincident
- Dual-ported zero fall-through time architecture
- Empty and Full flags signal FIFO status
- Programmable Almost-Empty and Almost-Full flags can be set to any depth
- Programmable Almost-Empty and Almost-Full flags default to Empty+7, and Full-7, respectively
- Output enable puts output data bus in high impedance state
- Produced with advanced submicron CEMOS ${ }^{\text {M }}$ technology
- Available in 32-pin plastic leaded chip carrier (PLCC) and ceramic leadless chip carrier (LCC)
- For Through-Hole product please see the IDT72200/ 72210/72420 data sheet
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT72201/72211/72420 SyncFIFO ${ }^{\text {TM }}$ are very highspeed, low-power first-in, first-out (FIFO) memories with clocked read and write controls. The IDT72201/72211/72420
have a 256,512 , and $64 \times 9$-bit memory array, respectively. These FIFOs are applicable for a wide variety of data buffering needs such as graphics, local area networks (LANs) and interprocessor communication.

These FIFOs have 9 -bit input and output ports. The input port is controlled by a free-running clock (WCLK), and two write enable pins (WEN1, WEN2). Data is read into the Synchronous FIFO on every clock when the write enable pins are asserted. The output port is controlled by another clock pin (RCLK) and two read enable pins ( $\overline{\mathrm{REN} 1}, \overline{\mathrm{REN} 2}$ ). The read clock can be tied to the write clock for single clock operation or the two clocks can run asynchronous of one another for dual clock operation. An output enable pin ( $\overline{\mathrm{OE}})$ is provided on the read port for three-state control of the output.

The Synchronous FIFOs have two fixed flags, Empty ( $\overline{\mathrm{EF}}$ ) and Full $(\overline{\mathrm{FF}})$. Two programmable flags, Almost-Empty ( $\overline{\mathrm{PAE}})$ and Almost-Full (PAF), are provided for improved system control. The programmable flags default to Empty+7 and Full7 for $\overline{\mathrm{PAE}}$ and $\overline{\mathrm{PAF}}$, respectively. The programmable flag offset loading is controlled by a simple state machine and is initiated by asserting the load pin (ID).

The IDT72201/72211/72420 are fabricated using IDT's high-speed submicron CEMOS ${ }^{\text {TM }}$ technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.


## PIN CONFIGURATION



PIN DESCRIPTIONS
2655 drw 02

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| D0-D8 | Data Inputs | 1 | Data inputs for a 9-bit bus. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal read and write pointers are set to the first location of the RAM array, $\overline{\mathrm{FF}}$ and $\overline{\mathrm{PAF}}$ go high, and $\overline{\mathrm{PAE}}$ and $\overline{\mathrm{EF}}$ go low. A reset is required before an initial WRITE after power-up. |
| WCLK | Write Clock | 1 | Data is written into the FIFO on a LOW-to-HIGH transition of WCLK when the Write Enable(s) are asserted. |
| $\overline{\text { WEN1 }}$ | Write Enable 1 | 1 | If the FIFO is configured to have programmable flags, $\overline{\text { WEN1 }}$ is the only write enable pin. When WEN1 is LOW, data is written into the FIFO on every LOW-to-HIGH transition WCLK. If the FIFO is configured to have two write enables, $\overline{\text { WEN } 1 ~ m u s t ~ b e ~ L O W ~ a n d ~ W E N 2 ~ m u s t ~ b e ~}$ HIGH to write data into the FIFO. Data will not be written into the FIFO if the FF is LOW. |
| WEN2/LD | Write Enable 2/ Load | 1 | The FIFO is configured at reset to have two write enables or programmable flags. If WEN2 $\overline{\overline{L D}}$ is HIGH at reset, this pin operates as a second write enable. If WEN2/ $\overline{L D}$ is LOW at reset, this pin operates as a control to load and read the programmable flag offsets. If the FIFO is configured to have two write enables, $\overline{\text { WEN1 }}$ must be LOW and WEN2 must be HIGH to write data into the FIFO. Data will not be written into the FIFO if the FF is LOW. If the FIFO is configured to have programmable flags, WEN $2 / \overline{L D}$ is held LOW to write or read the programmable flag offsets. |
| Qo-Q8 | Data Outputs | 0 | Data outputs for a 9-bit bus. |
| RCLK | Read Clock | 1 | Data is read from the FIFO on a LOW-to-HIGH transition of RCLK when $\overline{\text { REN1 }}$ and $\overline{\text { REN2 }}$ are asserted. |
| $\overline{\text { REN }}$ | Read Enable 1 | 1 | When $\overline{\text { REN1 }}$ and $\overline{\text { REN2 }}$ are LOW, data is read from the FIFO on every LOW-to-HIGH transition of RCLK. Data will not be read from the FIFO if the $\overline{\mathrm{EF}}$ is LOW. |
| $\overline{\text { REN2 }}$ | Read Enable 2 | 1 | When $\overline{\mathrm{RE}} \overline{\mathrm{N} 1}$ and $\overline{\mathrm{REN2}}$ are LOW, data is read from the FIFO on every LOW-to-HIGH transition of RCLK. Data will not be read from the FIFO if the EF is LOW. |
| $\overline{\mathrm{OE}}$ | Output Enable | 1 | When $\overline{\mathrm{OE}}$ is LOW, the data output bus is active. If $\overline{\mathrm{OE}}$ is HIGH, the output data bus will be in a high impedance state. |
| $\overline{\mathrm{EF}}$ | Empty Flag | 0 | When $\overline{\mathrm{EF}}$ is LOW, the FIFO is empty and further data reads from the output are inhibited. When $\overline{\mathrm{EF}}$ is HIGH, the FIFO is not empty. $\overline{\mathrm{EF}}$ is synchronized to RCLK. |
| $\overline{\text { PAE }}$ | Programmable Almost-Empty Flag | 0 | When $\overline{\text { PAE }}$ is LOW, the FIFO is almost empty based on the offset programmed into the FIFO. The default offset at reset is Empty $+7 . \overline{\text { PAE }}$ is synchronized to RCLK. |
| $\overline{\text { PAF }}$ | Programmable Almost-Full Flag | 0 | When $\overline{\text { PAF }}$ is LOW, the FIFO is almost full based on the offset programmed into the FIFO. The default offset at reset is Full-7. $\overline{\text { PAF }}$ is synchronized to WCLK. |
| $\overline{\mathrm{FF}}$ | Full Flag | O | When $\overline{F F}$ is LOW, the FIFO is full and further data writes into the input are inhibited. When $\overline{F F}$ is HIGH, the FIFO is not full. $\overline{\mathrm{FF}}$ is synchronized to WCLK. |
| Vcc | Power |  | One +5 volt power supply pin. |
| GND | Ground |  | One 0 volt ground pin. |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than thoselistedunderABSOLUTEMAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicatedin the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED

OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCCM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| VCCC | Commercial <br> Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL | Input Low Voltage <br>  <br> Military | - | - | 0.8 | V |

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

|  |  | IDT72201IDT72211IDT72421Commercialtclk $=15,20,25,50 \mathrm{~ns}$Min. $\quad$ Typ. Max. |  |  | IDT72201 <br> IDT72211 <br> IDT72421 <br> Military <br> tclk $=$ <br> Min. $20,50 n s$ <br> Myp. Max. |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter |  |  |  |  |  |  |  |
| ILI ${ }^{(1)}$ | Input Leakage Current (Any Input) | -1. | - | -1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| 120 ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, $10 \mathrm{H}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage, loL $=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| Icc ${ }^{(3)}$ | Active Power Supply Current | - | - | 140 | - | - | 160 | mA |

## NOTES:

2655 tw 04

1. Measurements with $0.4 \leq \operatorname{VIN} \leq$ Vout.
2. $\overline{\mathrm{OE}} \geq \mathrm{VIH}, 0.4 \leq \mathrm{VOUT} \leq \mathrm{Vcc}$.
3. Measurements are made with outputs open. Tested at fCLK $=20 \mathrm{MHz}$.

Typical ICC1 $=65+($ fCLK * $1.1 / \mathrm{MHz}$ ) $+($ fcLk * $\mathrm{CL} * * 0.03 / \mathrm{MHz}-\mathrm{pF}$ ) mA
fCLK $=1 /$ tclk.
$\mathrm{CL}=$ external capacitive load ( 30 pF typical)

CAPACITANCE ( $T_{A}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{CIN}^{(2)}$ | Input <br> Capacitance | V IN $=0 \mathrm{~V}$ | 10 | pF |
| CouT(1,2) | Output <br> Capacitance | VOUT $=0 \mathrm{~V}$ | 10 | pF |

## NOTES:

2655 tbl 05

1. With output deselected ( $\overline{O E}=$ HIGH).
2. Characterized values, not currently tested.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, T A=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, T A=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Com'l. IDT72201L15 IDT72211L15 IDT72421L15 Min. Max. | Comm <br> IDT72201L20 <br> IDT72211L20 <br> IDT72421L20 <br> Min. Max. | mercial and Mi IDT72201L25 IDT72211L25 IDT72421L25 Min. Max. | Iltary IDT72201L50 IDT72211L50 IDT72421L50 Min. Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| is | Clock Cycle Frequency | 66.7 | 50 | 40 | 20 | MHz |
| 1 A | Data Access Time | 2. | $2 \quad 12$ | $3 \quad 15$ | $3 \quad 25$ | ns |
| tCLK | Clock Cycle Time | 15 | 20 | 25 | 50 | ns |
| tCLKH | Clock High Time | 6\% | 8 | 10 | 20 | ns |
| tCLKL | Clock Low Time | 6 - | 8 | 10 | 20 | ns |
| tDS | Data Set-up Time | 4 , | 5 | 6 | 10 | ns |
| tDH | Data Hold Time | - | 1 - | 1 - | 2 | ns |
| tENS | Enable Set-up Time | 4.\% | 5 | 6 | 10 | ns |
| tenh | Enable Hold Time | 1, \% | 1 | 1 | 2 | ns |
| IRS | Reset Pulse Width(1) | 15 , - | 20 | 25 | 50 | ns |
| tRSS | Reset Set-up Time | 15 | 20 | 25 | 50 | ns |
| tRSF | Reset to Flag Time and Output Time | $\cdots$ - ${ }^{\text {- }}$. 15 | 20 | 25 | 50 | ns |
| tolz | Output Enable to Output in Low Z ${ }^{(2)}$ | 0\%. | 0 | 0 | 0 | ns |
| toe | Output Enable to Output Valid | 3 - 8 | 310 | $3 \quad 13$ | 328 | ns |
| tohz | Output Enable to Output in High Z ${ }^{\text {(2) }}$ | 38 | 310 | 313 | 328 | ns |
| tWFF | Write Clock to Full Flag | -10 10 | 12 | 15 | 30 | ns |
| tREF | Read Clock to Empty Flag | 10 | 12 | 15 | 30 | ns |
| tPAF | Write Clock to Programmable Almost-Full Flag | $\cdots \quad 10$ | 12 | 15 | 30 | ns |
| tPAE | Read Clock to Programmable Almost-Empty Flag | 10 | 12 | 15 | 30 | ns |
| tSKEW1 | Skew Time Between Read Clock and Write Clock for Empty Flag and Full Flag | 6\% ${ }_{\text {\% }}$ - | 8 | 10 | 15 | ns |
| tSkEW2 | Skew Time Between Read Clock and Write Clock for Programmable Almost-Empty Flag and Programmable Almost-Full Flag | $\overline{15 \%}$ | 18 - | 20 - | 30 | ns |

NOTES:

1. Pulse widths less than minimum values are not allowed.
2. Values guaranteed by design, not currently tested.

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | $3 n \mathrm{~s}$ |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |


or equivalent circuit
Figure 1. Output Load
*Includes jig and scope capacitances.

## SIGNAL DESCRIPTIONS

## INPUTS:

Data In (D0-D8) - Data inputs for 9-bit wide data.

## CONTROLS:

Reset ( $\overline{\mathrm{RS}}$ ) - Reset is accomplished whenever the Reset $(\overline{\mathrm{RS}})$ input is taken to a low state. During reset, both internal read and write pointers are set to the first location. A reset is required after power-up before a write operation can take place. The FullFlag ( $\overline{\mathrm{FF}}$ ) and Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) will be reset to high after tRSF. The Empty Flag ( $\overline{\mathrm{EF}}$ ) and Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) will be reset to low after tRSF. During reset, the output register is initialized to all zeros and the offset registers are initialized to their default values.

Write Clock (WCLK) - A write cycle is initiated on the LOW-to-HIGH transition of the write clock (WCLK). Data setup and hold times must be met in respect to the LOW-to-HIGH transition of the write clock (WCLK). The Full Flag $(\overline{F F})$ and Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) are synchronized with respect to the LOW-to-HIGH transition of the write clock (WCLK).

The write and read clocks can be asynchronous or coincident.

Write Enable 1 ( $\overline{\mathrm{WEN} 1}$ ) - If the FIFO is configured for programmable flags, Write Enable 1 (WEN1) is the only enable control pin. In this configuration, when Write Enable 1 (WEN1) is low, data can be loaded into the input register and RAM array on the LOW-to-HIGH transition of every write clock (WCLK). Data is stored in the RAM array sequentially and independently of any on-going read operation.

In this configuration, when Write Enable 1 (WEN1) is high, the input register holds the previous data and no new data is allowed to be loaded into the register.

If the FIFO is configured to have two write enables, which allows for depth expansion, there are two enable control pins. See Write Enable 2 paragraph below for operation in this configuration.

To prevent data overflow, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operations. Upon the completion of a valid read cycle, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go high after tWFF, allowing a valid write to begin. Write Enable 1 (WEN1) is ignored when the FIFO is full.

Read Clock (RCLK) - Data can be read on the outputs on the LOW-to-HIGH transition of the read clock (RCLK). The Empty Flag ( $\overline{\mathrm{EF}}$ ) and Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) are synchronized with respect to the LOW-to-HIGH transition of the read clock (RCLK).

The write and read clocks can be asynchronous or coincident.

Read Enables ( $\overline{\mathrm{REN} 1}, \overline{\mathrm{REN} 2})$ —When both Read Enables (REN1, REN2) are low, data is read from the RAM array to the output register on the LOW-to-HIGH transition of the read clock (RCLK).

When either Read Enable ( $\overline{\operatorname{REN} 1}, \overline{\mathrm{REN} 2}$ ) is high, the output register holds the previous data and no new data is allowed to be loaded into the register.

When all the data has been read from the FIFO, the Empty Flag ( $\overline{E F}$ ) will go low, inhibiting further read operations. Once a valid write operation has been accomplished, the Empty Flag ( $\overline{E F}$ ) will go high after tREF and a valid read can begin. The Read Enables ( $\overline{R E N 1}, \overline{R E N} 2$ ) are ignored when the FIFO is empty.

Output Enable ( $\overline{\mathrm{OE}})$ - When Output Enable ( $\overline{\mathrm{OE}}$ ) is enabled (LOW), the parallel output buffers receive data from the output register. When Output Enable ( $\overline{\mathrm{OE}})$ is disabled (HIGH), the Q output data bus is in a high-impedance state.

Write Enable 2/Load (WEN2/LD) - This is a dual-purpose pin. The FIFO is configured at Reset to have programmable flags or to have two write enables, which allows depth expansion. If Write Enable 2/Load (WEN2/LD) is set high at Reset ( $\overline{\mathrm{RS}}=l o w$ ), this pin operates as a control to load and read the programmable flag offsets.

If the FIFO is configured to have two write enables, when Write Enable (WEN1) is low and Write Enable 2/Load (WEN2/ LD) is high, data can be loaded into the input register and RAM array on the LOW-to-HIGH transition of every write clock (WCLK). Data is stored in the RAM array sequentially and independently of any on-going read operation.

In this configuration, when Write Enable ( $\overline{\mathrm{WEN}}$ ) is high and/or Write Enable 2/Load (WEN2/LD) is low, the input register holds the previous data and no new data is allowed to be loaded into the register.

To prevent data overflow, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operations. Upon the completion of a valid read cycle, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go high after tWFF, allowing a valid write to begin. Write Enable 1 (WEN1) and Write Enable 2/Load (WEN2/LD) are ignored when the FIFO is full.

The FIFO is configured to have programmable flags when the Write Enable 2/Load (WEN2/LD) is set low at Reset ( $\overline{R S}=$ low). The IDT72201/72211/72420 devices contain four 8 -bit offset registers which can be loaded with data on the inputs, or read on the outputs. See Figure 3 for details of the size of the registers and the default values.

If the FIFO is configured to have programmable flags when the Write Enable 1 ( $\overline{\mathrm{WEN} 1}$ ) and Write Enable 2/Load (WEN2/ $\overline{L D})$ are set low, data on the inputs $D$ is written into the Empty (Least Significant Bit) offset register on the first LOW-to-HIGH transition of the write clock (WCLK). Data is written into the Empty (Most Significant Bit) offset register on the second LOW-to-HIGH transition of the write clock (WCLK), into the Full (Least Significant Bit) offset register on the third transition, and into the Full (Most Significant Bit) offset register on the fourth transition. The fifth transition of the write clock (WCLK) again writes to the Empty (Least Significant Bit) offset register.

However, writing all offset registers does not have to occur at one time. One or two offset registers can be written and then by bringing the Write Enable 2/Load (WEN2/LD) pin high, the FIFO is returned to normal read/write operation. When the Write Enable 2/Load (WEN2/LD) pin is set low, and Write Enable 1 (WEN1) is low, the next offset register in sequence is written.

The contents of the offset registers can be read on the output lines when the Write Enable 2/Load (WEN2/LD) pin is set low and both Read Enables (REN1, REN2) are set low. Data can be read on the LOW-to-HIGH transition of the read clock (RCLK).

A read and write should not be performed simultaneously to the offset registers.

| $\overline{L D}$ | $\overline{\text { WEN1 }}$ | WCLK ${ }^{(1)}$ | Selection |
| :---: | :---: | :---: | :--- |
| 0 | 0 | $f$ | Empty Offset (LSB) <br> Empty Offset (MSB) <br> Full Offset (LSB) <br> Full Offset (MSB)$\longrightarrow$ |
| 0 | 1 | $f$ | No Operation |
| 1 | 0 | $\int$ | Write Into FIFO |
| 1 | 1 | $S$ | No Operation |

NOTE:

1. The same selection sequence applies to reading from the registers. $\overline{R E N 1}$ and REN2 are enabled and read is performed on the LOW-toHIGH transition of RCLK.

Figure 2. Write Offset Register


2655 drw 05
Figure 3. Offset Register Location and Default Values

## OUTPUTS:

Full Flag ( $\overline{\mathrm{FF}}$ ) — The Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operation, when the device is full. If no reads are performed after Reset ( $\overline{\mathrm{RS}}$ ), the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low after 256 writes for the IDT72201, 512 writes for the IDT72211, and 64 writes for the IDT72421.

The Full Flag $(\overline{\mathrm{FF}})$ is synchronized with respect to the LOW-to-HIGH transition of the write clock (WCLK).

Empty Flag ( $\overline{\mathrm{EF}}$ ) - The Empty Flag ( $\overline{\mathrm{EF} \text { ) will go low, }}$ inhibiting further read operations, when the read pointer is equal to the write pointer, indicating the device is empty.

The Empty Flag ( $\overline{\mathrm{EF}}$ ) is synchronized with respect to the LOW-to-HIGH transition of the read clock (RCLK).

Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) - The Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) will go low when the FIFO reaches the Almost-Full condition. If no reads are performed after Reset ( $\overline{\mathrm{RS}}$ ), the Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) will go low after ( $256-\mathrm{m}$ ) writes for the IDT72201, ( $512-\mathrm{m}$ ) writes for the IDT72211, and ( $64-\mathrm{m}$ ) writes for the

IDT72421. The offset " $m$ " is defined in the Full offset registers.
If there is no Full offset specified, the Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) will go low at Full-7 words.

The Programmable Almost-Full Flag $(\overline{\mathrm{PAF}})$ is synchronized with respect to the LOW-to-HIGH transition of the write clock (WCLK).

Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) - The Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) will go low whenthe read pointer is " $n+1$ " locations less than the write pointer. The offset " $n$ " is defined in the Empty offset registers. If no reads are performed after Reset the Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) will go high after " $\mathrm{n}+1$ " for the IDT72201/72211/ 72421.

If there is no Empty offset specified, the Programmable Almost-Empty Flag (PAE) will go low at Empty+7 words.

The Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) is synchronized with respect to the LOW-to-HIGH transition of the read clock (RCLK).

Data Outputs (Qo-Q8) - Data outputs for a 9-bit wide data.

## TABLE 1: STATUS FLAGS

| NUMBER OF WORDS IN FIFO |  | $\overline{\text { FF }}$ | $\overline{\text { PAF }}$ | $\overline{\text { PAE }}$ | $\overline{\text { EF }}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 72201 | 72211 | 72421 |  |  |  |  |
| 0 | 0 | 0 | $H$ | $H$ | L | L |
| 1 to $n(1)$ | 1 to $n^{(1)}$ | 1 to $n^{(1)}$ | H | H | L | H |
| $(\mathrm{n}+1)$ to $(256 \cdot(\mathrm{~m}+1))$ | $(\mathrm{n}+1)$ to $(512-(\mathrm{m}+1))$ | $(\mathrm{n}+1)$ to $(64-(\mathrm{m}+1))$ | H | H | H | H |
| $(256-\mathrm{m})^{(2)}$ to 255 | $(512-\mathrm{m})^{(2)}$ to 511 | $(64-\mathrm{m})^{(2)}$ to 63 | H | L | H | H |
| 256 | 512 | 64 | L | L | H | H |

NOTES:

1. $n=$ Empty Offset ( $n=7$ default value)
2. $m=$ Full Offset ( $m=7$ default value)


## NOTES:

1. Holding WEN $2 \overline{L D}$ high during reset will make the pin act as a second write enable pin. Holding WEN2/(DD low during reset will make the pin act as a load enable for the programmable flag offset registers.
2. After reset, the outputs will be low if $\overline{O E}=0$ and tri-state if $\overline{O E}=1$.
3. The clocks (RCL.K, WCLK) can be free-running furing reset.

Figure 4. Reset Timing


NOTE:

1. tskEW1 is the minimum time between a rising RCLK edge and a rising WCLK edge for $\overline{F F}$ to change during the current clock cycle. If the time between

Figure 5. Write Cycle Timing


## NOTE:

1. TSKEW1 is the minimum time between a rising WCLK edge and a rising RCLK edge for $\overline{E F}$ to change during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than tSKEW1, then $\overline{E F}$ may not change state until the next RCLK edge. Figure 6 . Read Cycle Timing

Figure 6. Read Cycle Timing


## NOTE:

1. When $\operatorname{tSKEW} 1 \geq$ minimum specification, $\mathrm{t} F \mathrm{RL}=\mathrm{t} \mathrm{CLK}+\mathrm{tSKEW}$ :
tsKEW $1<$ minimum specification, tFRL $=2$ tCLK + tsKEW 1
The Latency Timings apply only at the Empty Boundary ( $\overline{E F}=$ LOW).

Figure 7. First Data Word Latency Timing


Figure 8. Full Flag Timing


2655 drw 11

## NOTE:

1. When tSKEW $1 \geq$ minimum specification, $t$ FRL maximum $=t C L K+$ tSKEW $_{1}$ tSKEW1 < minimum specification, tFRL maximum $=2$ tCLK + tSKEW 1
The Latency Timings apply only at at the Empty Boundary ( $\overline{\mathrm{EF}}+\mathrm{LOW}$ )

Figure 9. Empty Flag Timing


2655 drw 12

## NOTES:

1. PAF offset $=\mathrm{m}$
2. 256 - m words in FIFO for IDT72201. 512 - m words for IDT72211. 64 - m words in FIFO for IDT72421.
3. tsKEw is the minimum time between a rising RCLK edge and a rising WCLK edge for $\overline{\text { PAF }}$ to change during that clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than tsKEwz, then PAF may not change state until the next WCLK rising edge.
4. If a write is performed on this rising edge of the write clock, there will be Full - ( $\mathrm{m}-1$ ) words in the FIFO when PAF goes low.

Figure 10. Programmable Full Flag Timing


NOTES:

1. $P A E$ offset $=\mathrm{n}$.
2. ISKEWz is the minimum time between a rising WCLK edge and a rising RCLK edge for $\overline{P A E}$ to change during that clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than tskEwz, then PAE may not change state until the next RCLK rising edge.
3. If a read is performed on this rising edge of the read clock, there will be Empty $+(n-1)$ words in the FIFO when PAE goes low.

Figure 11. Programmable Empty Flag Timing


2655 drw 14

Figure 12. Write Offset Registers Timing


Figure 13. Read Offset Registers Timing

## OPERATING CONFIGURATIONS

SINGLE DEVICE CONFIGURATION - A single IDT72201/ $72211 / 72421$ may be used when the application requirements are for 256/512/64 words or less. When the IDT72201/72211/

72421 are in a Single Device Configuration, the Read Enable 2 ( $\overline{R E N} 2$ ) control input can be grounded (see Figure 14). In this configuration, the Write Enable 2/Load (WEN2/LD) pin is set low at Reset so that the pin operates as a control to load and read the programmable flag offsets.


2655 drw 16
Figure 14. Block Diagram of Single $256 \times 9 / 512 \times 9 / 64 \times 9$ Synchronous FIFO

WIDTH EXPANSION CONFIGURATION - Word width may be increased simply by connecting the corresponding input controls signals of multiple devices. Status flags ( $\overline{\mathrm{FF}}, \overrightarrow{\mathrm{PAE}}$, $\overline{\mathrm{PAF}}$ and $\overline{\mathrm{FF}}$ ) can be detected from any one device. Figure 15 demonstrates a 18-bit word width by using two IDT72201/ $72211 / 72421 \mathrm{~s}$. Any word width can be attained by adding additional IDT72201/72211/72421s.

When the IDT72201/72211/72421 are in a Width Expansion Configuration, the Read Enable 2 ( $\overline{\text { REN2 }}$ ) control input can be grounded (see Figure 15). In this configuration, the Write Enable 2/Load (WEN2/LD) pin is set low at Reset so that the pin operates as a control to load and read the programmable flag offsets.


2655 drw 17

Figure 15. Block Diagram of $256 \times 18 / 512 \times 18 / 64 \times 18$ Synchronous FIFO Used In a Width Expansion Configuration

DEPTH EXPANSION - The IDT7221/72211/72421 can be adapted to applications when the requirements are for greater than 256/512/64 words. The existence of two enable pins on the read and write port allow depth expansion. The Write Enable 2/Load pin is used as a second write enable in a depth expansion configuration thus the Programmable flags are set to the default values. Depth expansion is possible by using one enable input for system control while the other enable input is controlled by expansion logic to direct the flow of data. A typical application would have the expansion logic alternate
data access from one device to the next in a sequential manner. The IDT72201/72211/72421 operates in the Depth Expansion configuration when the following conditions are met:

1. The WEN2/LD pin is held high during Reset so that this pin operates a second Write Enable.
2. External logic is used to control the flow of data.

Please see the Applicatioin Note" DEPTH EXPANSION USING 72211 SYNCHRONOUS FIFOs" for details of this configuration.

## ORDERING INFORMATION

IDT



## FEATURES:

- $512 \times 18$-bit and $1024 \times 18$-bit memory array structures
- 20 ns read / write cycle time
- Easily expandable in depth and width
- Read and write clocks can be asynchronous or coincident
- Dual-port zero fall-through time architecture
- Programmable almost-empty and almost-full flags
- Empty and Full flags signal FIFO status
- Half-Full flag capability in a single device configuration
- Output enable puts output data bus in high impedance
- First device controls all flag logic in depth expansion
- Produced with advanced submicron CEMOS ${ }^{\text {TM }}$ technology
- Available in a 68 -lead pin grid array (PGA), and plastic leaded chip carrier (PLCC)
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT72215A and IDT72225A are very high speed, lowpower first-in, first-out (FIFO) memories with clocked read and write controls. The IDT72215A has a $512 \times 18$-bit memory array, while the IDT72225A has a $1024 \times 18$-bit memory array. These FIFOs are applicable for a wide variety of data buffering needs, such as optical disk controllers, local area networks (LANs), and interprocessor communication.

Both FIFOs have 18 -bit input and output ports. The input port is controlled by a free-running clock (WCLK), and a data input enable pin (WEN). Data is read into the synchonous FIFO on every clock when WEN is asserted. The output port is controlled by another clock pin (RCLK) and another enable pin ( $\overline{\operatorname{REN}}$ ). The read clock can be tied to the write clock for single clock operation or the two clocks can run asynchronous of one another for dual clock operation. An output enable pin $\overline{O E}$ ) is provided on the read port for three-state control of the output.

FUNCTIONAL BLOCK DIAGRAM


## DESCRIPTION (Continued):

The synchronous FIFOs have two fixed flags, Empty ( $\overline{\mathrm{EF}}$ ) and Full ( $\overline{\mathrm{FF}}$ ), and two programmable flags, Almost-Empty ( $\overline{\mathrm{PAE}}$ ) and Almost-Full ( $\overline{\mathrm{PAF}}$ ). The offset loading of the programmable flags is controlled by a simple state machine, and is initiated by asserting the load pin (LD). A Half-Full flag $(\overline{\mathrm{HF}})$ is available when the FIFO is used in a single device configuration.

The IDT72215A and IDT72225A are depth expandable using a daisy-chain technique. The $\overline{\mathrm{XI}}$ and $\overline{\mathrm{XO}}$ pins are used to expand the FIFOs. To permit programmable flags in depth expansion, the first device indicated by setting FL to low, controls the flags.

The IDT72215A/72225A is fabricated using IDTs high speed submicron CEMOS technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

PIN CONFIGURATIONS

| 11 |  | Vcc | Q3 | GND | Q0 | $\overline{\mathrm{WXO}} \overline{\mathrm{HF}}$ | $\overline{\mathrm{RXI}}$ | Vcc | $\overline{\text { WEN }}$ | $\overline{F L}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 10 | GND | Q4 | Q2 | 01 | $\overline{\mathrm{RXO}}$ | $\overline{F F}$ | $\overline{\text { PAF }}$ | $\overline{\text { WXI }}$ | WCLK | $\overline{\text { PAE }}$ | Do |  |
| 09 | Q6 | Q5 |  |  |  |  |  |  |  | D2 | D1 |  |
| 08 | Q7 | Vcc |  |  |  |  |  |  |  | D4 | D3 |  |
| 07 | GND | Q8 |  |  |  |  |  |  |  | D6 | D5 |  |
| 06 | Q10 | Q9 |  |  |  |  |  |  |  | GND | D7 |  |
| 05 | Q11 | Vcc |  |  |  |  |  |  |  | Vcc | D8 |  |
| 04 | GND | Q12 |  |  |  |  |  |  |  | D10 | D9 |  |
| 03 | Q14 | Q13 |  |  |  |  |  |  |  | D12 | D11 |  |
| 02 | Vcc | Q15 | Q16 | Vcc | GND | $\overline{\mathrm{RS}}$ | $\overline{\text { LD }}$ | RCLK | D17 | D14 | D13 |  |
| 01 |  | GND | Q17 | $\overline{E F}$ | Vcc | $\overline{O E}$ | $\overline{\text { REN }}$ | GND | D16 | D15 |  |  |
|  | A | B | c | D | E | F | G | H | J | K | L | 2719 drw 02 |

## PIN CONFIGURATIONS (Continued)



## PIN DESCRIPTIONS

| Symbol | Name | VO | Description |
| :---: | :---: | :---: | :---: |
| $\mathrm{D}_{0}-\mathrm{D}_{17}$ | Data Inputs | 1 | Data inputs for a 18-bit bus. |
| $\overline{\text { RS }}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal read and write pointers are set to the first location of the <br>  initial WRITE after power-up. |
| WCLK | Write Clock | 1 | Data is written into the FIFO on a LOW-to-HIGH transition of WCLK when Write Enable WEN is asserted (LOW). |
| WEN | Write Enable | 1 | When WEN is LOW, data is written into the FIFO on every LOW-to-HIGH transition of WCLK. When WEN is high, the FIFO holds the previous data. Data will not be written into the FIFO if the $\overline{\mathrm{FF}}$ is LOW. |
| RCLK | Read Clock | I | Data is read from the FIFO on a LOW-to-HIGH transition of RCLK when Read Enable REN is asserted (LOW). |
| REN | Read Enable | 1 | When $\overline{\text { REN }}$ is LOW, data is read from the FIFO on every LOW-to-HIGH transition of RCLK. When REN is high, the output register holds the previous data. Data will not be read from the FIFO if the EF is LOW. |
| $\overline{\mathrm{OE}}$ | Output Enable | 1 | When $\overline{\mathrm{OE}}$ is LOW, the data output bus is active. If $\overline{\mathrm{OE}}$ is HIGH , the output data bus will be in a high impedance state. |
| $\overline{\text { LD }}$ | Load | 1 | When $\overline{\mathrm{LD}}$ is LOW, data on the inputs $\mathrm{D}_{0}-\mathrm{D}_{15}$ is written to the offset and depth registers on the LOW-to-HIGH transition of the WCLK, when WEN is LOW. When $\overline{L D}$ is LOW, data on the outputs $Q_{0}-Q_{15}$ is read from the offset and depth registers on the LOW-toHIGH transition of the RCLK, when REN is LOW. |
| $\overline{\mathrm{FL}}$ | First Load | 1 | In the single device or width expansion configuration, $\overline{\mathrm{FL}}$ is grounded. In the depth expansion configuration, $F \mathrm{FL}$ is grounded on the first device (first load device) and set to high for all other devices in the daisy chain. |
| $\overline{\text { WXI }}$ | Write Expansion Input | 1 | In the single device or width expansion configuration, $\bar{W} X I$ is grounded. In the depth expansion configuration, $\overline{\mathrm{WXI}}$ is connected to $\overline{\mathrm{WXO}}$ (Write Expansion Out) of the previous device. |
| $\overline{\mathrm{RXI}}$ | Read Expansion Input | 1 | In the single device or width expansion contiguration, $\overline{\mathrm{RXI}}$ is grounded. In the depth expansion configuration, $\overline{\mathrm{RXI}}$ is connected to $\overline{\mathrm{RXO}}$ (Read Expansion Out) of the previous device. |
| $\overline{\mathrm{EF}}$ | Empty Flag | 0 | When EF is LOW, the FIFO is empty and further data reads from the output are inhibited. When EF is HIGH, the FIFO is not empty. $\overline{\mathrm{EF}}$ is synchronized to RCLK. |
| $\overline{\text { PAE }}$ | Programmable Almost-Empty Flag | 0 | When $\overline{\text { PAE }}$ is LOW, the FIFO is almost empty based on the offset programmed into the FIFO. The default offset at reset is $1 / 8$ full. |
| $\overline{\text { PAF }}$ | Programmable Almost-Full Flag | 0 | When $\overline{\text { PAF }}$ is LOW, the FIFO is almost full based on the offset programmed into the FIFO. The default offset at reset is $7 / 8$ full. |
| $\overline{\mathrm{FF}}$ | Full Flag | 0 | When $\overline{F F}$ is LOW, the FIFO is full and further data writes into the input are inhibited. When $\overline{\mathrm{FF}}$ is HIGH, the FIFO is not full. $\overline{\text { FF }}$ is synchronized to WCLK. |
| $\overline{\mathrm{WXO}} / \overline{\mathrm{HF}}$ | Write Expansion Out/Half-Full Flag | 0 | In the single device or width expansion configuration, the device is more than half full when $\overline{\mathrm{HF}}$ is LOW. In the depth expansion configuration, a pulse is sent from $\overline{\mathrm{WXO}}$ to $\bar{W}$ XI of the next device when the last location in the FIFO is written. |
| $\overline{\mathrm{RXO}}$ | Read Expansion Out | 0 | In the depth expansion configuration, a pulse is sent from $\overline{\mathrm{RXO}}$ to $\overline{\mathrm{RXI}}$ of the next device when the last location in the FIFO is read. |
| $Q_{0} \cdot Q_{17}$ | Data Outputs | 0 | Data outputs for a 18-bit bus. |
| $\mathrm{V}_{\mathrm{Cc}}$ | Power |  | Eight +5 volt power supply pins. |
| GND | Ground |  | Eight 0 volt ground pins. |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Mil. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2719 tbl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| $\mathrm{CIN}^{(2)}$ | Input Capacitance | VIN $=0 \mathrm{~V}$ | 10 | pF |
| CouT $^{(1,2)}$ | Output Capacitance | Vout $=0 \mathrm{~V}$ | 10 | pF |

NOTES:
2719 tbl 03

1. With output deselected. ( $\overline{O E}=$ high $)$
2. Characterized values, not currently tested.

## RECOMMENDED DC

OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccm | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Votage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Votage <br> Military | 2.2 | - | - | V |
| VIL $^{(1)}$ | Input Low Voltage <br> Com'l. and Mil. | - | - | 0.8 | V |

NOTE:
2719 |t 04

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72215A <br> IDT72225A <br> Commerclal <br> tCLK $=20,25,50 \mathrm{~ns}$ |  |  | IDT72215AIDT72225AMilitarytcLK $=25,30,50 \mathrm{~ns}$ |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $\mathrm{ILI}^{(1)}$ | Input Leakage Current (any input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{L}_{\mathrm{LO}}{ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output Logic "1" Voltage, $\mathrm{bH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Logic "0" Voltage, $\mathrm{bL}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{ICCl}^{(3)}$ | Active Power Supply Current | - | - | 250 | - | - | 300 | mA |
| $\mathrm{ICC2}^{(3)}$ | Average Standby Current (All Input $=\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$, except RCLK and WCLK which are free-running) | - | - | 60 | - | - | 75 | mA |

NOTES:

1. Measurements with $0.4 \leq \mathrm{VIN} \leq$ Vout.
2. $\overline{\mathrm{OE}} \geq \mathrm{VIH}_{1}, 0.4 \leq$ Vout $\leq \mathrm{VCC}$.
3. Tested at $\mathbf{f}=\mathbf{2 0} \mathbf{M H z}$.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { Com'l. } \\ \text { IDT72215L20 } \\ \text { IDT72225L20 } \end{gathered}$ |  | Com'I. \& MII. 1DT72215L25 IDT72225L25 |  | $\begin{gathered} \text { Mil. } \\ \text { IDT72215L30 } \\ \text { ID } 72225 \mathrm{~L} 30 \end{gathered}$ |  | Com'I. 8 MII. IDT72215L50 IDT72225L50 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIİ. | Max. | MIİ. | Max. | Miln. | Max. | Miln. | Max. |  |
| ts | Clock Cycle Frequency | - | 50 | - | 40 | - | 33 | - | 20 | MHz |
| tA | Data Access Time | 2 | 14 | 3 | 15 | 3 | 18 | 3 | 25 | ns |
| tCLK | Clock Cycle Time | 20 | - | 25 | - | 30 | - | 50 | - | ns |
| ICLKH | Clock High Time | 8 | - | 10 | - | 12 | - | 20 | - | ns |
| tCLKL | Clock Low Time | 9 | - | 10 | - | 12 | - | 20 | - | ns |
| tDS | Data Set-up Time | 5 | - | 6 | - | 7 | - | 10 | - | ns |
| tDH | Data Hold Time | 1 | - | 1 | - | 1 | - | 2 | - | ns |
| tENS | Enable Set-up Time | 5 | - | 6 | - | 7 | - | 10 | - | ns |
| tenh | Enable Hold Time | 1 | - | 1 | - | 1 | - | 2 | - | ns |
| tRS | Reset Pulse Width ${ }^{(1)}$ | 20 | - | 25 | - | 30 | - | 50 | - | ns |
| tRSS | Reset Set-up Time ${ }^{(2)}$ | 12 | - | 15 | - | 18 | - | 30 | - | ns |
| tRSF | Reset to Flag and Output Time | - | 20 | - | 25 | - | 30 | - | 50 | ns |
| tolz | Output Enable to Output in Low Z ${ }^{(2)}$ | 0 | 一 | 0 | - | 0 | - | 0 | - | ns |
| toe | Output Enable to Output Valid | - | 9 | - | 12 | - | 15 | - | 20 | ns |
| tohz | Output Enable to Output in High Z ${ }^{(2)}$ | 1 | 9 | 1 | 12 | 1 | 15 | 1 | 20 | ns |
| twFF | Write Clock to Full Flag | - | 14 | - | 16 | - | 18 | - | 30 | ns |
| tref | Read Clock to Empty Flag | - | 12 | - | 15 | - | 18 | - | 30 | ns |
| tPaF | Clock to Programmable Almost-Full Flag | - | 20 | - | 22 | - | 24 | - | 35 | ns |
| tpae | Clock to Programmable AlmostEmpty Flag | - | 20 | - | 22 | - | 24 | - | 35 | ns |
| thF | Clock to Half-Full Fiag | - | 20 | - | 22 | - | 24 | - | 35 | ns |
| 1xO | Clock to Expansion Out | - | 12 | - | 15 | - | 18 | - | 30 | ns |
| tx | Expansion In Pulse Width | 8 | - | 10 | - | 12 | - | 20 | - | ns |
| tXIS | Expansion In Set-Up Time | 8 | - | 10 | - | 12 | - | 20 | - | ns |
| tSKEW1 | Skew time between Read Clock \& Write Clock for Full Flag | 14 | - | 16 | - | 18 | - | 20 | - | ns |
| tSKEW2 | Skew time between Read Clock \& Write Clock for Empty Flag | 14 | - | 16 | - | 18 | - | 20 | - | ns |

NOTES:

1. Pulse widths less than minimum values are not allowed.
2. Values guaranteed by design, not currently tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 3ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |


or equivalent circuit
Flgure 1. Output Load
*Includes jig and scope capacitances.

## SIGNAL DESCRIPTIONS:

## INPUTS:

## DATA IN (Do - D17)

Data inputs for 18 -bit wide data.

## CONTROLS:

## RESET ( $\overline{\operatorname{RS}}$ )

Reset is accomplished whenever the Reset ( $\overline{\mathrm{RS}}$ ) input is taken to a low state. During reset, both internal read and write pointers are set to the first location. A reset is required after power up before a write operation can take place. The Full Flag ( $\overline{\mathrm{FF}})$, Half-Full Flag $(\overline{\mathrm{HF}})$, and Programmable Almost-Full Flag ( $\overline{\text { PAF }})$ will be reset to high after tRSF. The Empty Flag $(\overline{\mathrm{EF}})$ and Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}})$ will be reset to low after trsf.

## WRITE CLOCK (WCLK)

A write cycle is initiated on the low-to-high transition of the write clock (WCLK). Data set-up and hold times must be met with respect to the low-to-high transition of the write clock (WCLK).

The write and read clocks can be asynchronous or coincident.

## WRITE ENABLE ( $\overline{\text { WEN }}$ )

When Write Enable (WEN) is low, data can be loaded into the input register and RAM array on the low-to-high transition of every write clock (WCLK). Data is stored in the RAM array sequentially and independently of any on-going read operation.

When Write Enable ( $\overline{\text { WEN }}$ ) is high, the input register holds the previous data and no new data is loaded into the FIFO.

To prevent data overtlow, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operations. Upon the completion of a valid read cycle, the Full Flag ( $\overline{\mathrm{FF}}$ ) will go high after twFF allowing a write to begin. Write Enable ( $\overline{W E N}$ ) is ignored when the FIFO is full.

## READ CLOCK (RCLK)

Data can be read on the outputs on the low-to-high transition of the read clock (RCLK), when Output Enable ( $\overline{\mathrm{OE}})$ is set low.

The write and read clocks can be asynchronous or coincident.

## READ ENABLE ( $\overline{\operatorname{REN}}$ )

When Read Enable ( $\overline{\mathrm{REN}}$ ) is low, data is loaded into the RAM array to the output register on the low-to-high transition of the read clock (RCLK).

When Read Enable ( $\overline{\mathrm{REN}}$ ) is high, the output register holds the previous data and no new data is loaded into the register.

When all the data has been read from the FIFO, the Empty Flag ( $\overline{E F}$ ) will go low, inhibiting further read operations. Once a write is performed, the Empty Flag ( $\overline{\mathrm{EF}})$ will go high after tREF and a read can begin. Read Enable ( $\overline{\mathrm{REN}}$ ) is ignored when the FIFO is empty.

## OUTPUT ENABLE ( $\overline{O E}$ )

When Output Enable ( $\overline{\mathrm{OE} \text { ) is enabled (low), the parallel }}$ output buffers receive data from the output register. When Output Enable ( $\overline{\mathrm{OE}}$ ) is disabled (high), the Q output data bus is in a high impedance state.

## LOAD ( $\overline{\text { LD }})$

The IDT72215A and IDT72225A devices contain two 16bit offset registers and a 6-bit depth register which can be loaded with data on the inputs, or read on the outputs. When the Load ( $\overline{\mathrm{LD}})$ pin is set low and $\overline{\text { WEN }}$ is set low, data on the inputs D0-D15 is written into the Empty offset register on the first low-to-high transition of the write clock (WCLK). When the Load ( $\overline{\mathrm{LD}}$ ) pin and Write Enable ( $\overline{\mathrm{WEN}}$ ) are held low then data is written into the Full offset register on the second low-to-high transition of the write clock (WCLK) and into the Depth register on the third transition. The fourth transition of the write clock (WCLK) again writes to the Empty offset register.

However, writing all offset registers does not have to occur at one time. One or two offset registers can be written and then by bringing the Load ( $\overline{\mathrm{LD}}$ ) pin high, the FIFO is retumed to normal read/write operation. When the Load ( $\overline{L D}$ ) pin is set low, and Write Enable ( $\overline{W E N}$ ) is low, the next offset register in sequence is written.

When the Load pin is low and Write Enable is high, the offset register counter increments without writing into the offset registers.

The contents of the offset registers can be read on the output lines when the Load ( $\overline{\mathrm{LD}}$ ) pin is set low and $\overline{\text { REN }}$ is set low. Data can be read on the low-to-high transition of the read clock (RCLK) when $\overline{R E N}$ is enabled (low).

A read and a write should not be performed simultaneously to the offset registers.

| LD | WEN | WCLK $^{(1)}$ | SELECTION |
| :--- | :--- | :--- | :--- |
| 0 | 0 |  | WRITING TO OFFSET REGISTERS: <br> EMPTY OFFSET <br> FULL OFFSET <br> DEPTH REGISTER |
| 0 | 1 | INCREMENTING OFFSET REGISTER <br> COUNTER BUT NOT WRITING: <br> EMPTY OFFSET <br> FULL OFFSET <br> DEPTH REGISTER |  |
| 1 | 0 | WRITE INTO FIFO |  |
| NOOPERATION |  |  |  |

## NOTE:

1. The same selection sequence applies to reading from the registers. $\overline{R E N}$ is enabled and read is performed on the low-to-high transition of RCLK.

FIgure 2. Write Offset Register

## FIRST LOAD ( $\overline{\mathrm{FL}})$

First Load ( $\overline{\mathrm{FL}}$ ) is grounded to indicate operation in the Single Device or Width Expansion mode. In the Depth Expansion configuration, First Load $(\overline{\mathrm{FL}})$ is grounded to indicate it is the first device loaded and is set to high for all other devices in the daisy chain. (See Operating Configurations for further details.)

## WRITE EXPANSION INPUT ( $\overline{\mathrm{WXI}}$ )

This is a dual purpose pin. Write Expansion In ( $\overline{\mathrm{WXI}}$ ) is grounded to indicate operation in the Single Device or Width Expansion mode. Write Expansion In (商XI) is connected to Write Expansion Out ( $\overline{\mathrm{WXO}}$ ) of the previous device in the Depth Expansion or Daisy Chain mode.

## READ EXPANSION INPUT ( $\overline{\mathrm{RXI}})$

This is a dual purpose pin. Read Expansion In ( $\overline{\mathrm{RXI}})$ is grounded to indicate operation in the Single Device or Width Expansion mode. Read Expansion In ( $\overline{\mathrm{RXI}})$ is connected to Read Expansion Out ( $\overline{\mathrm{RXO}})$ of the previous device in the Depth Expansion or Daisy Chain mode.

## OUTPUTS:

## FULL FLAG ( $\overline{F F}$ )

The Full Flag ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operation, indicating that the device is full. If no reads are performed after Reset ( $\overline{\mathrm{RS}}$ ), the Full Flag ( $\overline{\mathrm{FF}}$ ) will go low after 512 writes for the IDT72215SA and 1024 writes for the IDT72225A.

The Full Flag ( $\overline{\mathrm{FF}}$ ) is updated on the low-to-high transition of the write clock (WCLK).

## EMPTY FLAG ( $\overline{E F}$ )

The Empty Flag ( $\overline{\mathrm{EF}}$ ) will go low, inhibiting further read operations, when the read pointer is equal to the write pointer, indicating the device is empty.

The Empty Flag ( $\overline{\mathrm{EF}}$ ) is updated on the low-to-high transition the read clock (RCLK).


NOTE:
2719 dww 24

1. Any bits of the offset register not being programmed should be set to zero.

Figure 3. Offsel Register Location and Default Values

| IDT72215A |  | IDT72225A |  |
| :---: | :---: | :---: | :---: |
| Data Loaded In Depth Regiser | Total Depth In Expansion Configuration | $\begin{aligned} & \text { Data Loaded } \\ & \text { In Depth } \\ & \text { Register } \\ & \hline \end{aligned}$ | Total Depth In Expansion Configuration |
| 0 or 1 | 512 | 0 or 1 | 1024 |
| 2 | 1024 | 2 | 2048 |
| 3 | 1536 | 3 | 3072 |
| 4 | 2048 | 4 | 4096 |
| 5 | 2560 | 5 | 5120 |
| 6 | 3072 | 6 | 6144 |
| - | - | - | - |
| - | - | - | - |
| - | - | - | - |
| 32 | 16384 | 32 | 32768 |

Figure 4. Depth Register Programming

TABLEI-STATUS FLAGS

| Number of Words in FIFO |  | $\overline{\text { FF }}$ | $\overline{\text { PAF }}$ | $\overline{\mathrm{HF}}$ | $\overline{\text { PAE }}$ | EF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 72215A | 72225A |  |  |  |  |  |
| 0 | 0 | H | H | H | L | L |
| 1 to $\mathrm{n}^{(1)}$ | 1 to $\mathrm{n}^{(1)}$ | H | H | H | L | H |
| $(\mathrm{n}+1)$ to 257 | $(\mathrm{n}+1)$ to 513 | H | H | H | H | H |
| 258 to (512-(m+1)) | 514 to (1024-(m+1)) | H | H | L | H | H |
| $(512-m)^{(2)}$ to 511 | $(1024-\mathrm{m})^{(2)}$ to 1023 | H | L | L | H | H |
| 512 | 1024 | L | L | L | H | H |

NOTES:

1. $n=$ Empty Offset (Default Values : 72215A $n=63: 72225 A n=127$ )
2. $m=$ Full Offset (Default Values : 72215A $m=63: 72225 A m=127$ )

## PROGRAMMABLE ALMOST-FULL FLAG ( $\overline{\text { PAF }}$ )

The Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) will go low when FIFO reaches the Almost-Full condition. If no reads are performed after Reset ( $\overline{\mathrm{RS}}$ ), the Programmable Almost Full Flag ( $\overline{\mathrm{PA}})$ will go low after (512-m) writes for the IDT72215A and (1024-m) writes for the IDT72225A. The offset " m " is defined in the FULL offset register.

If there is no Full offset specified, the Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) will be low when the device is $7 / 8$ full to completely full.

The Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) is asserted low on the low-to-high transition of the write clock (WCLK). $\overline{\text { PAF }}$ is reset to high on the low-to-high transition of the read clock (RCLK). Thus the $\overline{\mathrm{PAF}}$ is asychronous.

## PROGRAMMABLE ALMOST-EMPTY FLAG ( $\overline{\text { PAE }}$ )

The Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}})$ will go low when the read pointer is " $n+1$ " locations less than the write pointer. The offset " $n$ " is defined in the EMPTY offset register.

If there is no Empty offset specified, the Programmable Almost Empty Flag ( $\overline{\mathrm{PAE}}$ ) will be low when the device is completely empty to $1 / 8$ full.

The Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) is asserted low on the low-to-high transition of the read clock (RCLK). $\overline{\text { PAE }}$ is reset to high on the low-to-high transition of the write clock (WCLK). Thus the $\overline{\mathrm{PAF}}$ is asychronous.

WRITE EXPANSION OUT/HALF-FULL FLAG (WXO/TF)
This is a dual-purpose output. In the Single Device and Width Expansion mode, when Write Expansion in (WXI) is grounded, this output acts as an indication of a half-full memory.

After half of the memory is filled, and at the low-to-high transition of the next write cycle, the Half-Full Flag goes low and will remain set until the difference between the write pointer and read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag $(\overline{\mathrm{HF}})$ is then reset to high by the low-to-high transition of the read clock (RCLK). The $\overline{\mathrm{HF}}$ is asychronous.

In the Depth Expansion or Daisy Chain mode, Write Expansion In ( $\overline{\mathrm{WXI}}$ ) is connected to Write Expansion Out (WXO) of the previous device. This output acts as a signal to the next device in the Daisy Chain by providing a pulse when the previous device write to the last location of memory.

## READ EXPANSION OUT ( $\overline{\mathrm{RXO}}$ )

Inthe Depth Expansion or Daisy Chain configuration, Read Expansion In ( $\overline{\mathrm{RXI}})$ is connected to Read Expansion Out ( $\overline{\mathrm{RXO}}$ ) of the previous device. This output acts as a signal to the next device in the Daisy Chain by providing a pulse when the previous device reads from the last location of memory.

## DATA OUTPUTS (Q0-Q17)

Qo-Q17 are data outputs for 18 -bit wide data.


Figure 5. Reset Timing ${ }^{(2)}$
NOTE:

1. After reset, the outputs will be low if $\overline{O E}=0$ and tri-state if $\overline{O E}=1$.
2. The clocks (RCLK, WCLK) can be free-running during reset.

$\overline{R E N}$


Figure 6. Write Cycle Timing

NOTE:

1. tsKEW1 is the minimum time between a rising RCLK edge and a rising WCLK edge for $\overline{F F}$ to change during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than tsKEW1, then FF may not change state until the next WCLK edge.


Figure 7. Read Cycle Timing
NOTE:

1. tSKEW2 is the minimum time between a rising WCLK edge and a failing RCLK edge for $\overline{E F}$ to change during the current clock cycle. If the time between the rising edge of WCLK and the falling edge of RCLK is less than tsKEW2, then $\overline{E F}$ may not change state until the next RCLK edge.


Figure 8. First Data Word Latency after Reset with Simultaneous Read and Write
NOTE:

1. When tSKEW2 $\geq$ minimum specification, tFRL (maximum) $=1.5^{*}$ tCLK + tSKEW2. tsKEW $2<$ minimum specification, trRL (maximum) $=2.5^{*}$ tCLK + tSKEW2. The Latency Timing apply only at the Empty Boundary ( $\overline{E F}=$ LOW).


Figure 9. Full Flag Tlming

NOTE:

1. tsKEW 1 is the minimum time between a rising RCLK edge and a rising WCLK edge for $\overline{F F}$ to change during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than tsKEw1, then FF may not change state until the next WCLK edge.


Figure 10. Empty Flag Timing

## NOTE:

1. When tSKEW2 $\geq$ minimum specification, tFRL (maximum) $=1.5^{*}$ t $\mathrm{CLK}+\mathrm{tSKEW} 2 . \operatorname{tsKEW} 2<$ minimum specification, tral (maximum) $=2.5^{*}$ teLK + tSKEW2. The Latency Timing apply only at the Empty Boundary ( $\overline{E F}=$ LOW).


Figure 11. Write Programmable Registers


Figure 12. Read Programmable Registers


Figure 13. Programmable Almost Empty Flag Timing
NOTE:

1. PAE is offset $=n$. Number of data words written into FIFO already $=n$.


Figure 14. Programmable Almost-Full Flag Timing

## NOTES:

1. PAF offset $=\mathrm{m}$. Number of data words written into FIFO already $=511-\mathrm{m}$ for the IDT72215A and $1023-\mathrm{m}$ for the IDT72225A.
2. $512-\mathrm{m}$ words in FIFO for IDT72215A. $1024-\mathrm{m}$ word in FIFO for IDT72225A.
3. 511 - m words in FIFO for IDT72215A. 1023 - m word in FIFO for IDT72225A.


Figure 15. Half-Full Flag Timing


Figure 16. Write Expansion Out Timing
NOTE:

1. Write to Last Physical Location.


Figure 17. Read Expansion Out Timing
NOTE:

1. Read from Last Physical Location.


Figure 18. Write Expansion In Timing


Figure 19. Read Expansion In Timing

## OPERATING CONFIGURATIONS

## SINGLE DEVICE CONFIGURATION

A single IDT72215A 72225 A may be used when the application requirements are for $512 / 1024$ words or less. The IDT72215A/72225A are in a single Device Configuration
when the Write Exansion $\ln (\overline{\mathrm{WXI}})$, Read Expansion $\ln (\overline{\mathrm{RXI}})$, and First Load ( $\overline{\mathrm{FL}})$ control inputs are grounded. (See Figure 20.)


Figure 20. Block Diagram of Single $512 \times 18 / 1024 \times 18$ Synchronous FIFO

## WIDTH EXPANSION CONFIGURATION

Word width may be increased simply by connecting the corresponding control signals of multiple devices. Status flags ( $\overline{\mathrm{EF}}, \overline{\mathrm{PAE}}, \overline{\mathrm{HF}}, \overline{\mathrm{PAF}}$, and $\overline{\mathrm{FF}}$ ) can be detected from any
one device. Figure 21 demonstrates a 36-word width by using two IDT72215A.72225As. Any word width can be attained by adding additional IDT72215A72225As.


NOTE:

1. Flag detection is accomplshed by monitoring the flag signals on either (any) device used in width expansion configuration. Do not connect any output control signals together.

Figure 21. Block Dlagram of $512 \times 36 / 1024 \times 36$ Synchronous FIFO Memory Used in a a Width Expansion Conflguration

## DEPTH EXPANSION CONFIGURATION (WITH PROGRAMMABLE FLAGS)

The IDT72215A/72225A can easily be adapted to applications when the requirements are for greater than 512/1024 words. Figure 22 demonstrates Depth Expansion using three IDT72215A72225As. Any depth up to 32768 can be attained by adding IDT72225As. The IDT72215A/72225A operates in the Depth Expansion configuration with programmable flags when the following conditions are met:

1. The first device must be designated by grounding the

First Load ( $\overline{\mathrm{FL}})$ control input.
2. All other devices must have $\overline{\mathrm{FL}}$ in the high state.
3. The Write Expansion Out ( $\overline{\mathrm{WXO}})$ pin of each device must be tied to the Write Expansion In (WXI) pin of the next device. See Figure 20.
4. The Read Expansion Out ( $\overline{\mathrm{RXO}})$ pin of each device must be tied to the Read Expansion In ( $\overline{\mathrm{RXI})}$ pin of the next device. See Figure 20.
5. To permit programmable flags, the first component controls the flags, and the flags are ignored on all other components. The total depth of the configuration is programmed in the master device by loading the total number of FIFOs into the depth register.
6. All Load ( $\overline{\mathrm{LD}})$ pins are tied together.
7. The Halt-Full Flag $(\overline{\mathrm{HF}})$ is not available in the Depth Expansion Configuration.


Figure 22. Block Diagram of $1536 \times 18 / 3072 \times 18$ Synchronous FIFO Memiory With Programmable Flags used in Depth Expansion Configuration

## ORDERING INFORMATION




## FEATURES:

- 1024, 2048, and $4096 \times 8$-bit memory array structures
- 15 ns read / write cycle time
- Read and write clocks can be asynchronous or coincident
- Dual-ported zero fall-through time architecture
- Empty and Full flags signal FIFO status
- Almost-empty and almost-full flags set to Empty+7 and Full-7 respectively
- Output enable puts output data bus in high impedance state
- Produced with advanced submicron CEMOS ${ }^{\text {TM }}$ technology
- Available in 28 -pin 300 mil plastic DIP and 300 mil ceramic DIP
- For surface mount product please see the IDT72221/ 72231/72241 data sheet
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT72220/72230/72240 SyncFIFOTM are very high speed, low-power first-in, first-out (FIFO) memories with
clocked read and write controls. The IDT72220/72230/72240 have a 1024, 2048, and $4096 \times 8$-bit memory array, respectively. These FIFOs are applicable for a wide variety of data buffering needs, such as graphics, local area networks (LANs), and interprocessor communication.

These FIFOs have 8 -bit input and output ports. The input port is controlled by a free-running clock (WCLK), and a write enable pin (WEN). Data is read into the Synchronous FIFO on every clock when WEN is asserted. The output port is controlled by another clock pin (RCLK) and a read enable pin ( $\overline{\operatorname{REN}}$ ). The read clock can be tied to the write clock for single clock operation or the two clocks can run asynchronous of one another for dual clock operation. An output enable pin ( $\overline{\mathrm{OE}}$ ) is provided on the read port for three-state control of the output.

These Synchronous FIFOs have two end-point flags, Empty ( $\overline{\mathrm{FF}}$ ) and Full ( $\overline{\mathrm{FF}}$ ), and two partial flags, Almost-Empty ( $\overline{\mathrm{AE}}$ ) and Almost-Full ( $\overline{\mathrm{AF}}$ ), for improved system control. The partial flags are set to Empty +7 and Full- 7 for $\overline{\mathrm{AE}}$ and $\overline{\mathrm{AF}}$, respectively.

The IDT72220/72230/72240 are fabricated using IDT's high speed submicron CEMOS ${ }^{\text {TM }}$ technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION



PIN DESCRIPTIONS

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| Do - D7 | Data Inputs | 1 | Data inputs for a 8-bit bus. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal read and write pointers are set to the first location of the RAM array, $\overline{F F}$ and $\overline{A F}$ go high, and $\overline{A E}$ and $\overline{E F}$ go low. A reset is required before an initial WRITE after power-up. |
| WCLK | Write Clock | 1 | Data is written into the FIFO on a LOW-to-HIGH transition of WCLK when WEN is asserted. |
| WEN | Write Enable | 1 | When WEN is LOW, data is written into the FIFO on every LOW-to-HIGH transition of WCLK. Data will not be written into the FIFO if the $\overline{\mathrm{FF}}$ is LOW. |
| Q0-Q7 | Data Outputs | 0 | Data outputs for a 8-bit bus. |
| RCLK | Read Clock | 1 | Data is read from the FIFO on a LOW-to-HIGH transition of RCLK when REN is asserted. |
| $\overline{\mathrm{REN}}$ | Read Enable | I | When $\overline{\text { REN }}$ is LOW, data is read from the FIFO on every LOW-to-HIGH transition of RCLK. Data will not be read from the FIFO if the EF is LOW. |
| $\overline{\mathrm{OE}}$ | Output Enable | I | When $\overline{\mathrm{OE}}$ is LOW, the data output bus is active. II $\overline{\mathrm{OE}}$ is HIGH, the output data bus will be in a high impedance state. |
| $\overline{E F}$ | Empty Flag | 0 | When $\overline{\mathrm{EF}}$ is LOW, the FIFO is empty and further data reads from the output are inhibited. When EF is HIGH, the FIFO is not empty. EF is synchronized to RCLK. |
| $\overline{A E}$ | Almost-Empty Flag | 0 | When $\overline{A E}$ is LOW, the FIFO is almost empty based on the offset Empty+7. $\overline{A E}$ is synchronized to RCLK. |
| $\overline{\mathrm{AF}}$ | Almost-Full Flag | 0 | When $\overline{\mathrm{AF}}$ is LOW, the FIFO is almost full based on the offset Full-7. $\overline{\mathrm{AF}}$ is synchronized to WCLK. |
| $\overline{\text { FF }}$ | Full Flag | 0 | When $\overline{\text { FF }}$ is LOW, the FIFO is full and further data writes into the input are inhibited. When $\overline{\text { FF }}$ is HIGH, the FIFO is not full. $\overline{F F}$ is synchronized to WCLK. |
| Vcc | Power |  | One +5 volt power supply pin. |
| GND | Ground |  | One 0 volt ground pin. |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercia! | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| louT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2749 ы 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | UnIt |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCCM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| VCCC | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL | Input Low Voltage <br> Com'l. \& Mil. | - | - | 0.8 | V |

CAPACITANCE ( $\mathrm{T} A=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| $\mathrm{CIN}^{(2)}$ | Input Capacitance | VIN $=0 \mathrm{~V}$ | 10 | pF |
| Cour $^{(1,2)}$ | Output Capacitance | Vout $=0 \mathrm{~V}$ | 10 | pF |

NOTE:

1. With output deselected. $(\overline{\mathrm{OE}}=$ high $)$
2. Characterized values, not currently tested.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { IDT72220, IDT72230 } \\ \text { IDT72240 } \\ \text { Commercial } \\ \text { tCLK }=15,20,25,50 \mathrm{~ns} \end{gathered}$ |  |  | IDT72220, IDT72230, IDT72240 Mlilitary$\text { tCLK }=20,25,50 \mathrm{~ns}$ |  |  | UnIt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $1 \mathrm{ILI}^{(1)}$ | Input Leakage Current (any input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| ILO ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, IOH = -2 mA | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage, $10 \mathrm{~L}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| Icci ${ }^{(3)}$ | Active Power Supply Current | - | - | 140 | - | - | 160 | mA |

NOTES:
2749 tbl 05

1. Measurements with $0.4 \leq \mathrm{VIN} \leq$ Vout.
2. $\overline{O E} \geq V_{\mathbb{H}}, 0.4 \leq$ Vout $\leq$ Vcc.
3. Measurements are made with outputs open.

Tested at fCLK $=20 \mathrm{MHz}$.
Typical ICC1 $=65+($ fCLK $* 1.1 / \mathrm{MHz})+($ fCLK $* \mathrm{CL} * 0.03 / \mathrm{MHz}-\mathrm{pF}) \mathrm{mA}$
fcLK $=1 /$ tclk
$\mathrm{CL}=$ external capacitive load (30 pF typical)

## AC ELECTRICAL CHARACTERISTICS

(Commercial: Vcc $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Com'l. IDT72220L15 IDT72230L15 IDT72240L15 |  | IDT72220L20 <br> IDT72230L20 <br> IDT72240L20 |  | IDT72220L25 IDT72230L25 IDT72240L25 |  | IDT72220L50 IDT72230L50 IDT72240L50 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| fs | Clock Cycle Frequency | - | 66.7 | - | 50 | - | 40 | - | 20 | MHz |
| ta | Data Access Time | 2 | 10 | 2 | 12 | 3 | 15 | 3 | 25 | ns |
| tCLK | Clock Cycle Time | 15 | - | 20 | - | 25 | - | 50 | - | ns |
| tCLKH | Clock High Time | 6 | - | 8 | - | 10 | - | 20 | - | ns |
| tCLKL | Clock Low Time | 6 | - | 8 | - | 10 | - | 20 | - | ns |
| tos | Data Set-up Time | 4 | - | 5 | - | 6 | - | 10 | - | ns |
| toh | Data Hold Time | 1 | - | 1 | - | 1 | - | 2 | - | ns |
| tENS | Enable Set-up Time | 4 | - | 5 | - | 6 | - | 10 | - | ns |
| tenh | Enable Hold Time | 1 | - | 1 | - | 1 | - | 2 | - | ns |
| tRS | Reset Pulse Width ${ }^{(1)}$ | 15 | - | 20 | - | 25 | - | 50 | - | ns |
| trss | Reset Set-up Time | 15 | - | 20 | - | 25 | - | 50 | - | ns |
| trsF | Reset to Flag and Output Time | - | 15 | - | 20 | - | 25 | - | 50 | ns |
| tolz | Output Enable to Output in Low Z $^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| toe | Output Enable to Output Valid | 3 | 8 | 3 | 10 | 3 | 13 | 3 | 28 | ns |
| tOHZ | Output Enable to Output in High Z ${ }^{(2)}$ | 3 | 8 | 3 | 10 | 3 | 13 | 3 | 28 | ns |
| twFF | Write Clock to Full Flag | - | 10 | - | 12 | - | 15 | - | 30 | ns |
| treF | Read Clock to Empty Flag | - | 10 | - | 12 | - | 15 | - | 30 | ns |
| taf | Write Clock to Almost-Full Flag | - | 10 | - | 12 | - | 15 | - | 30 | ns |
| tAE | Read Clock to Almost-Empty Flag | - | 10 | - | 12 | - | 15 | - | 30 | ns |
| tSKEW1 | Skew time between Read Clock \& Write Clock for Empty Flag \& Full Flag | 6 | - | 8 | - | 10 | - | 15 | - | ns |
| tSKEW2 | Skew time between Read Clock \& Write Clock for Almost-Empty Flag \& Almost-Full Flag | 15 | - | 18 | - | 20 | - | 30 | - | ns |

NOTES:

1. Pulse widths less than minimum are not allowed.
2. Values guaranteed by design, not currently tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 3ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |



Figure 1. Output Load

[^3]|  | CMOS PARALLEL SyncFIFO™ (CLOCKED FIFO) <br> $1024 \times 9$-BIT, $2048 \times 9$-BIT <br> \& $4096 \times 9$-BIT | ADVANCE INFORMATIN IDT72221 IDT72231 IDT72241 |
| :---: | :---: | :---: |

## FEATURES:

- 1024, 2048, and $4096 \times 9$-bit memory array structures
- 15ns read / write cycle time
- Read and write clocks can be asynchronous or coincident
- Dual-ported zero fall-through time architecture
- Empty and Full flags signal FIFO status
- Programmable almost-empty and almost-full flags can be set to any depth
- Programmable almost-empty and almost-full flags default to Empty+7 and Full-7 respectively
- Output enable puts output data bus in high impedance state
- Produced with advanced submicron CEMOSTM technology
- Available in 32 -pin plastic leaded chip carrier (PLCC) and ceramic leadless chip carrier (LCC)
- For Through-Hole product please see the IDT72220/ 72230/72240 data sheet
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT72221/72231/72241 SyncFIFOTM are very high speed, low-power first-in, first-out (FIFO) memories with clocked read and write controls. The IDT72221/72231/ 72241 have a 1024, 2048, and $4096 \times 9$-bit memory array, respectively. These FIFOs are applicable for a wide variety of data buffering needs, such as graphics, local area networks (LANs), and interprocessor communication.

These FIFOs have 9 -bit input and output ports. The input port is controlled by a free-running clock (WCLK), and write enable pins (WEN1, WEN2). Data is read into the Synchronous FIFO on every clock when the write enable pins are asserted. The output port is controlled by another clock pin (RCLK) and two read enable pins ( $\overline{\mathrm{REN} 1}, \overline{\mathrm{REN} 2}$ ). The two enable pins on each port are provided to allow for depth expansion. The read clock can be tied to the write clock for single clock operation or the two clocks can run asynchronous of one another for dual clock operation. An output enable pin $\overline{(\overline{O E})}$ is provided on the read port for three-state control of the output.

## FUNCTIONAL BLOCK DIAGRAM



CEMOS and SyncFIFO are trademarks of Integrated Device Techology, Inc.

## DESCRIPTION (Continued)

The Synchronous FIFOs have two fixed flags, Empty ( $\overline{\mathrm{EF}}$ ) and Full ( $\overline{\mathrm{FF}}$ ). Two programmable flags, Almost-Empty ( $\overline{\text { PAE }}$ ) and Almost-Full ( $\overline{\mathrm{PAF}}$ ), are provided for improved system control. The programmable flags default to Empty +7 and Full7 for PAE and PAF respectively. The programmable flag offset loading is controlled by a simple state machine, and is initiated by asserting the load pin ( $\overline{\mathrm{LD}}$ ).

The IDT72221/72231/72241 are fabricated using IDT's high speed submicron CEMOS ${ }^{\text {TM }}$ technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## PIN CONFIGURATION



## PIN DESCRIPTION

| Symbol | Name | IO | Description |
| :---: | :---: | :---: | :---: |
| Do - D8 | Data Inputs | 1 | Data inputs for a 9-bit bus. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal read and write pointers are set to the first location of the RAM array, $\overline{F F}$ and $\overline{\text { PAF go high, and PAE and EF go low. A reset is required before an }}$ initial WRITE after power-up. |
| WCLK | Write Clock | 1 | Data is written into the FIFO on a LOW-to-HIGH transition of WCLK when the Write Enable(s) are asserted. |
| WEN1 | Write Enable 1 | 1 | It the FIFO is configured to have programmable flags, $\overline{\text { WEN } 1}$ is the only write enable pin. When WEN1 is LOW, data is written into the FIFO on every LOW-to-HIGH transition of WCLK. If the FIFO is configured to have two write enables, WEN1 must be LOW \& WEN2 must be HIGH to write data into the FIFO. Data will not be written into the FIFO if the $\overline{\mathrm{FF}}$ is LOW. |
| WEN2 $\overline{\text { L }}$ | Write Enable 21 Load | I | The FIFO is configured at reset to have two write enables or programmable flags. If WEN2 $\overline{\Lambda D}$ is HIGH at reset, this pin operates as a second write enable. If WEN2 $\overline{\Lambda D}$ is LOW at reset, this pin operates as a control to load and read the programmable flag offsets. If the FIFO is configured to have two write enables, WEN1 must be LOW \& WEN2 must be HIGH to write data into the FIFO. Data will not be written into the FIFO if the $\overline{\mathrm{FF}}$ is LOW. If the FIFO is configured to have programmable flags, WEN2/LD is held LOW to write or read the programmable flag offsets. |
| Q0 - Q6 | Data Outputs | 0 | Data outputs for a 9-bit bus. |
| RCLK | Read Clock | 1 | Data is read from the FIFO on a LOW-to-HIGH transition of RCLK when REN1 \& REN2 are asserted. |
| $\overline{\text { REN } 1}$ | Read Enable 1 | 1 | When $\overline{\text { REN } 1 ~ a n d ~ R E N 2 ~ a r e ~ L O W, ~ d a t a ~ i s ~ r e a d ~ f r o m ~ t h e ~ F I F O ~ o n ~ e v e r y ~ L O W-t o-H I G H ~}$ transition of RCLK. Data will not be read from the FIFO if the EF is LOW. |
| $\overline{\mathrm{REN2}}$ | Read Enable 2 | 1 | When $\overline{\operatorname{REN} 1}$ and $\overline{\mathrm{REN} 2}$ are LOW, data is read from the FIFO on every LOW-to-HIGH transition of RCLK. Data will not be read from the FIFO if the EF is LOW. |
| $\overline{\mathrm{OE}}$ | Output Enable | 1 | When $\overline{\mathrm{OE}}$ is LOW, the data output bus is active. If $\overline{\mathrm{OE}}$ is HIGH, the output data bus will be in a high impedance state. |
| $\overline{\mathrm{EF}}$ | Empty Flag | 0 | When EF is LOW, the FIFO is empty and further data reads from the output are inhibited. When $\overline{E F}$ is HIGH, the FIFO is not empty. $\overline{E F}$ is synchronized to RCLK. |
| $\overline{\text { PAE }}$ | Programmable Almost-Empty Flag | 0 | When $\overline{\text { PAE }}$ is LOW, the FIFO is almost empty based on the offset programmed into the FIFO. The default offset at reset is Empty+7. PAE is synchronized to RCLK. |
| $\overline{\text { PAF }}$ | Programmable Almost-Full Flag | 0 | When $\overline{\text { PAF }}$ is LOW, the FIFO is almost full based on the offset programmed into the FIFO. The default offset at reset is Full-7. $\overline{\text { PAF }}$ is synchronized to WCLK. |
| $\overline{\mathrm{FF}}$ | Full Flag | 0 | When $\overline{F F}$ is LOW, the FIFO is full and further data writes into the input are inhibited. When $\overline{\mathrm{FF}}$ is HIGH, the FIFO is not full. $\overline{\mathrm{FF}}$ is synchronized to WCLK. |
| Vcc | Power |  | One +5 volt power supply pin. |
| GND | Ground |  | One 0 volt ground pin. |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2750 t1 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VccM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL | Input Low Voltage <br> Com'l. \& Mil. | - | - | 0.8 | V |

2750 to 04

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| $\mathrm{CIN}^{(2)}$ | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 10 | pF |
| $\mathrm{Cour}^{(1,2)}$ | Output Capacitance | Vout $=0 \mathrm{~V}$ | 10 | pF |

NOTE:
2750 t03

1. With output deselected. ( $\overline{\mathrm{OE}}=$ high)
2. Characterized values, not currently tested.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{Vcc}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{Vcc}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { IDT72221, IDT72231, } \\ \text { IDT72241 } \\ \text { Commercial } \\ \text { tcLK }=15,20,25,50 \mathrm{~ns} \end{gathered}$ |  |  | $\begin{gathered} \hline \text { IDT72221, IDT72231, } \\ \text { IDT72241 } \\ \text { Milltary } \\ \text { tCLK }=20,25,50 \mathrm{~ns} \\ \hline \end{gathered}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Milin | Typ. | Max. | Mlin | Typ. | Max. |  |
| $L_{1}{ }^{(1)}$ | Input Leakage Current (any input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| Lo ${ }^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, $\mathrm{OH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage, loL $=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{lcCa}_{1}{ }^{(3)}$ | Active Power Supply Current | - | - | 140 | - | - | 160 | mA |

NOTES:

1. Measurements with $0.4 \leq \operatorname{VIN} \leq$ Vout.
2. $\overline{O E} \geq \mathrm{VIH}, 0.4 \leq$ Vout $\leq$ Vcc.
3. Measurements are made with outputs open.

Tested at fclk $=20 \mathrm{MHz}$.
Typical ICC1 $=65+($ fCLK $* 1.1 / M H z)+($ fCLK $* C L * 0.03 / M H z-p F) ~ m A ~$
fclk $=1 /$ tclk
$\mathrm{CL}_{\mathrm{L}}=$ external capacitive load ( 30 pF typical)

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Com'I.IDT72221L15IDT72231L15IDT72241L15 |  | IDT72221L20 IDT72231L20 IDT72241L20 |  | $\begin{aligned} & \text { IDT72221L25 } \\ & \text { IDT72231L25 } \\ & \text { IDT72241L25 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT72221L50 } \\ & \text { IDT72231L50 } \\ & \text { IDT72241L50 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ts | Clock Cycle Frequency | - | 66.7 | - | 50 | - | 40 | - | 20 | MHz |
| tA | Data Access Time | 2 | 10 | 2 | 12 | 3 | 15 | 3 | 25 | ns |
| tClk | Clock Cycle Time | 15 | - | 20 | - | 25 | - | 50 | - | ns |
| tCLKH | Clock High Time | 6 | - | 8 | - | 10 | - | 20 | - | ns |
| tCLKL | Clock Low Time | 6 | - | 8 | - | 10 | - | 20 | - | ns |
| tDS | Data Set-up Time | 4 | - | 5 | - | 6 | - | 10 | - | ns |
| tDH | Data Hold Time | 1 | - | 1 | - | 1 | - | 2 | - | ns |
| tins | Enable Set-up Time | 4 | - | 5 | - | 6 | - | 10 | 一 | ns |
| tENH | Enable Hold Time | 1 | - | 1 | - | 1 | - | 2 | - | ns |
| tRS | Reset Pulse Width ${ }^{(1)}$ | 15 | - | 20 | - | 25 | - | 50 | - | ns |
| tRSS | Reset Set-up Time | 15 | - | 20 | - | 25 | - | 50 | - | ns |
| tRSF | Reset to Flag and Output Time | - | 15 | - | 20 | - | 25 | - | 50 | ns |
| tolz | Output Enable to Output in Low Z ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| toe | Output Enable to Output Valid | 3 | 8 | 3 | 10 | 3 | 13 | 3 | 28 | ns |
| tohz | Output Enable to Output in High $\mathbf{Z}^{(2)}$ | 3 | 8 | 3 | 10 | 3 | 13 | 3 | 28 | ns |
| twFF | Write Clock to Full Flag | - | 10 | - | 12 | - | 15 | - | 30 | ns |
| treF | Read Clock to Empty Flag | - | 10 | - | 12 | - | 15 | - | 30 | ns |
| tPAF | Write Clock to Programmable Almost-Full Flag | - | 10 | - | 12 | - | 15 | - | 30 | ns |
| tPaE | Read Clock to Programmable AlmostEmpty Flag | - | 10 | - | 12 | - | 15 | - | 30 | ns |
| tSKEW1 | Skew time between Read Clock \& Write Clock for Empty Flag \& Full Flag | 6 | - | 8 | - | 10 | - | 15 | - | ns |
| tSKEW2 | Skew time between Read Clock \& Write Clock for Programmable Almost-Empty Flag \& Programmable Almost-Full Flag | 15 | - | 18 | - | 20 | - | 30 | - | ns |

## NOTES:

1. Pulse widths less than minimum are not allowed.
2. Values guaranteed by design, not currently tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :---: | :---: |
| Input Rise/Fall Times | 3ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |


or equivalent circuit
Figure 1. Output Load
-Includes jig and scope capabilities.

## CMOS PARALLEL SyncFIFO ${ }^{\text {M }}$ (CLOCKED FIFO) $2048 \times 18$-BIT \& $4096 \times 18$-BIT

## ADVANCED INFORMATION IDT72235 IDT72245

## FEATURES:

- $2048 \times 18$-bit and $4096 \times 18$-bit memory array structures
- 20ns read / write cycle time
- Easily expandable in depth and width
- Read and write clocks can be asynchronous or coincident
- Dual-port zero fall-through time architecture
- Programmable almost-empty and almost-full flags
- Empty and Full flags signal FIFO status
- Half-Full flag capability in a single device configuration
- Output enable puts output data bus in high impedance state
- First device controls all flag logic in depth expansion
- Produced with advanced submicron CEMOS ${ }^{\text {rM }}$ technology
- Available in a 68 -lead pin grid array (PGA), and plastic leaded chip carrier (PLCC)
- Military product compliant to MIL-STD-883, Class B

DESCRIPTION:
The IDT72235 and IDT72245 are very high speed, low-powerfirst-in, first-out (FIFO) memories with clocked read and write controls. The IDT72235 has a $2048 \times 18$-bit memory array, while the IDT72245 has a $4096 \times 18$-bit memory array. These FIFOs are applicable for a wide variety of data buffering needs, such as optical disk controllers, local area networks (LANs), and interprocessor communication.

Both FIFOs have 18 -bit input and output ports. The input port is controlled by a free-running clock (WCLK), and a data input enable pin (WEN). Data is read into the synchronous FIFO on every clock when $\bar{W} E N$ is asserted. The output port is controlled by another clock pin (RCLK) and another enable pin ( $\overline{\mathrm{REN}})$. The read clock can be tied to the write clock for single clock operation or the two clocks can run asynchronous of one another for dual clock operation. An output enable pin $(\overline{\mathrm{OE}})$ is provided on the read port for three-state control of the output.

The synchronous FIFOs have two fixed flags, Empty ( $\overline{\mathrm{EF}}$ ) and Full ( $\overline{\mathrm{FF}}$ ), and two programmable flags, Almost-Empty ( $\overline{\mathrm{PAE}}$ ) and Almost-Full ( $\overline{\mathrm{PAF}}$ ). The offset loading of the programmable flags is controlled by a simple state machine, and is initiated by asserting the load pin (LD). A Half-Full flag $\overline{(\mathrm{HF})}$ is available when the FIFO is used in a single device configuration.

The IDT72235 and IDT72245 are depth expandable using a daisy-chain technique. The $\overline{\mathrm{XI}}$ and $\overline{\mathrm{XO}}$ pins are used to expand the FIFOs. To permit programmable flags in depth expansion, the first device, indicated by setting $\overline{F L}$ to low, controls the flags.

The IDT72235/72245 is fabricated using IDT's high speed submicron CEMOS ${ }^{\text {™ }}$ technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.


PIN CONFIGURATIONS



## PIN DESCRIPTION

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| Do-D17 | Data Inputs | 1 | Data inputs for a 18-bit bus. |
| $\overline{\overline{R S}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set low, internal read and write pointers are set to the first location of the RAM array, $\overline{\mathrm{FF}}$ and $\overline{\mathrm{PAF}}$ go high, and $\overline{\text { PAE }}$ and $\overline{\mathrm{EF}}$ go low. A reset is required before an initial WRITE after power-up. |
| WCLK | Write Clock | 1 | Data is written into the FIFO on a LOW-to-HIGH transition of WCLK when Write Enable WEN is asserted (LOW). |
| WEN | Write Enable | 1 | When WEN is LOW, data is written into the FIFO on every LOW-to-HIGH transition of WCLK. When WEN is high, the FIFO holds the previous data. Data will not be written into the FIFO if the $\overline{\mathrm{FF}}$ is LOW. |
| RCLK | Read Clock | 1 | Data is read from the FIFO on a LOW-to-HIGH transition of RCLK when Read Enable $\overline{R E N}$ is asserted (LOW). |
| $\overline{\text { REN }}$ | Read Enable | 1 | When $\overline{\text { REN }}$ is LOW, data is read from the FIFO on every LOW-to-HIGH transition of RCLK. When $\overline{R E N}$ is high, the output register holds the previous data. Data will not be read from the FIFO if the EF is LOW. |
| $\overline{O E}$ | Output Enable | 1 | When $\overline{\mathrm{OE}}$ is LOW, the data output bus is active. If $\overline{\mathrm{OE}}$ is HIGH, the output data bus will be in a high impedance state. |
| $\overline{\text { LD }}$ | Load | 1 | When $\overline{L D}$ is LOW, data on the inputs Do-D15 is written to the offset and depth registers on the LOW-to-HIGH transition of the WCLK, when WEN is LOW. When LD is LOW, data on the outputs Q0-Q15 is read from the offset and depth registers on the LOW-toHIGH transition of the RCL.K, when REN is LOW. |
| $\overline{\text { FL }}$ | First Load | 1 | In the single device or width expansion configuration, $\overline{\mathrm{FL}}$ is grounded. In the depth expansion configuration, $\overline{\mathrm{FL}}$ is grounded on the first device (first load device) and set to high for all other devices in the daisy chain. |
| $\overline{\text { WXI }}$ | Write Expansion Input | 1 | In the single device or width expansion configuration, $\overline{\mathrm{WXI}}$ is grounded. In the depth expansion configuration, WXI is connected to WXO (Write Expansion Out) of the previous device. |
| $\overline{\mathrm{RXI}}$ | Read Expansion Input | 1 | In the single device or width expansion configuration, $\overline{\mathrm{RXI}}$ is grounded. In the depth expansion configuration, $\overline{\mathrm{RXI}}$ is connected to $\overline{\mathrm{KXO}}$ (Read Expansion Out) of the previous device. |
| $\overline{\mathrm{EF}}$ | Empty Flag | 0 | When $\overline{E F}$ is LOW, the FIFO is empty and further data reads from the output are inhib ited. When EF is HIGH, the FIFO is not empty. EF is synchronized to RCLK. |
| $\overline{\text { PAE }}$ | Programmable Almost-Empty Flag | 0 | When PAE is LOW, the FIFO is almost empty based on the offset programmed into the FIFO. The default offset at reset is $1 / 8$ full. |
| $\overline{\text { PAF }}$ | Programmable Almost-Full Flag | 0 | When $\overline{\mathrm{PAF}}$ is LOW, the FIFO is almost full based on the offset programmed into the FIFO. The default offset at reset is $7 / 8$ full. |
| $\overline{\mathrm{FF}}$ | Full Flag | 0 | When $\overline{F F}$ is LOW, the FIFO is full and further data writes into the input are inhibited. When $\overline{\text { FF }}$ is HIGH, the FIFO is not full. $\overline{\text { FF }}$ is synchronized to WCLK. |
| $\overline{\mathrm{WXO} / \mathrm{HF}}$ | Write Expansion Out/Half-Full Flag | 0 | In the single device or width expansion configuration, the device is more than half full when $\overline{\mathrm{HF}}$ is LOW. In the depth expansion configuration, a pulse is sent from $\overline{W X O}$ to WXI of the next device when the last location in the FIFO is written. |
| $\overline{\mathrm{RXO}}$ | Read Expansion Out | 0 | In the depth expansion configuration, a pulse is sent from $\overline{\mathrm{RXO}}$ to $\overline{\mathrm{RXI}}$ of the next device when the last location in the FIFO is read. |
| Q0-Q17 | Data Outputs | 0 | Data outputs for a 18-bit bus. |
| Vcc | Power |  | Eight +5 volt power supply pins. |
| GND | Ground |  | Eight 0 volt ground pins. |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Mlilitary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with respect to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under <br> Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | 50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maimum rating conditions for extended periods may affect reliabilty.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vccm | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vccc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| $\mathrm{VIH}^{\text {Comput High Voltage }}$ | 2.2 | - | - | V |  |
| $\mathrm{VIL}^{\text {(1) }}$ | Military | Input Low Voltage <br> Commercial \& Military | - | - | 0.8 |

NOTE:
2729 t103

1. 1.5 V undershoots are allowed for 10 s once per cycle.

DC ELECTRICAL CHARACTERISTICS
(Commercial: VCC $=5 \mathrm{~V} \pm 10 \%, T A=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72235 <br> IDT72235 <br> Commercial $\text { tcLK }=20,25,50 \mathrm{~ns}$ |  |  | IDT72245 <br> IDT72245 Military tCLK $=25,30,50 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $1 \mathrm{IL}^{(1)}$ | Input Leakage Current (any input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{LLO}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic " 1 " Voltage, $1 \mathrm{OH}=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage, $1 \mathrm{OL}=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{lcCl}^{(3)}$ | Active Power Supply Current | - | - | 250 | - | - | 300 | mA |
| $\mathrm{ICC2}{ }^{(3)}$ | Average Standby Current (All Input $=\mathrm{Vcc}-0.2 \mathrm{~V}$, except RCLK and WCLK which are free-running) | - | - | 60 | - | - | 75 | mA |

NOTES:

1. Measurements with $0.4 \leq \mathrm{V}$ IN $\leq$ Vout.
2. $\overline{O E} \geq$ VIH, $0.4 \leq$ VOUT $\leq$ Vcc.
3. Tested at $f=20 \mathrm{MHz}$.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: Vcc $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { IDT72235L20 } \\ \text { IDT72245L20 } \\ \text { Com'l. } \\ \hline \end{gathered}$ |  | IDT72235L25 IDT72245L25 Com'l. \& MII. |  | IDT72235L30 IDT72245L30 Mil. |  | $\begin{aligned} & \text { IDT72235L50 } \\ & \text { IDT72245L50 } \\ & \text { Com'I. \& Mil. } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| fs | Clock Cycle Frequency | - | 50 | - | 40 | - | 33 | - | 20 | MHz |
| tA | Data Access Time | 2 | 14 | 3 | 15 | 3 | 18 | 3 | 25 | ns |
| tCLK | Clock Cycle Time | 20 | - | 25 | - | 30 | - | 50 | - | ns |
| tCl.KH | Clock High Time | 8 | - | 10 | - | 12 | - | 20 | - | ns |
| tCLKL | Clock Low Time | 9 | - | 10 | - | 12 | - | 20 | - | ns |
| tDG | Data Set-up Time | 5 | - | 6 | - | 7 | - | 10 | - | ns |
| tDH | Data Hold Time | 1 | - | 1 | - | 1 | - | 2 | - | ns |
| tENS | Enable Set-up Time | 5 | - | 6 | - | 7 | - | 10 | - | ns |
| tenh | Enable Hold Time | 1 | - | 1 | - | 1 | - | 2 | - | ns |
| trs | Reset Pulse Width ${ }^{(1)}$ | 20 | - | 25 | - | 30 | - | 50 | - | ns |
| tRSS | Reset Set-up Time ${ }^{(2)}$ | 12 | - | 15 | - | 18 | - | 30 | - | ns |
| tRSF | Reset to Flag and Output Time | - | 20 | - | 25 | - | 30 | - | 50 | ns |
| tolz | Output Enable to Output in Low $\mathbf{Z}^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| toe | Output Enable to Output Valid | - | 9 | - | 12 | - | 15 | - | 20 | ns |
| tohz | Output Enable to Output in High $\mathbf{Z}^{(2)}$ | 1 | 9 | 1 | 12 | 1 | 15 | 1 | 20 | ns |
| twFF | Write Clock to Full Flag | - | 14 | - | 16 | - | 18 | - | 30 | ns |
| tREF | Read Clock to Empty Flag | - | 12 | - | 15 | - | 18 | - | 30 | ns |
| tPaF | Clock to Programmable Almost-Full Flag | - | 20 | - | 22 | - | 24 | - | 35 | ns |
| tPaE | Clock to Programmable Almost-Empty Flag | - | 20 | - | 22 | - | 24 | - | 35 | ns |
| thf | Clock to Half-Full Flag | - | 22 | - | 22 | - | 24 | - | 35 | ns |
| txo | Clock to Expansion Out | - | 12 | - | 15 | - | 18 | - | 30 | ns |
| txI | Expansion In Pulse Width | 8 | - | 10 | - | 12 | - | 20 | - | ns |
| txis | Expansion In Set-Up Time | 8 | - | 10 | - | 12 | - | 20 | - | ns |
| tSKEW1 | Skew time between Read Clock \& Write Clock for Full Flag | 14 | - | 16 | - | 18 | - | 20 | - | ns |
| tSKEW2 | Skew time between Read Clock \& Write Clock for Empty Flag | 14 | - | 16 | - | 18 | - | 20 | - | ns |

NOTES:

1. Pulse widths less than minimum values are not allowed.
2. Values guaranteed by design, not currently tested.

CMOS PARALLEL FIFO
IDT72401
$64 \times 4$-BIT AND $64 \times 5$-BIT
IDT72402
IDT72403
IDT72404

## FEATURES:

- First-In/First-Out dual-port memory
- $64 \times 4$ organization (IDT72401/03)
- $64 \times 5$ organization (IDT72402/04)
- IDT72401/02 pin and functionally compatible with MMI67401/02
- RAM-based FIFO with low fall-through time
- Low power consumption
- Active: 175mW (typ.)
- Maximum shift rate - 45 MHz
- High data output drive capability
- Asynchronous and simultaneous read and write
- Fully expandable by bit width
- Fully expandable by word depth
- IDT72403/04 have Output Enable pin to enable output data
- High-speed data communications applications
- High-performance CEMOS ${ }^{\text {™ }}$ technology
- Available in CERDIP, plastic DIP and SOIC
- Military product compliant to MIL-STD-883, Class B
- Standard Military Drawing\# 5962-86846 and 5962-89523 is listed on this function.


## DESCRIPTION:

The IDT72401 and IDT72403 are asynchronous highperformance First-In/First-Out memories organized 64 words by 4 bits. The IDT72402 and IDT72404 are asynchronous high-performance First-In/First-Out memories organized as 64 words by 5 bits. The IDT72403 and IDT72404 also have an

Output Enable ( $\overline{O E}$ ) pin. The FIFOs accept 4-bit or 5-bit data at the data input (Do-D3,4). The stored data stack up on a first-in/first-out basis.

A Shift Out (SO) signal causes the data at the next to last word to be shifted to the output while all other data shifts down one location in the stack. The Input Ready (IR) signal acts like a flag to indicate when the input is ready for new data (IR = HIGH) or to signal when the FIFO is full (IR = LOW). The Input Ready signal can also be used to cascade multiple devices together. The Output Ready (OR) signal is a flag to indicate that the output remains valid data ( $O R=H I G H$ ) or to indicate that the FIFO is empty ( $O R=L O W$ ). The Output Ready can also be used to cascade multiple devices together.

Width expansion is accomplished by logically ANDing the Input Ready (IR) and Output Ready (OR) signals to form composite signals.

Depth expansion is accomplished by tying the data inputs of one device to the data outputs of the previous device. The Input Ready pin of the receiving device is connected to the Shift Out pin of the sending device and the Output Ready pin of the sending device is connected to the Shift In pin of the receiving device.

Reading and writing operations are completely asynchronous allowing the FIFO to be used as a buffer between two digital machines of widely varying operating frequencies. The 45 MHz speed makes these FIFOs ideal for high-speed communication and controller applications.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



2747 drw 01

## PIN CONFIGURATIONS



(IDT72404 Only)


NOTES:

1. Pin 1: NC - No Connection IDT72401

OE - IDT72403
2. Pin 1: NC - No Connection IDT72402

OE - IDT72404

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | RatIng | Commerclal | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG <br> $\cdot$ | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| louT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2747 tol 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING CONDITIONS

| Symbol | Parameter | MIn. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vcc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{VIH}^{(1)}$ | Input High Voltage | 2.0 | - | - | V |
| VIL $^{(1)}$ | Input High Voltage | - | - | 0.8 | V |

NOTE:

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 5 | pF |
| COUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 7 | pF |

NOTE:

1. This parameter is sampled and not $100 \%$ tested.

DC ELECTRICAL CHARACTERISTICS
(Commercial: Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unlt |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{1 C}{ }^{(1)}$ | Input Clamp Voltage |  | - | - | - |
| VIL | Low-Level Input Current | $\mathrm{Vcc}=\mathrm{Max} ., \mathrm{GND} \leq \mathrm{V}_{1} \leq \mathrm{Vcc}$ | -10 | - | $\mu \mathrm{A}$ |
| VIH | High-Level Input Current | Vcc = Max., GND $\leq \mathrm{V}_{1} \leq \mathrm{Vcc}$ | - | 10 | $\mu \mathrm{A}$ |
| VoL | Low-Level Output Current | $\mathrm{VcC}=\mathrm{Min} ., \mathrm{loL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | High-Level Output Current | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |
| $\mathrm{los}^{(2)}$ | Output Short-Circuit Current | $\mathrm{Vcc}=$ Max., $\mathrm{VO}=\mathrm{GND}$ | -20 | -90 | mA |
| IHZ | Off-State Output Current | $\mathrm{Vcc}=\mathrm{Max} ., \mathrm{VO}=2.4 \mathrm{~V}$ | - | 20 | $\mu \mathrm{A}$ |
| ILZ | (IDT72403 and IDT72404) | $\mathrm{Vcc}=\mathrm{Max} ., \mathrm{Vo}=0.4 \mathrm{~V}$ | -20 | - | $\mu \mathrm{A}$ |
| $\mathrm{lcc}^{(3,4)}$ | Supply Current | $V C C=M a x ., f=10 M H z$ <br> Commercial <br> Military | - | $\begin{aligned} & 35 \\ & 45 \end{aligned}$ | mA |

NOTES:
2747 tol 04

1. FIFO is able to withstand a-1.5V undershoot for less than 10 ns .
2. Not more than one output should be shorted at a time and duration of the short-circuit should not exceed one second. Guaranteed but not tested.
3. Icc measurements are made with outputs open. $\overline{\mathrm{OE}}$ is HIGH for IDT72403/72404.
4. For frequencies greater than 10 MHZ , Icc $=35 \mathrm{~mA}+(1.5 \mathrm{~mA} \times[f-10 \mathrm{MHz}])$ commercial, and $\mathrm{IcC}=45 \mathrm{~mA}+(1.5 \mathrm{~mA} \times[f-10 \mathrm{MHz}]) \mathrm{military}$.

## OPERATING CONDITIONS

(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | FIgure | Commerclal <br> IDT72401L45 <br> IDT72402L45 <br> IDT72403L.45 <br> IDT72404L45 |  | Military and Commercial |  |  |  |  |  |  |  | UnIt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | IDT72401L35 IDT72402L35 IDT72403L35 IDT72404L. 35 |  | IDT72401L25 <br> IDT72402L25 <br> IDT72403L25 <br> IDT72404L25 |  | IDT72401L15 <br> IDT72402L15 <br> IDT72403L15 <br> IDT72404L15 |  | IDT72401L10 <br> IDT72402L10 <br> IDT72403L10 <br> IDT72404L10 |  |  |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| tSIH ${ }^{(1)}$ | Shift in HIGH Time | 2 | 9 | - | 9 | - | 11 | - | 11 | - | 11 | - | ns |
| tsil | Shift in LOW Tlme | 2 | 11 | - | 17 | - | 24 | - | 25 | - | 30 | - | ns |
| tios | Input Data Set-up | 2 | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tide | Input Data Hold Time | 2 | 13 | - | 15 | - | 20 | - | 30 | - | 40 | - | ns |
| tsor ${ }^{(1)}$ | Shift Out HIGH Time | 5 | 9 | - | 9 | - | 11 | - | 11 | - | 11 | - | ns |
| tSOL | Shift Out LOW Time | 5 | 11 | - | 17 | - | 24 | - | 25 | - | 25 | - | ns |
| tMRW | Master Reset Pulse | 8 | 20 | - | 25 | - | 25 | - | 25 | - | 30 | - | ns |
| tMRS | Master Reset Pulse to SI | 8 | 10 | - | 10 | - | 10 | - | 25 | - | 35 | - | ns |
| tSIR | Data Set-up to IR | 4 | 3 | - | 3 | - | 5 | - | 5 | - | 5 | - | ns |
| thin | Data Hold from IR | 4 | 13 | - | 15 | - | 20 | - | 30 | - | 30 | - | ns |
| tSOR ${ }^{(4)}$ | Data Set-up to OR HIGH | 7 | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | Flgure | Commerclal <br> IDT72401L45 <br> IDT72402L45 <br> IDT72403L45 <br> IDT72404L45 |  | Military and Commerclal |  |  |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | IDT72401L35 <br> IDT72402L35 <br> IDT72403L35 <br> IDT72404L35 |  | $\begin{aligned} & \text { IDT72401L25 } \\ & \text { IDT72402L25 } \\ & \text { IDT72403L25 } \\ & \text { IDT72404L25 } \end{aligned}$ |  | IDT72401L15 IDT72402L15 IDT72403L15 IDT72404L15 |  | $\begin{aligned} & \hline \text { IDT72401L10 } \\ & \text { IDT72402L10 } \\ & \text { IDT72403L10 } \\ & \text { IDT72404L10 } \\ & \hline \end{aligned}$ |  |  |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| tin | Shitt In Rate | 2 | - | 45 | - | 35 | - | 25 | - | 15 | - | 10 | MHz |
| tIRL ${ }^{(1)}$ | Shift In to Input Ready LOW | 2 | - | 18 | - | 18 | - | 21 | - | 35 | - | 40 | ns |
| tIRH ${ }^{(1)}$ | Shift In to Input Ready HIGH | 2 | - | 18 | - | 20 | - | 28 | - | 40 | - | 45 | ns |
| IOUT | Shift Out Rate | 5 | - | 45 | - | 35 | - | 25 | - | 15 | - | 10 | MHz |
| torL ${ }^{(1)}$ | Shift Out to Output Ready LOW | 5 | - | 18 | - | 18 | - | 19 | - | 35 | - | 40 | ns |
| torH ${ }^{(1)}$ | Shift Out to Output Ready HIGH | 5 | - | 19 | - | 20 | - | 34 | - | 40 | - | 55 | ns |
| tod | Output Data Hold (Previous Word) | 5 | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tods | Output Data Shift (Next Word) | 5 | - | 19 | - | 20 | - | 34 | - | 40 | - | 55 | ns |
| tPT | Data Throughput or "Fall-Through" | 4,7 | - | 30 | - | 34 | - | 40 | - | 65 | - | 65 | ns |
| tMRORL | Master Reset to OR LOW | 8 | - | 25 | - | 28 | - | 35 | - | 35 | - | 40 | ns |
| tMRIRH | Master Reset to IR HIGH | 8 | - | 25 | - | 28 | - | 35 | - | 35 | - | 40 | ns |
| tMRQ | Master Reset to Data Output LOW | 8 | - | 20 | - | 20 | - | 25 | - | 35 | - | 40 | ns |
| toos ${ }^{(3)}$ | Output Valid from $\overline{\mathrm{OE}}$ LOW | 9 | - | 12 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| thZOE ${ }^{(3,4)}$ | Output HIGH-Z from О $\overline{\text { E }}$ HIGH | 9 | - | 12 | - | 12 | - | 15 | - | 25 | - | 30 | ns |
| tIPH ${ }^{(2,4)}$ | Input Ready Pulse HIGH | 4 | 9 | - | 9 | - | 11 | - | 11 | - | 11 | - | ns |
| topH ${ }^{(2,4)}$ | Ouput Ready Pulse HIGH | 7 | 9 | - | 9 | - | 11 | - | 11 | - | 11 | - | ns |

## NOTES:

1. Since the FIFO is a very high-speed device, care must be excercised in the design of the hardware and timing utilized within the design. Device grounding and decoupling are crucial to correct operation as the FIFO will respond to very small glitches due to long reflective lines, high capacitances and/or poor supply decoupling and grounding. A monolithic ceramic capacitor of $0.1 \mu \mathrm{~F}$ directly between Vcc and GND with very short lead length is recommended.
2. This parameter applies to FIFOs communicating with each other in a cascaded mode. IDT FIFOs are guaranteed to cascade with other IDT FIFOs of like speed grades.
3. IDT72403 and IDT72404 only.
4. Guaranteed by design but not currently tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |  |  |
| :--- | :---: | :---: | :---: |
| Input Rise/Fall Times | 3ns |  |  |
| Input Timing Reference Levels | 1.5 V |  |  |
| Output Reference Levels | 1.5V |  |  |
| Output Load | See Figure 1 |  |  |
| 2754 tol 08 |  |  |  |

> GND

## SIGNAL DESCRIPTIONS

## INPUTS:

DATA INPUT (D0-3, 4)
Data input lines. The IDT72401 and IDT72403 have a 4bit data input. The IDT72402 and IDT72404 have a 5 -bit data input.

## CONTROLS:

## SHIFT IN (SI)

Shift In controls the input of the data into the FIFO. When Sl is HIGH, data can be written to the FIFO via the Do-3, 4 lines.

## SHIFT OUT (SO)

Shift Out controls the output of data of the FIFO. When SO is HIGH, data can be read from the FIFO via the Data Output (Q0-3, 4) lines.

## MASTER RESET ( $\overline{M R}$ )

Master Reset clears the FIFO of any data stored within. Upon power up, the FIFO should be cleared with a Master Reset. Master Reset is active LOW.

## INPUT READY (IR)

When Input Ready is HIGH, the FIFO is ready for new input data to be written to it. When IR is LOW the FIFO is unavailable for new input data. Input Ready is also used to cascade many FIFOs together, as shown in Figures 10 and 11 in the Applications section.

## OUTPUT READY (OR)

When Output Ready is HIGH, the output (Q0-3, 4) contains valid data. When OR is LOW, the FIFO is unavailable for new output data. Output Ready is also used to cascade many FIFOs together, as shown in Figures 10 and 11.


Figure 1. AC Test Load
*Including scope and jig

## OUTPUTS:

## DATA OUTPUT (Q0-3, 4)

Data Output lines. The IDT72401 and IDT72403 have a 4bit data output. The IDT72402 and IDT72404 have a5-bit data output.

## FUNCTIONAL DESCRIPTION

These $64 \times 4$ and $64 \times 5$ FIFOs are designed using a dual port RAM architecture as opposed to the traditional shift register approach. This FIFO architecture has a write pointer, a read pointer and control logic, which allow simultaneous read and write operations. The write pointer is incremented by the falling edge of the Shift In (SI) control; the read pointer is incremented by the falling edge of the Shift Out (SO). The Input Ready (IR) signals when the FIFO has an available memory location; Output Ready (OR) signals when there is valid data on the output. Output Enable ( $\overline{\mathrm{OE}}$ ) provides the

## FIFO Reset

The FIFO must be reset upon power up using the Master Reset ( $\overline{\mathrm{MR}}$ ) signal. This causes the FIFO to enter an empty state, signified by Output Ready (OR) being LOW and Input Ready (IR) being HIGH. In this state, the data outputs (Qo-3, 4) will be LOW.

## Data Input

Data is shifted in on the LOW-to-HIGH transition of Shift In (SI). This loads input data into the first word location of the FIFO and causes Input Ready to go LOW. On the HIGH-toLOW transition of Shift In, the write pointer is moved to the next word position and Input Ready (IR) goes HIGH, indicating the readiness to accept new data. If the FIFO is full, Input Ready will remain LOW until a word of data is shifted out.

## Data Output

Data is shifted out on the HIGH-to-LOW transition of Shift Out (SO). This causes the internal read pointer to be advanced to the next word location. If data is present, valid data will appear on the outputs and Output Ready (OR) will go HIGH. If data is not present, Output Ready will stay LOW indicating the FIFO is empty. The last valid word read from the FIFO will remain at the FIFO s output when it is empty. When the FIFO is not empty, Output Ready (OR) goes LOW on the LOW-to-HIGH transition of Shift Out. Previous data remains on the output until the HIGH-to-LOW transition of Shift Out (SO).

## Fall-Through Mode

The FIFO operates in a fall-through mode when data gets shifted into an empty FIFO. After a fall-through delay the data propagates to the output. When the data reaches the output, the Output Ready (OR) goes HIGH. Fall-through mode also occurs when the FIFO is completely full. When data is shifted out of the full FIFO, a location is available for new data. After a fall-through delay, the Input Ready goes HIGH. If Shift In is HIGH, the new data can be written to the FIFO.

## TIMING DIAGRAMS



Figure 2. Input Timing


## NOTES:

1. Input Ready HIGH indicates space is available and a Shift In pulse may be applied.
2. Input Data is loaded into the first word.
3. Input Ready goes LOW indicating the first word is full.
4. The write pointer is incremented.
5. The FIFO is ready for the next word.
6. If the FIFO is full then the Input Ready remains LOW.

NOTE: Shift In pulses applied while Input Ready is LOW will be ignored (see Figure 4).
Figure 3. The Mechanism of Shifting Data into the FIFO

## TIMING DIAGRAMS (Continued)



## NOTES:

1. FIFO is initially full.
2. Shift Out pulse is applied.
3. Shift $\ln$ is held HIGH.
4. As soon as Input Ready becomes HIGH the Input Data is loaded into the FIFO.
5. The write pointer is incremented. Shift In should not go LOW until (tPT + tIPH).

Figure 4. Data is Shlfted in Whenever Shift In and Input Ready are Both HIGH


## NOTES:

1. This data is loaded consecutively A, B, C.
2. Data is shifted out when Shift Out makes a HIGH to LOW transition.

FIgure 5. Output Timing

## TIMING DIAGRAMS (Continued)



NOTES:

1. Input Ready HIGH indicates that data is available and a Shift In pulse may be applied.
2. Shift Out goes HIGH causing the next step.
3. Output Ready goes LOW.
4. The read pointer is incremented.
5. Output Ready goes HIGH indicating that new data (B) is now available at the FIFO outputs.
6. If the FIFO has only one word loaded (A DATA) then Output Ready stays LOW and the A DATA remains unchanged at the outputs.
7. Shift Out pulses applied when Output Ready is LOW will be ignored.

Figure 6. The Mechanism of Shifting Data Out of the FIFO


Figure 7. tPT and toph Specification


NOTE:

1. Worst case, FIFO initially full.

Figure 8. Master Reset Timing

TIMING DIAGRAMS (Continued)


NOTE:

1. High-Z transitions are referenced to the steady-state $\mathrm{VOH}-500 \mathrm{mV}$ and $\mathrm{VOL}+500 \mathrm{mV}$ levels on the output. thzoe is tested with 5 pF load capacitance instead of 30 pF as shown in Figure 1.

Figure 9. Output Enable Timing, IDT72403 and IDT72404 Only

## APPLICATIONS



NOTE:

1. FIFOs can be easily cascaded to any desired path. The handshaking and associated timing between the FIFOs are handled by the inherent timing of the devices.

Figure 10. $128 \times 4$ Depth Expansion


NOTES:

1. When the memory is empty, the last word will remain on the outputs until the Master Reset is strobed or a new data word falls through to the output. However, OR will remain LOW, indicating data at the output is not valid.
2. When the output data changes as a result of a pulse on SO, the OR signal always goes LOW before there is any change in output data and stays LOW until the new data has appeared on the outputs. Anytime OR is HIGH, there is valid stable data on the outputs.
3. If SO is held HIGH while the memory is empty and a word is written into the input, that word will appear at the output atter a fall-through time. OR will go HIGH for one internal cycle (at least topL) and then go back LOW again. The stored word will remain on the outputs. If more words are written into the FIFO, they will line up behind the first word and will not appear on the outputs until SO has been brought LOW.
4. When the Master Reset is brought Low, the outputs are cleared to LOW, IR goes HIGH and OR goes LOW. If SI is HIGH when the Master Reset goes HIGH, the data on the inputs will be written into the memory and IR will return to the LOW state until $\mathcal{H}$ is brought LOW. If SI is LOW when the Master Reset is ended, IR will go HIGH, but the data in the inputs will not enter the memory until SI goes HIGH.
5. FIFOs are expandable on depth and width. However, in forming wider words, two external gates are required to generate composite Input and Output Ready flags. This is due to the variation of delays of the FIFOs.

Figure 11. $192 \times 12$ Depth and Width Expansion

## ORDERING INFORMATION



## DESCRIPTION:

The IDT72413 is a $64 \times 5$, high speed First-In/First-Out (FIFO) that loads and empties data on a first-in-first-out basis. It is expandable in bit width. All speed versions are cascadable in depth.

The FIFO has a Half-Full Flag, which signals when it has 32 or more words in memory. The Almost-FulVEmpty Flag is active when there are 56 or more words in memory or when there are 8 or less words in memory.

The IDT72413 is pin and functionally compatible to the MMI67413. It operates at a shift rate of 45 MHz . This makes it ideal for use in high-speed data buffering applications. The IDT72413 can be used as a rate buffer, between two digital systems of varying data rates, in high-speed tape drivers, hard disk controllers, data communications controllers and graphics controllers.

The IDT72413 is fabricated using IDTs high-performance CEMOS process. This process maintains the speed and high output drive capability of TTL circuits in low-power CMOS.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION



## RECOMMENDED OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vcc | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{VIH}^{(1)}$ | Input High Voltage | 2.0 | - | - | V |
| VIL $^{(1)}$ | Input Low Voltage | - | - | 0.8 | V |

NOTE:
2748 \# 03

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Mlilitary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2748 thl 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 5 | pF |
| Cour | Output Capacitance | $\mathrm{VoUT}=\mathrm{OV}$ | 7 | pF |

NOTE:

1. This parameter is sampled and not $100 \%$ tested.
2. Characterized values, not currently listed.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions |  |  |  | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VIC}^{(1)}$ | Input Clamp Voltage |  |  |  |  | - | - |  |
| lil | Low-Level Input Current | Vcc = Max., GND $\leq \mathrm{V}_{1} \leq \mathrm{Vcc}$ |  |  |  | -10 | - | $\mu \mathrm{A}$ |
| liH | High-Level Input Current | $\mathrm{VcC}=$ Max., GND $\leq \mathrm{VI}^{5} \leq \mathrm{Vcc}$ |  |  |  | - | 10 | $\mu \mathrm{A}$ |
| VOL | Low-Level Output Current | $\mathrm{VCC}=$ Min. | IOL (Q0-4) | Mil. | 12 mA | - | 0.4 | V |
|  |  |  |  | Com'l. | 24 mA |  |  |  |
|  |  |  | loL (IR, OR) ${ }^{(2)}$ |  | 8 mA |  |  |  |
|  |  |  | loL (HF, AF/E) |  | 8 mA |  |  |  |
| VOH | High-Level Output Current | $\mathrm{VCC}=$ Min. | $\mathrm{IOH}(\mathrm{QO}-4)$ |  | $-4 \mathrm{~mA}$ | 2.4 | - | V |
|  |  |  | IOH (IR, OR) |  | -4mA |  |  |  |
|  |  |  | IOH (HF, AF/E) |  | $-4 \mathrm{~mA}$ |  |  |  |
| $10{ }^{(3)}$ | Output Short-Circuit Current | $V C C=M a x$. | $\mathrm{Vo}=0 \mathrm{~V}$ |  |  | -20 | -90 | mA |
| IHZ | Off-State Output Current | $\mathrm{VcC}=\mathrm{Max}$. | $\mathrm{VO}=2.4 \mathrm{~V}$ |  |  | - | 20 | $\mu \mathrm{A}$ |
| ILZ |  | $V C C=M a x . \quad V O=0.4 V$ | $V o=0.4 \mathrm{~V}$ |  |  | -20 | - |  |
| $\mathrm{ICC}^{(4)}$ | Supply Current | $\mathrm{VCC}=\mathrm{Max} ., \overline{\mathrm{OE}}=\mathrm{HIGH}$ <br> Inputs LOW, $\mathfrak{f = 2 5 M H z}$ |  | Mil. |  | - | 70 | mA |
|  |  |  |  | Com'l. |  | - | 60 |  |

## NOTES:

2748 th 04

1. FIFO is able to withstand a-1.5V undershoot for less than 10 ns .
2. Care should be taken to minimize as much as possible the DC and capactive load on IR and OR when operating at frequencies above 25 mHz .
3. Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second. Guaranteed by design, but not currently tested.
4. For frequencies greater than $25 \mathrm{MHz}, \mathrm{ICC}=60 \mathrm{~mA}+(1.5 \mathrm{~mA} \times \llbracket-25 \mathrm{MHz}])$ commercial and $I C C=70 \mathrm{~mA}+(1.5 \mathrm{~mA} \times[f-25 \mathrm{MHz}])$ military .

OPERATING CONDITIONS
(Commercial: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | Figure | Military |  | Military \& Commerclal |  | Commerelal |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | IDT72413L45 |  | IDT72413L35 |  | IDT72413L25 |  |  |
|  |  |  | Min. | Max. | Min. | , Max. | Min. | Max. |  |
| $\operatorname{tSIH}^{(1)}$ | Shift in HIGH Time | 2 | 9 | - | 9 | - | 16 | - | ns |
| tSIL ${ }^{(1)}$ | Shift in LOW TIme | 2 | 11 | - | 17 | - | 20 | - | ns |
| tIDS | Input Data Set-up | 2 | 0 | - | 0 | - | 0 | - | ns |
| tIDH | Input Data Hold Time | 2 | 13 | - | 15 | - | 25 | - | ns |
| tsor ${ }^{(1)}$ | Shift Out HIGH Time | 5 | 9 | - | 9 | - | 16 | - | ns |
| tSOL | Shift Out LOW Time | 5 | 11 | - | 17 | - | 20 | - | ns |
| tMRW | Master Reset Pulse | 8 | 20 | - | 30 | - | 35 | - | ns |
| tMRS ${ }^{(3)}$ | Master Reset Pulse to SI | 8 | 20 | - | 35 | - | 35 | - | ns |
| NOTE: |  |  |  |  |  |  |  |  | 748 bl 0 |

## NOTE:

rounding and decoupling are crucial to correct operation as the FIFO will respond to very small glitches due to long reflective lines, high capacitances and/or poor supply decoupling and grounding. A monolithic ceramic capacitor of $0.1 \mu \mathrm{~F}$ directly between VCC and GND with very short lead length is recommended.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | Figure | $\begin{gathered} \hline \text { Military } \\ \hline \text { IDT72413L45 } \end{gathered}$ |  | Military \& Commerclal |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | IDT72413L35 |  | IDT72413L25 |  |  |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| fin | Shift In Rate | 2 | - | 45 | - | 35 | - | 25 | MHz |
| $\operatorname{tIRL}^{(1)}$ | Shift In $\uparrow$ to Input Ready LOW | 2 | - | 18 | - | 18 | - | 28 | ns |
| $\operatorname{tIRH}^{(1)}$ | Shift In $\downarrow$ to Input Ready HIGH | 2 | - | 18 | - | 20 | - | 25 | ns |
| fout | Shift Out Rate | 5 | - | 45 | - | 35 | - | 25 | MHz |
| torL ${ }^{(1)}$ | Shift Out $\downarrow$ to Output Ready LOW | 5 | - | 18 | - | 18 | - | 28 | ns |
| tort ${ }^{(1)}$ | Shift Out $\downarrow$ to Output Ready HIGH | 5 | - | 19 | - | 20 | - | 25 | ns |
| tODH ${ }^{\text {(1) }}$ | Output Data Hold Previous Word | 5 | 5 | - | 5 | - | 5 | - | ns |
| tods | Output Data Shift Next Word | 5 | - | 19 | - | 20 | - | 20 | ns |
| tPT | Data Throughput or "Fall-Through" | 4,7 | - | 25 | - | 28 | - | 40 | ns |
| tMRORL | Master Reset $\downarrow$ to Output Ready LOW | 8 | - | 25 | - | 28 | - | 30 | ns |
| tMRIRH ${ }^{(3)}$ | Master Reset $\uparrow$ to Input Ready HIGH | 8 | - | 25 | - | 28 | - | 30 | ns |
| tMRIRL $^{(2)}$ | Master Reset $\downarrow$ to Input Ready LOW | 8 | - | 25 | - | 28 | - | 30 | ns |
| tMRO | Master Reset $\downarrow$ to Outputs LOW | 8 | - | 20 | - | 25 | - | 35 | ns |
| tMRHF | Master Reset $\downarrow$ to Half-Full Flag | 8 | - | 25 | - | 28 | - | 40 | ns |
| tMRAFE | Master Reset $\downarrow$ to AF/E Flag | 8 | - | 25 | - | 28 | - | 40 | ns |
| tIPH ${ }^{(3)}$ | Input Ready Pulse HIGH | 4 | 5 | - | 5 | - | 5 | - | ns |
| toph ${ }^{(3)}$ | Ouput Ready Pulse HIGH | 7 | 5 | - | 5 | - | 5 | - | ns |
| tord ${ }^{(3)}$ | Output Ready $\uparrow$ HIGH to Valid Data | 5 | - | 5 | - | 5 | - | 7 | ns |
| taEH | Shift Out $\uparrow$ to AF/E HIGH | 9 | - | 28 | - | 28 | - | 40 | ns |
| tAEL | Shift In $\uparrow$ to AF/E | 9 | - | 28 | - | 28 | - | 40 | ns |
| tAFL | Shift Out $\uparrow$ to AF/E LOW | 10 | - | 28 | - | 28 | - | 40 | ns |
| taFH | Shift In $\uparrow$ to AF/E HIGH | 10 | - | 28 | - | 28 | - | 40 | ns |
| thFH | Shift In $\uparrow$ to HF HIGH | 11 | - | 28 | - | 28 | - | 40 | ns |
| tHFL | Shif Out $\uparrow$ to HF LOW | 11 | - | 28 | 一 | 28 | - | 40 | ns |
| tPHZ ${ }^{(3)}$ | Output Disable Delay | 12 | - | 12 | - | 12 | - | 15 | ns |
| tPLZ ${ }^{(3)}$ |  | 12 | - | 12 | - | 12 | - | 15 |  |
| tPLZ ${ }^{(3)}$ | Output Enable Delay | 12 | - | 15 | - | 15 | - | 20 | ns |
| tPHZ ${ }^{(3)}$ |  | 12 | - | 15 | - | 15 | - | 20 |  |

## NOTES:

1. Since the FIFO is a very high-speed device, care must be taken in the design of the hardware and the timing utilized within the design. Device grounding and decoupling are crucial to correct operation as the FIFO will respond to very small glitches due to long reflective lines, high capacitances and/or poor supply decoupling and grounding. A monolithic ceramic capacitor of $0.1 \mu \mathrm{~F}$ directly between VCC and GND with very short lead length is recommended.
2. If the FIFO is full, (IR = HIGH), $\overline{M R} \downarrow$ forces IR to go LOW, and $\overline{M R} \uparrow$ causes IR to go HIGH.
3. Guaranteed by design but not currently tested.

AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 3ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |
| 2754 tol 08 |  |

STANDARD TEST LOAD

or equivalent circuit
*Including scope and jig


2748 dw 03

RESISTOR VALUES FOR STANDARD TEST LOAD

| IoL | R1 | R2 |
| :---: | :---: | :---: |
| 24 mA | $200 \Omega$ | $300 \Omega$ |
| 12 mA | $390 \Omega$ | $760 \Omega$ |
| 8 mA | $600 \Omega$ | $1200 \Omega$ |

Figure 1. Output Load

## DATA OUTPUT

Data is shifted out on the HIGH-to-LOW transition of Shift Out (SO). This causes the internal read pointer to be advanced to the next word location. If data is present, valid data will appear on the outputs and Output Ready (OR) will go HIGH. If data is not present, Output Ready will stay LOW indicating the FIFO is empty. The last valid word read from the FIFO will remain at the FIFOs output when it is empty. When the FIFO is not empty Output Ready (OR) goes LOW on the LOW-to-HIGH transition of Shift Out.

## FALL-THROUGH MODE

The FIFO operates in a Fall-Through Mode when data gets shifted into an empty FIFO. After the fall-through delay the data propagates to the output. When the data reaches the output, the Output Ready (OR) goes HIGH.

A Fall-Through Mode also occurs when the FIFO is completely full. When data is shifted out of the full FIFO a location is available for new data. After a fall-through delay, the Input Ready goes HIGH. If Shift In is HIGH, the new data can be written to the FIFO. The fall-through delay of a RAMbased FIFO (one clock cycle) is far less than the delay of a Shift register-based FIFO.

## SIGNAL DESCRIPTIONS:

## INPUTS:

## DATA INPUT (D0-4)

Data input lines. The IDT72413 has a 5 -bit data input.

## CONTROLS:

SHIFT IN (SI)
Shift In controls the input of the data into the FIFO. When SI is HIGH , data can be written to the FIFO via the DO-4 lines. The data has to meet set-up and hold time requirements with respect to the rising edge of S .

## SHIFT OUT (SO)

Shift Out controls the outputs data from the FIFO.

## MASTER RESET ( $\overline{\mathrm{MR}}$ )

Master Reset clears the FIFO of any data stored within. Upon power up, the FIFO should be cleared with a Master Reset. Master Reset is active LOW.

## HALF-FULL FLAG (HF)

Half-Full Flag signals when the FIFO has 32 or more words in it.

## INPUT READY(IR)

When Input Ready is HIGH, the FIFO is ready for new input data to be written to it. When IR is LOW, the FIFO is unavailable for new input data, Input Ready is also used to cascade many FIFOs together, as shown in Figure 13 in the Applications section.

## OUTPUT READY (OR)

When Output Ready is HIGH, the output ( $\mathrm{CO}_{\mathrm{O}}-4$ ) contains valid data. When OR is LOW, the FIFO is unavailable for new output data. Output Ready is also used to cascade many FIFOs together, as shown in Figure 13 in the Applications section.

## OUTPUT ENABLE ( $\overline{O E}$ )

Output Enable is used to enable the FIFO outputs onto a bus. Output Enable is active LOW.

## ALMOST-FULL/EMPTY FLAG (AFE)

Almost-Full/Empty Flag signals when the FIFO is $7 / 8$ full ( 56 or more words) or $1 / 8$ from empty ( 8 or less words).

## OUTPUTS: <br> DATA OUTPUT (Q0-4)

Data output lines, three-state. The IDT72413 has a 5 -bit output.

## TIMING DIAGRAMS



Figure 2. Input Timing

## TIMING DIAGRAMS (Continued)



## NOTES:

1. Input Ready HIGH indicates space is available and a Shift in pulse may be applied.
2. Input Data is loaded into the FIFO.
3. Input Ready goes LOW indicating the FIFO is unavailable for new data.
4. The write pointer is incremented.
5. The FIFO is ready for the next word.
6. If the FIFO is full, then the Input Ready remains LOW.
7. Shift In pulses applied while Input Ready is LOW will be Ignored (see Figure 4).

Figure 3. The Machanism of Shifting Data Into the FIFO


Figure 4. Data Is Shifted In Whenever Shift In and Input Ready are Both HIGH

TIMING DIAGRAMS (Continued)


NOTES:

1. This data is loaded consecutively A, B, C.
2. Output data changes on the falling edge of $S O$ after a valid Shift Out sequence, i.e., OR and $S O$ are both high together.

Figure 5. Output TIming


## NOTES:

1. Output Ready HIGH indicates that data is available and a Shift Out pulse may be applied.
2. Shift Out goes HIGH causing the next step.
3. Output Ready goes LOW.
4. Read pointer is incremented.
5. Output Ready goes HIGH indicating that new data (B) will be available at the FIFO outputs after torD ns.
6. If the FIFO has only one word loaded (A DATA), Output Ready stays LOW and the A-DATA remains unchanged at the outputs.
7. Shift Out pulses applied when Output Ready is LOW will be ignored.

Figure 6. The Mechanism of Shifiling Data Out of the FIFO
timing diagrams (Continued)


NOTE:

1. FIFO initailly empty.

Figure 7. tPT and toph Specification


## NOTE:

1. FIFO is partially full.

Figure 8. Master Reset Timing

## TIMING DIAGRAMS (Continued)



NOTE

1. FIFO contains 9 words (one more than Almost-Empty).

Figure 9. taeh and tael Specifications


NOTE:

Figure 10. tafh and tafl. Speciflcations


Figure 11. thFL and thFH Specifications


NOTES:
2748 dmw 14

1. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control.
2. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.

Figure 12. Enable and Disable

## APPLICATIONS



NOTE:

1. FIFOs are expandable in width. However, in forming wider words two external gates are required to generate composite Input and Output Ready flags. This requirement is due to the different fall-through times of the FIFOs.

Figure 13. $\mathbf{6 4 \times 1 5} \mathbf{~ F I F O}$ with IDT72413


2748 drw 16
NOTE:

1. Cascading the FIFOs in word width is done by ANDing the IR and OR as shown in Figure 13.

Figure 14. Application for IDT72413 for Two Asynchronous Systems


NOTE:

1. FIFOs can be easily cascaded to any desired depth. The handshaking and associated timing between the FIFOs are handled by the inherent timing of the devices.

Figure 15. $128 \times 5$ Depth Expansion

## ORDERING INFORMATION



6

# BUS-MATCHING <br> BIDIRECTIONAL FIFO <br> $512 \times 18$-BIT - $1024 \times 9$-BIT 

IDT7251
IDT7252

## FEATURES:

- Two side-by-side FIFO memory arrays for bidirectional data transfers
- $512 \times 18$ - Bit $-1024 \times 9$ - Bit (IDT7251, IDT72510)
- $1024 \times 18$ - Bit $-2048 \times 9$ - Bit (IDT7252, IDT72520)
- 18 bit data bus on Port A side and 9 bit data bus on Port $B$ side
- Can be configured for 18-to-9-bit, 36-to-9-bit, or 36-to-18bit communication
- Fast 35 ns access time
- Fully programmable standard microprocessor interface
- Built-in bypass path for direct data transfer between two ports
- Two fixed flags, Empty and Full, for both the A-to-B and the B-to-A FIFO
- Two programmable flags, Almost-Empty and Almost-Full for each FIFO
- Programmable flag offset can be set to any depth in the FIFO
- Any of the eight internal flags can be assigned to four external flag pins
- Flexible reread/rewrite capabilities.
- On-chip parity checking and generation
- Standard DMA control pins for data exchange with peripherals
- IDT7251 and IDT7252 available in 48 -pin plastic or ceramic DIP
- IDT72510 and IDT72520 available in 52-pin PLCC packages (includes LDRER, LDREW, RESET, and one extra GND pin)


## DESCRIPTION:

The IDT7251, IDT72510, IDT7252, and IDT72520 are highly integrated first-in, first-out memories that enhance processor-to-processor and processor-to-peripheral communications. IDT BiFIFOs integrate two side-by-side memory arrays for data transfers in two directions.

The BiFIFOs have two ports, A and B , that both have standard microprocessor interfaces. All BiFIFO operations are controlled from the 18 -bit wide Port A. The BiFIFOs incorporate bus matching logic to convert the 18 -bit wide memory data paths to the 9 -bit wide Port B data bus. The BiFIFOs have a bypass path that allows the device connected to Port A to pass messages directly to the Port B device.

Ten registers are accessible through Port A, a Command Register, a Status Register, and eight Configuration Registers.

The IDT BiFIFOs have programmable flags. Each FIFO memory array has four internal flags, Empty, Almost-Empty, Almost-Full and Full, for a total of eight internal flags. The Almost-Empty and Almost-Full flag offsets can be set to any depth through the Configuration Registers. These eight internal flags can be assigned to any of four external flag pins (FLGA-FLGD) through one Configuration Register.

Port B has parity, reread/rewrite and DMA functions. Parity generation and checking can be done by the BiFIFO on data passing through Port B. The Reread and Rewrite controls will read or write Port B data blocks multiple times. The BiFIFOs have three pins, REQ, ACK and CLK, to control DMA transfers from Port $B$ devices.

- Military product compliant to MIL-STD-883, Class B


## SIMPLIFIED BLOCK DIAGRAM



## PIN CONFIGURATIONS




PLCC
TOP VIEW

## PIN DESCRIPTIONS

| Symbol | Name | 10 | Description |
| :---: | :---: | :---: | :---: |
| Dao-Dat5 | Data A | 1/0 | Data inputs and outputs for 16 bits of the 18-bit Port A bus. |
| Da1G-Da17 | Parity A | 1/0 | Da16 is the parity bit for Da0-DA7. Da17 is the parity bit for DagDA15. DA16 and DA17 can be used as wwo extra data bits if the parity generate function is disabled. |
| CSA | Chip Select A | 1 | Port $A$ is accessed when Chip Select $A$ is LOW. |
| $\overline{\text { DSA }}$ | Data Strobe A | 1 | Data is written into Port A on the rising edge of Data Strobe when Chip Select is LOW. Data is read out of Port A on the falling edge of Data Strobe when Chip Select is LOW. |
| R/WA | Read/Write A | 1 | This pin controls the read or write direction of Port A. When CSA is LOW and R/W ${ }_{\text {A }}$ is HIGH, data is read from Port A on the falling edge of DSA. When CSA is LOW and R/WA is LOW, data is written into Port A on the falling edge of DSA. |
| Ao, Al | Addresses | 1 | When Chip Select $A$ is asserted, $A_{0}, A_{1}$, and Read/Write $A$ are used to select one of six internal resources. |
| Deo-Db7 | Data 8 | $1 / 0$ | Data inputs \& outputs for 8 bits of the 9-bit Port B bus. |
| D88 | Parity B | $1 / 0$ | D88 is the parity bit for D80-D87. Des can be used as a data bit if the parity generate function is disabled. |
| $\overline{\mathrm{Fa}}$ (DSB) | Read B | I or 0 | If Port $B$ is programmed to processor mode, this pin functions as an input. If Port $B$ is programmed to peripheral mode this pin functions as an output. This pin can function as part of an Intel-style interface ( $\overline{\mathrm{F}} \mathrm{B}$ ) or as part of a Motorola-style interface ( DSB ). As an Intel-style interface, data is read from Port B on a falling edge of FB. As a Motorola-style interface, data is read on the falling edge of $\overline{D S B}$ or written on the rising edge of BSs through Port B. The Default is Intel-style processor mode (FB as an input). |
| $\bar{W}\left(\mathrm{R} / \mathrm{W}_{\mathrm{B}}\right)$ | Write B | I or 0 | If Port B is programmed to processor mode, this pin functions as an input. If Port B is programmed to peripheral mode this pin functions as an output. This pin can function as part of an Intel-style interface (W8) or as part of a Motorola-style interface ( $\mathrm{R} / \mathrm{WB}$ ). As an Intel-style interface, data is written to Port B on a rising edge of WB. As a Motorola-style interface, data is read ( $\mathrm{R} / \mathrm{W}_{3}=\mathrm{HIGK}$ ) or written ( $\mathrm{R} / \overline{\mathrm{W}}=\mathrm{LOW}$ ) to Port B in conjunction with a Data Strobe B falling or rising edge. The Default is Intel-style processor mode (WB as an input). |
| RER | Reread | 1 | Loads $\mathrm{A} \rightarrow \mathrm{B}$ FIFO Read Pointer with the value of the Reread Pointer when LOW. |
| REW | Rewrite | 1 | Loads B $\rightarrow$ A FIFO Write Pointer with the value of the Rewrite Pointer when LOW. |
| LDRER | Load Reread | 1 | Loads the Reread Pointer with the value of the $\mathrm{A} \rightarrow \mathrm{B}$ FIFO Read Pointer when HIGH. This signal is a pin on the IDT72510/520; it is accessible through the Command Register on all four parts. |
| LDREW | Load Rewrite | 1 | Loads the Rewrite Pointer with the value of the B $\rightarrow \mathrm{A}$ FIFO Write Pointer when HIGH. This signal is a pin on the IDT72510/520; it is accessible through the Command Register on all four parts. |
| REQ | Request | 1 | When Port B is programmed in peripheral mode, asserting this pin begins a data transfer. Request can be programmed either active HIGH or active LOW. |
| ACK | Acknowledge | 0 | When Port B is programmed in peripheral mode, Acknowledge is asserted in response to a Request signal. This confirms that a data transfer may begin. Acknowledge can be programmed either active HIGH or active LOW. |
| CLK | Clock | 1 | This pin is used to generate timing for $A C K, \bar{F}_{B}, \bar{W}_{B}, \overline{D S B}$ and $\mathrm{R} / \bar{W}_{B}$ when Port B is in the peripheral mode. |
| FLGA-FLGD | Flags | 0 | These four outputs pins can be assigned any one of the eight internal flags in the BiFIFO. Each of the two internal FIFOs $(A \rightarrow B$ and $B \rightarrow A)$ has four internal flags: Empty, Almost-Empty, Almost-Full, and Full. If parity checking is enabled, the FLGA pin can also be assigned as a parity error output. |
| $\overline{\mathrm{RS}}$ | Reset | I | A LOW on this pin will perform a reset of all BiFIFO functions. Hardware reset pin is only available for IDT72510/72520. Software reset can be achieved through command register for all four devices. |
| Vcc | Power |  | There are two +5 V power pins on all four devices. |
| GND | Ground |  | There are three Ground pins at OV for the IDT7251/52. There are four ground pins for the IDT72510/520. |



NOTES:
(") Can be programmed either active high or active low in internal configuration registers.
$(\dagger)$ Available as a pin on the IDT72510/520. Accessible on all parts through internal registers.
$(t \dagger)$ Can be programmed through an internal configuration register to be either an input or an output.

## FUNCTIONAL DESCRIPTION

IDT's BiFIFO family is versatile for both multiprocessor and peripheral applications. Data can be sent through both FIFO memories concurrently, thus freeing both processors from laborious direct memory access (DMA) protocols and frequent interrupts.

Two full 18 -bit wide FIFOs are integrated into the IDT BiFIFO, making simultaneous data exchange possible. Each FIFO is monitored by separate internal read and write pointers, so communication is not only bidirectional, it is also totally independent in each direction. The processor connected to Port A of the BiFIFO can send or receive messages directly to the Port B device using the BiFIFO's 9-bit bypass path.

The BiFIFOs can be used in three different bus configurations: 18 bits to 9 bits, 36 bits to 9 bits and 36 bits to 18 bits. One BiFIFO can be used for the 18 - to 9 -bit configuration, and two BiFIFOs are required for 36 - to 9 -bit or 36 - to 18 -bit configurations. Bits 11 and 12 of Configuration Register 5 determine the BiFIFO configuration (see Table 11 for Configuration Register 5 format).

The microprocessor or microcontroller connected to Port A controls all operations of the BiFIFÓs. Thus, all Port A interface pins are inputs driven by the controlling processor. Port B can be programmed to interface either with a second processor or a peripheral device. When Port B is programmed in processor interface mode, the Port B interface pins are inputs driven by the second processor. If a peripheral device is connected to the BiFIFOs, Port B is programmed to peripheral interface mode and the interface pins are outputs.

## 18- to 9-bit Configurations

A single BiFIFO can be configured to connect an 18-bit processor to another 9 -bit processor or a 9 -bit peripheral. Bits 11 and 12 of Configuration Register 5 should be set to 00 for a stand-alone configuration. Figures 1 and 2 show the BiFIFO in 18- to 9 -bit configurations for processor and peripheral interface modes respectively.

## 36- to 9-blt Configurations

Two BiFIFOs can be hooked together to create a 36 -bit to 9 -bit configuration. This means that a 36 -bit processor can talk to a 9 -bit processor or a 9 -bit peripheral. Both BiFIFOs are programmed simultaneously through Port A by placing one command word on the most significant 16 data bits and one command word on the least significant 16 data bits (parity bits should be ignored).

One BiFIFO must be programmed as the master device and the other BiFIFO is the slave device. Bits 11 and 12 of Configuration Register 5 are set to 10 for the slave device and 11 for the master device. The first two 9 -bit words on Port B are read from or written to the slave device and the next two 9 -bit words go to the master device.

When both BiFIFOs are in peripheral interface mode, the Port B interface pins of the master device are outputs and this BiFIFO controls the bus. The Port B interface pins of the slave device are inputs driven by the master BifiFO. Two BiFIFOs are connected in Figure 4 to create a 36- to 9 -bit peripheral interface.

The two BiFIFOs shown in Figure 3 are configured to connect a 36 -bit processor to a 9 -bit processor.

## 36-BIT PROCESSOR to 18-BIT PROCESSOR CONFIGURATION



NOTE:
Figure 1. 36- to 18-Bit Processor Interface Conflguration

1. Upper BifIFO only is used in 18 - to 9 -bit configuration. Note that $C$ nt/ $A$ refers to $\overline{C_{S}} A, A 1, A 0, R \bar{W} A$ and $\overline{\mathrm{DS}} A ; C n t / B$ refers to $R \bar{W} B$ and $\overline{\mathrm{DS} B}$ or $\bar{R} B$ and $\bar{W} B$.

## 36-BIT PROCESSOR to 18 -BIT PERIPHERAL CONFIGURATION



Figure 2. 36- to 18-Bit Perlpheral Interface Configuration
NOTE:

1. Upper BiFIFO only is used in 18- to 9-bit configuration. Note that Cnt/ $A$ refers to $\overline{\mathrm{CS}} \mathrm{A}, \mathrm{A} 1, \mathrm{~A}, \mathrm{R} / \overline{\mathrm{W} A}$ and $\overline{\mathrm{DS}} \mathrm{A}$; Cnt/ $B$ refers to R/信B and $\overline{\mathrm{DS}} \mathrm{B}$ or $\bar{R} B$ and $\bar{W} B$.

## 36- to 18-bit Configurations

In a 36- to 18 -bit configuration, two BiFIFOs operate in parallel. Both BiFIFOs are programmed simultaneously, 16 data bits to each device with the 4 parity bits ignored.

Both BiFIFOs must be programmed into stand-alone mode for a 36-bit processor to communicate with an 18-bit processor or an 18-bit peripheral. This means that bits 11 and 12 of Configuration Register 5 must be set to 00 .

This configuration can be extended to wider bus widths (54- to 27-bits, 72 - to 36 -bits, ...) by adding more BiFIFOs to the configuration. Figures 1 and 2 show multiple BiFIFOs configured for processor and peripheral interface modes respectively.

## Processor Interface Mode

When a microprocessor or microcontroller is connected to Port B , all BiFIFOs in the configuration must be programmed to processor interface mode. In this mode, all Port B interface controls are inputs. Both REQ and CLK pins should be pulled LOW to ensure that the set-up and hold time requirements for these pins are met during reset. Figures 1 and 3 show BiFIFOs in processor interface mode.

## Peripheral Interface Mode

If Port B is connected to a peripheral controller, all BiFIFOs in the configuration must be programmed in the peripheral interface mode. To assure fixed high states for $\bar{R} B$ and $\bar{W}_{B}$ before they are programmed into an output, both pins should
be pulled-up to Vcc with 10K resistors.
If the BiFIFOs are in stand-alone configuration mode (18-to 9-bit, 36 - to 18-bit, ...), then the Port B interface pins are all outputs. Of course, only one set of Port B interface pins should be used to control a single peripheral device, while the other interface pins are all ignored. Figure 2 shows standalone configuration BiFIFOs connected to a peripheral.

In a 36- to 9 -bit configuration, the master device controls the bus. The Port $B$ interface pins of the master device are outputs and the interface pins of the slave device are inputs. A 36- to 9-bit configuration of two BiFIFOs connected to a peripheral is shown in Figure 4.

## Port A Interface

The BiFIFO is straightforward to use in microprocessorbased systems because each BiFIFO port has a standard microprocessor control set. Port $A$ has access to six resources: the $\mathrm{A} \rightarrow$ B FIFO, the $\mathrm{B} \rightarrow \mathrm{A}$ FIFO, the 9 -bit direct data bus (bypass path), the configuration registers, status and command registers. The Port A Address and Read/Write pins determine the resource being accessed as shown in Table 1. Data Strobe is used to move data in and out of the BiFIFO.

When either of the internal FIFOs are accessed 18 bits of data are transferred across Port A. Since the bypass path is only 9 bits wide, the least significant byte with parity (DaO-DA7, DA16) is used on Port A. All of the registers are 16 bits wide which means only the data bits (Da0-DA15) are passed by Port A.

## 36-BIT PROCESSOR to 9-BIT PROCESSOR CONFIGURATION



Figure 3. 36- to 9-Bit Processor Interface Configuration
NOTE:

1. Cnt/ $A$ refers to $\overline{C S} A, A 1, A 0, R / \bar{W} A$ and $\overline{D S A} ; C n t / B$ refers to $R / \bar{W} B$ and $\overline{D S} B$ or $\bar{R} B$ and $\bar{W} B$.

## 36-BIT PROCESSOR to 9-BIT PERIPHERAL CONFIGURATION



Figure 4. 36- to 9-Bit Peripheral Interface Configuration
NOTE:

1. Cnt/ $A$ refers to $\overline{C S} A, A 1, A 0, R / \bar{W} A$ and $\overline{\mathrm{DS}} \mathrm{A} ;$ Cnt/ $B$ refers to $\mathrm{R} \overline{\mathrm{W}} \mathrm{B}$ and $\overline{\mathrm{DS}} \mathrm{B}$ or $\overline{\mathrm{R}} \mathrm{B}$ and $\overline{\mathrm{W}} \mathrm{B}$.

## PORT A RESOURCES

| $\overline{C S} A$ | $\mathbf{A}_{1}$ | $\mathbf{A D}_{0}$ | Read | Write |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | B $\rightarrow$ A FIFO | A $\rightarrow$ B FIFO |
| 0 | 0 | 1 | 9-bit Bypass Path | 9-bit Bypass Path |
| 0 | 1 | 0 | Configuration <br> Registers | Configuration <br> Registers |
| 0 | 1 | 1 | Status Register | Command Register |
| 1 | X | X | Disabled | Disabled |

2669 Tbl 02
Table 1. Accessing Port A Resources Using © $\overline{C S A}, A 0$, and $A 1$

## Bypass Path

The bypass path acts as a bidirectional bus transceiver directly between Port A and Port B. The direct connection requires that the Port A interface pins are inputs and the Port B interface pins are outputs. The bypass path is 9 bits wide in an 18 - to 9 -bit configuration or in a 36 - to 9 -bit configuration. Only in the 36 - to 18 -bit configuration is the bypass path 18 bits wide.

During bypass operations; the BiFIFOs must be programmed into peripheral interface mode. Bit 10 of Configuration Register 5 (see Table 11) is set to 1 for peripheral interface mode. In a 36- to 9 -bit configuration, both Port B data buses will be active. Data written into Port A will appear on both master and slave Port B buses concurrently. To avoid Port B bus contention, the data on DA0-DA7 and DA16 of both BiFIFOs should be exactly the same. Data read from Port A will appear on pins DA0-DA7 and DA16 of both BiFIFOs within the same 36bit word.

## Command Register

Ten registers are accessible through Port A, a Command Register, a Status Register, and eight Configuration Registers.

The Command Register is written by setting $\overline{\mathrm{CS}} \mathrm{A}=0$, $\mathrm{A}_{1}=1, \mathrm{~A}_{0}=1$. Commands written into the BiFIFO have a 4 -bit opcode (bit 8 - bit 11) and a 3 -bit operand (bit 0 - bit 2) as shown in Figure 5. The commands can be used to reset the BiFIFO, to select the Configuration Register, to perform intelligent reread/rewrite, to set the Port B DMA direction, to set the Status Register format, to modify the Port B Read and Write Pointers, and to clear Port B parity errors. The command opcodes are shown in Table 2.

The reset command initializes different portions of the BiFIFO depending on the command operand. Table 3 shows the reset command operands.

The Configuration Register address is set directly by the command operands shown in Table 4.

Intelligent reread/rewrite is performed by changing the Port B Read Pointer with the Reread Pointer or by changing the

## COMMAND OPERATIONS

| Command <br> Opcode | Function |
| :---: | :--- |
| 0000 | Reset BiFIFO (see Table 3) |
| 0001 | Select Configuration Register (see Table 4) |
| 0010 | Load Reread Pointer with Read Pointer Value |
| 0011 | Load Rewrite Pointer with Write Pointer Value |
| 0100 | Load Read Pointer with Reread Pointer Value |
| 0101 | Load Write Pointer with Rewrite Pointer Value |
| 0110 | Set DMA Transfer Direction (see Table 5) |
| 0111 | Set Status Register Format (see Table 6) |
| 1000 | Increment in byte for A $\rightarrow$ B FIFO Read Pointer <br> (Port B) |
| 1001 | Increment in byte for B $\rightarrow$ A FIFO Write Pointer <br> (Port B) |
| 1010 | Clear Write Parity Error Flag |
| 1011 | Clear Read Parity Error Flag |

Table 2. Functions Performed by Port A Commands
Port B Write Pointer with the Rewrite Pointer. No command operands are required to perform a reread/rewrite operation.

When Port B of the BiFIFO is in peripheral mode, the DMA direction is controlled by the Command Register. Table 5 shows the Port B read/write DMA direction operands.

The BiFIFO supports two Status Register formats. Status Register format 1 gives all the internal flag status, while Status Register format 0 provides the data in the Odd Byte Register. Table 6 gives the operands for selecting the appropriate Status Register format. See Table 8 for the details of the two Status Register formats.

Two commands are provided to increment the Port B Read and Write Pointers in case reread/rewrite is performed. Incrementing the pointers guarantees that pointers will be on a word boundary when an odd number of bytes is transmitted through PortB. Nooperands are required for these commands.
When parity check errors occur on Port B, a clear parity error command is needed to remove the parity error. There are no operands for these commands.

## Reset

The IDT72510 and IDT72520 have a hardware reset pin ( $\overline{\mathrm{RS}}$ ) that resets all BiFIFO functions. A hardware reset requires the following four conditions: $\overline{\mathrm{R}} \mathrm{B}$ and $\overline{\mathrm{W}} \mathrm{B}$ must be HIGH, $\overline{\text { RER }}$ and $\overline{\text { REW }}$ must be HIGH, LDRER and LDREW must be LOW, and $\overline{\mathrm{DS}}$ A must be HIGH (Figure 9). After a hardware reset, the BiFIFO is in the following state: Configuration Registers $0-3$ are $\mathbf{0 0 0 0} \mathrm{H}$, Configuration Register 4 is set

## COMMAND FORMAT



Figure 5. Format for Commands Written Into Port A

## RESET COMMAND FUNCTIONS

| Reset <br> Operands | Function |
| :---: | :--- |
| 000 | No Operation |
| 001 | Reset B $\rightarrow$ A FIFO (Read, Write, and Rewrite <br> Pointers $=0$ ) |
| 010 | Reset A $\rightarrow$ B FIFO (Read, Write, and Reread <br> Pointers $=0$ ) |
| 011 | Reset B $\rightarrow$ A and A $\rightarrow$ B FIFO |
| 100 | Reset Internal DMA Request Circuitry |
| 101 | No Operation |
| 110 | No Operation |
| 111 | Reset All |

Table 3. Reset Command Functions
to $\mathbf{6 4 2 0 H}$, and Configuration Registers 5 and 7 are 0000 H . Additionally, Status Register format 0 is selected, all the pointers including the Reread and Rewrite Pointers are set to 0 , the odd byte register valid bit is cleared, the DMA direction is set to $B \rightarrow A$ write, the internal DMA request circuitry is cleared (set to its initial state), and all parity errors are cleared.

A software reset command can reset $A \rightarrow B$ pointers and the $B \rightarrow A$ pointers to 0 independently or together. The request (REQ) DMA circuitry can also be reset independently. A software Reset All command resets all the pointers, the DMA request circuitry, and sets all the Configuration Registers to their default condition. Note that a hardware reset is NOT the same as a software Reset All command. Table 7 shows the BiFIFO state after the different hardware and software resets.

SELECT CONFIGURATION REGISTER COMMAND FUNCTIONS

| Operands | Function |
| :---: | :--- |
| 000 | Select Configuration Register 0 |
| 001 | Select Configuration Register 1 |
| 010 | Select Configuration Register 2 |
| 011 | Select Configuration Register 3 |
| 100 | Select Configuration Register 4 |
| 101 | Select Configuration Register 5 |
| 110 | Select Configuration Register 6 |
| 111 | Select Configuration Register 7 |

2669 bl06
Table 4. Select Configuration Register Command Functions.
DMA DIRECTION COMMAND FUNCTIONS

| Operands | Functlon |
| :---: | :--- |
| $X X 0$ | Write B $\rightarrow$ A FIFO |
| $X X 1$ | Read A $\rightarrow$ B FIFO |

Table 5. Set DMA Direction Command Functions. Command Only Operates In Perlpheral Interface Mode

STATUS REGISTER FORMAT COMMAND FUNCTIONS

| Operands | Function |
| :---: | :--- |
| $X X 0$ | Status Register Format 0 |
| $X X 1$ | Status Register Format 1 |

Table 6. Command Functlons to Set the Status Register Format

## STATE AFTER RESET

|  | Hardware Reset | Software Reset |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ( $\overline{\mathrm{RS}}$ asserted, IDT72510 \& IDT72520 only) | $B \rightarrow A(001)$ | $A \rightarrow B(010)$ | $\begin{gathered} B \rightarrow A \text { and } \\ A \rightarrow B(011) \end{gathered}$ | Internal Request (100) | All (111) |
| Configuration Registers 0-3 | 0000H | - | - | - | - | 0000H |
| Configuration Register 4 | 6420 H | - | - | - | - | 6420 H |
| Configuration Register 5 | 0000H | - | - | - | - | 0000 H |
| Configuration Register 7 | 0000 H | - | - | - | 一 | 0000 H |
| Status Register format | 0 | - | - | - | - | - |
| $\mathrm{B} \rightarrow \mathrm{A}$ Read, Write, Rewrite Pointers | 0 | 0 | - | 0 | - | 0 |
| $\mathrm{A} \rightarrow \mathrm{B}$ Read, Write, Reread Pointers | 0 | - | 0 | 0 | - | 0 |
| Odd byte register valid bit | clear | clear | - | clear | - | clear |
| DMA direction | $B \rightarrow A$ write | - | - | - | - | - |
| DMA internal request | clear | - | - | - | clear | clear |
| Parity errors | clear | - | - | - | - | - |

Table 7. The BIFIFO State After a Reset Command

## Status Register

The Status Register reports the state of the programmable flags, the DMA read/write direction, the Odd Byte Register valid bit, and parity errors. The Status Register is read by setting $\overline{C S}_{A}=0, A 1=1, A 0=1$ (see Table 1).

There are two Status Register formats that are set by a Status Register format command. Format 0 stores the Odd Byte Register data in the lower eight bits of the Status Register, while format 1 reports the flag states and the DMA read/write direction in the lower eight bits. The upper eight bits are identical for bothformats. The flag states, the parity errors, the Odd Byte Register valid bit, and the Status Register format are all in the upper eight bits of the Status Register. See Table 8 for both Status Register formats.

## Configuration Registers

The eight Configuration Register formats are shown in Table 9. Configuration Registers 0-3 contain the programmable flag offsets for the Almost Empty and Almost Full flags. These offsets are set to 0 when a hardware reset or a software reset all is applied. Note that Table 9 shows that Configuration Registers $0-3$ are 10 bits wide to accommodate the 1024 locations in each FIFO memory of the IDT7252/520. Only 9 least significant bits are used for the 512 locations of the IDT7251/510; the most significant bit, bit 9 , must be set to 0 .

Configuration Register 4 is used to assign the internal flags to the external flag pins (FLGA-FLGD). Each external flag pin is assigned an internal flag based on the four bit codes shown in Table 10. The default condition for Configuration Register 4 is 6420 H as shown in Table 7. The default flag assignments are: FLGD is assigned $B \rightarrow A$ Full, $F L G c$ is assigned $B \rightarrow A$ Empty, FLGB is assigned $A \rightarrow B$ Full, FLGA is assigned $A \rightarrow B$ Empty.

## STATUS REGISTER FORMAT 0

| Bit | Signal |
| :---: | :---: |
| 0 | Odd Byte Register |
| 1 |  |
| 2 |  |
| 3 |  |
| 4 |  |
| 5 |  |
| 6 |  |
| 7 |  |
| 8 | Valid Bit |
| 9 | Write Parity Error |
| 10 | Read Parity Error |
| 11 | Status Register Format $=0$ |
| 12 | A $\rightarrow$ B Full Flag |
| 13 | A $\rightarrow$ B Almost-Full Flag |
| 14 | $\mathrm{B} \rightarrow \mathrm{A}$ Empty Flag |
| 15 | B $\rightarrow$ A Almost-Empty Flag |

Configuration Register 5 is a general control register. The format of Configuration Register 5 is shown in Table 11. Bit 0 sets the Intel-style interface ( $\overline{\mathrm{R}} \mathrm{B}, \bar{W}_{B}$ ) or Motorola-style interface ( $\overline{\mathrm{DS}} \mathrm{B}, \mathrm{R} / \overline{\mathrm{W}} \mathrm{B}$ ) for Port B . Bit 1 changes the byte order for data coming through Port B. Bits 2 and 3 redefine Full and Empty Flags for reread/rewrite data protection.

Bits 4-9 control the DMA interface and are only applicable in peripheral interface mode. In processor interface mode, these bits are don't care states. Bits 4 and 5 set the polarity of the DMA control pins REQ and ACK, respectively. An internal clock controls all DMA operations. This internal clock is derived from the extemal clock (CLK). Bit 9 determines the internal clock frequency: the internal clock = CLK or the internal clock $=$ CLK divided by 2 . Bit 8 sets whether $\bar{R}_{B}, \bar{W}_{B}$, and $\overline{\mathrm{DSB}}$ are asserted for either one or two internal clocks. Bits 6 and 7 set the number of internal clocks between REQ assertion and ACK assertion. The timing can be from 2 to 5 cycles as shown in Figure 17.

Bit 10 controls Port B processor or peripheral interface mode. In processor mode, the Port B control pins ( $\bar{R} B, \bar{W} B$, $\overline{\mathrm{DS}} \mathrm{B}, \mathrm{R} \overline{\mathrm{W}} \mathrm{B}$ ) are inputs and the DMA controls are ignored. In peripheral mode, the Port $B$ control pins are outputs and the DMA controls are active.

Bits 11 and 12 set the width expansion mode. For 18- to 9 -bit configurations or 36 - to 18 -bit configurations, the BiFIFO should be set in stand-alone mode. For a 36- to 9-bit configuration, one BiFIFO must be in slave mode and the other Bi FIFO must be in master mode. The master BiFIFO allows the first two bytes transferred across Port B to go to the slave BiFIFO, then the next two bytes go to the master BiFIFO.

Configuration Register 7 controls the parity functions of Port B as shown in Table 12. Either parity generation or parity

## STATUS REGISTER FORMAT 1

| Bit | Signal |
| :---: | :--- |
| 0 | Reserved |
| 1 | Reserved |
| 2 | Reserved |
| 3 | DMA Direction |
| 4 | A $\rightarrow$ B Empty Flag |
| 5 | A $\rightarrow$ B Almost-Empty Flag |
| 6 | B $\rightarrow$ A Full Flag |
| 7 | B $\rightarrow$ A Almost-Full Flag |
| 8 | Valid Bit |
| 9 | Write Parity Error |
| 10 | Read Parity Error |
| 11 | Status Register Format $=1$ |
| 12 | A $\rightarrow$ B Full Flag |
| 13 | A $\rightarrow$ B Almost-Full Flag |
| 14 | B $\rightarrow$ A Empty Flag |
| 15 | B $\rightarrow$ A Almost-Empty Flag |

Table 8. The Two Status Reglster Formats

## CONFIGURATION REGISTER FORMATS



## NOTE:

1. Bit 9 of Configuration Registers $0-3$ must be set to 0 on the IDT7251 and IDT72510.

Table 9. The BIFIFO Configuration Register Formats
checking is enabled for data read and written through Port B . Bit 8 controls parity checking and generation for $B \rightarrow A$ write data. Bit 9 controls parity checking and generation for $A \rightarrow B$ read data. Bit 10 controls whether the parity is odd or even. Bit 11 is used to assign the internal parity checking error to the FLGA pin. When the parity error is assigned to FLGA, the Configuration Register 4 flag assignment for FLGA is ignored.

## Programmable Flags

The IDT BiFIFO has eight internal flags; four of these flags have programmable offsets, the other four are empty or full. Associated with each FIFO memory array are four internal flags, Empty, Almost-Empty, Almost-Full and Full, for the total of eight internal flags. The Almost-Empty and Almost-Full offsets can be set to any depth through the Configuration Registers 0-3 (see Table 9). The offset (or depth) of FIFO RAM array is based on the unit of an 18-bit word. The flags are asserted at the depths shown in Table 13. After a hardware reset or a software reset all, the almost flag offsets are set to 0 . Even though the offsets are equivalent, the Empty and AI-most-Empty flags have different timing which means that the flags are not coincident. Similarly, the Full and Almost-Full flags are not coincident because of timing.

These eight internal flags can be assigned to any of four external flag pins (FLGA-FLGD) through Configuration Register 4 (see Table 10). For the specific flag timings, see Figures 20-23.

The current state of all eight flags is available in the Status Register in Status Register format 1. InStatus Register format 0 , only four flags can be found in the Status Register (see Table 8).

EXTERNAL FLAG ASSIGNMENT CODES

| Assignment <br> Code | Internal Flag Assigned to Flag Pin |
| :--- | :--- |
| 0000 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Empty }}$ |
| 0001 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Almost-Empty }}$ |
| 0010 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Full }}$ |
| 0011 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Almost-Full }}$ |
| 0100 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\mathrm{Empty}}$ |
| 0101 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Almost-Empty }}$ |
| 0110 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Full }}$ |
| 0111 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Almost-Full }}$ |
| 1000 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Empty |
| 1001 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Almost-Empty |
| 1010 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Full |
| 1011 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Almost-Full |
| 1100 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Empty |
| 1101 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Almost-Empty |
| 1110 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Full |
| 1111 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Almost-Full |

2669 tbl 13
Table 10. Configuration Register 4 Internal Flag Assignments to External Flag Pins.

## Port B Interface

Port B also has parity, reread/rewrite and DMA functions. Port B can be configured to interface to either Intel-style ( $\overline{\mathrm{R}} \mathrm{B}$, $\overline{\mathrm{W}}$ ) or Motorola-style ( $\overline{\mathrm{DS}} \mathrm{B}, \mathrm{R} / \overline{\mathrm{W}}$ B) devices in Configuration Register 5 (see Table 11). Port B can also be configured to talk to a processor or a peripheral device through Configuration Register 5. In processor interface mode, the Port B interface controls are inputs. In peripheral interiace mode, the Port B interface controls are outputs. After a hardware reset or a software Reset All command, Port B defaults to an Intel-style processor interiace; the controls are inputs.

Two 9-bit words are put together to create each 18 -bit word stored in the internal FIFOs. The first 9 -bit word written to Port

B goes into the Odd Byte Register shown in the detailed block diagram. The Odd Byte Register valid bit (Bit 8) in the Status Register is 1 when this first 9 -bit word is written. The data bits from Port B (DBo-DB7) are also stored in the lower 8 bits of the Status Register when Status Register format 0 is selected (see Table 8). The second write on Port B moves the 9-bits from Port B and the 9-bits in the Odd Byte Register into the $B \rightarrow A$ FIFO and advances the $B \rightarrow A$ Write Pointer. The Status Register valid bit is set to 0 after the second write.

When Port B reads data from the $\mathrm{A} \rightarrow \mathrm{B}$ FIFO, two buffers choose which 9 of the 18 memory bits are sent to Port B. These buffers alternate between the upper 9 bits (DAB-DA15, DA17) and the lower 9 bits (DAO-DA7, DA16). The A $\rightarrow$ B Read

## CONFIGURATION REGISTER 5 FORMAT

| Blt | Function |  |  |
| :---: | :---: | :---: | :---: |
| 0 | Select Port B Interface $\bar{R} B \& \overline{W_{B}}$ or $\overline{D S B} \& R \bar{W}_{B}$ | 0 | Pins are $\overline{\mathrm{F}}_{\mathrm{B}}$ and $\bar{W}_{B}$ (Intel-style interface) |
|  |  | 1 | Pins are $\overline{\mathrm{DS}}_{8}$ and $\mathrm{R} / \bar{W}_{\mathrm{B}}$ (Motorola-style interface) |
| 1 | Byte Order of 18-bit Word | 0 | Lower byte DA7-DA0 and parity Da16 are read or written first on Port B |
|  |  | 1 | Upper byte DA15-DA8 and parity Da17 are read or written first on Port B |
| 2 | Full Flag Definition | 0 | Full Flag is asserted when write pointer meets read pointer |
|  |  | 1 | Full Flag is asserted when write pointer meets reread pointer |
| 3 | Empty Flag Definition | 0 | Empty Flag is asserted when read pointer meets write pointer |
|  |  | 1 | Empty Flag is asserted when read pointer meets rewrite pointer |
| 4 | REQ Pin Polarity | 0 | REQ pin active HIGH |
|  |  | 1 | REQ pin active LOW |
| 5 | ACK Pin Polarity | 0 | ACK pin active LOW |
|  |  | 1 | ACK pin active HIGH |
| 7-6 | REQ / ACK Timing | 00 | 2 internal clocks between REQ assertion and ACK assertion |
|  |  | 01 | 3 internal clocks between REQ assertion and ACK assertion |
|  |  | 10 | 4 internal clocks between REQ assertion and ACK assertion |
|  |  | 11 | 5 internal clocks between REQ assertion and ACK assertion |
| 8 | Port B Read and Write Timing Control for Peripheral Mode | 0 | $\overline{\mathrm{R}}$ B, $\overline{\mathrm{W}} \mathrm{B}$, and $\overline{\mathrm{DS}} \mathrm{B}$ are asserted for 1 internal clock |
|  |  | 1 | $\overline{\mathrm{R}}, \bar{W}_{\mathrm{B}}$, and $\overline{\mathrm{DS}} \mathrm{B}$ are asserted for 2 internal clocks |
| 9 | Internal Clock Frequency Control | 0 | internal clock = CLK |
|  |  | 1 | internal clock $=$ CLK divided by 2 |
| 10 | Port B Interface Mode Control | 0 | Processor interface mode (Port B controls are inputs) |
|  |  | 1 | Peripheral interface mode (Port B controls are outputs) |
| 12-11 | Width Expansion Mode Control | 00 | Stand-alone mode (18-to 9-bits, 36- to 18-bits) |
|  |  | 01 | Reserved |
|  |  | 10 | Slave width expansion mode (36- to 9-bits) |
|  |  | 11 | Master width expansion mode (36- to 9-bits) |
| 13 | Unused | . |  |
| 14 | Unused |  |  |
| 15 | Unused |  |  |

Table 11. BIFIFO Configuration Reglster 5 Format

## CONFIGURATION REGISTER 7 FORMAT



2669 tol 15

Table 12. BIFIFO Configuration Register 7 Format

Pointer is advanced after every two Port B reads.
The BiFIFO can be set to order the 9-bit data so the first 9bits go to the LSB (DA0-DA7, DA16) or the MSB (DA8-DA15, DA17) of Port A. This data ordering is controlled by bit 1 of Configuration Register 5 (see Table 11).

## DMA Control Interface

The BiFIFO has DMA control to simplify data transfers with peripherals. For the BiFIFO DMA controls (REQ, ACK and CLK) to operate, the BiFIFO must be in peripheral interface mode (Configuration Register 5, Table 11).

DMA timing is controlled by the external clock input, CLK. An internal clock is derived from this CLK signal to generate the $\overline{\mathrm{R}} \mathrm{B}, \bar{W}_{B}, \overline{\mathrm{DS}} \mathrm{B}$ and $\mathrm{R} / \bar{W}_{B}$ output signals. The internal clock also determines the timing between REQ assertion and ACK assertion. Bit 9 of Configuration Register 5 determines whether the internal clock is the same as CLK or whether the internal clock is CLK divided by 2.

Bit 8 of Configuration Register 5 sets whether $\overline{\mathrm{R}} \mathrm{B}, \overline{\mathrm{W}} \mathrm{B}$ and $\overline{\mathrm{DS}} \mathrm{B}$ are asserted for 1 or 2 internal clocks. Bits 6 and 7 of Configuration Register 5 set the number of clocks between REQ assertion and ACK assertion. The clocks between REQ assertion and ACK assertion can be 2, 3, 4 or 5.

Bits 4 and 5 of Configuration Register 5 set the polarity of
the REQ and ACK pins, respectively.
A DMA transfer command sets the Port B read/write direction (see Table 5). The timing diagram for DMA transfers is shown in Figure 17. The basic DMA transfer starts with REQ assertion. After 2 to 5 internal clocks, ACK is asserted by the BiFIFO. ACK will not be asserted if a read is attempted on an Empty $A \rightarrow B$ FIFO or if a write is attempted on a Full $B \rightarrow A$ FIFO. If the BiFIFO is in Motorola-style interface mode, R $\bar{W} B$ is set at the same time that ACK is asserted. One internal clock later, $\overline{\mathrm{DSB}}$ is asserted. If the BiFIFO is in Intel-style interface mode, either $\bar{R} B$ or $\bar{W} B$ is asserted one internal clock after ACK assertion. These read/write controls stay asserted for 1 or 2 internal clocks, then $A C K, \overline{D S} B, \bar{R} B$ and $\bar{W} B$ are made inactive. This completes the transfer of one 9-bit word.

On the next rising edge of CLK, REQ is sampled. If REQ is still asserted, another DMA transferstarts with the assertion of ACK. Data transfers will continue as long as REQ is asserted.

## Parity CheckIng and Generation

Parity generation or checking is performed by the BiFIFO on data passing through Port B. Parity can either be odd or even as determined by Bit 10 of Configuration Register 7.

When parity checking is enabled, DB8 is treated as a data bit. DBs data will be passed to DA16 (bypass operation) or stored in the RAM array (FIFO operation) for B->A operation;

## INTERNAL FLAG TRUTH TABLE

| Number of Words in FIFO |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| From | To | Empty Flag | Almost-Empty Flag | Almost-Full Flag | Full Flag |
| 0 | 0 | Asserted | Asserted | Not Asserted | Not Asserted |
| 1 | $n$ | Not Asserted | Asserted | Not Asserted | Not Asserted |
| $n+1$ | D $-(m+1)$ | Not Asserted | Not Asserted | Not Asserted | Not Asserted |
| D $-m$ | D -1 | Not Asserted | Not Asserted | Asserted | Not Asserted |
| D | D | Not Asserted | Not Asserted | Asserted | Asserted |

## NOTE:

1. BiFIFO flags can be assigned to external flag pins to be observed. $D=F I F O$ depth (IDT7251/510 $=512$, IDT7252/520 $=1024$ ), $n=$ Almost-Empty flag offset, $m=$ Almost-Full flag offset.

Table 13. Internal Flag Truth Table.
similarly, DA16 or parity bits from the RAM array will be passed to DB8 for $A->B$ operations. $A->B$ read parity errors and $B->A$ write parity errors are shown in Bit 9 and 10 in the Status Register. If an external parity error signal is required, a logical OR of the two parity error bits is brought out to FLGA pin by setting Bit 11 of Configuration Register 7.

Parity generation creates the ninth bit. This ninth bit is placed on DB8 for A->B read operation, and on DA16 or RAM array for B->A write operation.

It is recommended that if the parity pins (Db8, DA16, and Da17) are not used, they should be pulled down with 10K resistors for noise immunity.

## Intelligent Reread/Rewrite

Intelligent reread/rewrite is a method the BiFIFO uses to help assure data integrity. Port B of the BiFIFO has two extra pointers, the Reread Pointer and the Rewrite Pointer. The Reread Pointer is associated with the A->B FIFO Read Pointer, while the Rewrite Pointer is associated with the B->A FIFO Write Pointer. The Reread Pointer holds the start address of a data block in the A->B FIFO RAM, and the Read Pointer is the current address of the same FIFO RAM array. By loading the Read Pointer with the value held in the Reread Pointer (RER asserted), reads will start over at the beginning of the data block. In order to mark the beginning of a data block, the Reread Pointer should be loaded with the Read

REREAD OPERATIONS


## REWRITE OPERATIONS



Figure 7. BIFIFO Rewrite Operations

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect To <br> Ground | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TbiAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

2669 th 17

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC OPERATING

 CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCCM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| VCCC | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input HIGH Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input HIGH Voltage <br> Military | 2.2 | - | - | V |
| VIL ${ }^{(1)}$ | Input LOW Voltage <br> Commercial and <br> Military | - | - | 0.8 | V |

NOTE:

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

DC ELECTRICAL CHARACTERISTICS
(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7251L <br> IDT7252L <br> IDT72510L <br> IDT72520L <br> Commercial $t \mathrm{~A}=35,50,80 \mathrm{~ns}$ |  |  | IDT7251L <br> IDT7252L <br> IDT72510L <br> IDT72520L <br> Military <br> $t \mathrm{~A}=40,50,80 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| ILL ${ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{lOL}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage lout $=-1 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage lout $=4 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| lcc1 ${ }^{(3)}$ | Average Vcc Power Supply Current | - | 150 | 220 | - | 180 | 250 | mA |
| lcce ${ }^{(3)}$ | Average Standby Current $(\overline{\mathrm{R}} \mathrm{B}=\overline{\mathrm{W}} \mathrm{B}=\overline{\mathrm{DS}} \mathrm{A}=$ Vif) | - | 8 | 12 | - | 12 | 25 | mA |
| lcc3 ${ }^{(3)}$ | $\begin{aligned} & \text { Power Down Current (All Inputs = Vcc - } \\ & 0.2 \mathrm{~V} \text { ) } \end{aligned}$ | - | - | 2 | - | - | 4 | mA |

NOTES:

1. Measurements with $0.4 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{Vcc}, \overline{\mathrm{DS}} \mathrm{A}=\overline{\mathrm{DS}} \geq \mathrm{VIH}$. 2. Measurements with $0.4 \mathrm{~V} \leq \mathrm{Vout} \leq \mathrm{Vcc}, \overline{\mathrm{DS}} \mathrm{A}=\overline{\mathrm{DS}} \mathrm{B} \geq \mathrm{VIH}$. 3. Icc measurements are made with outputs open.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 3 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 8 |

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN $^{(2)}$ | Input Capacitance | VIN $=0 \mathrm{~V}$ | 8 | pF |
| COUT ${ }^{(1,2)}$ | Output Capacitance | Vout $=0 \mathrm{~V}$ | 12 | pF |

## NOTES:

1. With output deselected.

2669 tbl 21
2. Characterized values, not currently tested.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commerclal <br> IDT7251L35 <br> IDT7252L35 <br> IDT72510L35 <br> IDT72520L35 |  | Military <br> IDT7251L40 <br> ID77252L40 <br> IDT72510L40 <br> IDT72520L40 |  | Commercial and Military |  |  |  | Unit | Timing <br> Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | IDT7251L50 <br> IDT7252L50 <br> IDT72510L50 <br> IDT72520L50 | IDT7251L80 <br> IDT7252L80 <br> IDT72510L80 <br> IDT72520L80 |  |  |  |
|  |  | Min. | Max. |  |  | Min. | Max. | Min. | Max. |  |  | Min. | Max. |
| RESET TIMING (Port A and Port B) |  |  |  |  |  |  |  |  |  |  |  |
| tRSC | Reset cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 9 |
| tRS | Reset pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 9 |
| tRSS | Reset set-up time | 35 | - | 40 | - | 50 | - | 80 | - | ns | 9 |
| tRSR | Reset recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 9 |
| trsf | Flag reset pulse width | - | 45 | - | 50 | - | 65 | - | 100 | ns | 9 |
| PORT A TIMING |  |  |  |  |  |  |  |  |  |  |  |
| taA | Port A access time | - | 35 | - | 40 | - | 50 | - | 80 | ns | 12, 14, 15 |
| taLz | Read or write pulse LOW to data bus at low Z | 5 | - | 5 | - | 5 | - | 10 | - | ns | 12, 15, 16 |
| taHz | Read or write pulse HIGH to data bus at high Z | - | 20 |  | 25 | - | 30 | - | 30 | ns | 12, 14, 15, 16 |
| tadV | Data valid from read pulse HIGH | 5 | - | 5 | - | 5 | - | 5 | - | ns | 12, 14, 16 |
| tanc | Read cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 12 |
| taRPW | Read pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 12, 14, 15 |
| taRR | Read recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 12 |
| tas | $\overline{\mathrm{CS}} \mathrm{A}, \mathrm{A} 0, \mathrm{~A} 1, \mathrm{R} / \bar{W}_{\mathrm{A}}$ set-up time | 5 | - | 5 | - | 5 | - | 10 | - | ns | 10, 12, 16 |
| taH | $\overline{\mathrm{CS}} \mathrm{A}, \mathrm{A} 0, \mathrm{~A}_{1}, \mathrm{R} / \bar{W}_{\mathrm{A}}$ hold time | 5 | - | 5 | - | 5 | - | $10$ | - | ns | 10, 12 |
| tads | Data set-up time | 18 | - | 20 | - | 30 | - | 40 | $\square$ | ns | 11, 12, 14, 15 |
| taDH ${ }^{(1)}$ | Data hold time. | 0 | - | 0 | - | 5 | - | 10 | - | ns | 11, 12, 14, 15 |
| tawc | Write cycle time | 45 | - | 50. | - | 65 | - | 100 | - | ns | 12 |
| tawpw | Write pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 11, 12, 14 |
| tawn | Write recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 12 |
| tawrcom | Write recovery time after a command | 35 | - | 40 | - | 50 | - | 80 | - | ns | 11. |

NOTE:

1. The minimum data hold time is 5 ns ( 10 ns for the 80 ns speed grade) when writing to the Command, Status or Configuration registers.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commercial <br> IDT7251L35 <br> IDT7252L35 <br> IDT72510L35 <br> IDT72520L35 |  |  |  | Commercial and Military |  |  |  | Unit | Timing <br> Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | IDT7251L40 <br> IDT7252L40 <br> IDT72510L40 <br> IDT72520L40 |  | 1D77251L50 <br> IDT7252L50 <br> IDT72510L50 <br> IDT72520L50 |  | IDT7251L80 <br> IDT7252L80 <br> IDT72510L80 <br> IDT72520L80 |  |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| PORT B PROCESSOR INTERFACE TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tbal | Port B access time with no parity | - | 35 | - | 40 | - | 50 | - | 80 | ns | 13, 14, 15 |
| tba2 | Port B access time with parity | - | 42 | - | 48 | - | 60 | - | 90 | ns | 13, 14, 15 |
| tblz | Read or write pulse LOW to data bus at low $\mathbf{Z}$ | 5 | - | 5 | - | 5 | - | 10 | - | ns | 13, 14, 15 |
| tbhz | Read or write pulse HIGH to data bus at high Z |  | 20 | - | 25 | - | 30 | - | 30 | ns | 13, 14, 15 |
| tbov | Data valid from read pulse HIGH | 5 | - | 5 | - | 5 | - | 10 | - | ns | 13, 14, 15, 16 |
| tbrc | Read cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 13 |
| tbrPW | Read pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 13 |
| tbrR | Read recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 13 |
| tbs | $\mathrm{R} \overline{\mathrm{W}}$ B set-up tim 3 | 5 | - | 5 | - | 5 | - | 10 | - | ns | 13 |
| tb | $\mathrm{R} \bar{W} \mathrm{~B}$ hold time | 5 | - | 5 | - | 5 | - | 10 | - | ns | 13 |
| tbDS 1 | Data set-up time with no parity | 18 | - | 20 | - | 30 | - | 40 | - | ns | 13, 14, 15 |
| tbDH1 | Data hold time with no parity | 0 | - | 0 | - | 5 | - | 10 | - | ns | 13, 14, 15 |
| tbos2 | Data set-up time with parity | 22 | - | 25 | - | 35 | - | 45 | - | ns | 13, 14, 15 |
| tbDH2 | Data hold time with parity | 0 | - | 0 | - | 5 | - | 10 | - | ns | 13, 14, 15 |
| tbwc | Write cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 13 |
| tbwPW | Write pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 13, 15 |
| tbwn | Write recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 13 |

PORT B PERIPHERAL INTERFACE TIMING

| tbckc | Clock cycle time | 20 | - | 20 | - | 25 | - | 40 | - | ns | 17 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tbckn | Clock pulse HIGH time | 6 | - | 8 | - | 10 | - | 16 | - | ns | 17 |
| tbckl | Clock pulse LOW time | 6 | - | 8 | - | 10 | - | 16 | - | ns | 17 |
| tbreqs | Request set-up time | 5 | - | 5 | - | 10 | - | 10 | - | ns | 17 |
| tbreah | Request hold time | 5 | - | 5 | - | 5 | - | 5 | - | ns | 17 |
| tbackl | Delay from a rising clock edge to ACK switching | - | 18 | - | 20 | - | 25 | - | 35 | ns | 17 |

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commercial |  | Military |  | Commercial and Military |  |  |  | Unit | Timing Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IDT7251L35 <br> IDT7252L35 <br> IDT72510L35 <br> IDT72520L35 |  | IDT7251L40 <br> IDT7252L40 <br> IDT72510L40 <br> IDT72520L40 |  | IDT7251L50 <br> IDT7252L50 <br> IDT72510L50 <br> IDT72520L50 |  | IDT7251L80 <br> IDT7252L80 <br> IDT72510L80 <br> IDT72520L80 |  |  |  |
| PORT B RETRANSMIT and PARITY TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tboseh | $\overline{R E R}, \overline{R E W}$, LDRER, LDREW set-up and recovery time | 10 | - | 10 | - | 15 | - | 15 | - | ns | 9, 18 |
| tbPER | Parity error time | 25 | - | 25 | - | 30 | - | 30 | - | ns | 19 |
| BYPASS TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tBYA | Bypass access time | - | 20 | - | 25 | - | 30 | - | 40 | ns | 16 |
| tBYD | Bypass delay | - | 15 | - | 17 | - | 20 | - | 30 | ns | 16 |
| tBYDV | Bypass data valid time | 20 | - | 20 | - | 20 | - | 20 | - | ns | 16 |
| FLAG TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tref | Read clock edge to Empty Flag asserted | - | 35 | - | 35 | - | 45 | - | 60 | ns | 14, 15, 20, 22 |
| twef | Write clock edge to Empty Flag not asserted | - | 35 | - | 35 | - | 45 | - | 60 | ns | 14, 15, 20, 22 |
| tRFF | Read clock edge to Full Flag not asserted | - | 35 | - | 35 | - | 45 | - | 60 | ns | 14, 15, 21, 23 |
| twff | Write clock edge to Full Flag asserted | - | 35 | - | 35 | - | 45 | - | 60 | ns | 14, 15, 21, 23 |
| trate | Read clock edge to Almost-Empty Flag asserted | - | 50 | - | 50 | - | 60 | - | 75 | ns | 20, 22 |
| twaEf | Write clock edge to Almost-Empty Flag not asserted | - | 50 | - | 50 | - | 60 | - | 75 | ns | 20, 22 |
| traff | Read clock edge to Almost-Full Flag not asserted | - | 50 | - | 50 | - | 60 | - | 75 | ns | 21, 23 |
| twaff | Write clock edge to Almost-Full Flag asserted | - | 50 | - | 50 | - | 60 | - | 75 | ns | 21, 23 |

## NOTES:

1. Read and Write are internal signals derived from $\overline{D S}_{A}, R \bar{W} A, \overline{D S}_{B}, R \bar{W} B, \bar{R} B$, and $\bar{W}_{B}$.
2. Although the flags, Empty, Almost-Empty, Almost-Full, and Full Flags are internal flags, the timing given is for those assigned to external pins.


Figure 9. Hardware Reset Timing for IDT72510/520


Figure 10. Basic Port A Control Signal Timing (Applies to All Port A Timing)


Flgure 11. Port A Command Timing (Write)

## WRITE



READ


Figure 12. Read and Write Timing for Port A

WRITE


NOTES:

1. tbosi and tbDH1 are with parity checking or if parity is ignored, tbos2 and tboH2 are with parity generation.
2. $\bar{F}_{B}=1$

READ


NOTES:
2669 dw 18

1. tbal is with parity checking or if parity is ignored, tbaz is with parity generation.
2. $W_{B}=1$

Figure 13. Port B Read and Write Timing. Processor Interface Mode Only

A $\rightarrow$ B FIFO WRITE

## FLOW-THROUGH



NOTES:

1. Assume the flag pin is programmed active low.
2. tba1 is with parity checking or if parity is ignored, tba2 is with parity generation.
3. $R W_{A}=0$.

B $\rightarrow$ A FIFO READ FLOW-THROUGH


NOTES:

1. Assume the flag pin is programmed active low.
2. tbosi \& tboH1 is with parity checking or if parity is ignored, tbDS2 \& tboh2 is with parity generation.
3. $R W_{A}=1$.

Figure 14. Port A Read and Write Flow-Through Timing. Processor Interface Mode Only

## B $\rightarrow$ A FIFO WRITE FLOW-THROUGH



NOTES:

1. Assume the flag pin is programmed active low.
2. thos \& tbont are with parity checking or if parity is ignored, tbos 2 tboH2 are with parity generation.
3. $R \bar{N}_{A}=1$.

A $\rightarrow$ B FIFO READ FLOW-THROUGH


NOTES:
2669 drw 19

1. Assume the flag pin is programmed active low.
2. tbA1 are with parity checking or if parity is ignored, tba2 are with parity generation.
3. $R \bar{W} A=0$.

Figure 15. Port B Read and Write Flow-Through Timing

## $B \rightarrow A$ READ BYPASS



NOTE:

1. Once the bypass starts, any data changes on Port B bus (Byte $0 \rightarrow$ Byte 1) will be passed to Port A bus.
2. $\overline{W B}=1$.

## A $\rightarrow$ B WRITE BYPASS



NOTE:

1. Once the bypass starts, any data changes on Port $A$ bus (Byte $0 \rightarrow$ Byte 1) will be passed to Port $B$ bus.

Figure 16. Bypass Path Timing. BIFIFO Must be in Peripheral Interface Mode

## SINGLE WORD DMA TRANSFER



1. tbA1, tbDS $\&$ tbOH1 are with parity checking or if parity is ignored, tbA2, tbDS $2 \&$ tboh 2 are with parity.

## BLOCK DMA TRANSFER



Figure 17. Port B Read and Write DMA Timing. Peripheral Interface Mode Only


Figure 18. Port B Reread and Rewrite Timing for Intelligent Retransmit

Set Parlty Error: FLGA is assigned as the parity error pin
$\overline{\mathrm{R}}, \mathrm{W}_{\mathrm{B}}(\mathrm{or} \overline{\mathrm{DS}} \mathrm{B})$


Clear Parity Error: Command written into Port A clears parity error on FLGA pin


Figure 19. Port B Parity Error Timing


Figure 20. Empty and Almost-Empty Flag Timing for $\mathbf{B} \rightarrow \mathbf{A F I F O}$. ( $\mathbf{n}=$ Programmed Offset)


## NOTES:

1. B $\rightarrow$ A FIFO initially contains $D-(M+1)$ data words. $D=512$ for IDT 7251/510; $\mathrm{D}=1024$ for IDT7252/520.
2. Assume the flag pins are programmed active low.
3. For stand-alone mode only; in a 36 - to 9 -bit configuration, Port B reads must be doubled.
4. $R W_{A}=1$

Figure 21. Full and Almost-Full Flag Timing for B $\rightarrow \mathbf{A}$ FIFO. ( $\mathbf{m}=$ Programmed Offset)


Figure 22. Empty and Almost-Empty Flag Timing for A $\rightarrow$ B FIFO. ( $\mathbf{n}=$ Programmed Offset)


NOTES:
2669 drw 26

1. $A \rightarrow B$ FIFO initially contains $D-(M+1)$ data words. $D=512$ for IDT7251/510; $D=1024$ for IDT7252/520.
2. Assume the flag pins are programmed active low.
3. For stand-alone mode only; in a 36 - to 9 -bit configuration, Port B reads must be doubled.
4. $\mathrm{R} \bar{W}_{\mathrm{A}}=0$

Figure 23. Full and Almost-Full Flag Timing for $A \rightarrow B$ FIFO. ( $m=$ Programmed Offset)

## ORDERING INFORMATION



2669 drw 27


Integrated Device Technology, Inc.

PARALLEL BIDIRECTIONAL FIFO

## $512 \times 18$-BIT \& $1024 \times 18$-BIT

## FEATURES:

- Two side-by-side FIFO memory arrays for bidirectional data transfers
- $512 \times 18$ - Bit $-512 \times 18$ - Bit (IDT72511)
- $1024 \times 18$ - Bit - $1024 \times 18$ - Bit (IDT72521)
- 18-bit data buses on Port A side and Port B side
- Can be configured for 18 -to-18-bit or 36 -to- 36 -bit communication
- Fast 35 ns access time
- Fully programmable standard microprocessor interface
- Built-in bypass path for direct data transfer between two ports
- Two fixed flags, Empty and Full, for both the A-to-B and the B-to-A FIFO
- Two programmable flags, Almost-Empty and Almost-Full for each FIFO
- Programmable flag offset can be set to any depth in the FiFO
- Any of the eight flags can be assigned to four external flag pins
- Flexible reread/rewrite capabilities
- Six general-purpose programmable I/O pins
- Standard DMA control pins for data exchange with peripherals
- 68-pin PGA and PLCC packages


## DESCRIPTION:

The IDT72511 and IDT72521 are highly integrated first-in, first-out memories that enhance processor-to-processor and processor-to-peripheral communications. IDT BiFIFOs integrate two side-by-side memory arrays for data transfers in two directions.

The BiFIFOs have two ports, A and B , that both have standard microprocessor interfaces. All BiFIFO operations are controlled from the 18 -bit wide Port $A$. Port $B$ is also 18 bits wide and can be connected to another processor or a peripheral controller. The BiFIFOs have a 9 -bit bypass path that allows the device connected to Port A to pass messages directly to the Port B device.

Ten registers are accessible through Port A, a Command Register, a Status Register, and eight Configuration Registers.

The IDT BiFIFO has programmable flags. Each FIFO memory array has four internal flags, Empty, Almost-Empty, Almost-Full and Full, for a total of eight internal flags. The Almost-Empty and Almost-Full flag offsets can be set to any depth through the Configuration Registers. These eight internal flags can be assigned to any of four external flag pins (FLGA-FLGD) through one Configuration Register.

Port B has programmable I/O, reread/rewrite and DMA functions. Six programmable I/O pins are manipulated through two Configuration Registers. The Reread and Rewrite controls will read or write Port B data blocks multiple times. The BiFIFO has three pins, REQ, ACK and CLK, to control DMA transfers from Port B devices.

## SIMPLIFIED BLOCK DIAGRAM



2668 dm 01

## PIN CONFIGURATIONS



## PIN DESCRIPTION

| Symbol | Name | VO | Description |
| :---: | :---: | :---: | :---: |
| DA0-DA17 | Data A | I/O | Data inputs and outputs for the 18-bit Port A bus. |
| $\overline{\mathrm{CS}} \mathrm{A}$ | Chip Select A | 1 | Port A is accessed when Chip Select A is LOW. |
| $\overline{\text { DSA }}$ | Data Strobe A | 1 | Data is written into Port A on the rising edge of Data Strobe when Chip Select is LOW. Data is read outof Port A on the falling edge of Data Strobe when Chip Select is LOW. |
| $\mathrm{R} / \bar{W}_{A}$ | Read/Write A | 1 | This pin controls the read or write direction of Port A. When $\overline{C S} A$ is LOW and $R / \bar{W}_{A}$ is HIGH, data is read from Port $A$ on the falling edge of $\overline{D S A}$. When $\overline{C S A}$ is LOW and $R \bar{W}_{A}$ is LOW, data is written into Port A on the falling edge of DSA. |
| A0, A1 | Addresses | I | When Chip Select $A$ is asserted, $A Q A 1$, and Read/Write $A$ are used to select one of six internal resources. |
| D80-DB17 | Data B | I/O | Data inputs and outputs for the 18-bit Port B bus. |
| $\overline{\mathrm{R}} \mathrm{B}$ ( $\overline{\mathrm{DS}} \mathrm{B}^{\prime}$ | Read B | 1 or O | If Port B is programmed to processor mode, this pin functions as an input. If Port B is programmed to peripheral mode this pin functions as an output. This pin can function as part of an Intel-style interface ( $\overline{\mathrm{RB}}$ ) or as part of a Motorola-style interface ( $\overline{\mathrm{DS}} \mathrm{B}$ ). As an Intel-style interface, data is read from Port $B$ on a falling edge of $\overline{\mathrm{B}}$. As a Motorola-style interface, data is read on the falling edge of $\overline{\mathrm{DS}}$ or written on the rising edge of $\overline{\mathrm{DS}}$ through Port B . The default is Intel-style processor mode. ( $\overline{\mathrm{B}}$ as an input). |
| $\overline{W_{B}}\left(\mathrm{R} \bar{W}_{B}\right)$ | Write B | 1 or O | If Port B is programmed to processor mode, this pin functions as an input. If Port B is programmed to peripheral mode this pin functions as an output. This pin can function as part of an Intel-style interface ( $\overline{W_{B}}$ ) or as part of a Motorola-style interface ( $\mathrm{R} / \mathrm{W}_{B}$ ). As an Intel-style interface, data is written to Port B on a rising edge of WB. As a Motorola-style interface, data is $\operatorname{read}(R \bar{W} B=H I G H)$ or written ( $R \bar{W}$ B $=$ LOW) to Port B in conjunction with a Data Strobe B falling or rising edge. The defautt is Intel-style processor mode (WB as an input.) |
| $\overline{\mathrm{RER}}$ | Reread | 1 | Loads $\mathrm{A} \rightarrow \mathrm{B}$ FiFO Read Pointer with the value of the Reread Pointer when LOW. |
| $\overline{\text { REW }}$ | Rewrite | 1 | Loads B $\rightarrow$ A FIFO Write Pointer with the value of the Rewrite Pointer when LOW. |
| LDRER | Load Reread | 1 | Loads the Reread Pointer with the value of the A $\rightarrow$ B FIFO Read Pointer when HIGH. |
| LDREW | Load Rewrite | 1 | Loads the Rewrite Pointer with the value of the B $\rightarrow$ A FIFO Write Pointer when HIGH. |
| REQ | Request | 1 | When Port $B$ is programmed in peripheral mode, asserting this pin begins a data transfer. Request can be programmed either active HIGH or active LOW. |
| ACK | Acknowledge | 0 | When Port B is programmed in peripheral mode, Acknowledge is asserted in response to a Request signal. This confirms that a data transfer may begin. Acknowledge can be programmed either active HIGH or active LOW. |
| CLK | Clock | 1 | This pin is used to generate timing for $A C K, \bar{R}_{B}, \bar{W} B, \overline{D S B}$ and $R \bar{W} B$ when Port $B$ is in the peripheral mode. |
| $\begin{aligned} & \text { FLGA } \\ & \text { FLGD } \end{aligned}$ | Flags | 0 | These four outputs pins can be assigned any one of the eight internal flags in the BiFIFO. Each of the two internal FIFOs $(A \rightarrow B$ and $B \rightarrow A)$ has four internal flags: Empty, Almost-Empty, Almost-Full and Full. |
| PIO-PIO5 | $\begin{array}{\|l\|} \hline \text { Programt } \\ \text { mable Inputs/ } \\ \text { Outputs } \\ \hline \end{array}$ | 1/0 | Six general purpose I/O pins. The input or output direction of each pin can be set independently. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | A LOW on this pin will perform a reset of all BiFIFO functions. |
| Vcc | Power |  | There are two +5 V power pins. |
| GND | Ground |  | There are five Ground pins at OV. |

## DETAILED BLOCK DIAGRAM



NOTES:
(*) Can be programmed either active high or active low in internal configuration registerers.
(tt) Can be programmed through an internal configuration register to be either an input or an output.

## FUNCTIONAL DESCRIPTION

IDT's BiFIFO family is versatile for both multiprocessor and peripheral applications. Data can be sent through both FIFO memories concurrently, thus freeing both processors from laborious direct memory access (DMA) protocols and frequent interrupts.

Two full 18-bit wide FIFOs are integrated into the IDT BiFIFO, making simultaneous data exchange possible. Each FIFO is monitored by separate internal read and write pointers, so communication is not only bidirectional, it is also totally independent in each direction. The processor connected to Port A of the BiFIFO can send or receive messages directly to the Port B device using the BiFIFO's 9-bit bypass path.

The BiFIFO can be used in different bus configurations: 18 bits to 18 bits and 36 bits to 36 bits. One BiFIFO can be used for the 18- to 18-bit configuration, and two BiFIFOs are required for 36- to 36 -bit configuration. This configuration can be extended to wider bus widths (54- to 54 -bits, 72 - to 72-bits, ...) by adding more BiFIFOs to the configuration.

The microprocessor or microcontroller connected to Port A controls all operations of the BiFIFO. Thus, all Port A interface pins are inputs driven by the controlling processor. Port B can be programmed to interface either with a second processor or a peripheral device. When Port $B$ is programmed in processor interface mode, the Port B interface pins are inputs driven by the second processor. If a peripheral device is connected to the BiFIFO, Port B is programmed to peripheral interface mode and the interface pins are outputs.

## 18- to 18-blt Configurations

A single BiFIFO can be configured to connect an 18-bit processor to another 18-bit processor or an 18-bit peripheral. The upper BiFIFO shown in each of the Figures 1 and 2 can be used in 18- to 18-bit configurations for processor and peripheral interface modes respectively.

## 36- to 36-blt Configurations

In a 36- to 36-bit configuration, two BiFIFOs operate in parallel. Both BiFIFOs are programmed simultaneously, 18 data bits to each device. Figures 1 and 2 show multiple BiFIFOs configured for processor and peripheral interface modes respectively.

## Processor Interface Mode

When a microprocessor or microcontroller is connected to Port B , all BiFIFOs in the configuration must be programmed to processor interface mode. In this mode, all Port B interface controls are inputs. Both REQ and CLK pins should be pulled LOW to ensure that the setup and hold time requirements for these pins are met during reset. Figure 1 shows the BiFIFO in processor interface mode.

## Peripheral Interface Mode

If Port B is connected to a peripheral controller, all BiFIFOs in the configuration must be programmed in peripheral interface mode. In this mode, all the Port B interface pins are all outputs. To assure fixed high states for $\bar{R} B$ and WB before they are programmed into an output, these two pins should be pulled up to Vcc with 10K resistors. Of course, only one set of Port B interface pins should be used to control a single peripheral device, while the other interface pins are all ignored. Figure 2 shows a BiFIFO configuration connected to a peripheral.


Figure 1. 36-Bit Processor to 36-Bit Processor Configuration
NOTE:

1. 36- to 36-bit processor interface configuration. Upper BiFIFO only is used in 18-to 18-bit configuration. Note that Cnt/ $A$ refers to $\overline{\operatorname{CSA}}, \mathbf{A} 1, A, R / 2$ $\bar{W}_{\mathrm{A}}$, and $\overline{\mathrm{DSA}}$; Cnt/ $B$ refers to $\mathrm{R} \overline{\mathrm{W}} \mathrm{B}$ and $\overline{\mathrm{DS}} \mathrm{B}$ or $\overline{\mathrm{R}} \mathrm{B}$ and $\overline{\mathrm{W}} \mathrm{B}$.


Figure 2. 36-Bit Processor to 36-Bit Peripheral Configuration
NOTE:

1. 36- to 36 -bit peripheral interface configuration. Upper BiFIFO only is used in 18-to 18 -bit configuration. Note that Cntl $A$ refors to $\bar{C} S A, A 1, A 0, R /$ $\bar{W} A$, and $\overline{D S A} ; C n t l B$ refers to $\mathrm{F} / \bar{W} B$ and $\overline{\mathrm{DS}} \mathrm{B}$ or $\overline{\mathrm{R}} \mathrm{B}$ and $\bar{W} B$.

## Port A Interface

The BiFIFO is straightforward to use in microprocessorbased systems because each BiFIFO port has a standard microprocessor control set. Port A has access to six resources: the $\mathrm{A} \rightarrow \mathrm{B}$ FIFO, the $\mathrm{B} \rightarrow \mathrm{A}$ FIFO, the 9 -bit direct data bus (bypass path), the configuration registers, status and command registers. The Port A Address and Read/Write pins determine the resource being accessed as shown in Table 1. Data Strobe is used to move data in and out of the BiFIFO.

When either of the internal FIFOs are accessed, 18 bits of data are transferred across Port A. Since the bypass path is only 9 bits wide, the least significant byte (DA0-Da7, DA16) is used on Port A. All of the registers are 16 bits wide which means only the data bits (Da0-DA15) are passed by Port A.

## Bypass Path

The bypass path acts as a bidirectional bus transceiver directly between Port A and Port B. The direct connection requires that the Port A interface pins are inputs and the Port B interface pins are outputs. The bypass path is 9 bits wide in an 18- to 18 -bit configuration or 18 bits wide in a 36 - to 36-bit configuration.

During bypass operations, the BiFIFOs must be programmed into peripheral interface mode. Bit 10 of Configu-
ration Register 5 (see Table 10) is set to 1 for peripheral interface mode.

## Command Register

Ten registers are accessible through Port A, a Command Register, a Status Register, and eight Configuration Registers.

The Command Register is written by setting $\overline{\mathrm{CS}} \mathrm{A}=0$, $A_{1}=1, A_{0}=1$. Commands written into the BiFIFO have a 4 -bit opcode (bit 8 - bit 11) and a 3 -bit operand (bit 0 -bit 2 ) as shown in Figure 3. The commands can be used to reset the BiFIFO, to select the Configuration Register, to perform intelligent reread/rewrite, to set the Port B DMA direction, to set the Status Register format, and to modify the Port B Read and Write Pointers. The command opcodes are shown in Table 2.
The reset command initializes different portions of the BiFIFO depending on the command operand. Table 3 shows the reset command operands.

The Configuration Register address is set directly by the command operands shown in Table 4.

Intelligent reread/rewrite is performed by interchanging the Port B Read Pointer with the Reread Pointer or by interchanging the Port B Write Pointer with the Rewrite Pointer. No command operands are required to perform a reread/ rewrite operation.

COMMAND FORMAT


548 tol 02
Figure 3. Format for Commands Written Into Port A

When Port B of the BiFIFO is in peripheral mode, the DMA direction is controlled by the Command Register. Table 5 shows the Port B read/write DMA direction operands.

Two commands are provided to increment the Port B Read and Write Pointers. No operands are required for these commands.

## Reset

The IDT72511 and IDT72521 have a hardware reset pin ( $\overline{\mathrm{RS}}$ ) that resets all BiFIFO functions. A hardware reset requires the following four conditions: $\overline{\mathrm{R} B}$ and $\bar{W} B$ must be HIGH, $\overline{\text { RER }}$ and $\overline{\text { REW }}$ must be HIGH, LDRER and LDREW must be LOW, and DSA must be HIGH (Figure 9). After a hardware reset, the BiFIFO is in the following state: Configuration Registers $0-3$ are $\mathbf{0 0 0 0 H}$, Configuration Register 4 is set to 6420 H , and Configuration Registers 5, 6 and 7 are 0000 H . Additionally, all the pointers including the Reread and Rewrite Pointers are set to 0 , the DMA direction is set to $B \rightarrow A$ write, and the internal DMA request circuitry is cleared (set to its initial state).

A software reset command can reset $\mathrm{A} \rightarrow \mathrm{B}$ pointers and the $B \rightarrow A$ pointers to 0 independently or together. The internal request DMA circuitry can also be reset independently. A

PORT A RESOURCE SELECTION

| CSA | $A_{1}$ | $A_{0}$ | Read | Write |
| :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | 0 | B $\rightarrow$ A FIFO | A $\rightarrow$ B FIFO |
| 0 | 0 | 1 | 9-bit Bypass Path | 9-bit Bypass Path |
| 0 | 1 | 0 | Configuration <br> Registers | Configuration <br> Registers |
| 0 | 1 | 1 | Status Register | Command <br> Register |
| $\mathbf{1}$ | X | X | Disabled | Disabled |

2668 b103
Table 1. Accessing Port A Resources Using CSA, A0 and A1
COMMAND OPERATIONS

| Command <br> Opcode | Functlon |
| :---: | :--- |
| 0000 | Reset BiFIFO (see Table 3) |
| 0001 | Select Configuration Register (see Table 4) |
| 0010 | Load Reread Pointer with Read Pointer Value |
| 0011 | Load Rewrite Pointer with Write Pointer Value |
| 0100 | Load Read Pointer with Reread Pointer Value |
| 0101 | Load Write Pointer with Rewrite Pointer Value |
| 0110 | Set DMA Transfer Direction (see Table 5) |
| 0111 | Reserved |
| 1000 | Increment A $\rightarrow$ B FIFO Read Pointer (Port B) |
| 1001 | Increment B $\rightarrow$ A FIFO Write Pointer (Port B) |
| 1010 | Reserved |
| 1011 | Reserved |

Table 2. Functions Performed by Port A Commands
software Reset All command resets all the pointers, the DMA request circuitry, and sets all the Configuration Registers to their default condition. Note that a hardware reset is NOT the same as a software Reset All command. Table 6 shows the BiFIFO state after the different hardware and software resets

## Status Register

The Status Register reports the state of the programmable flags and the DMA read/write direction. The Status Register is read by setting $\overline{\mathrm{CS}} \mathrm{A}=0, \mathrm{~A}=1, \mathrm{~A} 0=1$ (see Table 1). See Table 7 for the Status Register format.

## Configuration Registers

The eight Configuration Register formats are shown in Table 8. Configuration Registers 0-3 contain the programmable

## RESET COMMAND FUNCTIONS

| Reset <br> Operands | Functlon |
| :---: | :--- |
| 000 | No Operation |
| 001 | Reset B $\rightarrow$ A FIFO (Read, Write, and Rewrite <br> Pointers $=0$ |
| 010 | Reset A $\rightarrow$ B FIFO (Read, Write, and Reread <br> Pointers = 0) |
| 011 | Reset B $\rightarrow$ A and A $\rightarrow$ B FIFO |
| 100 | Reset Internal DMA Request Circuitry |
| 101 | No Operation |
| 110 | No Operation |
| 111 | Reset All |

2668 tbl0
Table 3. Reset Command Functions
SELECT CONFIGURATION REGISTER/ COMMAND FUNCTIONS

| Operands | Functlon |
| :---: | :--- |
| 000 | Select Configuration Register 0 |
| 001 | Select Configuration Register 1 |
| 010 | Select Configuration Register 2 |
| 011 | Select Configuration Register 3 |
| 100 | Select Configuration Register 4 |
| 101 | Select Configuration Register 5 |
| 110 | Select Configuration Register 6 |
| 111 | Select Configuration Register 7 |

2068tbl06
Table 4. Select Configuration Register Functions.

## DMA DIRECTION COMMAND FUNCTIONS

| Operands | Function |
| :---: | :--- |
| XX0 | Write B $\rightarrow$ A FIFO |
| XX1 | Read A $\rightarrow$ B FIFO |

2668 107
Table 5. Set DMA Direction Command Functions. Command Only Operates In Perlpheral Interface Mode

## STATE AFTER RESET

|  | Hardware Reset (RS asserted) | Software Reset |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{B} \rightarrow \mathrm{A}(001)$ | $\mathrm{A} \rightarrow \mathrm{B}(010)$ | $\begin{aligned} & B \rightarrow A \text { and } \\ & A \rightarrow B(011) \end{aligned}$ | Internal Request (100) | All(111) |
| Configuration Registers 0-3 | 0000H | - | - | - | - | 0000H |
| Configuration Register 4 | 6420 H | - | - | - | - | 6420 H |
| Configuration Register 5 | 0000 H | - | - | - | - | 0000H |
| Configuration Register 6-7 | 0000H | - | - | - | - | 0000 H |
| Status Register format | 0 | - | - | - | - | - |
| $B \rightarrow A$ Read, Write, Rewrite Pointers | 0 | 0 | - | 0 | - | 0 |
| $A \rightarrow B$ Read, Write, Reread Pointers | 0 | - | 0 | 0 | - | 0 |
| DMA direction | $B \rightarrow A$ write | - | - | - | - | - |
| DMA internal request | clear | - | - | - | clear | clear |

2668 ы 08
Table 6. The BIFIFO State After a Reset Command
flagoffsets for the Almost-Empty and Almost-Full flags. These offsets are set to 0 when a hardware reset or a software Reset All is applied. Note that Table 8 shows that Configuration Registers $0-3$ are 10 bits wide to accommodate the 1024 locations in each FIFO memory of the IDT7252/520. Only 9 least significant bits are used for the 512 locations of the IDT7251/510; the most significant bit, bit 9 , must be set to 0 .

Configuration Register 4 is used to assign the internal flags to the external flag pins (FLGA-FLGD). Each external flag pin is assigned an internal flag based on the four bit codes shown in Table 9. The default condition for Configuration Register 4 is 6420 H as shown in Table 6. The default flag assignments are: FLGD is assigned $B \rightarrow A$ Full, FLGC is assigned $B \rightarrow A$ Empty, FLGB is assigned $A \rightarrow B$ Full, FLGA is assigned $A \rightarrow B$ Empty.

Configuration Register 5 is a general control register. The format of Configuration Register 5 is shown in Table 10.

Bit 0 sets the Intel-style interface ( $\overline{\mathrm{R}}, \overline{\mathrm{W}} \mathrm{B}$ ) orMotorola-style interface ( $\overline{\mathrm{DS}}, \mathrm{R} / \bar{W}_{\mathrm{B}}$ ) for Port B . Bits 2 and 3 redefine Full and Empty Flags for reread/rewrite data protection.

Bits 4-9 control the DMA interface and are only applicable in peripheral interface mode. In processor interface mode, these bits are don't care states. Bits 4 and 5 set the polarity of the DMA control pins REQ and ACK respectively. An internal clock controls all DMA operations. This internal clock is derived from the external clock (CLK). .Bit 9 determines the internal clock frequency: the internal clock $=$ CLK or the internal clock $=$ CLK divided by 2 . Bit 8 sets whether $\bar{R} B, \bar{W} B$, and $\overline{\mathrm{DS}} \mathrm{B}$ are asserted for either one or two internal clocks. Bits 6 and 7 set the number of internal clocks between REQ assertion and ACK assertion. The timing can be from 2 to 5 cycles as shown in Figure 17.

Bit 10 controls Port B processor or peripheral interface mode. In processor mode, the Port $B$ control pins ( $\bar{R} B, \bar{W}_{B}$, $\overline{\mathrm{DS}} \mathrm{B}, \mathrm{R} / \overline{\mathrm{W}} \mathrm{B}$ ) are inputs and the DMA controls are ignored. In peripheral mode, the Port $B$ control pins are outputs and the DMA controls are active.

Six PIO pins can be programmed as an input or output by the corresponding mask bits in Configuration Register 7.

The format of Configuration Register 7 is shown in Figure 5. Each bit of the register set the I/O direction independently. A logic 1 indicates that the corresponding PIO pin is an output, while a logic 0 indicates that the PIO pin is an input. This I/O mask register can be read or written.

A programmed output PIOi pin ( $i=0,1, \ldots 5$ ) displays the data latched in Bit i of Configuration Register 6. A programmed input PIOi pin allows Port A bus to sample the data on DAi by reading Configuration Register 6.

## STATUS REGISTER FORMAT

| Bit |  |
| :--- | :--- |
| 0 | Reserved |
| 1 | Reserved |
| 2 | Reserved |
| 3 | DMA Direction |
| 4 | A $\rightarrow$ B Empty Flag |
| 5 | A $\rightarrow$ B Almost-Empty Flag |
| 6 | B $\rightarrow$ A Full Flag |
| 7 | B $\rightarrow$ A Almost-Full Flag |
| 8 | Reserved |
| 9 | Reserved |
| 10 | Reserved |
| 11 | Reserved |
| 12 | A $\rightarrow$ B Full Flag |
| 13 | A $\rightarrow$ B Almost-Full Flag |
| 14 | B $\rightarrow$ A Empty Flag |
| 15 | B $\rightarrow$ A Almost-Empty Flag |

Table 7. The Status Register Format

## CONFIGURATION REGISTER FORMATS



## NOTE:

2668 drw 02

1. Bit 9 of Configuration Registers $0-3$ must be set to 0 on the IDT72511.

Table 8. The BIFIFO Configuration Reglster Formats

## Programmable Flags

The IDT BiFIFO has eight internal flags. Associated with each FIFO memory array are four internal flags, Empty, Almost-Empty, Almost-Full and Full, for the total of eight internal flags. The Almost-Empty and Almost-Full offsets can be set to any depth through the Configuration Registers 0-3 (see Table 8). The flags are asserted at the depths shown in Table 11. After a hardware reset or a software Reset All, the almost flag offsets are set to 0 . Even though the offsets are equivalent, the Empty and Almost-Empty flags have different timing which means that the flags are not coincident. Similarly, the Full and Almost-Full flags are not coincident after reset because of timing.

These eight internal flags can be assigned to any of four external flag pins (FLGA-FLGD) through Configuration Register 4 (see Table 9). For the specific flag timings, see Figures 20-23.

The current state of all eight flags is available in the Status Register.

EXTERNAL FLAG ASSIGNMENT CODES

| Assignment <br> Code | Internal Flag Assigned to Flag Pin |
| :--- | :--- |
| 0000 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Empty }}$ |
| 0001 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Almost-Empty }}$ |
| 0010 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Full |
| 0011 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Almost-Full }}$ |
| 0100 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Empty |
| 0101 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Almost-Empty }}$ |
| 0110 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Full |
| 0111 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Almost-Full }}$ |
| 1000 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Empty |
| 1001 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Almost-Empty |
| 1010 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Full |
| 1011 | $\mathrm{~A} \rightarrow \mathrm{~B}$ Almost-Full |
| 1100 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Empty |
| 1101 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Almost-Empty |
| 1110 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Full |
| 1111 | $\mathrm{~B} \rightarrow \mathrm{~A}$ Almost-Full |
|  |  |

2668 to 11
Table 9. Configuration Register 4 Internal Flag Assignments to External Flag Pins

## CONFIGURATION REGISTER 5 FORMAT



Table 10. BIFIFO Configuration Register 5 Format

## CONFIGURATION REGISTER 6 FORMAT

| 15 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Unused |  | PIO5 | PIO4 | PIO3 | PIO2 | PIO1 | PIOO |

Figure 4. BIFIFO Conflguration Reglster 6 Format for Programmable I/O Data

## CONFIGURATION REGISTER 7 FORMAT



Figure 5. BIFIFO Configuration Register 7 Format for Programmable VO Direction Mask

## Port B Interface

Port B has reread/rewrite and DMA functions. Port B can be configured to interface to either intel-style ( $\overline{\mathrm{R}} \mathrm{B}, \overline{\mathrm{W}} \mathrm{B}$ ) or Mo-torola-style ( $\overline{\mathrm{DSB}}, \mathrm{R} / \overline{\mathrm{W}} \mathrm{B}$ ) devices in Configuration Register 5 (see Table 10). Port B can also be contigured to talk to a processor or a peripheral device through Configuration Register 5. In processor interface mode, the Port B interface controls are inputs. In peripheral interiace mode, the Port B interface controls are outputs. After a hardware reset or a software Reset All command, Port B defaults to an Intel-style processor interface; the controls are inputs.

## DMA Control Interface

The BiFIFO has DMA control to simplify data transfers with peripherals. For the BiFIFO DMA controls (REQ, ACK and CLK) to operate, the BiFIFO must be in peripheral interface mode (Configuration Register 5, Table 10).

DMA timing is controlled by the external clock input, CLK. An internal clock is derived from this CLK signal to generate the $\overline{\mathrm{R}} \mathrm{B}, \overline{\mathrm{W}} \mathrm{B}, \overline{\mathrm{DS}} \mathrm{B}$ and $\mathrm{R} / \bar{W}_{\mathrm{B}}$ output signals. The internal clock also determines the timing between REQ assertion and ACK assertion. Bit 9 of Configuration Register 5 determines whether the internal clock is the same as CLK or whether the internal clock is CLK divided by 2.

Bit 8 of Configuration Register 5 set whether $\bar{R} B, \bar{W}_{B}$ and $\overline{\mathrm{DSB}}$ are asserted for 1 or 2 internal clocks. Bits 6 and 7 of Configuration Register 5 set the number of clocks between REQ assertion and ACK assertion. The clocks between REQ assertion and ACK assertion can be 2, 3, 4 or 5.

Bits 4 and 5 of Configuration Register 5 set the polarity of the REQ and ACK pins respectively.

A DMA transfer command sets the Port B read/write direction (see Table 5). The timing diagram for DMA transters is shown in Figure 17. The basic DMA transfer starts with REQ assertion. After 2 to 5 internal clocks, ACK is asserted by the BiFIFO. ACK will not be asserted if a read is attempted on an empty $\mathrm{A} \rightarrow \mathrm{BFIFO}$ or if a write is attempted on a full $\mathrm{B} \rightarrow \mathrm{A}$ FIFO. If the BiFIFO is in Motorola-style interface mode, $R / \bar{W} B$ is set
at the same time that ACK is asserted. One internal clock later, $\overline{\mathrm{DS}} \mathrm{B}$ is asserted. If the BiFIFO is in Intel-style interface mode, either $\overline{\mathrm{R}} \mathrm{B}$ or $\overline{\mathrm{W}} \mathrm{B}$ is asserted one internal clock after ACK assertion. These readwrite controls stay asserted for 1 or 2 internal clocks, then $\mathrm{ACK}, \overline{\mathrm{DS}}, \overline{\mathrm{R}} \mathrm{B}$ and $\overline{\mathrm{WB}}$ are made inactive. This completes the transfer of one 9 -bit word.

On the next rising edge of CLK, REQ is sampled. If REQ is still asserted, another DMA transfer starts with the assertion of ACK. Data transfers will continue as long as REQ is asserted.

## Intelligent Reread/Rewrite

Intelligent reread/rewrite is a method the BiFIFO uses to help assure data integrity. Port B of the BiFIFO has two extra pointers, the Reread Pointer and the Rewrite Pointer. The Reread Pointer is associated with the A $\rightarrow$ B FIFO Read Pointer, while the Rewrite Pointer is associated with the B->A FIFO Write Pointer. The Reread Pointer holds the start address of a data block in the A->B FIFO RAM, and the Read Pointer is the current address of the same FIFO RAM array. By loading the Read Pointer with the value held in the Reread Pointer (RER asserted), reads will start over at the beginning of the data block. In order to mark the beginning of a data block, the Reread Pointer should be loaded with the Read Pointer value (LDRER asserted) before the first read is performed on this data block. Figure 6 shows a Reread operation.

Similarly, the Rewrite Pointer holds the start address of a data block in the B->A FIFO RAM, while the Write Pointer is the current address within the RAM array. The operation of the REW and LDREW is identical to the RER and LDRER discussed above. Figure 7 shows a Rewrite operation.

For the reread data protection, Bit 2 of Configuration Register 5 canbe set to 1 to prevent the data block frombeing overwritten. In this way, the'assertion of $A->B$ fullflag will occur when the write pointer meets the reread pointer instead of the read pointer as in the normal definition. For the rewrite data protection, Bit 3 of Configuration Register 5 can be set to 1 to

INTERNAL FLAG TRUTH TABLE

| Number of Words in FIFO |  | Empty Flag | Almost-Empty Flag | Almost-Full Flag | Full Flag |
| :---: | :---: | :---: | :---: | :---: | :---: |
| From | To |  |  |  |  |
| 0 | 0 | Asserted | Asserted | Not Asserted | Not Asserted |
| 1 | n | Not Asserted | Asserted | Not Asserted | Not Asserted |
| $n+1$ | D - $(\mathrm{m}+1)$ | Not Asserted | Not Asserted | Not Asserted | Not Asserted |
| D - m | D-1 | Not Asserted | Not Asserted | Asserted | Not Asserted |
| D | D | Not Asserted | Not Asserted | Asserted | Asserted |

NOTE:

[^4]Table 11. Internal Flag Truth Table
prevent the data block from being read. In this case the assertion of B->A empty flag will occur when the read pointer meets the rewrite pointer instead of the write pointer.

In conclusion, Bit 2 and 3 of Configuration Register 5 are used to redefine Full \& Empty flags for data block partition. Although it can serve the purpose of data protection, the setting of these 2 bits is independent of the functions caused by RER/REW, or LDRER/LDREW assertions.

## Programmable Input/Output

The BiFIFO has six programmable $\mathrm{I} / 0$ pins ( PIO - PIO 5 ) which are controlled by Port A through Configuration Registers 6 and 7. Data from the programmable I/Opins is mapped directly to the six least significant bits of Configuration Register 6. Figure 4 shows the format of Configuration Register 6.

## REREAD OPERATIONS



FIgure 6. BIFIFO Reread Operations

This data is read or written by Port $A$ on the data pins (DA0-DA5). A programmed output PIOi pin ( $\mathrm{i}=0,1, \ldots, 5$ ) displays the data latched in Bit i of Configuration Register 6. A programmed input PIOi pin allows Port A bus to sample its data on Dai by reading Configuration Register 6. The read and write timing for the programmable I/O pins is shown in Figure 19. The direction of each programmable I/O pin can be set independently by programming the mask in Configuration Register 7. Each P10 pin has a corresponding input/output direction mask bit in Configuration Register 7. Figure 5 shows the format of Configuration Register 7. Setting a mask bit to a logic 1 makes the corresponding I/O pin an output. Mask bits set to logic 0 force the corresponding I/O pin to an input.

## REWRITE OPERATIONS



2668 drw 08

Figure 7. BIFIFO Rewrite Operations

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> With Respect To <br> Ground | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2668 tbl 15

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC OPERATING

 CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccm | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| VCCC | Commercial Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input HIGH Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input HIGH Voltage <br> Military | 2.2 | - | - | V |
| VIL $^{(1)}$ | Input LOW Voltage <br> Commercial and <br> Military | - | - | 0.8 | V |

NOTE:
2668 th 16

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72511L <br> IDT72521L <br> Commercial $t \mathrm{~A}=35,50,80 \mathrm{~ns}$ |  |  | IDT72511LIDT72521LMilitary$t_{A}=40,50,80 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| IIL ${ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| Ia ${ }^{(2)}$ | Output Leakage Current ${ }^{\text {- }}$ | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage lout $=-1 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage lout $=4 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| $\mathrm{lcci}^{(3)}$ | Average VCC Power Supply Current | - | 150 | 230 | - | 180 | 250 | mA |
| $\operatorname{lcc}^{(3)}$ | Average Standby Current ( $\overline{\mathrm{R}} \mathrm{B}=\overline{\mathrm{W}} \mathrm{B}=\overline{\mathrm{DS}} \mathrm{A}=$ VIH) | - | 8 | 12 | - | 12 | 25 | mA |
| $\operatorname{lcc3}{ }^{(3)}$ | Power Down Current (All Inputs = Vcc 0.2 V ) | - | - | 2 | - | - | 4 | mA |

## NOTES:

1. Measurements with $0.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{VCC}, \overline{\mathrm{DS}}_{\mathrm{A}}=\overline{\mathrm{DS}} \mathrm{B} \geq \mathrm{V}_{\mathrm{H}}$
2. Measurements with $0.4 \mathrm{~V} \leq$ Vout $\leq \mathrm{VCc}, \overline{\mathrm{DS}} \mathrm{A}=\overline{\mathrm{DSB}} \geq \mathrm{V} / H$
3. lec measurements are made with outputs open.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 3 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 8 |
| 2668 かl 18 |  |

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CiN $^{(2)}$ | Input Capacitance | Vin $=0 \mathrm{~V}$ | 8 | pF |
| Cout $^{(1.2)}$ | Output Capacitance | VouT $=0 \mathrm{~V}$ | 12 | pF |

## NOTES:

2668 tbl 19

1. With output deselected.
2. Characterized values, not currently tested.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commercial |  | Military |  | Commercial and Military |  |  |  | Unit | Timing <br> Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IDT72511L35 IDT72521L35 |  | IDT72511L40 <br> IDT72521L40 |  | IDT72511L50 <br> IDT72521L50 |  | IDT72511L80 <br> IDT72521L80 |  |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| RESET TIMING (Port A and Port B) |  |  |  |  |  |  |  |  |  |  |  |
| tRSC | Reset cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 9 |
| tRS | Reset pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 9 |
| tRSs | Reset set-up time | 35 | - | 40 | - | 50 | - | 80 | - | ns | 9 |
| tRSR | Reset recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 9 |
| tRSF | Flag reset pulse width | - | 45 | - | 50 | - | 65 | - | 100 | ns | 9 |

## PORT A TIMING

| taA | Port A access time | - | 35 | - | 40 | - | 50 | - | 80 | ns | 12, 14, 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| talz | Read or write pulse LOW to data bus at low Z | 5 | - | 5 | - | 5 | - | 10 | - | ns | 12, 15, 16 |
| taHz | Read or write pulse HIGH to data bus at high Z | - | 20 | - | 25 | - | 30 | - | 30 | ns | 12, 14, 15, 16 |
| taDV | Data valid from read pulse HIGH | 5 | - | 5 | - | 5 | - | 5 | - | ns | 12, 14, 16 |
| tanc | Read cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 12 |
| taRPW | Read pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 12, 14, 15 |
| taRR | Read recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 12 |
| taS | $\overline{\mathrm{CS}} \mathrm{A}, \mathrm{A}_{0}, \mathrm{~A}_{1}, \mathrm{R} / \bar{W}_{A}$ set-up time | 5 | - | 5 | - | 5 | - | 10 | - | ns | 10, 12, 16 |
| taH | $\overline{\mathrm{CS}}_{\mathrm{A}}, \mathrm{A}, \mathrm{A}_{1}, \mathrm{R} / \bar{W}_{\mathrm{A}}$ hold time | 5 | - | 5 | - | 5 | - | 10 | - | ns | 10, 12 |
| tads | Data set-up time | 18 | - | - 20 | - | 30 | - | 40 | - | ns | 11, 12, 14, 15 |
| taDH ${ }^{(1)}$ | Data hold time | 0 | - | 0 | - | 5 | - | 10 | - | ns | 11, 12, 14, 15 |
| tawc | Write cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 12 |
| tawpw | Write pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 11, 12, 14 |
| tawR | Write recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 12 |
| tawrcom | Write recovery time after a command | 35 | - | 40 | - | 50 | - | 80 | - | ns | 11 |

NOTE:
2668 tol 20

1. The minimum data hold time is 5 ns ( 10 ns for the 80 ns speed grade) when writing to the Command, Status or Configuration registers.

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{Vcc}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commercial <br> IDT72511L35 <br> IDT72521L35 |  | MilitaryIDT72511L40IDT72521L40 |  | Commerclal and Military |  |  |  | Unit | Timing <br> Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | IDT72511L50 <br> IDT72521L50 | IDT72511L80 <br> IDT72521L80 |  |  |  |
|  |  | Min. | Max. |  |  | Min. | Max. | Min. | Max. |  |  | Min. | Max. |
| PORT B PROCESSOR INTERFACE TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tbA | Port B access time | - | 35 | - | 40 | - | 50 | - | 80 | Z | 13, 14, 15 |
| tblz | Read or write pulse LOW to data bus at low Z | 5 | - | 5 | - | 5 | - | 10 | - | ns | 13, 14, 15 |
| tbHz | Read or write pulse HIGH to data bus at high Z | - | 20 | - | 25 | - | 30 | - | 30 | ns | 14, 13, 15 |
| tbov | Data valid from read pulse HIGH | 5 | - | 5 | - | 5 | - | 10 | - | ns | 13, 14, 15, 16 |
| tbrc | Read cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 13 |
| tbrPw | Read pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 13 |
| tbrR | Read recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 13 |
| tbs | $\mathrm{R} / \bar{W}_{B}$ set-up time | 5 | - | 5 | - | 5 | - | 10 | - | ns | 13 |
| tbH | $\mathrm{R} / \overline{\mathrm{W}}$ B hold time | 5 | - | 5 | - | 5 | - | 10 | - | ns | 13 |
| tbos | Data set-up time | 18 | - | 20 | - | 30 | - | 40 | - | ns | 13, 14, 15 |
| tbDH | Data hold time | 0 | - | 0 | - | 5 | - | 10 | - | ns | 13, 14, 15 |
| tbwc | Write cycle time | 45 | - | 50 | - | 65 | - | 100 | - | ns | 13 |
| tbwPW | Write pulse width | 35 | - | 40 | - | 50 | - | 80 | - | ns | 13,15 |
| tbwn | Write recovery time | 10 | - | 10 | - | 15 | - | 20 | - | ns | 13 |
| PORT B PERIPHERAL INTERFACE TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tbскс | Clock cycle time | 20 | - | 20 | - | 25 | - | 40 | - | ns | 17 |
| tbckн | Clock pulse HIGH time | 6 | - | 8 | - | 10 | - | 16 | - | ns | 17 |
| tbckl | Clock pulse LOW time | 6 | - | 8 | - | 10 | - | 16 | - | ns | 17 |
| tbreas | Request set-up time | 5 | - | 5 | - | 10 | - | 10 | - | ns | 17 |
| tbreat | Request hold time | 5 | - | 5 | - | 5 | - | 5 | - | ns | 17 |
| tbackl | Delay from a rising clock edge to ACK switching | - | 18 | - | 20 | - | 25 | - | 35 | ns | 17 |

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%$, $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%$, $\mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commercial <br> IDT72511L35 <br> IDT72521L35 |  | MilitaryIDT72511L40IDT72521L40 |  | Commercial and Military |  |  |  | Unit | Timing <br> Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | IDT72511L50 <br> IDT72521L50 | IDT72511L80 <br> IDT72521L80 |  |  |  |
|  |  | Min. | Max. |  |  | Min. | Max. | Min. | Max. |  |  | Min. | Max. |
| PORT B RETRANSMIT TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tboseh | $\overline{R E R}, \overline{R E W}$, LDRER, LDREW set-up and recovery time | 10 | - | 10 | - | 15 | - | 15 | - | ns | 9, 18 |
| PROGRAMMABLE I/O TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tPIOA | Programmable I/O access time | - | 25 |  | 25 | - | 30 | - | 30 | ns | 19 |
| tPIOS | Programmable l/O setup time | 5 | - | 5 | - | 10 | - | 10 | - | ns | 19 |
| tPIOH | Programmable I/O hold time | 5 | - | 5 | - | 10 | - | 10 | - | ns | 19 |
| BYPASS TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tBYA | Bypass access time | - | 20 | - | 25 | - | 30 | - | 40 | ns | 16 |
| tBYD | Bypass delay | - | 15 | - | 17 | - | 20 | - | 30 | ns | 16 |
| tBYDV | Bypass data valid time | 20 | - | 20 | - | 20 | - | 20 | - | ns | 16 |
| FLAG TIMING |  |  |  |  |  |  |  |  |  |  |  |
| tref | Read clock edge to Empty Flag asserted | - | 35 | - | 35 | - | 45 | - | 60 | ns | 14, 15, 20, 22 |
| tWEF | Write clock edge to Empty Flag not asserted | - | 35 | - | 35 | - | 45 | - | 60 | ns | 14, 15, 20, 22 |
| tRFF | Read clock edge to Full Flag not asserted | - | 35 | - | 35 | - | 45 | - | 60 | ns | 14, 15, 21, 23 |
| tWFF | Write clock edge to Full Flag asserted | - | 35 | - | 35 | - | 45 | - | 60 | ns | 14, 15, 21, 23 |
| tRaEF | Read clock edge to Almost-Empty Flag asserted | - | 50 | - | 50 | - | 60 | - | 75 | ns | 20, 22 |
| twaEF | Write clock edge to Almost-Empty Flag not asserted | - | 50 | - | 50 | - | 60 | - | 75 | ns | 20, 22 |
| traff | Read clock edge to Almost-Full Flag not asserted | - | 50 | - | 50 | - | 60 | - | 75 | ns | 21, 23 |
| tWAFF | Write clock edge to Almost-Full Flag asserted | - | 50 | - | 50 | - | 60 | - | 75 | ns | 21, 23 |

NOTES:

1. Read and write are internal signals derived from $\overline{D S}_{A}, R \bar{W}_{A}, \overline{D S}_{B}, R / \bar{W} B, \bar{R}_{B}$, and $\bar{W} B$.
2. Although the flags, Empty, Almost-Empty. Almost-Full, and Full Flags are internal flags, the timing given is for those assigned to external pins.


Figure 9. Hardware Reset Timing


Figure 10. Basic Port A Control Signal Timing (Applles to All Port A Timing)
$R / W_{A}$


Figure 11. Port A Command Timing (write).

WRITE


READ


Figure 12. Read and Write TIming for Port $A$

WRITE


NOTE:

1. $F_{B}=1$

READ


NOTE:

1. $\mathrm{K}_{\mathrm{B}}=1$

Figure 13. Port B Read and Write Timing, Processor Interface Mode Only

## $A \rightarrow B$ FIFO WRITE FLOW-THROUGH



NOTES:

1. Assume the flag pin is programmed active low.
2. $R W W_{A}=0$

## B $\rightarrow$ A FIFO READ FLOW-THROUGH



NOTES:

1. Assume the flag pin is programmed active low.
2. $R W W_{A}=1$

FIgure 14. Port A Read and Write Flow-Through Timing, Processor Interface Mode Only

## B $\rightarrow$ A FIFO WRITE FLOW-THROUGH



NOTES:

1. Assume the flag pin is programmed active low.
2. $R / \bar{W}_{A}=1$

## A $\rightarrow$ B FIFO READ FLOW-THROUGH



NOTES:

1. Assume the flag pin is programmed active low.
2. $R / \bar{W}_{A}=0$

Figure 15. Port B Read and Write Flow-Through Timing, Processor Interface Mode Only

## B $\rightarrow$ A READ BYPASS


notes:

1. Once the bypass mode starts, any data change on Port B bus (Byte $O \rightarrow$ Byte 1) will be passed to Port $A$ bus.
2. $\bar{W}_{B}=1$

## A $\rightarrow$ B WRITE BYPASS



NOTES:

1. Once the bypass mode starts, any data change on Port A bus (Byte $0 \rightarrow$ Byte 1) will be passed to Port B bus.
2. $\bar{R}_{B}=1$

Figure 16. Bypass Path Timing, BIFIFO Must Be in Peripheral Interface Mode

## SINGLE WORD DMA TRANSFER



## BLOCK DMA TRANSFER



Figure 17. Port B Read and Write DMA timing. Peripheral Interface Mode Only


Figure 18. Port B Reread and Rewrite Tlming for Intelligent Reread/Rewrite

Port A $\rightarrow$ PIO WRITE


P1O $\rightarrow$ Port A READ


Figure 19. Programmable I/O TIming


NOTES:

1. $B \rightarrow A$ FIFO is initially empty.
2. Assume the flag pins are programmed active low.
3. $R W_{A}=1$

Figure 20. Empty and Almost-Empty Flag Timing for B $\rightarrow \mathbf{A}$ FIFO, ( $\mathbf{n}=$ programmed offset)


## NOTES:

1. $B \rightarrow A$ FIFO initially contains $D-(M+1)$ data words. $D=512$ for IDT72511; $D=1024$ for IDT72521.
2. Assume the flag pins are programmed active low.
3. $R W_{A}=1$

Figure 21. Full and Almost-Full Flag Timing for $B \rightarrow A$ FIFO, ( $m=$ programmed offset)


## NOTES:

1. $A \rightarrow B$ FIFO is initially empty.
2. Assume the flag pins are programmed active low.
3. $R W_{A}=1$

Figure 22. Empty and Almost-Empty Flag Tlming for $\mathbf{A} \rightarrow \mathrm{B}$ FIFO, ( $\mathrm{n}=$ programmed offset)


## NOTES:

1. B $\rightarrow$ A FIFO initially contains $D-(M+1)$ data words. $D=512$ for IDT72511; $D=1024$ for IDT72521.
2. Assume the flag pins are programmed active low.
3. $R \bar{W}_{A}=1$

Figure 23. Full and Almost-Full Flag Tlming for $\mathbf{A} \rightarrow \mathbf{B}$ FIFO, ( $\mathbf{m}=$ programmed offsel)

## ORDERING INFORMATION



PARALLEL SyncBiFIFOTM (CLOCKED BIDIRECTIONAL FIFO) $256 \times 18$-BIT AND $512 \times 18$-BIT

## PRELIMINARY IDT72605 IDT72615

## FEATURES:

- Two independent FIFO memories for fully bidirectional data transfers
- $256 \times 18$ organization (IDT 72605)
- $512 \times 18$ organization (IDT 72615)
- Synchronous interface for fast ( 25 ns ) read and write cycle times
- Each data port has an independent clock and read/write control
- Output enable is provided on each port as a three-state control of the data bus
- Built-in bypass path for direct data transfer between two ports
- Two fixed flags, Empty and Full, for both the A-to-B and the B-to-A FIFO
- Programmable flag offset can be set to any depth in the FIFO
- The synchronous BiFIFO is packaged in a 68-pin PGA and PLCC
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT72605 and IDT72615 are very high speed, low powerbidirectional FIFO memories with synchronous interface
for fast read and write cycle times. The SyncBiFIFOrm is a data buffer that can store or retrieve information from two sources simultaneously. Two dual-port FIFO memory arrays are contained in the SyncBiFIFO; one data buffer for each direction.

The SyncBiFIFO has registers on all inputs and outputs. Data is only transferred into the I/O registers on clock edges, hence the interfaces are synchronous. Each Port has its own independent clock. Data transfers to the I/O registers are gated by the enable signals. The transfer direction for each port is controlled independently by a read/write signal. Individual output enable signals control whether the SyncBiFIFO is driving the data lines of a port or whether those data lines are in a high impedance state.

Bypass control allows data to be directly transferred from input to output register in either direction.

The SyncBiFIFO has eight flags. The flag pins are full, empty, almost-full, or almost-empty for both FIFO memories. The offset depths of the almost-full and almost-empty flags can be programmed to any location.

The SyncBiFIFO is fabricated using IDT's high speed submicron CEMOS ${ }^{T M}$ technology. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

FUNCTIONAL BLOCK DIAGRAM

SyncFiFIFO and CEMOS are trademarks of Integrated Device Technology, Inc.


## PIN CONFIGURATIONS




## PIN DESCRIPTION

| Symbol | Name | 10 | Description |
| :---: | :---: | :---: | :---: |
| Da0-Da17 | Data A | I/O | Data inputs \& outputs for the 18-bit Port A bus. |
| $\overline{\mathrm{CS}} \mathrm{A}$ | Chip Select A | 1 | Port $A$ is accessed when $\overline{C S} A$ is LOW. Port A is inactive if $\overline{C S A}$ is HIGH. |
| $\mathrm{R} \bar{W}_{A}$ | Read/Write A | 1 | This pin controls the read or write direction of Port $A$. If RWW is LOW, Data A input data is written into Port $A$. If $R \bar{W} A$ is HIGH, Data A output data is read from Port $A$. In bypass mode, when $R \bar{W}_{A}$ is LOW, message is written into $A \rightarrow B$ output register. If $R \bar{W}_{A}$ is HIGH, message is read from $B \rightarrow A$ output register. |
| CLKA | Clock A | 1 | CLKA is typically a free running clock. Data is read or written into Port A on the rising edge of CLKA. |
| $\overline{\mathrm{EN}}$ A | Enable A | I | When $\overline{E N} A$ is LOW, data can be read or written to Port A. When ENA is HIGH, no data transfers occur. |
| $\overline{\mathrm{OE}} \mathrm{A}$ | Output Enable A | I | When R/ $\bar{W}_{A}$ is HIGH , Port $A$ is an output bus and $\overline{O E}_{A}$ controls the high impedance state of DaO-Da17. If $\overline{O E}_{A}$ is HIGH, Port $A$ is in a high impedance state. If $\overline{O E} A$ is LOW while $\overline{C S A}$ is LOW and $R / \bar{W}_{A}$ is HIGH, Port $A$ is in an active (low impedance) state. |
| A0, A1, A2 | Addresses | 1 | When $\overline{C S} A$ is asserted, $A_{0}, A_{1}, A_{2}$ and R $\bar{W}_{A}$ are used to select one of six internal resources. |
| DB0-D817 | Data B | 1/0 | Data inputs \& outputs for the 18 -bit Port B bus. |
| $\mathrm{R} \overline{\mathrm{W}}$ B | Read/Write B | 1 | This pin controls the read or write direction of Port B. If $\mathrm{R} \overline{\mathrm{W}} \mathrm{B}$ is LOW, Data B input data is written into Port B. If R/WB is HIGH, Data B output data is read from Port B. In bypass mode, when $R \bar{W}_{B}$ is LOW, message is written into $A \rightarrow B$ output register. If $R \bar{W}_{B}$ is HIGH, message is read from $B \rightarrow A$ output register. |
| CLKB | Clock B | 1 | Clock B is typically a free running clock. Data is read or written into Port B on the rising edge of CLKB. |
| $\overline{\mathrm{EN}} \mathrm{B}$ | Enable B | 1 | When ENB is LOW, data can be read or written to Port B . When $\overline{\mathrm{EN}} \mathrm{B}$ is HIGH, no data transfers occur. |
| $\overline{\mathrm{OEB}}$ | Output Enable B | 1 | When $\mathrm{R} \bar{W}_{B}$ is HIGH , Port B is an output bus and $\overline{\mathrm{OE}} \mathrm{B}$ controls the high impedance state of Dro-DB17. If $\overline{\mathrm{OE}} \mathrm{B}$ is HIGH , Port B is in a high impedance state. If $\overline{O E}_{B}$ is LOW while $\mathrm{R} \bar{W}_{B}$ is HIGH, Port B is in an active (low impedance) state. |
| $\overline{E F F}^{\text {AB }}$ | A $\rightarrow$ B Empty Flag | 0 | When $\overline{E F F}_{A B}$ is LOW, the $A \rightarrow B$ FIFO is empty and further data reads from Port $B$ are inhibited. When EFAB is HIGH, the FIFO is not empty. EFAB is synchronized to CLKB. In the bypass mode, EFAB HIGH indicates that data DAO-DA17 is available for passing through. After the data DBo-D817 has been read, EFAB goes LOW. |
| $\overline{\text { PAEAB }}$ | $A \rightarrow B$ <br> Programmable <br> Almost-Empty Flag | 0 | When $\overline{\text { PAEAB }}$ is LOW, the $A \rightarrow B$ FIFO is almost empty. An almost empty FIFO contains less than or equal to the offset programmed into PAEAB Register. When PAEAB is HIGH, the $\mathrm{A} \rightarrow \mathrm{B}$ FIFO contains more than offset in $\overline{\mathrm{PAE}}_{A B}$ Register. The default offset value for $\overline{\mathrm{PAE}} \mathrm{AB}$ Register is 8. $\overline{\mathrm{PAE}} \mathrm{AB}$ is synchronized to CLKB. |
| $\overline{\text { PAF }}^{\text {AB }}$ | $A \rightarrow B$ <br> Programmable Almost-Full Flag | 0 | When $\overline{\mathrm{PAF}}_{\text {AB }}$ is LOW, the $\mathrm{A} \rightarrow \mathrm{B}$ FIFO is almost full. An almost full FIFO contains greater than the FIFO depth minus the offset programmed into $\overline{\mathrm{PAF}}_{A B}$ Register. When $\overline{\mathrm{PAF}}_{\mathrm{AB}}$ is HIGH, the $A \rightarrow B$ FIFO contains less than or equal to the depth minus the offset in $\overline{\text { PAFAB }}$ Register. The default offset value for $\overline{\text { PAF }} A B$ Register is 8 . $\overline{P A F A B ~}_{A B}$ is synchronized to CLKA. |
| $\overline{\text { FF }}$ AB | $\mathrm{A} \rightarrow$ B Full Flag | 0 | When $\overline{F F}_{A B}$ is LOW, the $A \rightarrow B$ FIFO is full and further data writes into Port $A$ are inhibited. When $\overline{F F}_{A B}$ is HIGH, the FIFO is not full. $\overline{F F}_{A B}$ is synchronized to CLKA. In bypass mode, $\overline{\text { FF }}_{A B}$ tells Port $A$ that a message is waiting in Port B's output register. If $\overline{F F}_{A B}$ is LOW, a bypass message is in the register. If FFAB is HIGH, Port B has read the message and another message can be written into Port $A$. |
| $\overline{E F B A}$ | $\mathrm{B} \rightarrow \mathrm{A}$ Empty Flag | 0 | When EFBA is LOW, the B $\rightarrow \mathrm{A}$ FIFO is empty and further data reads from Port A are inhibited. When $\overline{E F B A}_{B A}$ is HIGH, the FIFO is not empty. EFBA is synchronized to CLKA. In the bypass mode, EFBA HIGH indicates that data D8o-DB17 is available for passing through. After the data Dao-Dait has been read, EFBA goes LOW on the following cycle. |
| $\overline{\text { PAEBA }}$ | $B \rightarrow A$ <br> Programmable <br> Almost-Empty Flag | 0 | When $\overline{\text { PAEBA }}$ B is LOW, the B $\rightarrow \mathrm{A}$ FIFO is almost empty. An almost empty FIFO contains less than or equal to the offset programmed into PAEBA Register. When PAEBA is HIGH, the $\mathrm{B} \rightarrow \mathrm{A}$ FIFO contains more than offset in $\overline{\mathrm{PAE}} \mathrm{BA}$ Register. The default offset value for $\overline{\mathrm{PAE}} \mathrm{BA}$ Register is 8. $\overline{\text { PAEBA }}$ is synchronized to CLKA. |
| $\overline{\text { PAF }}{ }^{\text {A }}$ | $\overline{B \rightarrow A}$ <br> Programmable Almost-Full Flag | 0 | When $\overline{\text { PAF }} \mathrm{BA}$ is LOW, the $\mathrm{B} \rightarrow \mathrm{A}$ FIFO is almost full. An almost full FIFO contains greater than the FIFO depth minus the offset programmed into $\overline{\text { PAF }}_{B A}$ Register. When $\overline{\text { PAF }}^{\prime} B A$ is HIGH, the B $\rightarrow \mathrm{A}$ FIFO contains less than or equal to the depth minus the offset in $\overline{\mathrm{PAF}} \mathrm{BA}$ Register. The default offset value for $\overline{\text { PAFBA Register is } 8 . ~ \overline{P A F B A}}$ is synchronized to CLKB. |

PIN DESCRIPTION (Continued)

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{FF}} \mathrm{BA}$ | B $\rightarrow$ A Full Flag | 0 | When $\overline{F F} B A$ is LOW, the $B \rightarrow A$ FIFO is full and further data writes into Port $B$ are inhibited. When $\overline{F F}_{B A}$ is HIGH, the FIFO is not full. $\overline{F F}_{B A}$ is synchronized to CLKB. In bypass mode, $\overline{F F} B A$ tells Port B that a message is waiting in Port A's output register. If $\overline{F F B A}$ is LOW, a bypass message is in the register. If FFBA is HIGH, Port A has read the message and another message can be written into Port B. |
| BYPB | Port B Bypass Flag | 0 | This flag informs Port B that the Synchronous BiFIFO is in bypass mode. When BYPB is LOW, Port A has placed the FIFO into bypass mode. If BYPB is HIGH, the Synchronous BiFIFO passes data into memory. BYPB is synchronized to CLKB. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | A LOW on this pin will perform a reset of all Synchronous BiFIFO functions. |
| Vcc | Power |  | There are three +5 V power pins. |
| GND | Ground |  | There are seven Ground pins at OV. |

2704 thl 01

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Mil. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to Ground | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than those listedunder ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC

OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCCM | Military Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| VCCC | Commercial Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH | Input High Voltage Military | 2.2 | - | - | V |
| $\mathrm{VIL}^{(1)}$ | Input Low Voltage <br> Commercial and Military | - | - | 0.8 | V |

NOTE:

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

CAPACITANCE ( $T A=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN $^{(2)}$ | Input Capacitance | VIN $=0 \mathrm{~V}$ | 10 | pF |
| COUT $^{(1,2)}$ | Output Capacitance | VOUT $=0 \mathrm{~V}$ | 10 | pF |

NOTES:

1. With output deselected.
2. Characterized values, not currently tested.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72615L <br> IDT72605L <br> Commercial $\text { tCLK }=25,35,50 \mathrm{~ns}$ |  |  | IDT72615L <br> IDT72605L Military tCLK $=30,35,50 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $11{ }^{(1)}$ | Input Leakage Current (Any Input) | -1 | - | 1 | -10 | - | 10 | $\mu \mathrm{A}$ |
| $1 \mathrm{OL}^{(2)}$ | Output Leakage Current | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage IOUT $=-2 \mathrm{~mA}$ | 2.4 | - | - | 2.4 | - | - | V |
| Vol | Output Logic "0" Voltage lout $=8 \mathrm{~mA}$ | - | - | 0.4 | - | - | 0.4 | V |
| Icc ${ }^{(3)}$ | Average Vcc Power Supply Current | - | - | 250 | - | - | 300 | mA |

NOTES:

1. Measurements with $0.4 \mathrm{~V} \leq \mathrm{V} \mathbb{I N} \leq \mathrm{Vcc}$.
2. $\overline{O E} \geq \mathrm{VIH}_{\mathrm{H}} ; 0.4 \leq$ VOUT $\leq$ VCc.
3. Tested with outputs open.

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 3 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 2 |



Flgure 2. Ouiput Load

* Includes jig and scope capacitances.


## AC ELECTRICAL CHARACTERISTICS

(Commercial: Vcc $=5 \mathrm{~V} \pm 10 \%$, $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Military: Vcc $=5 \mathrm{~V} \pm 10 \%$, $\mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter |  | m'l. |  | Mil. | Com'l. and Mil. |  |  |  |  | Timing |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{gathered} \text { 615L25 } \\ \text { 605L25 } \\ \text { Max. } \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { IDT7261 } \\ \text { IDT7260 } \\ \text { Min. } \end{array}$ | 615L30 <br> 605L30 <br> Max. | $\begin{gathered} \text { IDT72615L35 } \\ \text { IDT72605L35 } \\ \text { MIn. Max. } \\ \hline \end{gathered}$ |  | IDT72615L50 <br> IDT72605L50 <br> Min. Max. |  | Unit |  |
| fCLK | Clock frequency | - | 40 | - | 33 | - | 28 | - | 20 | MHz | - |
| tCLK | Clock cycle time | 25 | - | 30 | - | 35 | - | 50 | - | ns | 4,5,6,7 |
| tCLKH | Clock high time | 10 | - | 12 | - | 14 | - | 20 | - | ns | 4,5,6,7,12,13,14,15 |
| tCLKL | Clock low time | 10 | - | 12 | - | 14 | - | 20 | - | ns | 4,5,6,7,12,13,14,15 |
| tRS | Reset pulse width | 25 | - | 30 | - | 35 | - | 50 | - | ns | 3 |
| tRSS | Reset set-up time | 15 | - | 18 | - | 21 | - | 30 | - | ns | 3 |
| trSF | Reset to flags in intial state | - | 25 |  | 30 | - | 35 | - | 50 | ns | 3 |
| tA | Data access time | 3 | 15 | 3 | 18 | 3 | 21 | 3 | 25 | ns | 5,7,8,9,10,11 |
| tcs | Control signal set-up time ${ }^{(1)}$ | 6 | - | 7 | - | 8 | - | 10 | - | ns | $\begin{aligned} & 4,5,6,7,8,9,10,11,12 \\ & 13,14,15 \end{aligned}$ |
| tch | Control signal hold time ${ }^{(1)}$ | 1 | - | 1 | - | 1 | - | 1 | - | ns | $\begin{aligned} & 4,5,6,7,10,11,12,13 \\ & 14,15 \end{aligned}$ |
| tDS | Data set-up time | 6 | - | 7 | - | 8 | - | 10 | - | ns | 4,6,8,9,10,11 |
| tDH | Data hold time | 1 | - | 1 | 二 | 1 | - | 1 | - | ns | 4,6 |
| toE | Output Enable LOW to output data valid ${ }^{(2)}$ | 3 | 13 | 3 | 16 | 3 | 20 | 3 | 28 | ns | 5,7,8,9,10,11 |
| tolz | Output Enable LOW to data bus at low $\mathrm{Z}^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns | 5,7,8,9,10,11 |
| torz | Output Enable HIGH to data bus at high $\mathrm{Z}^{(2)}$ | 3 | 13 |  | 16 |  | 20 | 3 | 28 | ns | 5,7,10,11 |
| tFF | Clock to Full Flag time | - | 15 | - | 18 | - | 21 | - | 30 | ns | 4,6,10,11 |
| tEF | Clock to Empty Flag time | - | 15 | - | 18 | - | 21 | - | 30 | ns | 5,7,8,9,10,11 |
| tPAE | Clock to Programmable Almost Empty Flag time | - | 15 |  |  |  | 21 | - | 30 | ns | 12,14 |
| tPAF | Clock to Programmable Almost Full Flag time | - | 15 |  | 18 |  | 21 | - | 30 | ns | 13,15 |
| tSKEW1 | Skew between CLKA \& CLKB for Empty/Full Flags | 12 | - | 15 | - | 17 | - | 20 | - | ns | 4,5,6,7,8,9,10,11 |
| tSKEW2 | Skew between CLKA \& CLKB for Programmable Flags | 19 | - |  | - |  | - | 34 | - | ns | 4, 7,12,13,14,15 |

NOTES

1. Control signals refer to $\overline{C S}_{A}, R \overline{W W}_{A}, \overline{E N}_{A}, A 2, A 1, A 0, R / \bar{W} B, \overline{E N B}$.
2. Minimum values are guaranteed by design.

## FUNCTIONAL DESCRIPTION

IDT's SyncBiFIFO is versatile for both multiprocessor and peripheral applications. Data can be stored or retrieved from two sources simultaneously.

The SyncBiFIFO has registers on all inputs and outputs. Data is only transferred into the I/O registers on clock edges, hence the interfaces are synchronous. Two dual-port FIFO memory arrays are contained in the SyncBiFIFO; one data buffer for each direction. Each Port has its own independent clock. Data transfers to the I/O registers are gated by the enable signals. The transfer direction for each port is controlled independently by a read/write signal. Individual output enable signals control whether the SyncBiFIFO is driving the data lines of a port or whether those data lines are in a high impedance state. The processor connected to Port A of the BiFIFO can send or receive messages directly to the Port B device using the 18-bit bypass path.

The SyncBiFIFO can be used in multiples of 18 -bits. The upper SyncBiFIFO shown in Figures 1 can be used in 18- to 18-bit configurations for processor interface mode. In a 36- to 36-bit configuration, two SyncBiFIFOs operate in parallel. Both devices are programmed simultaneously, 18 data bits to each device. This configuration can be extended to wider bus widths (54- to 54-bits, 72- to 72-bits, etc.) by adding more SyncBiFIFOs to the configuration. Figure 1 show multiple SyncBiFIFOs configured for multiprocessor communication.

The microprocessor or microcontroller connected to Port A controls all operations of the SyncBiFIFO. Thus, all Port A interface pins are inputs driven by the controlling processor. Port B interfaces with a second processor. The Port B control pins are inputs driven by the second processor.

## RESET

Reset is accomplished whenever the Reset ( $\overline{\mathrm{RS}}$ ) input is taken to a low state. During reset, both intemal read and write pointers are set to the first location. A reset is required after power up before a write operation can take place. The $A \rightarrow B$ and $B \rightarrow A$ FIFO Empty Flags ( $\overline{E F} A B, \overline{E F} B A$ ) and Programmable Almost Empty Flags ( $\overline{\mathrm{PAE}} \mathrm{AB}, \overline{\mathrm{PAE}} \mathrm{BA}$ ) will be set to low after trsF. The $A \rightarrow B$ and $B \rightarrow A$ FIFO Full Flags ( $\overline{\mathrm{FF}} \mathrm{AB}, \overline{\mathrm{FF}} \mathrm{BA}$ ) and Programmable Almost Full Flags ( $\overline{\text { PAFAB }}, \overline{\text { PAFBA) will be set to high after tRSF. After the }}$ reset, the offsets of the Almost-Empty Flags and AlmostFull Flags for the $\mathrm{A} \rightarrow \mathrm{B}$ and $\mathrm{B} \rightarrow \mathrm{A}$ FIFO offset default to 8 .

## PORT A INTERFACE

The SyncBiFIFO ${ }^{\text {mM }}$ is straightiorward to use in micro-processor-based systems because each port has a standard microprocessor control set. Port A interfaces with microprocessor through the three address pins (A2-A0) and a Chip Select $\overline{C S A}$ pins. When $\overline{C S A}$ is asserted, $A 2, A 1, A 0$ and $R / \bar{W}_{A}$ are used to select one of six internal resources (Table 1).

With $A 2=0$ and $A 1=0$, A0 determines whether data can be read out of output register or be written into the FIFO ( $\mathrm{A} 0=0$ ), or the data can pass through the FIFO through the bypass path ( $A 0=1$ ).

With $A 2=1$, four programmable flags (two $A \rightarrow B$ FIFO programmable flags and two $B \rightarrow A$ FIFO programmable flags) can be selected: the $\mathrm{A} \rightarrow \mathrm{B}$ FIFO Almost-Empty Flag Offset ( $\mathrm{A} 1=0, \mathrm{~A} 0=0$ ), $A \rightarrow B$ FIFO Almost-Full Flag Offset ( $A 1=0, A 0=1$ ), B $\rightarrow A$ FIFO Almost-Empty Flag Offset ( $A 1=1$, $A 0=0$ ), $B \rightarrow A$ FIFO Almost-Full Flag Offset ( $A 1=1, A 0=1$ ).

Port $A$ is disabled when $\overline{C S} A$ is deasserted and data $A$ is in high impedance state.


2704 drw 04
NOTES:

1. Upper SyncBiFIFO only is used in 18 - to 18 -bit configuration.
2. Control $A$ Consists of $R / W_{A}, \overline{E N}_{A}, \overline{O E}_{A}, \overline{C S}_{A}, A_{2}, A_{1}, A 0$. Control $B$ consists of $R \bar{W} B, \overline{E N B}_{B}, \overline{O E}_{B}$.

Figure 1. 36- to 36 -blt Processor Interface Configuration

| $\overline{\mathrm{CS}} \mathbf{A}$ | R/W ${ }_{\text {A }}$ | ENA | OEA | Data A VO | Port A Operatlon |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 | Data $A$ is written on CLKA $\uparrow$. This write cycle immediately following low impedance cycle is prohibited. |
| 0 | 0 | 0 | 1 | 1 | Data $A$ is written on CLKA $\uparrow$. |
| 0 | 0 | 1 | X | 1 | Data $A$ is ignored |
| 0 | 1 | 0 | 0 | 0 | Data is read ${ }^{\text {(1) }}$ from RAM array to output register on CLKA $\uparrow$, Data $A$ is low impedance |
| 0 | 1 | 0 | 1 | 0 | Data is read(1) from RAM array to output register on CLKA $\uparrow$, Data $A$ is high impedance |
| 0 | 1 | 1 | 0 | 0 | Output register does not change ${ }^{(2)}$, Data A is low impedance |
| 0 | 1 | 1 | 1 | 0 | Output register does not change ${ }^{(2)}$, Data $A$ is high impedance |
| 1 | 0 | X | X | 1 | Data $A$ is ignored (3) |
| 1 | 1 | X | X | 0 | Data $A$ is high impedance(3) |

NOTES
2704 blos

1. When $A_{2} A_{1} A 0=000$, the next $B \rightarrow A$ FIFO value is read out of the output register and the read pointer advances. If $A_{2} A 1 A 0=001$, the bypass path is selected and bypass data from the Port $B$ input register is read from the Port $A$ output register. If $A_{2} A_{1} A 00=1 X X$, a flag offset register is selected and its offset is read out through Port A output register.
2. Regardless of the condition of $A_{2} A_{1} A_{0}$, the data in the Port $A$ output register does not change and the $B \rightarrow A$ read pointer does not advance.
3. If CSA is HIGH, then BYPB is HIGH. No bypass occur under this condition.

Table 1. Port A Operation Control Signals

## BYPASS PATH

The bypass paths provide direct communication between Port A and Port B. There are two full 18 -bit bypass paths, one in each direction. During a bypass operation data is passed directly between the input and output registers, the FIFO memory is undisturbed.

Port A initiates and terminates all bypass operations. The bypass flag, BYPB, is asserted to inform Port B that a bypass operation is beginning. The bypass flag state is controlled by the Port A controls, atthough the BYPB signal is synchronized to CLKB. So, BYPB is asserted on the next rising edge of CLKB when $\mathrm{A}_{2} \mathrm{~A} 1 \mathrm{~A} 0=001$. When Port A returns to normal FIFO mode ( $\mathrm{A} 2 \mathrm{~A} 1 \mathrm{~A} 0=000$ ), BYPB is deasserted on the next CLKB rising edge.

Once the SyncBiFIFO is in bypass mode, all data transfers are controlled by the standard Port A ( $\overline{\mathrm{CS}} \mathrm{A}, \mathrm{R} / \overline{\mathrm{W}} \mathrm{A}, \mathrm{CLKA}$,
 pins. Each bypass path can be considered as a one word deep FIFO. Data is held in each output register until it is read. Since the controls of each port operates independently, Port A can be reading bypass data at the same time Port $B$ is reading bypass data.

When R/WA and ENA is LOW, data on pins DAO-DA17 is written into Port A through the input register. Following the rising edge of CLKA for this write, the $\mathrm{A} \rightarrow \mathrm{B}$ Full Flag (FFAB) goes LOW. Subsequent writes into Port A are blocked by internal logic until $\overline{F F}_{A B}$ goes HIGH again. On the next CLKB rising edge, the $A \rightarrow B$ Empty Flag (EFAB) goes HIGH indicating to Port B that data is available at its output register. Once RNB is HIGH and ENB is LOW, data is read into the Port B output register. OEB still controls whether Port B is in a high-impedance state. When $\overline{O E} B$ is LOW, the output register data appears at DBo-DB17. EFAB goes LOW following the CLKB rising edge for this read. FFAB $^{\text {A }}$ is brought

HIGH on the next CLKA rising edge letting Port A know that another word can be written through the bypass path.

Bypass data transfers from Port B to Port A work in a similar manner with EFBA, $\overline{F F}_{B A}$ indicating the Port A output register state.

When the Port A address changes from bypass mode ( $\mathrm{A}_{2} \mathrm{~A}_{1} \mathrm{~A} 0=001$ ) to FIFO mode ( $\mathrm{A}_{2} \mathrm{~A}_{1} \mathrm{~A}_{\mathrm{O}}=000$ ) on the rising edge of CLKA, the data held in the Port B output register may be overwritten. Unless Port A monitors the BYPB pin and waits for Port $B$ to clock out the last bypass word, data from the $A \rightarrow B$ FIFO will overwrite data in the Port $B$ output register. BYPB will go HIGH on the rising edge of CLKB signifying that Port B has finished its last bypass operation. Port B must read any bypass data in the output register on this last CLKB clock or it is lost and the SyncBiFIFO returns to FIFO operations. It is especially important to monitor BYPB when CLKB is much slower than CLKA to avoid this condition. BYPB will also go HIGH after CSA is brought HIGH; in this manner the Port B bypass data in the output register may also be lost.
Since the Port A processor controls CSA and the bypass mode, this scenario can be handled for $\mathrm{B} \rightarrow \mathrm{A}$ bypass data. The Port A processor must be set up to read the last bypass word before leaving bypass mode.

## PORT A CONTROL SIGNALS

The Port A control signals pins dictate the various operations shown in Table 2. Port A is accessed when $\overline{C S}_{A}$ is LOW, and is inactive if $\overline{C S A}$ is HIGH. R $\bar{W} A$ and ENA lines determine when Data A can be written or read. If $R / \bar{W} A$ and $\overline{E N} A$ are LOW, data is written into input register on the low-to-high transition of CLKA. If R/WA is HIGH and $\overline{O E A}_{A}$ is LOW, data comes out of bus and is read from output register into three-state buffer. Refer to pin descriptions for more information.

| $\overline{\text { CSA }}$ | A2 | A1 | Ao | Read | Write |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | $\mathrm{~B} \rightarrow$ A FIFO | A $\rightarrow$ B FIFO |
| 0 | 0 | 0 | 1 | 18 -bit Bypass Path |  |
| 0 | 1 | 0 | 0 | A $\rightarrow$ B FIFO Almost-Empty <br> Flag Offset |  |
| 0 | 1 | 0 | 1 | A $\rightarrow$ B FIFO Almost-Full <br> Flag Offset |  |
| 0 | 1 | 1 | 0 | $\mathrm{B} \rightarrow$ A FIFO Almost-Empty <br> Flag Offset |  |
| 0 | 1 | 1 | 1 | B $\rightarrow$ A FIFO Almost-Full <br> Flag Offset |  |
| 1 | X | X | X | Port A Disabled |  |

Table 2. Accessing Port A Resources Using $\overline{C S} A, A_{2}, A_{1}$, and $A 0$

## PROGRAMMABLE FLAGS

The IDT SyncBiFIFO has eight flags: four flags for $A \rightarrow B$ FIFO ( $\mathrm{EFAB}_{A B}, \overline{\mathrm{PAE}} \mathrm{AB}, \overline{\mathrm{PAFAB}}, \overline{\mathrm{FF}} \mathrm{AB}$ ), and four flags for $\mathrm{B} \rightarrow \mathrm{A}$ FIFO ( $\overline{\mathrm{EF}} \mathrm{BA}, \overline{\mathrm{PAE}} \mathrm{BA}, \overline{\mathrm{PAF}} \mathrm{BA}, \overline{\mathrm{FF}} \mathrm{BA})$. The Empty and Full flags have fixed offsets, while the Almost Empty and Almost Full offsets can be set to any depth through the Flag Offset Registers (see Table 3). The flags are asserted at the depths shown in the Flag Truth Table (Table 4). After reset, the programmable flag offsets are set to 8 . This means the Almost Empty flags are asserted at Empty +8
words deep, and the Almost Full flags are asserted at Full 8 words deep.

The $\overline{\mathrm{PAEAB}}^{2}$ is synchronized to CLKB, while $\overline{\mathrm{PAF}}_{\mathrm{AB}}$ is synchronized to CLKA; and $\overline{\text { PAE }}$ BA is synchronized to CLKA, while $\overline{\text { PAF }} B A$ is synchronized to CLKB. If the minimum time (tSKEW2) between a rising CLKB and a rising CLKA is met, the flag will change state on the current clock; otherwise, the flag may not change state until the next clock rising edge. For the specific flag timings, refer to Figures 12-15.
$\overline{\text { PAE }}_{\text {AB }}$ Register

| 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | X | X | X | X | X | X | X |  |  |  |  |  |  | g |  |  |

$\overline{\text { PAF }}_{\text {AB }}$ Register

| 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | X | X | X | X | X | X | X |  | $\mathrm{A} \rightarrow \mathrm{B}$ |  |  |  |  |  |  |

$\overline{\text { PAEBA Register }}$
$\overline{\text { PAFBA Register }}$

| 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | X | X | X | X | X | X | X | $\mathrm{B} \rightarrow$ A FIFO Almost-Empty Flag Offset |  |  |  |  |  |  |  |  |
| 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| X | X | X | X | X | X | X | X | X | $\mathrm{B} \rightarrow \mathrm{A}$ FIFO Almost-Full Flag Offset |  |  |  |  |  |  |  |  |

NOTE:

1. Bit 8 must be set to 0 for the IDT72605 ( $256 \times 18$ ) Synchronous BiFIFO.

Table 3. Flag Offset Reglster Format

| Number of Words In FIFO |  | $\overline{E F}$ | $\overline{\text { PAE }}$ | $\overline{\text { PAF }}$ | $\overline{\text { FF }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| From | To |  |  |  |  |
| 0 | 0 | Low | Low | High | High |
| 1 | n | High | Low | High | High |
| n+1 | D-(m+1) | High | High | High | High |
| D-m | D-1 | High | High | Low | High |
| D | D | High | High | Low | Low |

$\mathrm{n}=$ Programmable Empty Offset ( $\overline{\text { PAE }}_{\mathrm{AB}}$ Register or $\overline{\text { PAE }}_{\mathrm{BA}}$ Register)
$m=$ Programmable Full Offset (PAFAB Register or PAFBA Register)
D = FIFO Depth (IDT72605 = 256 words, IDT72615=512 words)
Table 4. Internal Flag Truth Table

## PORT B CONTROL SIGNALS

The Port B control signals pins dictate the various operations shown in Table 5. Port B is independent of $\overline{\mathrm{CS}} \mathrm{A}$. $\mathrm{R} \overline{\mathrm{W}} \mathrm{B}$ and $\overline{\mathrm{ENB}} \mathrm{l}$ lines determine when Data can be written or read in Port B. If $\mathrm{R} \bar{W} \mathrm{~B}$ and $\overline{\mathrm{EN}} \mathrm{B}$ are LOW, data is written into input register, and on low-to-high transition of CLKB data is written into input register and the FIFO memory.

If $\mathrm{R} \overline{\mathrm{W}} \mathrm{B}$ is HIGH and $\overline{\mathrm{OE}}_{\mathrm{B}}$ is LOW, data comes out of bus and is read from output register into three-state buffer. In bypass mode, if R/WB is LOW, bypass messages are transferred into $B \rightarrow A$ output register. If $R \bar{W} A$ is HIGH, bypass messages are transferred into $A \rightarrow B$ output register. Refer to pin descriptions for more information.

| R/ $/ \bar{W}$ B | ENB | $\overline{\mathrm{OEB}}$ | Data B /O | Port B Operation |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | I | Data B is written on CLKB $\uparrow$. This write cycle immediately foliowing output low impedance cycle is prohibited |
| 0 | 0 | 1 | I | Data B is written on CLKB $\uparrow$. |
| 0 | 1 | X | 1 | Data B is ignored |
| 1 | 0 | 0 | 0 | Data is read(1) from RAM array to output register on CLKB $\uparrow$, Data B is low impedance |
| 1 | 0 | 1 | 0 | Data is read ${ }^{(1)}$ from RAM array to output register on CLKB $\uparrow$, Data B is high impedance |
| 1 | 1 | 0 | 0 | Output register does not change ${ }^{(2)}$, Data $\mathbf{B}$ is low impedance |
| 1 | 1 | 1 | 0 | Output register does not change(2), Data $B$ is high impedance |

NOTES:
2704 tol 08

1. When $A_{2} A_{1} A_{0}=000$ or $1 X X$, the next $A \rightarrow B$ FIFO value is read out of the output register and the read pointer advances. If $A_{2} A_{1} A_{0}=001$, the bypass path is selected and bypass data is read from the Port B output register.
2. Regardless of the condition of $A 2 A 1 A 0$, the data in the Port $B$ output register does not change and the $A \rightarrow B$ read pointer does not advance.

Table 5. Port B Operation Control Signals


2704 drw 06
Figure 3. Reset TIming


Figure 4. Port $A(A \rightarrow B)$ Write Timing


2704 drw 08
Figure 5. Port $A(B \rightarrow A)$ Read Timing


Figure 6. Port $B(B \rightarrow A)$ Write Timing


Figure 7. Port $B(A \rightarrow B)$ Read Timing


6
NOTE:

1. When tsKew $1 \geq$ minimum specification, trRL(Max.) $=$ tCLK + tSKEW 1
tsKEW1 < minimum specification, tFRL(Max.) $=2$ tCLK + tsKEW1
The Latency Timing apply only at the Empty Boundary ( $\overline{\mathrm{EF}}=$ Low).
Figure 8. A $\rightarrow$ B First Data Word Latency after Reset for Simultaneous Read and Write


NOTE:

1. When tskew $1 \geq$ minimum specification, $t$ FRL(Max. $)=$ tCLK + tskEw 1 tSKEW1 < minimum specification, tFRL(Max.) $=$ 2tcLK + tsKEW1
The Latency Timing apply only at the Empty Boundary ( $\overline{\mathrm{EF}}=$ Low).
Figure 9. B $\rightarrow$ A First Data Word Latency after Reset for Simultaneous Read and Write


NOTES:

1. When $\overline{C S}_{A}$ is brought HIGH, $A \rightarrow B$ Bypass mode will switch to FIFO mode on the following CLKA going low-to-high.
2. After the bypass operation is completed, the BYPB goes from low-to-high; this will reset all bypass flags. The bypass path becomes available for the next bypass operation.
3. When A-side changed from bypass mode into FIFO mode, B-side only has one cycle to read the bypass data. On the next cycle, B-side will be forced back to FIFO mode.

Figure 10. $\mathbf{A} \rightarrow \mathrm{B}$ Bypass Timing


2704 drw 14
NOTES:

1. When $\overline{\mathrm{CS}}$ A is brought $\mathrm{HIGH}, \mathrm{A} \rightarrow \mathrm{B}$ Bypass mode will switch to FIFO mode on the following CLKA going low-to-high.
2. After the bypass operation is completed, the $\overline{\mathrm{BYPB}}$ goes from low-to-high; this will reset all bypass flags. The bypass path becomes available for the next bypass operation.
3. When A-side changed from bypass mode into FIFO mode, B-side only has one cycle to read the bypass data. On the next cycle, B-side will be forced back to FIFO mode.

Figure 11. $\mathrm{B} \rightarrow \mathrm{A}$ Bypass Timing


## NOTES:

1. tSKEW the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{P A E}_{A B}$ to change during that clock cycle. If the time between the rising edge of CLKA and the rising edge of CLKB is less than tSKEW, then PAEAB may not go HIGH until the next CLKB rising edge.
2. If a read is performed on this rising edge of the read clock, there will be Empty $+(n+1)$ words in the FIFO when PAE goes low.

Figure 12. A $\rightarrow$ B Programmable Almosi-Empty Flag Timing


NOTES:

1. tSKEW2 is the minimum time between a rising CLKg edge and a rising CLKA edge for $\overline{\text { PAF }}_{A B}$ to change during that clock cycle. If the time between the rising edge of CLKB and the rising edge of CLKA is less than tsKewz, then PAFAB may not go HIGH until the next CLKA rising edge.
2. If a write is performed on this rising edge of the write clock, there will be Full - ( $m+1$ ) words in the FIFO when $\overline{\text { PAF gces low. }}$

Figure 13. $\mathbf{A} \rightarrow \mathrm{B}$ Programmable Almost-Full Flag Timing


## NOTES:

1. tSKEWz is the minimum time between a rising CLKB edge and a rising CLKA edge for PAEBA to change during that dock cycle. If the time between the rising edge of CLKB and the rising edge of CLKA is less than tskewz, then PAEBA may not go HIGH until the next CLKKA rising edge.
2. If a read is performed on this rising edge of the read clock, there will be Empty $+(n-1)$ words in the FIFO when PAE goes low.

Figure 14: $B \rightarrow A$ Programmable Almost-Empty Flag Timing


## NOTES:

1. tSKEW2 is the minimum time between a rising CLKB edge and a rising CLKA edge for $\overline{P A F B A}$ to change during that clock cycle. If the time between the rising edge of CLKB and the rising edge of CLKA is less than tskewz, then PAFBA may not go HIGH until the next CLKA rising edge.
2. If a write is performed on this rising edge of the write clock, there will be Full - $(m+1)$ words in the FIFO when PAF goes low.

Figure 15. $\mathbf{B} \rightarrow \mathrm{A}$ Programmable Almost-Full Flag Timing

## ORDERING INFORMATION



# CEMERAL MHORMATOR 

# TEOHNOLOCY AND CAPABHMTES 

QUALITY AND RELIABLITY

## PAORARE DIACRAM OUTLWNES

ECl PRODUCTS

FHOPRODUCTS

## SPECIALTY MEMORY PRODUCTS

SUBSYSTEMS PRODUCTS

APPLICATION AND TECHNHCA NOTES

## MULTI-PORT RAMS

Integrated Device Technology has emerged as the leading multi-port RAM supplier by combining CEMOS technology with innovative circuit design. With system performance advantages as a goal, we have brought system design expertise together with circuit and technology expertise in defining dual-port and four-port RAM products. Our dual-port memories are now industry standards.

The synergistic relationship between advanced process technology, system expertise and unique design capability add value beyond that normally achieved. As an example, our dual-port memories provide arbitration along with a completely tested solution to the metastability problem. Various arbitration techniques are available to the designer to prevent contention and system wait states. On-chip hardware arbitration, "semaphore" token passing or software arbitration allow
the most efficient memory to be selected for each application. At IDT, innovation counts only when it provides system advantages to the user.

Both commercial and military versions of all IDT memories are available. Our military devices are manufactured and processed strictly in conformance with all the administrative processing and performance requirements of MIL-STD-883. Because we anticipated increased military radiation resistance requirements, all devices are also offered with special radiation resistant processing and guarantees. As the leading supplier of military specialty RAMs, IDT provides performance and quality levels second to none.

Our commercial dual-port and four-port memories, in fact, share most processing steps with military devices.

## TABLE OF CONTENTS

PAGE
SPECIALTY MEMORY PRODUCTS
IDT7130 8K (1K $\times 8$ ) Dual-Port RAM (MASTER) ..... 7.1
IDT7140 8K ( $1 \mathrm{~K} \times 8$ ) Dual-Port RAM (SLAVE) ..... 7.1
IDT7030 8K ( $1 \mathrm{~K} \times 8$ ) Dual-Port RAM (MASTER) ..... 7.2
IDT7040 8K ( $1 \mathrm{~K} \times 8$ ) Dual-Port RAM (SLAVE) ..... 7.2
IDT7010IDT70104IDT70101IDT701059K ( $1 \mathrm{~K} \times 9$ ) Dual-Port RAM (MASTER)7.3
9K (1K $\times 9$ ) Dual-Port RAM (SLAVE) ..... 7.3
9K (1K x 9) Dual-Port RAM (MASTER w/Interrupts) ..... 7.4
9K (1K x 9) Dual-Port RAM (SLAVE w/Interrupis) ..... 7.4
16K (2K x 8) Dual-Port RAM (MASTER) ..... 7.5
IDT713216K (2K x 8) Dual-Port RAM (SLAVE)7.5
IDT7142
16K (2K $\times 8$ ) Dual-Port RAM (MASTER) ..... 7.6
IDT703216K (2K $\times 8$ ) Dual-Port RAM (SLAVE)7.6
IDT7042
IDT71321
IDT71421
16K (2K x 8) Dual-Port RAM (MASTER w/Interrupts) ..... 7.7
16K (2K x 8) Dual-Port RAM (SLAVE w/Interrupts) ..... 7.7
IDT7012 18K (2K x 9) Dual-Port RAM ..... 7.8
IDT70121
18K (2K x 9) Dual-Port RAM (MASTER w/Interrupts) ..... 7.9
IDT7012518K ( $2 K \times 9$ ) Dual-Port RAM (SLAVE w/Interrupts)7.9
IDT7133IDT7143IDT7133SALAIDT7143SALAIDT7134
32K (2K x 16) Dual-Port RAM (MASTER) ..... 7.10
32K (2K x 16) Dual-Port RAM (SLAVE) ..... 7.10
32K (2K x 16) Dual-Port RAM (MASTER) ..... 7.11
32K (2K x 16) Dual-Port RAM (SLAVE) ..... 7.11
32K (4K x 8) Dual-Port RAM ..... 7.12
IDT7134SALA $32 \mathrm{~K}(4 \mathrm{~K} \times 8$ ) Dual-Port RAM ..... 7.13
IDT71342
IDT71342SA/LA
IDT7014
IDT7024
IDT7005
32K ( $4 \mathrm{~K} \times 8$ ) Dual-Port RAM (w/Semaphores) ..... 7.14 ..... 7.15
32K (4K x 8) Dual-Port RAM (w/Semaphores)
32K (4K x 8) Dual-Port RAM (w/Semaphores)
32K (4K x 9) Dual-Port RAM ..... 7.16
$64 \mathrm{~K}(4 \mathrm{~K} \times 16)$ Dual-Port RAM ..... 7.17
64K (8K x 8) Dual-Port RAM ..... 7.18
IDT7025 128K (8K x 16) Dual-Port RAM ..... 7.19
IDT7006128K (16K x 8) Dual-Port RAM7.20
IDT7050 $8 \mathrm{~K}(1 \mathrm{~K} \times 8)$ FourPort ${ }^{\text {TM }}$ RAM ..... 7.21
IDT70527.22
IDT71502 ..... 7.23
16K (2K x 8) FourPort ${ }^{\text {tM }}$ RAM


## FEATURES

- High-speed access
-Military: 25/30/35/45/55/70/90/100/120ns (max.)
-Commercial: 20/25/30/35/45/55/70/90/100ns (max.)
- Low-power operation
—IDT7130/IDT7140SA
Active: 325mW (typ.)
Standby: 5mW (typ.)
-IDT7130/IDT7140LA
Active: 325mW (typ.)
Standby: 1mW (typ.)
- MASTER IDT7130 easily expands data bus width to 16-or-more-bits using SLAVE IDT7140
- On-chip port arbitration logic (IDT7130 Only)
- BUSY output flag on IDT7130; $\bar{B}$ USY input on IDT7140
- INT flag for port-to-port communication
- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL-compatible, single $5 \mathrm{~V} \pm 10 \%$ power supply
- Military product compliant to MIL-STD-883, Class B
- Standard Military Drawing \#5962-86875


## DESCRIPTION

The IDT7130/IDT7140 are high speed $1 \mathrm{~K} \times 8$ dual-port static RAMs. The IDT7130 is designed to be used as a stand-alone 8-bit dual-port RAM or as a "MASTER" dualport RAM together with the IDT7140 "SLAVE" dual-port in 16 -bit-or-more word width systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 16-or-more-bit memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide two independent ports with separate control, address and I/O pins that permit independent asynchronous access for reads or writes to any location in memory. An automatic power down feature, controlled by $\overline{C E}$, permits the on chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only 325 mW of power at maximum access times as fast as 20 ns . Lowpower (LA) versions offer battery backup data retention capability, with each dual-port typically consuming $200 \mu w$ from a 2 V battery.

The IDT7130/IDT7140 devices are packaged in 48-pin sidebraze or plastic DIPs, 48- or 52-pin LCCs, 52-pin PLCCs, and 48-Lead flatpacks.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

FUNCTIONAL BLOCK DIAGRAM


NOTES:

1. IDT7130 (MASTER): BUSY is open drain output and requires pullup 2689 drw 01 resistor.
IDT7140 (SLAVE): $\overline{B U S Y}$ is input.
2. Open drain output: requires pullup resistor.

CEMOS is a trademark of Integrated Device Technology, Inc.

## PIN CONFIGUARATIONS



ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2689 tbl 01

1. Stresses greater than those listed under ABSOLUTEMAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.


RECOMMENDED
DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5(1)$ | - | 0.8 | V |

NOTE:
2689 th 02

1. $\mathrm{VIL}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

2689 か1 03

## DC ELECTRICAL CHARACTERISTICS OVER THE <br> OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | $\begin{aligned} & \text { IDT7130SA } \\ & \text { IDT7140SA } \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7130LA } \\ & \text { IDT7140LA } \\ & \text { Max. Max. } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \|니| | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{~V} \mathrm{~N}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lıo| | Output Leakage Current | $\overline{\mathrm{C}} \mathrm{E}=\mathrm{VIH}, \mathrm{Vout}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage $\left(1 / 00-1 / O_{7}\right)$ | $\mathrm{OL}=4.0 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| Vol | Open Drain Output <br> Low Voltage ( $\overline{\mathrm{BUSY}}, \overline{\mathrm{NT}}$ ) | $\mathrm{OL}=16 \mathrm{~mA}$ | - | 0.5 | - | 0.5 | V |
| VOH | Output High Voltage | $1 \mathrm{OH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Conditions | Version | $\begin{array}{\|c} \left.7130 \times 22^{2,6}, 6\right) \\ 7140 \times 20^{206} \\ \text { Typ. Max. } \\ \hline \end{array}$ | $\begin{aligned} & 7130 \times 2565 \\ & 7140 \times 25^{6)} \\ & \text { Typ. Max. } \\ & \hline \end{aligned}$ | $\begin{aligned} & 7130 \times 30^{(6)} \\ & 7140 \times 30^{(6)} \\ & \text { Typ. Max. } \\ & \hline \end{aligned}$ | 7130 <br> 7140 <br> Typ. | $\begin{aligned} & \begin{array}{l} \times 35(7) \\ \times 8357 \\ M a x . \end{array} \\ & \hline \end{aligned}$ | 7130 <br> 7140 <br> Typ. <br> 75 |  | Uni |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{VIL} \\ & \text { Outputs Open } \\ & \mathrm{f}=\mathrm{fmAX}^{(4)} \end{aligned}$ | Mil. $\begin{gathered}\text { SA } \\ \\ \text { LA }\end{gathered}$ | - | 75 300 <br> 75 220 | $\begin{array}{\|ll\|} \hline 75 & 290 \\ 75 & 210 \\ \hline \end{array}$ | 75 75 | $\begin{array}{r} 280 \\ 200 \\ \hline \end{array}$ | 75 | $\begin{aligned} & 230 \\ & 185 \\ & \hline \end{aligned}$ | mA |
|  |  |  | Com'l. SA | 75 260 <br> 75 190 | $\begin{array}{ll} 75 & 250 \\ 75 & 180 \\ \hline \end{array}$ | 75 240 <br> 75 170 | 75 75 | $\begin{array}{r} 195 \\ 155 \\ \hline \end{array}$ | 75 | $\begin{aligned} & 190 \\ & 145 \\ & \hline \end{aligned}$ |  |
| ISB1 | Standby Current (Both Ports - TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH}^{2}$ $f=f M A X^{(4)}$ | Mil. SA | - - | $\begin{array}{ll}25 & 75 \\ 25 & 55\end{array}$ | $25 \% 75$ $25 \% 55$ | 25 | 75 | 25 | 65 55 | mA |
|  |  |  | Com'l. SA | 25 65 <br> 25 45 | $\begin{array}{ll}25 & 65 \\ 25 & 45\end{array}$ | 25** 65 | 25 | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | 25 | 65 45 |  |
| ISB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CE}}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{\mathrm{IH}}$ Active Port Outputs Open, $f=$ fmax ${ }^{(4)}$ | Mil.SA | - - | $\begin{array}{lr} 50 & 180 \\ 50 & 8140 \\ \hline \end{array}$ | 46 175 <br> 46 135 | 40 | $\begin{aligned} & 170 \\ & 130 \\ & \hline \end{aligned}$ | 40 | $\begin{aligned} & 135 \\ & 110 \end{aligned}$ | mA |
|  |  |  | Com'l. ${ }_{\text {LA }}$ | 50 180 <br> 50 130 | $\begin{aligned} & 50 \times 170 \\ & 50 . ~ \\ & \hline 20 \end{aligned}$ | 46 155 <br> 46 110 | 40 40 | $\begin{gathered} 130 \\ 95 \end{gathered}$ | 40 | $\begin{aligned} & 120 \\ & 85 \\ & \hline \end{aligned}$ |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ Vin $\geq$ Vcc -0.2 V or $V \operatorname{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)}$ | Mil.SA | - - | $\begin{aligned} & 3.2 .40 \\ & 0.4 \quad 10 \\ & \hline \end{aligned}$ | $\begin{array}{ll} \hline 1.2 & 40 \\ 0.4 & 10 \\ \hline \end{array}$ | $\begin{aligned} & 1.2 \\ & 0.4 \\ & \hline \end{aligned}$ | $\begin{aligned} & 35 \\ & 10 \\ & \hline \end{aligned}$ | 1.0 0.2 | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | mA |
|  |  |  | Com'l. ${ }^{\text {SA }}$ | 1.2 15 <br> 0.4 $\%$ | $\begin{array}{cc} 1.2 & 15 \\ 0.4 & 4 \end{array}$ | $\begin{array}{cc} 1.2 & 15 \\ 0.4 & 4 \\ \hline \end{array}$ | 1.0 0.2 | $\begin{gathered} 15 \\ 4 \end{gathered}$ | 1.0 0.2 | $\begin{gathered} 15 \\ 4 \\ \hline \end{gathered}$ |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs, $\mathrm{f}=0^{(5)}$ ) | One Port $\overline{C E L}$ or <br> $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> Vin $\geq$ Vcc -0.2 V or <br> $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs <br> Open, $f=$ fmax ${ }^{(4)}$ | Mil. $\begin{array}{r}\text { SA } \\ \\ \hline\end{array}$ |  | 50 170 <br> 46 135 | $\begin{array}{ll} 45 & 160 \\ 42 & 125 \\ \hline \end{array}$ |  | $\begin{array}{r} 150 \\ 115 \\ \hline \end{array}$ |  | $\begin{gathered} 125 \\ 95 \\ \hline \end{gathered}$ | mA |
|  |  |  | $\text { Com'l. } \begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | 50 160 <br> 46 125 | 50 150 <br> 46 115 | 45 137 <br> 42 105 |  | $\begin{gathered} 115 \\ 90 \end{gathered}$ |  | $\begin{gathered} 105 \\ 80 \end{gathered}$ |  |

## NOTES:

1. " $x$ " in part numbers indicates power rating (SA or LA).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. At $f=$ fimax, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 /$ trc, and using "AC TEST CONDITIONS" of input levels of GND to 3V.
5. $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby.
6. Not available in DIP packages, see 7030/40 data sheet.
7. DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ only, see $7030 / 40$ data sheet.

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$ (Continued) (Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | Version | 7130 7140 Typ. | $\begin{aligned} & \times 55 \\ & \times 55 \\ & \text { Max. } \end{aligned}$ |  | $\begin{aligned} & \times 70 \\ & \times 70 \\ & \text { Max. } \end{aligned}$ |  | $\begin{aligned} & \times 90 \\ & \times 90 \\ & \text { Max. } \end{aligned}$ | 7130 7140 Typ. | $\begin{aligned} & \times 100 \\ & \times 100 \\ & \text { Max. } \end{aligned}$ | 7130 <br> 7140 <br> Typ. <br> 65 | $\begin{aligned} & 120^{(3)} \\ & 120^{(3)} \\ & \text { Max. } \end{aligned}$ | Un |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{VIL} \\ & \text { Outputs Open } \\ & \mathrm{f}=\mathrm{fmax}^{(4)} \end{aligned}$ | Mil. SA | $\begin{aligned} & 65 \\ & 65 \end{aligned}$ | $\begin{aligned} & 230 \\ & 185 \end{aligned}$ | $\begin{aligned} & 65 \\ & 65 \end{aligned}$ | $\begin{aligned} & 225 \\ & 180 \end{aligned}$ | $\begin{aligned} & 65 \\ & 65 \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \end{aligned}$ | $\begin{aligned} & 65 \\ & 65 \end{aligned}$ | 190 155 | $\begin{aligned} & 65 \\ & 65 \\ & \hline \end{aligned}$ | $\begin{aligned} & 190 \\ & 155 \end{aligned}$ |  |
|  |  |  | Com'l. LA | $\begin{aligned} & 00 \\ & \hline 65 \\ & 65 \\ & \hline \end{aligned}$ | $\begin{aligned} & 100 \\ & 180 \\ & 140 \end{aligned}$ | $\begin{aligned} & 05 \\ & \hline 65 \\ & 65 \end{aligned}$ | $\begin{aligned} & 100 \\ & \hline 180 \\ & 135 \end{aligned}$ | $\begin{aligned} & 05 \\ & \hline 65 \\ & 65 \end{aligned}$ | $\begin{aligned} & 100 \\ & \hline 180 \\ & 130 \\ & \hline \end{aligned}$ | $\begin{aligned} & 05 \\ & \hline 65 \\ & \hline \end{aligned}$ | $\begin{array}{r} 105 \\ 180 \\ 130 \\ \hline \end{array}$ |  |  |  |
| ISB1 | Standby Current (Both Ports - TTL Level Inputs) | $\begin{aligned} & \overline{\overline{C E} L} \text { and } \overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{f}=\mathrm{fmax}^{(4)} \end{aligned}$ | Mil. SA | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 55 \end{aligned}$ | 25 | $\begin{aligned} & 65 \\ & 55 \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \end{array}$ | $\begin{aligned} & \hline 65 \\ & 45 \\ & \hline \end{aligned}$ | 25 25 | 65 45 | 25 | $\begin{aligned} & 65 \\ & 45 \\ & \hline \end{aligned}$ |  |
|  |  |  | Com'l. SA | $\begin{aligned} & 25 \\ & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \\ & \hline \end{aligned}$ | 25 | $\begin{aligned} & 60 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{array}{r} 55 \\ \hline 35 \end{array}$ | 25 <br> 25 | $\begin{array}{r} 55 \\ 35 \\ \hline \end{array}$ |  |  |  |
| ISB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CEL}}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH}$ Active Port Outputs Open, $f=$ fmax ${ }^{(4)}$ | Mil. SA | $\begin{array}{r} 40 \\ 40 \\ \hline \end{array}$ | $\begin{array}{r} 135 \\ 110 \\ \hline \end{array}$ | 40 | $\begin{aligned} & 135 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 125 \\ & 100 \\ & \hline \end{aligned}$ | 40 40 | 125 100 | 40 | $\begin{aligned} & 125 \\ & 100 \\ & \hline \end{aligned}$ |  |
|  |  |  | Com'lisa | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} 115 \\ 85 \end{gathered}$ | 40 | 110 85 | 40 40 | 110 75 | 40 40 | 110 75 |  | 二 |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{C E R} \geq$ Vcc -0.2V <br> VIN $\geq$ Vcc -0.2 V or <br> $\mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)}$ | Mil. SA | $\begin{aligned} & 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | 1.0 0.2 | 30 10 | $\begin{array}{\|l\|} \hline 1.0 \\ 0.2 \end{array}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | 1.0 0.2 | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | 1.0 0.2 | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ |  |
|  |  |  | Com'l. SA | $\begin{aligned} & \hline 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 4 \end{gathered}$ | $\begin{aligned} & \hline 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 4 \end{gathered}$ | $\begin{aligned} & \hline 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 4 \end{gathered}$ | $\begin{aligned} & \hline 1.0 \\ & 0.2 \end{aligned}$ | 15 <br> 4 |  | - |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs, $f=0^{(5)}$ ) | One Port $\overline{C E}$ L or <br> $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> VIN $\geq$ Vcc -0.2 V or <br> Vin $\leq 0.2 \mathrm{~V}$ <br> Active Port Outputs <br> Open, $f=f$ max ${ }^{(4)}$ | Mil.SA <br> LA | $\begin{array}{r} 40 \\ 35 \\ \hline \end{array}$ | $\begin{aligned} & 120 \\ & 90 \\ & \hline \end{aligned}$ | 40 35 | $\begin{gathered} 115 \\ 85 \\ \hline \end{gathered}$ | 40 <br> 35 | $\begin{aligned} & 110 \\ & 80 \\ & \hline \end{aligned}$ | 40 35 | 110 <br> 80 | 35 | $\begin{array}{r} 110 \\ 80 \\ \hline \end{array}$ |  |
|  |  |  | Com'l. SA |  | $\begin{gathered} 100 \\ 75 \end{gathered}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ |  |  | $\begin{aligned} & 95 \\ & 70 \end{aligned}$ |  |  |  |  | mA |

NOTES:

1. " $x$ " in part numbers indicates power rating (SA or LA).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. At $f=$ fmax, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 / t \mathrm{tc}$, and using "AC TEST CONDITIONS" of input levels of GND to $3 V$.
5. $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby.

DATA RETENTION CHARACTERISTICS (LA Version Only)

| Symbol | Parameter | Test Conditions |  | IDT7 Min. | $\begin{aligned} & \text { AIDT } \\ & \text { Typ. } \end{aligned}$ | A Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\mathrm{VCc}=2.0 \mathrm{~V}, \overline{\mathrm{CE}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ Mil.$\mathrm{Com} \mathrm{m}^{\prime}$.$\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or VIN $\leq 0.2 \mathrm{~V}$ |  | 2.0 | - | 0 | V |
| ICCDR | Data Retention Current |  |  | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  |  | - | 100 | 1500 | $\mu \mathrm{A}$ |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $t \mathrm{R}^{(3)}$ | Operation Recovery Time |  |  | tRC( ${ }^{(2)}$ | - | - | ns |

## NOTES:

1. $\mathrm{VCC}=2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$
2. tRC = Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Puise Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1, 2, 3 and 4 |

2689 tb 08


Flgure 1. Output Load


Figure 3. $\overline{B U S Y}$ and $\overline{N T}$ Output Load


Figure 2. Output Load (for thz, tic, twz, and tow)


Figure 4. $\overline{\text { BUSY }}$ and $\overline{\mathrm{INT}}$ Output Load (for 20ns, 25ns and 30 ns versions)

* Including scope and jig


## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE(5)| Symbol | Parameter | $\begin{aligned} & 7130 \times 20^{(2,6)} \\ & 7140 \times 20^{(2,6)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 25^{(6)} \\ & 7140 \times 25^{(6)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 30^{(6)} \\ & 7140 \times 30^{(6)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 35^{(7)} \\ & 7140 \times 35^{(7)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 45 \\ & 7140 \times 45 \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 20 | - | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| tAA | Address Access Time | - | 20 | - | 25 | - | 30 | - | 35 | - | 45 | ns |
| tace | Chip Enable Access Time | - | 20 | - | 25 | - | 30 | - | 35 | - | 45 | ns |
| táe | Output Enable Access Time | - | 10 | - | 42 | - | 15 | - | 25 | - | 30 | ns |
| tor | Output Hold From Address Change | 0 | - | 0* | * | 0 | - | 0 | - | 0 | - | ns |
| tıZ | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,4)}$ | 0 | - | O\%, | - | 0 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ |  | 8 | - | 10 | - | 12 | - | 15 | - | 20 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(4)}$ |  | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

AC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(5)}$ (Continued)

| Symbol | Parameter | $\begin{aligned} & 7130 \times 55 \\ & 7140 \times 55 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 70 \\ & 7140 \times 70 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 90 \\ & 7140 \times 90 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 100 \\ & 7140 \times 100 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 120^{(3)} \\ & 7140 \times 120^{(3)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 55 | - | 70 | - | 90 | - | 100 | - | 120 | - | ns |
| tAA | Address Access Time | - | 55 | - | 70 | - | 90 | - | 100 | - | 120 | ns |
| tACE | Chip Enable Access Time | - | 55 | - | 70 | - | 90 | - | 100 | - | 120 | ns |
| taoe | Output Enable Access Time | - | 35 | - | 40 | - | 40 | - | 40 | - | 60 | ns |
| tor | Output Hold From Address Change | 0 | - | 0 | - | 10 | - | 10 | - | 10 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 30 | - | 35 | - | 40 | - | 40 | - | 40 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(4)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2,3 and 4).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. " $x$ " in part numbers indicates power rating (SA or LA).
6. Not available in DIP packages, see 7030/40 data sheet.
7. DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ only, see $7030 / 40$ data sheet.

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE (1, 2, 4)


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE (1; 3)


## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (7)

| Symbol | Parameter | $\begin{aligned} & 7130 \times 20^{(2,8)} \\ & 7140 \times 20^{(2,8)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 25^{(8)} \\ & 7140 \times 25^{(8)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 30^{(8)} \\ & 7140 \times 30^{(8)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 35^{(9)} \\ & 7140 \times 35^{(9)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 45 \\ & 7140 \times 45 \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time(5) | 20 | - | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| tEW | Chip Enable to End of Write | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| taw | Address Valid to End of Write | 15 | - | 20 | - | 25\% | 二 | 30 | - | 35 | - | ns |
| tas | Address Set-up Time | 0 | - | 0 | - | 0** | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(6)}$ | 15 | - | 20 | + | 25 | - | 30 | - | 35 | - | ns |
| twr | Write Recovery Time | 0 | - | 0 \% | \% | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 10 | - | 12, | - | 15 | - | 20 | - | 20 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | $8{ }^{8}$ | $\stackrel{-}{-}$ | 10 | - | 12 | - | 15 | - | 20 | ns |
| toh | Data Hold Time | 0 | \% ${ }_{\text {, }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twZ | Write Enabled to Output in High Z ${ }^{(1,4)}$ | - | 8 | - | 10 | - | 12 | - | 15 | - | 20 | ns |
| tow | Output Active From End of Write ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (7)| Symbol | Parameter | $\begin{aligned} & 7130 \times 55 \\ & 7140 \times 55 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 70 \\ & 7140 \times 70 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 90 \\ & 7140 \times 90 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 100 \\ & 7140 \times 100 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 120^{(3)} \\ & 7140 \times 120^{(3)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twC | Write Cycle Time(5) | 55 | - | 70 | - | 90 | - | 100 | - | 120 | - | ns |
| tEW | Chip Enable to End of Write | 40 | - | 50 | - | 85 | - | 90 | - | 100 | - | ns |
| taw | Address Valid to End of Write | 40 | - | 50 | - | 85 | - | 90 | - | 100 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(6)}$ | 40 | - | 50 | - | 55 | - | 55 | - | 65 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data Valid to End of Write | 20 | - | 30 | - | 40 | - | 40 | - | 40 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 30 | - | 35 | - | 40 | - | 40 | - | 40 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High Z (1,4) | - | 30 | - | 35 | - | 40 | - | 40 | - | 50 | ns |
| tow | Output Active From End of Write (1, 4) | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1, 2, 3 and 4).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. For MASTER/SLAVE combination, twC $=$ tBAA + twp.
6. Specified for $\overline{\mathrm{OE}}$ at high (Refer to "Timing Waveform of Write Cycle", Note 7)
7. " $x$ " in part numbers indicates power rating (SA or LA).
8. Not available in DIP packages, see 7030/40 data sheet.
9. DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ only, see $7030 / 40$ data sheet.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter(1) | Conditions | Max. | Unit |
| :--- | :--- | :--- | ---: | ---: |
| CIN | Input Capacitance | ViN $=0 \mathrm{~V}$ | 11 | pF |
| CoUT | Output Capacitance | $\mathrm{V} \operatorname{IN}=0 \mathrm{~V}$ | 11 | pF |

## NOTE:

2689 tbl 13

1. This parameter is determined by device characterization but is not production tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 , (R/ $\bar{W}$ CONTROLLED TIMING) $(1,2,3,7)$


2689 dnw 09

TIMING WAVEFORM OF WRITE CYCLE NO. 2 , ( $\overline{\text { CE }}$ CONTROLLED TIMING) $(1,2,3,5)$


## NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. twa is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of the write cycle.
4. During this period, the l/O pins are in the output state and input signals must not be applied,
5. If the $\overline{C E}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig).
7. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be larger of twP or (tWZ + tDW) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twP.

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (8)| Symbol | Parameter | $\begin{aligned} & 7130 \times 20(1,10) \\ & 7140 \times 20^{(1,10)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 25^{(10)} \\ & 7140 \times 25^{(10)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 30^{(10)} \\ & 7140 \times 30^{(10)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 35^{(11)} \\ & 7140 \times 35^{(11)} \end{aligned}$ |  | $\begin{aligned} & 7130 \times 45 \\ & 7140 \times 45 \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (FOR MASTER IDT7130 ONLY) |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 20 | - | 25 | - | 30 | - | 35 | - | 35 | ns |
| tBDA | BUSY Disable Time to Address | - | 18 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tBAC | BUSY Access Time to Chip Enable | - | 20 | - | 20 | - | 25 | - | 30 | - | 30 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 18 | - | 20 |  | 25 | - | 25 | - | 25 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(3)}$ | - | 45 | - | 50 | $\stackrel{3}{3}$ | *55 | - | 60 | - | 70 | ns |
| todo | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - | 30 | - | 33 | $\stackrel{+}{+}$ | 33 | - | 35 | - | 45 | ns |
| tAPS | Arbitration Priority Set-up Time (4) | 5 | - | 5 | $\stackrel{4}{4}$ | 5 | - | 5 | - | 5 | - | ns |
| tBDD | BUSY Disable to Valid Datal(5) | - | Note 5 | $\rightarrow$ | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| BUSY INPUT TIMING (FOR SLAVE IDT7140 ONLY) |  |  |  |  |  |  |  |  |  |  |  |  |
| tw | Write to BUSY Input(6) | 0 | * | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| WWH | Write Hold After BUSY(7) | 12 | - | 15 | - | 20 | - | 20 | - | 20 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(9)}$ | - | 45 | - | 50 | - | 55 | - | 60 | - | 70 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - | 30 | - | 35 | - | 35 | - | 35 | - | 45 | ns |

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (8)

| Symbol | Parameter | $\begin{aligned} & 7130 \times 55 \\ & 7140 \times 55 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 70 \\ & 7140 \times 70 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 90 \\ & 7140 \times 90 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 100 \\ & 7140 \times 100 \end{aligned}$ |  | $\begin{aligned} & 7130 \times 120^{(2)} \\ & 7140 \times 120^{(2)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (FOR MASTER IDT7130 ONLY) |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 45 | - | 45 | - | 45 | - | 50 | - | 60 | ns |
| tBDA | BUSY Disable Time to Address | - | 40 | - | 40 | - | 45 | - | 50 | - | 60 | ns |
| tBAC | BUSY Access Time to Chip Enable | - | 35 | - | 35 | - | 45 | - | 50 | - | 60 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 30 | - | 30 | - | 45 | - | 50 | - | 60 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(3)}$ | - | 80 | - | 90 | - | 100 | - | 120 | - | 140 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - | 55 | - | 70 | - | 90 | - | 100 | - | 120 | ns |
| tAPS | Árbitration Priority Set-up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tBDD | BUSY Disable to Valid Data ${ }^{(5)}$ | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| BUSY INPUT TIMING (FOR SLAVE IDT7140 ONLY) |  |  |  |  |  |  |  |  |  |  |  |  |
| tWB | Write to BUSY Input ${ }^{(6)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After BUSY ${ }^{(7)}$ | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(9)}$ | - | 80 | - | 90 | - | 100 | - | 120 | - | 140 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - | 55 | - | 70 | - | 90 | - | 100 | - | 120 | ns |

NOTES:
2689 th 15

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. Port-to-port delay through RAM celis from writing port to reading port, refer to "Timing Waveform of Read With BUSY (For Master IDT7130 only)".
4. To ensure that the earlier of the two ports wins.
5. tBDD is a calculated parameter and is the greater of 0 , twDD-twP (actual) or tDDD-tow (actual).
6. To ensure that the write cycle is inhibited during contention.
7. To ensure that a write cycle is completed after contention.
8. " $x$ " in part numbers indicates power rating (SA or LA).
9. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With Port-to-Port Delay (For Slave IDT7140 Only)".
10. Not available in DIP packages, see 7030/40 data sheet.
11. DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ only, see $7030 / 40$ data sheet.

## TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}(1,2,3)$ (FOR MASTER IDT7130 ONLY)



NOTES:

1. To ensure that the earlier of the two ports wins.
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continously enabled for both ports.
4. $\overline{O E}$ at $L O$ for the reading port.

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$ (FOR SLAVE IDT7140 ONLY)


NOTES:

1. Assume $\overline{B U S Y}$ input at HI for the writing port, and $\overline{\mathrm{OE}}$ at $L O$ for the reading port.

2689 drw 12
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuosly enabled for both ports.

## TIMING WAVEFORM OF WRITE WITH BUSY INPUT (FOR SLAVE IDT7140 ONLY)



TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, CE ARBITRATION
$\overline{C E L}$ VALID FIRST:


2689 drw 14
CER VALID FIRST:


2689 dmw 15
TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION ${ }^{(1)}$
LEFT ADDRESS VALID FIRST:


2689 drw 16
RIGHT ADDRESS VALID FIRST:


2689 dmw 17
NOTE:

1. $\overline{C E L}=\overline{C E R}=V_{I}$

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(3)}$

| Symbol Parameter |  | $\begin{array}{\|l} \hline 7130 \times 20^{(1,4)} \\ 7140 \times 20^{(1,4)} \\ \text { Min. Max. } \end{array}$ | $\begin{array}{\|c\|} \hline 7130 \\ 7140 \\ \text { Min. } \\ \hline \end{array}$ | $\begin{aligned} & 25^{(4)} \\ & 25^{(4)} \\ & \text { Max. } \end{aligned}$ |  | $\begin{aligned} & 30^{(4)} \\ & 30^{(4)} \\ & \text { Max. } \end{aligned}$ | $\begin{aligned} & 7130 \times 35(5) \\ & 7140 \times 35(5) \\ & \text { Min. Max. } \\ & \hline \end{aligned}$ |  | $\begin{array}{r} 7130 \times 45 \\ 7140 \times 45 \\ \text { Min. Max. } \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Interrupt Timing |  |  |  |  |  |  |  |  |  |  |  |
| tas | Address Set-up Time | 0 | 0 | 榾 | 0 |  | 0 | - | 0 | - | ns |
| twR | Write Recovery Time | 0 | \& 0 | ** | 0 | - | 0 | - | 0 | - | ns |
| tINS | Interrupt Set Time | - < \% 20 | * ${ }^{\text {® }}$ | 25 | - | 30 | - | 35 | - | 40 | ns |
| tinf | Interrupt Reset Time | - 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE


1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. " $x$ " in part numbers indicates power rating (SA or LA).
4. Not available in DIP packages, see 7030/40 data sheet.
5. DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ only, see $7030 / 40$ data sheet.

TIMING WAVEFORM OF INTERRUPT MODE ${ }^{(1,2)}$
LEFT SIDE SETS $\overline{\operatorname{INT}} \mathrm{R}$ :


2689 drw 18
RIGHT SIDE CLEAR $\overline{\text { INTR: }}$

2. INTL and INTR are reset (high) during power up.

TIMING WAVEFORM OF INTERRUPT MODE $(1,2)$
RIGHT SIDE SETS $\overline{\operatorname{NT} T} \mathrm{~L}:$


## LEFT SIDE CLEAR $\overline{\operatorname{NT} T}$ :



NOTES:

1. $\overline{C E}=\overline{C E}_{R}=V_{I L}$
2. $\overline{\mathbb{N T} R}$ and $\overline{\mathbb{N T L}}$ are reset (high) during power up.

## 16-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



2689 drw 22
NOTE:

1. No arbitration in IDT7140 (SLAVE). BUSY-IN inhibits write in IDT7140 (SLAVE).

## FUNCTIONAL DESCRIPTION:

The IDT7130/IDT7140 provides two ports with separate control, address and VO pins that permit independent access for reads or writes to any locations in memory. The IDT7130/ IDT7140 has an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected (CE high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}}$ ). In the read mode, the port's $\overline{O E}$ turns on the output drivers when set LOW. Noncontention READ/WRITE conditions are illustrated in Table 1.

The interrupt flag ( $\overline{\mathrm{NNT}}$ ) permits communication between ports or systems. If the user chooses to use the interrupt function, a memory location (mail box or message center) is assigned to each port. The left port interrupt flag (INTL) is set when the right port writes to memory location 3FE (HEX). The left port clears the interrupt by reading address location 3FE. Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location 3FF (HEX) and to clear the interrupt flag ( $\overline{N T T R}_{\mathrm{R}}$ ), the right port must read the memory location 3FF. The message ( 8 -bits) at 3FE or 3FF is user defined. If the interrupt function is not used, address locations 3FE or 3FF are not used as mailboxes, but as part of the random access memory. Refer to Table II for the interrupt operation.

## ARBITRATION LOGIC

## FUNCTIONAL DESCRIPTION:

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimum and determine which port has access. In all cases, an active BUSY flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address data. It is important to note that the operation is invalid for the port
that has $\overline{B U S Y}$ set LOW. The delayed port will have access when BUSY goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{C E}$, on-chip control logic arbitrates between $\overline{\mathrm{CEL}}$ and $\overline{\mathrm{CE}} \mathrm{R}$ for access; or (2) if the $\overline{\mathrm{CEs}}$ are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's $\overline{B U S Y}$ flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION <br> MASTER/SLAVE DESCRIPTION:

Expanding the data bus width to sixteen-or-more-bits in a dual-port RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its $\overline{B U S Y L}$ while another activates its BUSYR signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid the "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only ono arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMs in width, the writing of the SLAVE RAMs must be delayed, until after the BUSY input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past BUSY to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than one chip is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

## TRUTH TABLES

TABLEI-NON-CONTENTION
READ/WRITE CONTROL ${ }^{(4)}$

| Left Or Right Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/W | $\overline{\text { CE }}$ | $\overline{O E}$ | D0-7 |  |
| $\bar{X}$ | H | X | Z | Port Disabled and in Power Down Mode ISB2 or ISB4 |
| X | H | X | Z | $\overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{H}$, Power Down Mode, IsB1 or ISB3 |
| L | L | X | DATAIN | Data on Port Written into Memory ${ }^{(2)}$ |
| H | L | L | DATAOUT | Data in Memory Output on Port ${ }^{(3)}$ |
| H | L | H | Z | High Impedance Outputs |

## NOTES:

1. AOL-A9L $\neq A 0 R-A 9 R$
2. If $\overline{B U S Y}=L$, data is not written
. If $\bar{B} \cup S Y=L$, data may not be valid, see twDD and toDD timing.
3. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=$ LOW, $\mathrm{X}=$ DON'T CARE, $\mathrm{Z}=$ HIGH IMPEDANCE

TABLE II - INTERRUPT FLAG(1, 4)

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W ${ }^{\text {L }}$ | $\overline{C E L}$ | $\overline{O E L}$ | A0L-A9L | INTL | R/W ${ }_{\text {R }}$ | $\overline{\text { CER }}$ | $\overline{\mathrm{OE}} \mathrm{R}$ | AoL-A9R | INTR |  |
| L | L | X | 3FF | X | X | X | X | X | $L^{(2)}$ | Set Right İNTR Flag |
| X | X | X | X | X | X | L | L | 3FF | $\mathrm{H}^{(3)}$ | Reset Right INTR Flag |
| X | X | X | X | $L^{(3)}$ | L | L | X | 3FE | X | Set Left INTL Flag |
| X | L | L | 3FE | $H^{(2)}$ | X | X | X | X | X | Reset Left $\overline{\text { NTL Flag }}$ |

NOTES:

1. Assumes $\overline{B U S Y L}=\overline{B U S Y} \bar{R}=\mathrm{H}$.
2. If $\overline{B_{U S Y}}=L$, then $N C$.
3. If $B U S Y L=L$, then $N C$.
4. $H=$ HIGH, $L=$ LOW,$X=$ DON'T CARE, NC $=$ NO CHANGE

TABLE III - ARBITRATION ${ }^{(2)}$

| Left Port |  | Right Port |  | Flags ${ }^{(1)}$ |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { CEL }}$ | AoL-A9L | $\overline{\text { CER }}$ | A0R-A9R | $\overline{\text { BUSYL }}$ | BUSYR |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | \# A0R-A9R | L | \# AOL-A9L | H | H | No Contention |
| Address Arbltration With CE Low Before Address Match |  |  |  |  |  |  |
| L | LV5R | L | LV5R | H | L | L-Port Wins |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |
|  |  |  |  |  |  |  |
| LL5R | $=$ A0R-A9R | LL5R | $=$ AOL-AgL | H | L | L-Port Wins |
| RL5L | = A0R-A9R | RL5L | $=$ AoL-AgL | L | H | R-Port Wins |
| LW5R | = A0R-A9R | LW5R | = AoL-AgL | H | L | Arbitration Resolved |
| LW5R | $=$ A0R-A9R | LW5R | = AOL-AgL | L | H | Arbitration Resolved |

## NOTES:

1. INT Flags Don't Care.
2. $X=$ DON'T CARE, $L=$ LOW, $H=$ HIGH

LV5R $=$ Left Address Valid $\geq 5$ ns before right address :
RV5L $=$ Right Address Valid $\geq 5$ ns before leff address.

Same $=$ Left and Right Addresses match within 5 ns of each other.
LL5R = Left $\overline{C E}=L O W \geq 5 n$ s before Right $\overline{C E}$.
RL5L $=$ Right $\overline{C E}=$ LOW $\geq 5$ ns before Left $\overline{C E}$.
LW5R $=$ Left and Right $\overline{C E}=$ LOW within 5 ns of each other.

## ORDERING INFORMATION



|  | CMOS DUAL-PORT RAM 8 K ( $1 \mathrm{~K} \times 8$-BIT) | PRELIMINARY IDT7030SA/LA IDT7040SA/LA |
| :---: | :---: | :---: |

## FEATURES:

- High-speed access
-Military: 25/35/45ns (max.)
-Commercial: 20/25/35ns (max.)
- Low-power operation
—IDT7030/40SA
Active: 375 mW (typ.)
Standby: 6 mW (typ.)
-IDT7030/40LA
Active: 375 mW (typ.)
Standby: 2 mW (typ.)
- MASTER IDT7030 easily expands data bus width to 16-or-more-bits using SLAVE IDT7040
- On-chip port arbitration logic (IDT7030 only)
- BUSY output flag on IDT7030; BUSY input on IDT7040
- INT flag for port-to-port communication
- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL-compatible, single $5 \mathrm{~V} \pm 10 \%$ power supply
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7030/IDT7040 are high speed 1 Kx8 dual-port static RAMs. The IDT7030 is designed to be used as a stand-alone 8 -bit dual-port RAM or as a "MASTER" dualport RAM together with the IDT7040 "SLAVE" dual-port in 16 -bit-or-more word width systems. Using the IDT MASTER/ SLAVE dual-port RAM approach in 16-or-more-bit memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide two independent ports with separate control, address and $1 / O$ pins that permit independent asynchronous access for reads or writes to any location in memory. An automatic power down feature, controlled by $\overline{\mathrm{CE}}$, permits the on chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only 375 mW of power at maximum access times as fast as 20ns. Lowpower (LA) versions offer battery backup data retention capability, with each dual-port typically consuming $200 \mu \mathrm{w}$ from a 2 V battery.

The IDT7030/IDT7040 devices are packaged in 48 -pin sidebraze or plastic DIPs.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

FUNCTIONAL BLOCK DIAGRAM


NOTE:

1. IDT7030 (MASTER): $\overline{B U S Y}$ is open drain output and requires pullup resistor. IDT7040 (SLAVE): $\overline{B U S Y}$ is input.
2. Open drain output: requires pullup resistor.

CEMOS is a trademark of Integrated Device Technology, Inc.

## PIN CONFIGURATIONS



## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTEMAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicatedin the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED
DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| ViH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5(1)$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

2690 th 03

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter(1) | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| COUT | Output Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 11 | PF |

NOTE:
2690 혀 04

1. This parameter is determined by device characterization but is not production tested.

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | $\begin{array}{r} \text { IDT7030SA } \\ \text { IDT7040SA } \\ \text { Min. Max. } \end{array}$ |  | IDT7030LAIDT7040LAMax. Max. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |
| \|| $ا$ \| | Input Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to VCC | - | 10 |  |  | - | 5 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{Vout}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage (//O0-l/O7) | $1 \mathrm{LL}=4.0 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| Vol | Open Drain Output <br> Low Voltage (BUSY, $\overline{\mathrm{NT}}$ ) | $\mathrm{loL}=16 \mathrm{~mA}$ | - | 0.5 | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

2690 tbl 05

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test ¢onditions | Version | $\begin{aligned} & 7030 \times 20^{(2)} \\ & 7040 \times 20^{(2)} \end{aligned}$ | $\begin{aligned} & 7030 \times 25 \\ & 7040 \times 25 \end{aligned}$ | $\begin{aligned} & 7030 \times 35 \\ & 7040 \times 35 \end{aligned}$ | $\begin{aligned} & 7030 \times 45^{(3)} \\ & 7040 \times 45(3) \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ. Max. | Typ. Max. | Typ. Max. | Typ. Max. |  |
| Icc | Dynamic Operating Current (Both Ports Active | $\begin{aligned} & \overline{C E}=\text { VIL } \\ & \text { Outputs Open } \\ & f=\text { fmAX }^{(4)} \end{aligned}$ |   <br> Mil. SA | - | 75 300 <br> 75 220 | $\begin{array}{ll} 75 & 280 \\ 75 & 200 \\ \hline \end{array}$ | 75 270 <br> 75 190 | A |
|  |  |  | Com'l. ${ }^{\text {SA }}$ | 75 260 <br> 75 $190 \%$ | 75 250 <br> 75 180 | 75 240 <br> 75 180 | - |  |
| IS81 | Standby Current (Both Ports - TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CE} L} \text { and } \overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH}_{\mathrm{IH}} \\ & \mathrm{f}=\mathrm{fmAX}^{(4)} \end{aligned}$ |   <br> Mil. SA | - | $\begin{array}{ll} \hline 25 & 75 \\ 25 & 55 \\ \hline \end{array}$ | 25 75 <br> 25 55 | $\begin{array}{ll} \hline 25 & 75 \\ 25 & 55 \\ \hline \end{array}$ | mA |
|  |  |  | Com'l. SA | 25. 65 | $\begin{array}{ll} \hline 25 & 65 \\ 25 & 45 \end{array}$ | $\begin{array}{ll} \hline 25 & 65 \\ 25 & 45 \end{array}$ | - |  |
| ISB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{V}_{\mathrm{H}}$ Active Port Outputs Open, $f=$ fmax $^{(4)}$ | Mil. SA | - - . | $\begin{array}{ll} \hline 50 & 180 \\ 50 & 140 \\ \hline \end{array}$ | 46 170 <br> 46 130 | $\begin{array}{ll} \hline 40 & 160 \\ 40 & 125 \\ \hline \end{array}$ | mA |
|  |  |  | Com'l. $\begin{gathered}\text { SA } \\ \text { LA }\end{gathered}$ | 50 ar 180 50.130 | $\begin{array}{ll} \hline 50 & 170 \\ 50 & 120 \\ \hline \end{array}$ | 46 155 <br> 46 110 | - |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | Both Ports $\overline{\mathrm{CE}}$. and $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\operatorname{VIN} \leq 0.2 \mathrm{~V}, \mathrm{t}=0^{(5)}$ |   <br> Mil. SA | - \#- | $\begin{array}{ll} \hline 1.2 & 40 \\ 0.4 & 10 \\ \hline \end{array}$ | $\begin{array}{ll} 1.2 & 35 \\ 0.4 & 10 \\ \hline \end{array}$ | $\begin{array}{ll} 1.0 & 35 \\ 0.2 & 10 \\ \hline \end{array}$ |  |
|  |  |  | Com'l. SA |  | $\begin{array}{cc} 1.2 & 15 \\ 0.4 & 4 \end{array}$ | 1.2 15 <br> 0.4 4 | 二 |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs, $\left.f=0^{(5)}\right)$ | One Port $\overline{C E}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ Vin $\geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or Vin $\leq 0.2 V$ Active Port Outputs Open, $f=\mathrm{fmax}^{(4)}$ | Mil. SA |  | 50 170 <br> 46 135 | 45 150 <br> 42 115 | 40 140 <br> 35 105 |  |
|  |  |  | Com'l. SA | 50 160 <br> 46 125 | 50 150 <br> 46 115 | $\begin{array}{ll}45 & 135 \\ 42 & 105\end{array}$ | 二 - |  |

## NOTES:

1. $x$ in part numbers indicates power rating (SA or LA).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. At $f=$ fMAx, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 / t R C$, and using "AC TEST CONDITIONS" of input levels of GND to 3 V .
5. $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby.

DATA RETENTION CHARACTERISTICS (LA Version Only)

| Symbol | Parameter | Test Conditions |  | IDT70 Min. | $\begin{aligned} & \text { A/DT7 } \\ & \text { Typs } \end{aligned}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\begin{aligned} & V c c=2.0 \mathrm{~V}, \overline{\mathrm{CE}} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{~V} \text { IN } \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \mathrm{V} \ln \leq 0.2 \mathrm{~V} \end{aligned}$ |  | 2.0 | - | 0 | V |
| ICCDR | Data Retention Current |  | Mil. | 二 | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | Com'l. | - | 100 | 1500 | $\mu \mathrm{A}$ |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | trc ${ }^{(2)}$ | - | - | ns |

NOTES:

1. $V C C=2 V, T A=+25^{\circ} \mathrm{C}$
2. $\mathrm{trC}=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM




Flgure 1. Output Load



Figure 2. Output Load (for thz, tiz, twz, and tow)

Figure 3. $\overline{\text { BUSY }}$ and INT Output Load

[^5]
## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(5)}$

| Symbol | Parameter | $\begin{aligned} & 7030 \times 20^{(2)} \\ & 7040 \times 20^{(2)} \end{aligned}$ | $\begin{aligned} & 7030 \times 25 \\ & 7040 \times 25 \end{aligned}$ |  | $\begin{aligned} & 7030 \times 35 \\ & 7040 \times 35 \end{aligned}$ |  | $\begin{aligned} & 7030 \times 45^{(3)} \\ & 7040 \times 45^{(3)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  | \% |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 20 \% | 25 | - | 35 | - | 45 | - | ns |
| tAA | Address Access Time | - \% 20 | - | 25 | - | 35 | - | 45 | ns |
| tace | Chip Enable Access Time | - \% 20 | - | 25 | - | 35 | - | 45 | ns |
| taoe | Output Enable Access Time | - \% 10 | - | 12 | - | 25 | - | 30 | ns |
| IOH | Output Hold From Address Change | 0 \% - | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,4)}$ | 0 - | 0 | - | 0 | - | 0 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | -\$\% 8 | - | 10 | - | 15 | - | 20 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(4)}$ |  | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(4)}$ | $\rightarrow$ \% 50 | - | 50 | - | 50 | - | 50 | ns |

NOTES:
2690 tol 09

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1, 2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. " $x$ " in part numbers indicates power rating (SA or LA).
timing waveform of read cycle no. 1 , EITHER SIDE ${ }^{(1,2,4)}$


2690 drw 05

TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE $(1,3)$


## AC ELECTRICAL CHARACTERISTICS OVER THE

## OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(7)}$

| Symbol | Parameter | $\begin{gathered} 7030 \times 20^{(2)} \\ 7040 \times 20^{(2)} \\ \text { Min. Max. } \end{gathered}$ | $\begin{aligned} & 7030 \times 25 \\ & 7040 \times 25 \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{aligned} & 7030 \times 35 \\ & 7040 \times 35 \end{aligned}$ |  | $\begin{aligned} & 7030 \times 45^{(3)} \\ & 7040 \times 45^{(3)} \\ & \text { Min. Max. } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Cycle |  |  |  |  |  |  |  |  |  |
| twC | Write Cycle Time ${ }^{(5)}$ | 20 \% | 25 | - | 35 | - | 45 | - | ns |
| tEW | Chip Enable to End of Write | $15 \%$ - | 20 | - | 30 | - | 35 | - | ns |
| taw | Address Valid to End of Write | 15 \% | 20 | - | 30 | - | 35 | - | ns |
| tAS | Address Set-up Time | 0 \% ${ }^{\text {N/ }}$ | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(6)}$ | 15\%- | 20 | - | 30 | - | 35 | - | ns |
| twR | Write Recovery Time | 0 \% | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 10** | 12 | - | 20 | - | 20 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,4)}$ | $\rightarrow$ \% 8 | - | 10 | - | 15 | - | 20 | ns |
| tDH | Data Hold Time | 0 菏 - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High Z ${ }^{(1,4)}$ | $\rightarrow 8$ | - | 10 | - | 15 | - | 20 | ns |
| tow | Output Active From End of Write (1,4). | 0\% - | 0 | - | 0 | - | 0 | - | ns |

NOTES:
2690 bl 10

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. For MASTERISLAVE combination, $t w C=t B A A+t w p$.
6. Specified for $\overline{O E}$ at high (Refer to "Timing Waveform of Write Cycle", Note 7)
7. " $x$ " in part numbers indicates power rating (SA or LA).

TIMING WAVEFORM OF WRITE CYCLE NO. $1,(\mathrm{R} / \overline{\mathrm{W}}$ CONTROLLED TIMING) $(1,2,3,7)$


2690 drw 07

TIMING WAVEFORM OF WRITE CYCLE NO. 2 , ( $\overline{\text { CE }}$ CONTROLLED TIMING) ${ }^{(1,2,3,5)}$


## NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (EWw or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. twR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of the write cycle.
4. During this period, the $1 / O$ pins are in the output state and input signals must not be applied.
5. If the CE low transition occurs simultaneously with or after the RW low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig).
7. If $\overline{O E}$ is low during a $\mathrm{R} \overline{\mathrm{W}}$ controlled write cycle, the write pulse width must be larger of twP or ( $\mathrm{tWZ}+$ tow) to allow the VO drivers to tum off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ coritrolled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(8)}$

| Symbol | Parameter | $\begin{aligned} & 7030 \times 20^{(1)} \\ & 7040 \times 20^{(1)} \\ & \text { Min. Max. } \end{aligned}$ | 7030 7040 Min. | $\begin{gathered} 0 \times 25 \\ \times 25 \\ \text { Max. } \end{gathered}$ |  | $\begin{aligned} & \times 35 \\ & 0 \times 35 \\ & \text { Max. } \end{aligned}$ |  | $\begin{aligned} & \times 45^{(2)} \\ & \times 45^{(2)} \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Busy Timing (For Master IDT7030 Only) |  |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | 20 | - | 25 | - | 35 | - | 35 | ns |
| tBDA | BUSY Disable Time to Address | , 18 | - | 20 | - | 30 | - | 35 | ns |
| tBAC | BUSY Access Time to Chip Enable | - $\% 20$ | - | 20 | - | 30 | - | 30 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - 18 | - | 20 | - | 25 | - | 25 | ns |
| twDD | Write Pulse to Data Delay ${ }^{(3)}$ | -. $\quad .45$ | - | 50 | - | 60 | - | 70 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - \% \% 30 | - | 35 | - | 45 | - | 55 | ns |
| taps | Arbitration Priority Set-up Time ${ }^{(4)}$ | $5 \geqslant$ - | 5 | - | 5 | - | 5 | - | ns |
| t8DD | BUSY Disable to Valid Data ${ }^{(5)}$ | - Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| Busy Input Timing (For Slave IDT7040 Only) |  | \% 1 |  |  | $0$ |  | $0$ |  |  |
| twB | Write to BUSY Input (6) | 0\% |  |  | - |  |  | ns |
| tWH | Write Hold After $\overline{\mathrm{BUSY}}{ }^{(7)}$ | 12. | 15 | - |  | 20 | - | 20 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(9)}$ | 45 | - | 50 | - | 60 | - | 70 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - 30 | - | 35 | - | 45 | - | 55 | ns |

## NOTES

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY (For Master IDT7030 only)".
4. To ensure that the earlier of the two ports wins.
5. tBDD is a calculated parameter and is the greater of 0 , twDD-twP (actual) or toDD-tow (actual).
6. To ensure that the write cycle is inhibited during contention.
7. To ensure that a write cycle is completed after contention.
8. " $x$ " in part numbers indicates power rating (SA or LA).

Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With Port-to-Port Delay (For Slave IDT7040 Only)".

TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}{ }^{(1,2,3)}$ (FOR MASTER IDT7030 ONLY)


## NOTES:

2690 drw 09

1. To ensure that the earlier of the two ports wins.
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuously enabled for both ports.
4. $\overline{O E}$ at $L O$ for the reading port.

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$ (FOR SLAVE IDT7040 ONLY)


NOTES:

1. Assume $\overline{\mathrm{B} U S \bar{Y}}$ input at HI for the writing port, and $\overline{\mathrm{OE}}$ at LO for the reading port.
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuously enabled for both ports.

TIMING WAVEFORM OF WRITE WITH BUSY INPUT (FOR SLAVE IDT7040 ONLY)


TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, $\overline{\text { CE ARBITRATION }}$
(FOR MASTER IDT7030 ONLY)
CEL VALID FIRST:


CER VALID FIRST:


TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION ${ }^{(1)}$ (FOR MASTER IDT7030 ONLY)

LEFT ADDRESS VALID FIRST:


RIGHT ADDRESS VALID FIRST:


[^6]AC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (3)

| Symbol | Parameter | $\begin{aligned} & 7030 \times 20^{(1)} \\ & 7040 \times 20^{(1)} \\ & \text { Min. Max. } \end{aligned}$ | $7040 \times 25$ <br> Min. Max. |  | $\begin{array}{r} 7030 \times 35 \\ 7040 \times 35 \\ \text { Min. Max. } \end{array}$ |  | $\begin{aligned} & 7030 \times 45^{(2)} \\ & 7040 \times 45^{(2)} \\ & \text { Min. Max. } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Interrupt Timing |  | \% |  |  |  |  |  |  |  |
| tas | Address Set-up Time | 0 \% - | 0 | - | 0 | - | 0 | - | ns |
| tWR | Write Recovery Time | $0 \%$ - | 0 | - | 0 | - | 0 | - | ns |
| tINS | Interupt Set Time | $\stackrel{20}{ }$ | - | 25 | - | 35 | - | 40 | ns |
| tiNR | Interupt Reset Time | $\cdots \quad 20$ | - | 25 | - | 35 | - | 40 | ns |

NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. " $x$ " in part numbers indicates power rating (SA or LA).

TIMING WAVEFORM OF INTERUPT MODE(1, 2)
LEFT SIDE SETS $\overline{\operatorname{INT} R: ~}$


2690 dw 16


1. $\overline{\mathrm{C} E L}=\overline{\mathrm{CE}}_{\mathrm{R}}=\mathrm{V} \mathrm{V}$
2. $\overline{\mathbb{N T}}$ and $\mathbb{I N T}_{\mathrm{I}}$ are reset (high) during power up.

## TIMING WAVEFORM OF INTERRUPT MODE (1, 2)

RIGHT SIDE SETS INTL:


## LEFT SIDE CLEARS $\overline{\text { INTL: }}$



NOTES:

1. $\overline{\mathrm{CEL}}=\overline{\mathrm{CEA}}=\mathrm{V}_{\mathrm{IL}}$
2. $\mathbb{I N T}_{\beta}$ and $\mathbb{N T T}$ are reset (high) during power up.

## 16-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



NOTE:

1. No arbitration in IDT7040 (SLAVE). $\bar{B} U S Y-I N ~ i n h i b i t s ~ w r i t e ~ i n ~ I D T 7040 ~(S L A V E) . ~($

## FUNCTIONAL DESCRIPTION

The IDT7030/IDT7040 provides two ports with separate control, address and V/O pins that permit independent access for reads or writes to any locations in memory. The IDT7030/ IDT7040 has an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{C E}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{O E}$ turns on the output drivers when set LOW. Noncontention READ/WRITE conditions are illustrated in Table 1.

The interrupt flag ( $\overline{\mathrm{INT}}$ ) permits communication between ports or systems. If the user chooses to use the interrupt function, a memory location (mail box or message center) is assigned to each port. The left port interrupt flag (INTL) is set when the right port writes to memory location 3FE (HEX). The left port clears the interrupt by reading address location 3FE (HEX). Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location 3FF (HEX) and to clear the interrupt flag (INTR) the right port must read the memory location 3FF. The message (8bits) at 3FE or 3FF is user defined. If the interrupt function is not used, address locations 3FE or 3FF are not used as mailboxes, but as part of the random access memory. Refer to Table II for the internupt operation.

## ARBITRATION LOGIC FUNCTIONAL DESCRIPTION

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimum and determine which port has access. In all cases, an active $\overline{B U S Y}$ flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address data. It is important to note that the operation is invalid for the port that has BUSY set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{C E}$, on-chip control logic arbitrates between $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \mathrm{R}$ for access; or (2) if the $\overline{\mathrm{CE}}$ s are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's BUSY flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION MASTER/SLAVE DESCRIPTION

Expanding the data bus width to sixteen-or-more-bits in a dual-port RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its BUSYL while another acitivates its BUSYR signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid the "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only one arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMS in width, the writing of the SLAVE RAMS must be delayed, until after the BUSY input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{B U S Y}$ to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than on chip is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to BUSY from the MASTER.

## TRUTH TABLES

## TABLE I - NON-CONTENTION

READ/WRITE CONTROL ${ }^{(4)}$

| Left Or Right Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/W | $\overline{\text { CE }}$ | $\overline{O E}$ | D0-7 |  |
| X | H | X | Z | Port Disabled and in Power Down Mode IsB2 or ISB4 |
| X | H | X | Z | $\overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{H}$, Power Down Mode, ISB1 or ISB3 |
| L | L | X | DATAIN | Data on Port Written into Memory(2) |
| H | L | L | DATAOUT | Data in Memory Output on Port (3) |
| H | L | H | Z | High Impedance Outputs |

## NOTES:

2690 tbl 13

1. $A O L-A 9 L \neq A 0 R-A g r$
2. If $\overline{B U S Y}=L$, data is not written.
3. If $\overline{B U S Y}=L$, data may not be valid, see twDD and toDD timing.
4. $H=H I G H, L=L O W, X=D O N ' T C A R E, Z=H I G H$ IMPEDANCE

TABLE II - INTERRUPT FLAG ${ }^{(1,4)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W ${ }_{\text {L }}$ | $\overline{\text { CEL }}$ | $\overline{\text { OEL }}$ | AoL - AgL | $\overline{\text { INTL }}$ | R/W ${ }_{\text {F }}$ | $\overline{\text { CER }}$ | $\overline{\text { OER }}$ | A0L - A9R | INTR |  |
| L | L | X | 3FF | X | X | X | X | X | $L^{(2)}$ | Set Right INTR Flag |
| X | X | X | X | X | X | L | L | 3FF | $H^{(3)}$ | Reset Right INTR Flag |
| X | X | X | X | $L^{(3)}$ | L | L | X | 3FE | X | Set Left INTL Flag |
| X | L | L | 3FE | $H^{(2)}$ | X | X | X | X | X | Reset Left INTL Flag |

NOTES:

1. Assume $\overline{B U S Y L}=\overline{B U S Y}=H$.
2. If $\overline{B U S Y} L=L$, then $N C$.
3. If $\overline{B U S Y} R=L$, then $N C$.
4. $H=H I G H, L=L O W, X=$ DON'T CARE, NC $=$ NO CHANGE.

TABLE II - ARBITRATION ${ }^{(1,2)}$

| Left Port |  | Right Port |  | Flags ${ }^{(1)}$ |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CE}}$ | A0L - A9L | $\overline{\text { CER }}$ | A0R - A9R | $\overline{\text { BUSYL }}$ | BUSYR |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | \# A0R - A9R | L | \# AOL - AgL | H | H | No Contention |

Address Arbitration With CE Low Before Address Match

| L | LV5R | L | LV5R | H | L | L-Port Wins |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |
| $\overline{\text { CE Arbitration With Address Match Before CE }}$ |  |  |  |  |  |  |
| LL5R | $=$ A0R - A9R | LL5R | $=\mathrm{AOL}$ - AgL | H | L | L-Port Wins |
| RL5L | $=A 0 R-A 9 R$ | RL5L | $=\mathrm{AOL}$ - AgL | L | H | R-Port Wins |
| LW5R | = A0R - A9R | LW5R | $=A O L$ - AgL | H | L | Arbitration Resolved |
| LW5R | = A0R - A9R | LW5R | $=\mathrm{AOL}$ - AgL | L | H | Arbitration Resolved |

## NOTES:

1. INT Flags Don't Care.
2. $X=$ DON'T CARE, $L=$ LOW, $H=$ HIGH

LV5R $=$ Left Address Valid $\geq 5$ ns before right address.
RV5L $=$ Right Address Valid $\geq 5$ ns before left address.
Same $=$ Lett and Right Addresses match within 5 ns of each other.
$\mathrm{LL5R}=\mathrm{Left} \overline{\mathrm{CE}}=\mathrm{LOW} \geq 5 \mathrm{~ns}$ before Right $\overline{\mathrm{CE}}$.
RL5L $=$ Right $\overline{C E}=L O W \geq 5 n$ before Left $\overline{C E}$.
LW5R = Left and Right $\overline{C E}=$ LOW within 5 ns of each other.

## ORDERING INFORMATION



2600 dww 21

HIGH-SPEED

## 1K x 9 DUAL-PORT STATIC RAM WITH BUSY

## PRELIMINARY IDT7010S/L IDT70104S/L

## FEATURES:

- High-speed access
- Military: 35/45/55/70ns (max.)
- Commercial: 25/35/45/55ns (max.)
- Low-power operation
- IDT7010/70104S

Active: 400 mW (typ.)
Standby: 7mW (typ.)

- IDT7010/70104L

Active: 400 mW (typ.)
Standby: 2 mW (typ.)

- Fully asynchronous operation from either port
- Each port has a 9-bit wide data path. The 9th bit could be used as the parity bit.
- MASTER IDT7010 easily expands data bus width to 18 bits or more using SLAVE IDT70104 chip.
- On-chip port arbitration logic (IDT7010 only)
- $\overline{B U S Y}$ output flag on MASTER; $\bar{B} U S Y$ input on SLAVE
- Battery backup operation - 2 V data retention
- TTL compatible, signal 5V ( $\pm 10 \%$ ) power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7010/IDT70104 are high-speed 1K X 9 dual-port static RAMs. The IDT7010 is designed to be used as a stand-
alone 9-bit dual-port RAM or as a "MASTER" dual-port RAM together with the IDT70104 "SLAVE" dual-port in 18-bit-ormore word width systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 18-bit or wider memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power down feature controlled by $\overline{\mathrm{CE}}$ permits the on-chip circuitry of each port to enter a very low standby power mode.

The devices utilize a9-bit wide data path to allow for control/ data and parity bits at the user's option. This feature is especially useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking.

Fabricated using IDT's CEMOS™ high-performance technology, these devices typically operate on only 400 mW of power at maximum access times as fast as 25 ns . Low-power (L) versions offer battery backup data retention capability with each port typically consuming $200 \mu \mathrm{~W}$ from a 2 V battery.

The IDT7010/IDT70104 devices are packaged in 48-pin sidebrazed or plastic DIPs, 48-pin LCCs and 48-pin flatpacks. The military devices are processed $100 \%$ in compliance to the test methods of MIL-STD-883, Method 5004.

FUNCTIONAL BLOCK DIAGRAM

NOTE:

1. 7010 (MASTER): $\overline{B U S Y}$ is totem-pole output. 70104 (SLAVE): $\overline{B U S Y}$ is input.
2. Arbitration Logic is for IDT7010 (MASTER).


## PIN CONFIGURATIONS



48-PIN DIP TOP VIEW


2651 drw 03
48-PIN LCC/FLATPACK TOP VIEW

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0.0 | V |
| ViH | Input High Votage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(ग)}$ | - | 0.8 | V |

NOTE:
2651 bb 02

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE（Vcc $=5.0 \mathrm{~V} \pm 10 \%$ ）

| Symbol | Parameter | Test Conditions | $\begin{gathered} 7010 S \\ 70104 S \end{gathered}$ |  | $\begin{gathered} 7010 \mathrm{~L} \\ 70104 \mathrm{~L} \\ \hline \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min． | Max． | Min． | Max． |  |
| ｜l｜L｜ | Input Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| ｜llol | Output Leakage Current | $\overline{C E}=$ VIH，Vout $=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| Vol． | Output Low Voltage（1／O0－1／O8），$\overline{\text { BUSY }}$ | $\mathrm{lOL}=4 \mathrm{~mA}$ | － | 0.4 | － | 0.4 | $V$ |
| VOH | Output High Voltage（1／O0－1／O8），BUSY | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | － | 2.4 | － | V |

DC ELECTRICAL CHARACTERISTICS OVER THE OPERATING
TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version | $\begin{aligned} & 7010 \times 25^{(2)} \\ & 70104 \times 25^{(2)} \end{aligned}$ |  | $\begin{array}{r} 7010 \times 35 \\ 70104 \times 35 \\ \hline \end{array}$ |  | $\begin{aligned} & 7010 \times 45 \\ & 70104 \times 45 \\ & \hline \end{aligned}$ |  | $\begin{array}{\|c} 7010 \times 55 \\ 70104 \times 55 \\ \hline \end{array}$ |  | $\begin{array}{\|c\|} \hline 7010 \times 70^{(3)} \\ 70104 \times 70^{(3)} \\ \hline \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ． | Max． | Typ． | Max． | Typ． | Max． | Typ． | Max． | Typ． | Max． |  |
| Icc | Dynamic <br> Operating | $\overline{\mathrm{CE}} \leq \mathrm{VIL}$ <br> Outputs Open $f=f \text { MAX }{ }^{(4)}$ | Mil．$\quad \mathrm{S}$ | － | － | $\begin{aligned} & 80 \\ & 80 \end{aligned}$ | $\begin{aligned} & 300 \\ & 220 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 290 \\ & 210 \end{aligned}$ | $\begin{aligned} & 70 \\ & 70 \end{aligned}$ | $\begin{aligned} & 285 \\ & 205 \end{aligned}$ | $\begin{aligned} & \hline 65 \\ & 65 \end{aligned}$ | $\begin{aligned} & 275 \\ & 200 \end{aligned}$ | mA |
|  | Current（Both Ports Active） |  | Com＇l． $\begin{array}{ll}\text { S } \\ & \text { L }\end{array}$ | $75$ | $\begin{aligned} & 260 \\ & 190 \end{aligned}$ | $75$ | $\begin{aligned} & 250 \\ & 180 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 245 \\ & 170 \end{aligned}$ | $\begin{aligned} & 70 \\ & 70 \end{aligned}$ | $\begin{aligned} & 235 \\ & 160 \end{aligned}$ | － | － |  |
| Is81 | Standby Current（Both <br> Ports — TTL <br> Level inputs） | $\overline{\mathrm{CE}} \mathrm{L}$ and$\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{\mathrm{IH}}$$f=f \max ^{(4)}$ | Mil． S <br>  L | － | － | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{array}{r} 80 \\ 60 \\ \hline \end{array}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{array}{r} 80 \\ 60 \\ \hline \end{array}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 55 \\ & \hline \end{aligned}$ | mA |
|  |  |  | Com＇l． $\begin{aligned} & \text { S } \\ & \\ & \\ & \text { L }\end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | － | － |  |
| ISB2 | Standby <br> Current（Both <br> Ports－TTL <br> Level Inputs） | $\overline{\mathrm{CE}}$ or <br> $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH}$ <br> Active Port <br> Outputs Open， $f=\text { fMAX }^{(4)}$ |   <br> Mil． S <br>  L | － | － | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 190 \\ & 145 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{array}{r} 170 \\ 140 \\ \hline \end{array}$ | $\begin{array}{r} 40 \\ 40 \\ \hline \end{array}$ | $\begin{aligned} & 170 \\ & 140 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 165 \\ & 135 \\ & \hline \end{aligned}$ | mA |
|  |  |  | Com＇l． $\begin{array}{ll}\text { S } \\ & \text { L }\end{array}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 175 \\ & 125 \end{aligned}$ | $\begin{aligned} & 46 \\ & 46 \end{aligned}$ | $\begin{aligned} & 160 \\ & 115 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 150 \\ & 105 \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | $\begin{gathered} 140 \\ 95 \end{gathered}$ | － | － |  |
| ISB3 | Full Standby Current（Both Ports－All CMOS Level Inputs） | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \mathrm{R} \geq$ $\mathrm{Vcc}-0.2 \mathrm{~V}$ Vin $\geq$ Vcc -0.2 V or Vin$\leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)}$ | Mil．$\quad \mathrm{S}$ | 二 | － | $\begin{aligned} & 1.2 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | 30 10 | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  |  |  | Com＇l． $\begin{aligned} & \text { S } \\ & \\ & \text { L．}\end{aligned}$ | $\begin{aligned} & 1.2 \\ & 0.4 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | $\begin{aligned} & 1.0 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & 15 \\ & 5.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 5.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 5.0 \end{aligned}$ | 三 | － |  |
| ISB4 | Full Standby Current（One Port－All CMOS Level Inputs） | One Port $\overline{C E} L$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}$ $-0.2 \mathrm{~V}, \mathrm{~V} \mathbb{N} \geq$ $\mathrm{Vcc}-0.2 \mathrm{~V}$ or $\mathrm{Vin} \leq 0.2 \mathrm{~V}$ Active Port Outputs Open， $f=$ fMAX $^{(4)}$ |  | － | 二 | $\begin{aligned} & 47 \\ & 44 \end{aligned}$ | $\begin{aligned} & 170 \\ & 130 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 160 \\ & 125 \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{aligned} & 155 \\ & 120 \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{aligned} & 150 \\ & 115 \end{aligned}$ | mA |
|  |  |  | Com＇l． S | $\begin{aligned} & 50 \\ & 46 \end{aligned}$ | $\begin{aligned} & 155 \\ & 120 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 142 \\ & 110 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 132 \\ & 100 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{gathered} 127 \\ 95 \end{gathered}$ | － | － |  |

NOTES：
1．＂$x$＂in part numbers indicates power rating（ S or L ）．
2． $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only．
3．$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only．
4．At $f=$ fMAX，address and data inputs（except Output Enable）are cycling at the maximum frequency of read cycle of $1 /$ thc，and using＊AC TEST CONDITIONS＂of input levels of GND to 3 V ．
5．$f=0$ means no address or control lines change．Applies only to inputs at CMOS level standby．

## DATA RETENTION CHARACTERISTICS (L Version Only)

| Symbol | Parameter | Test Condition |  | 7010L/70104L |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Typ. ${ }^{(1)}$ | Max. |  |
| VDR | Vcc for Data Retention | $\mathrm{Vcc}=2.0 \mathrm{~V}, \overline{\mathrm{CE}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | Mil. | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | Com'l. | - | 100 | 1500 | $\mu \mathrm{A}$ |
| $\operatorname{tcDa}^{(3)}$ | Chip Deselect to Data Retention Time | $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ |  | 0 | - | - | ns |
| $t R^{(3)}$ | Operation Recovery Time |  |  | trc ${ }^{(2)}$ | - | - | ns |

NOTES:

1. $V c c=2 \mathrm{~V}, \mathrm{TA}_{A}=+25^{\circ} \mathrm{C}$
2. $\mathrm{tRC}=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :--- |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1, $2 \& 3$ |



Figure 1. Output Load


2651 drw 06

Figure 2. Output Load (for tHZ, ILZ, tWZ, and tow)


2651 drw 07
Figure 3. BUSY Output Load
*Including scope and jig.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(5)}$

| Symbol | Parameter | $\begin{gathered} 7010 \times 25^{(2)} \\ 70104 \times 25^{(2)} \\ \hline \end{gathered}$ |  | $\begin{array}{r} 7010 \times 35 \\ 70104 \times 35 \\ \hline \end{array}$ |  | $\begin{gathered} 7010 \times 45 \\ 70104 \times 45 \end{gathered}$ |  | $\begin{gathered} 7010 \times 55 \\ 70104 \times 55 \\ \hline \end{gathered}$ |  | $\begin{gathered} 7010 \times 70^{(3)} \\ 70104 \times 70^{(3)} \\ \hline \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| taOE | Output Enable Access Time | - | 12 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tor | Output Hold From Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(4)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1, 2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. " $x$ " in part numbers indicates power rating (S or $L$ ).

TIMING WAVEFORM OF READ CYCLE NO. 1 , EITHER SIDE ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


## NOTES:

1. $\mathrm{R} \overline{\mathrm{W}}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{O E}=V \mathrm{VI}$.

AC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(7)}$

| Symbol | Parameter | $\begin{array}{\|c\|} \hline 7010 \times 25^{(2)} \\ 70104 \times 25^{(2)} \\ \hline \end{array}$ |  | $\begin{gathered} 7010 \times 35 \\ 70104 \times 35 \\ \hline \end{gathered}$ |  | $\begin{gathered} 7010 \times 45 \\ 70104 \times 45 \\ \hline \end{gathered}$ |  | $\begin{aligned} & 7010 \times 55 \\ & 70104 \times 55 \end{aligned}$ |  | $\begin{array}{\|c\|} \hline 7010 \times 70^{(3)} \\ 70104 \times 70^{(3)} \\ \hline \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time ${ }^{(5)}$ | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tew | Chip Enable to End of Write | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twP | Write Pulse Width ${ }^{(6)}$ | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 12 | - | 20 | - | 20 | - | 20 | 二 | 30 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High $\mathrm{Z}^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tow | Output Active From End of Write ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:
1.Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. For MASTER/SLAVE combination, twc = tBAA + twp.
6. Specified for $\overline{O E}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).
7. "x" in part numbers indicates power rating (S or L).

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter( ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | VIN $=$ OV | 11 | pF |
| CouT | Output <br> Capacitance | VOUT $=0 \mathrm{~V}$ | 11 | pF |

NOTE:

1. This parameter is determined by device characterization but is not production tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1, (R/ $\bar{W} \operatorname{CONTROLLED~TIMING)~})^{(1,2,3,7)}$


## TIMING WAVEFORM OF WRITE CYCLE NO. 2, ( $\overline{\text { CE }}$ CONTROLLED TIMING $)^{(1,2,3,5)}$



2651 diw 12
NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. TWR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of the write cycle.
4. During this period, the $1 / O$ pins are in the output state and input signals must not be applied.
5. If the $\overline{C E}$ low transition occurs simultaneously with or after the RWW low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig).
7. If $\overline{O E}$ is low during a $\mathrm{R} \overline{\mathrm{W}}$ controlled write cycle, the write pulse width must be the larger of twp or twz + tow to allow the I/O drivers to tum off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during as $\mathrm{R} \overline{\mathrm{W}}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(8)}$

| Symbol | Parameter | $\begin{aligned} & 70101 \times 25^{(1)} \\ & 70105 \times 25^{(1)} \end{aligned}$ |  | $\begin{aligned} & 70101 \times 35 \\ & 70105 \times 35 \end{aligned}$ |  | $\begin{aligned} & 70101 \times 45 \\ & 70105 \times 45 \end{aligned}$ |  | $\begin{array}{r} 70101 \times 55 \\ 70105 \times 55 \\ \hline \end{array}$ |  | $\begin{aligned} & 70101 \times 70^{(2)} \\ & 70105 \times 70^{(2)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Busy Timing (For Master IDT7010 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | $\overline{\text { BUSY }}$ Access Time to Address | - | 25 | - | 35 | - | 35 | - | 45 | - | 45 | ns |
| tBDA | BUSY Disable Time to Address | - | 20 | - | 30 | - | 35 | - | 40 | - | 40 | ns |
| tBac | BUSY Access Time to Chip Enable | - | 20 | - | 30 | - | 30 | - | 35 | - | 35 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 20 | - | 25 | - | 25 | - | 30 | - | 30 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(3)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 95 | ns |
| todo | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| Busy Input Timing (For Slave IDT70104 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| twb | Write to $\overline{\text { BUSY }}$ Input ${ }^{(6)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tWH | Write Hold After $\overline{\mathrm{UUSY}}^{(7)}$ | 15 | - | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| twDD | Write Pulse to Date Delay ${ }^{(9)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 95 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |

NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY (For MASTER IDT7010 only)".
4. To ensure that the earlier of the two ports wins.
5. tBDD is a calculated parameter and is the greater of 0, twDD - twP (actual) or toDD - tow (actual).
6. To ensure that a write cycle is inhibited during contention.
7. To ensure that a write cycle is completed after contention.
8. " $x$ " in part numbers indicates power rating ( $S$ or $L$ ).
9. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY Port-to-port Delay (For SLAVE IDT70104 only)".

TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}{ }^{(1,2,3)}$
(FOR MASTER IDT7010 ONLY)


NOTES:

1. To ensure that the earlier of the two ports wins.
2. Write Cycle parameters should be adhered to, in order to ensure proper writing.
3. Device is continuously enabled for both ports.
4. $\overline{O E}$ at LOW for the reading port.

## TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$

(FOR SLAVE IDT70104 ONLY)


NOTES:
2651 drw 14

1. Assume $\overline{\mathrm{BUSY}}$ input at HIGH for the writing port, and $\overline{\mathrm{OE}}$ at LOW for the reading port.
2. Write Cycle parameters should be adhered to, in order to ensure proper writing.
3. Device is continuously enabled for both ports.

TIMING WAVEFORM OF WRITE WITH $\overline{\text { BUSY }}$ INPUT (FOR SLAVE IDT70104 ONLY)


## TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, $\overline{\mathrm{CE}}$ ARBITRATION

$\overline{C E}$ Valid First:

$\overline{C E}{ }_{R}$ Valid First:


TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION ${ }^{(1)}$
Left Address Valid First:


Right Address Valid First:


## FUNCTIONAL DESCRIPTION

The IDT7010/70104 provides two ports with separate control, address and $1 / O$ pins that permit independent access for reads or writes to any location in memory. The IDT7010/70104 has an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{C E}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{O E}$ ). In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/WRITE conditions are illustrated in Table I.

## ARBITRATION LOGIC, FUNCTIONAL DESCRIPTION

The arbitration logic will resolve an address match or a chip enable match to 5 ns minimum and determine which port has access. In all cases, an active $\overline{B U S Y}$ flag will be set for the delayed port.

The $\overline{B U S Y}$ flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address and data. It is important to note that the operation is invalid for the port that has $\overline{B U S Y}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are
valid before $\overline{\mathrm{CE}}$, on-chip control logic arbitrates between $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}}$ for access; or (2) if the $\overline{\mathrm{CEs}}$ are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's BUSY flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION, MASTER/SLAVE DESCRIPTION

Expanding the data bus width to eighteen-or-more-bits in a dual-port RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its $\overline{B U S Y}$ while another activates its $\overline{B U S Y} \mathrm{~F}$ signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid this "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only one hardware arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMs in width, the writing of the SLAVE RAMs must be delayed, until atter the BUSY input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{B U S Y}$ to ensure that a write takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than than one chip is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inherited due to $\overline{B U S Y}$ from the MASTER.

## 18-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



1. No arbitration in IDT70104 (SLAVE). BUSY-IN inhibits write in IDT70104 (SLAVE).

## TRUTH TABLES

## TABLE I. NON-CONTENTION READ/WRITE <br> CONTROL ${ }^{(4)}$

| Left or Right Port ${ }^{(1)}$ |  |  |  | Functlon |
| :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ | $\overline{C E}$ | $\overline{O E}$ | Do-8 |  |
| X | H | X | Z | Port Disabled and in Power Down Mode, IsB2 or ISB4 |
| X | H | X | Z | $\overline{C E} R=\overline{C E} L=H$, Power Down Mode, IsB1 or IsB3 |
| L | L | X | DATAIN | Data on Port Written Into Memory ${ }^{(2)}$ |
| H | L | L | DATAOUT | Data in Memory Output on Port ${ }^{(3)}$ |
| H | L | H | Z | High Impedance Outputs |

NOTES:
2651 tol 12

1. $A O L-A 9 L \neq A O R-A 9 R$
2. If $\overline{B U S Y}=\mathrm{L}$, data is not written.
3. If $\overline{B U S Y}=L$, data may not be valid, see twDD and toDD timing.
4. $H=H I G H, L=L O W, X=D O N ' T C A R E, Z=H I G H$ IMPEDANCE

TABLE II. ARBITRATION ${ }^{(1)}$

| Left Port |  | Right Port |  | Flags |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CE}}$ | AOL - A9L | $\overline{\mathrm{CE}}$ R | A0R - A9R | $\overline{\text { BUSYL }}$ | $\overline{B U S Y}^{\text {R }}$ |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | $\neq A 0 R-A 9 R$ | L | $\neq \mathrm{AOL}$ - AgL | H | H | No Contention |

Address Arbitration With $\overline{C E}$ Low Before Address Match

| L | LV5R | L | LV5R | H | L | L-Port Wins |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |

$\overline{\text { CE }}$ Arbltration With Address Match Before $\overline{\mathrm{CE}}$

| LL5R | $=$ A0R - A9R | LL5R | $=$ A0L - A9L | H | L | L-Port Wins |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| RL5L | $=A 0 R-A 9 R$ | RL5L | $=$ A0L - A9L | L | $H$ | R-Port Wins |
| LW5R | $=A 0 R-A 9 R$ | LW5R | $=$ A0L - A9L | $H$ | L | Arbitration Resolved |
| LW5R | $=A 0 R-A 9 R$ | LW5R | $=$ A0L - A9L | L | $H$ | Arbitration Resolved |

NOTES:

1. $\mathrm{X}=$ DON'T CARE, $\mathrm{L}=\mathrm{LOW}, \mathrm{H}=\mathrm{HIGH}$

LV5R = Left Address Valid $\geq 5$ ns before right address.
RV5L $=$ Right Address Valid $\geq 5$ ns before left address.

Same $=$ Left and Right Addresses match within 5 ns of each other.
LL5R = Left $\overline{C E}=L O W>5 n s$ before Right $\overline{C E}$.
RL5L $=$ Right $\overline{C E}=L O W \geq 5 n s$ before Left $\overline{C E}$.
LW5R $=$ Left and right $\overline{C E}=$ LOW within 5 ns of each other.

## ORDERING INFORMATION



## FEATURES:

- High-speed access
- Military: 35/45/55/70ns (max.)
- Commercial: 25/35/45/55ns (max.)
- Low-power operation
- IDT70101/70105S Active: 400 mW (typ.) Standby: 7 mW (typ.)
- IDT70101/70105L Active: 400 mW (typ.) Standby: 2 mW (typ.)
- Fully asynchronous operation from either port
- Each port has a 9-bit wide data path. The 9th bit could be used as the parity bit.
- MASTER IDT70101 easily expands data bus width to 18 bits or more using SLAVE IDT70105 chip.
- On-chip port arbitration logic (IDT70101 only)
- BUSY output flag on MASTER; BUSY input on SLAVE
- $\overline{\text { INT }}$ (INTERRUPT) flag for port-to-port communication
- Battery backup operation - 2 V data retention
- TTL compatible, signal $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT70101/IDT70105 are high-speed 1K x 9 dual-port static RAMs. The IDT70101 is designed to be used as astandalone 9-bit dual-port RAM or as a "MASTER" dual-port RAM together with the IDT70105 "SLAVE" dual-port in 18-bit-ormore word width systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 18-bit or wider memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power down feature controlled by $\overline{\mathrm{CE}}$ permits the on-chip circuitry of each port to enter a very low standby power mode.

The devices utilize a 9-bit wide data path to allow for data/ control and parity bits at the user's option. This feature is especially useful in data communications applications where

FUNCTIONAL BLOCK DIAGRAM


## DESCRIPTION (Continued)

it is necessary to use a parity bit for transmission/reception error checking.

Fabricated using IDT's CEMOS ${ }^{\text {M }}$ high-perfomance technology, these devices typically operate on only 400 mW of power at maximum access times as fast as $\mathbf{2 5 n s}$. Low-power

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | MII. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| Vterm | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Tbias | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| Tsta | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

2652 tbi 01

1. Stresses greater than those listed under ABSOLUTEMAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.
(L) versions offer battery backup data retention capability with each port typically consuming $200 \mu \mathrm{~W}$ from a 2 V battery.

The IDT70101/IDT70105 devices are packaged in 52-pin LCCs and 52 -pin PLCCs. The military devices are processed $100 \%$ in compliance to the test methods of MIL-STD-883, Method 5004.

CAPACITANCE ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{ViN}=\mathrm{OV}$ | 11 | pF |
| CouT | Output <br> Capacitance | VOUT $=0 \mathrm{~V}$ | 11 | pF |

NOTE:

1. This parameter is determined by device characterization butis not production tested.

RECOMMENDED DC
OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VcC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0.0 | V |
| VIH | Input High Votage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## PIN CONFIGURATIONS



DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE（Vcc $=5.0 \mathrm{~V} \pm 10 \%$ ）

| Symbol | Parameter | Test Conditions | $\begin{aligned} & \hline 70101 S \\ & 70105 S \end{aligned}$ |  | $\begin{aligned} & \hline \text { 70101L } \\ & \text { 70105L } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min． | Max． | Min． | Max． |  |
| ｜｜Lا｜ | Input Leakage Current | $\mathrm{VcC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| ｜lıO｜ | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage（l／O－／／Os） | $\mathrm{lOL}=4 \mathrm{~mA}$ | － | 0.4 | － | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | － | 2.4 | － | V |

2652 tol 04

DC ELECTRICAL CHARACTERISTICS OVER THE OPERATING
TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=0.5 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Conditions | Version | $\begin{aligned} & 70101 \times 25^{(2)} \\ & 70105 \times 25^{(2)} \end{aligned}$ |  | $\begin{aligned} & 70101 \times 35 \\ & 70105 \times 35 \end{aligned}$ |  | $\begin{aligned} & 70101 \times 45 \\ & 70105 \times 45 \end{aligned}$ |  | $\begin{aligned} & 70101 \times 55 \\ & 70105 \times 55 \end{aligned}$ |  | $\begin{aligned} & 70101 \times 70^{(3)} \\ & 70105 \times 70^{(3)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ． | Max． | Typ． | Max． | Typ． | Max． | Typ． | Max． | Typ． | Max． |  |
| ICC | Dynamic Operating | $\overline{\overline{C E}} \leq \mathrm{VIL} .$ <br> Outputs Open | Mil． S <br>  L | － | － | $\begin{aligned} & 80 \\ & 80 \\ & \hline \end{aligned}$ | $\begin{aligned} & 300 \\ & 220 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{aligned} & 290 \\ & 210 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 70 \\ & \hline \end{aligned}$ | $\begin{aligned} & 285 \\ & 205 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 65 \\ & \hline \end{aligned}$ | $\begin{aligned} & 275 \\ & 200 \\ & \hline \end{aligned}$ | mA |
|  | Current（Both Ports Active） | $f=f m A x{ }^{(4)}$ | $\begin{array}{r} \text { Com'l. S } \\ \mathrm{L} \end{array}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 260 \\ & 190 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 250 \\ & 180 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 245 \\ & 170 \end{aligned}$ | $\begin{aligned} & 70 \\ & 70 \end{aligned}$ | $\begin{aligned} & 235 \\ & 160 \end{aligned}$ | 二 | － |  |
| ISB1 | Standby Current（Both | $\overline{C E} L$ and $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{V}_{\mathrm{IH}}$ | Mil． S <br>  L | － | － | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 55 \\ & \hline \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & \hline 65 \\ & 55 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 55 \\ & \hline \end{aligned}$ | mA |
|  | Ports－TTL <br> Level Inputs） | $f=f M A X^{(4)}$ | $\begin{array}{r} \text { Com'l. S } \\ \text { L } \end{array}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \\ & \hline \end{aligned}$ | 二 | － |  |
| ISB2 | Standby <br> Current（One | $\begin{aligned} & \overline{\overline{\mathrm{CE}}} \mathrm{~L} \text { or } \\ & \overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{V}_{1 H} \end{aligned}$ |  Mil． <br>  S | － | － | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & 190 \\ & 145 \\ & \hline \end{aligned}$ | $\begin{array}{r} 45 \\ 45 \\ \hline \end{array}$ | $\begin{array}{r} 170 \\ 140 \\ \hline \end{array}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 170 \\ & 140 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 165 \\ & 135 \\ & \hline \end{aligned}$ | mA |
|  | Port－TTL <br> Level Inputs） | Active Port Outputs Open， $f=f M_{A X}{ }^{(4)}$ | Com'l. S $L$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 175 \\ & 125 \end{aligned}$ | $\begin{aligned} & 46 \\ & 46 \end{aligned}$ | $\begin{aligned} & 160 \\ & 115 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 150 \\ & 105 \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | $\begin{gathered} 140 \\ 95 \end{gathered}$ | － | － |  |
| ISB3 | Full Standby Current（Both | Both Ports $\overline{\text { CEL }}$ and $\overline{\mathrm{CE}} \mathrm{R} \geq$ | $\begin{array}{ll} \hline \text { Mil. } & \mathrm{S} \\ & \mathrm{~L} \\ \hline \end{array}$ | 二 | 二 | $\begin{aligned} & 1.2 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  | Ports－All CMOS Level Inputs） | $\begin{aligned} & \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc} \\ & -0.2 \mathrm{~V} \text { or } \mathrm{VIN} \\ & \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)} \end{aligned}$ | $\begin{array}{r} \text { Com'l. S } \\ \mathrm{L} \end{array}$ | $\begin{aligned} & 1.2 \\ & 0.4 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | $\begin{aligned} & 1.2 \\ & 0.4 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | $\begin{aligned} & \hline 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | － | － |  |
| IS84 | Full Standby Current（One | One Port CEL or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}$ |   <br> Mil． S <br>  L | － | － | $\begin{aligned} & 47 \\ & 44 \end{aligned}$ | $\begin{aligned} & 170 \\ & 130 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 160 \\ & 125 \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{aligned} & 155 \\ & 120 \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{aligned} & 150 \\ & 115 \\ & \hline \end{aligned}$ | mA |
|  | Port－All CMOS Level Inputs） | $\begin{aligned} & -0.2 \mathrm{~V} \text { VIN } \geq \\ & \text { Vcc }-0.2 \mathrm{~V} \text { or } \\ & \text { VIN } \leq 0.2 \mathrm{~V} \\ & \text { Active Port } \\ & \text { Outputs Open, } \\ & \mathrm{f}=\mathrm{fmax}^{(4)} \end{aligned}$ | Com'l. S $\mathrm{L}$ | $\begin{aligned} & 50 \\ & 46 \end{aligned}$ | $\begin{aligned} & 155 \\ & 120 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 142 \\ & 110 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 132 \\ & 100 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{gathered} 127 \\ 95 \end{gathered}$ | － | － |  |

NOTES：
1．＂x＂in part numbers indicates power rating（S or L）．
2． $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only．
3．$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only．
4．At $f$＝fMAX，address and data inputs（except Output Enable）are cycling at the maximum frequency of read cycle of $1 /$ trc，and using＂AC TEST CONDITIONS＂ of input levels of GND to 3V．
5．$f=0$ means no address or control lines change．Applies only to inputs at CMOS level standby．

## DATA RETENTION CHARACTERISTICS (L Version Only)



NOTES:
2652 tb 06

1. $\mathrm{Vcc}=2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$
2. $\mathrm{thC}=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

Input Pulse Levels Input Rise/Fall Times
Input Timing Reference Levels
Output Reference Levels

Output Load $\qquad$ | $2652 \pm 107$ |
| ---: | ---: |

Figure 1. Output Load
2652 draw 04


Figure 2. Output Load (for thy, twa, and tow)


Figure 3. $\overline{\mathrm{BUSY}}$ and INT Output Load

[^7]IDT70101S/L, IDT70105S/L
HIGH-SPEED $1 \mathrm{~K} \times 9$ DUAL-PORT STATIC RAM
MILITARY AND COMMERCIAL TEMPERATURE RANGES

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(5)}$

| Symbol | Parameter | $\begin{aligned} & 70101 \times 25^{(2)} \\ & 70105 \times 25^{(2)} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 70101 \times 35 \\ & 70105 \times 35 \end{aligned}$ |  | $\begin{array}{r} 70101 \times 45 \\ 70105 \times 45 \\ \hline \end{array}$ |  | $\begin{array}{r} 70101 \times 55 \\ 70105 \times 55 \\ \hline \end{array}$ |  | $\begin{array}{\|l\|} \hline 70101 \times 70^{(3)} \\ 70105 \times 70^{(3)} \\ \hline \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tAOE | Output Enable Access Time | - | 12 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tor | Output Hold From Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(4)}$ | 0 | - | 0. | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(4)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ range only.
4. This parameter guaranteed but not tested.
5. " $x$ " in part numbers indicates power rating (S or L).

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


NOTES:
2652 drw 09

1. $R / \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{\mathrm{OE}}=\mathrm{VIL}$

AC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(7)}$

| Symbol | Parameter | $\begin{aligned} & 70101 \times 25^{(2)} \\ & 70105 \times 25^{(2)} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 70101 \times 35 \\ & 70105 \times 35 \end{aligned}$ |  | $\begin{aligned} & 70101 \times 45 \\ & 70105 \times 45 \end{aligned}$ |  | $\begin{aligned} & 70101 \times 55 \\ & 70105 \times 55 \end{aligned}$ |  | $\begin{aligned} & 70101 \times 70^{(3)} \\ & 70105 \times 70^{(3)} \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time ${ }^{(5)}$ | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tEW | Chip Enable to End of Write | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(6)}$ | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| twn | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data Valid to End of Write | 12 | - | 20 | - | 20 | - | 20 | - | 30 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High $\mathbf{Z}^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | 二 | 35 | ns |
| tow | Output Active From End of Write ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1, 2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. For MASTER/SLAVE combination, twc $=$ tsAA + twp.
6. Specified for $\overline{O E}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).
7. "x" in part numbers indicates power rating (S or L).

TIMING WAVEFORM OF WRITE CYCLE NO. 1, (R/W CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


2652 drw 10

TIMING WAVEFORM OF WRITE CYCLE NO. 2, ( $\overline{\text { CE }}$ CONTROLLED TIMING) $)^{(1,2,3,5)}$


1. $\mathrm{R} \overline{\mathrm{W}}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. tWR is measured from the earlier of $\overline{C E}$ or $R / \bar{W}$ going high to the end of the write cycle.
4. During this period, the I/O pins are in the output state and input signals must not be applied.
5. If the CE low transition occurs simultaneously with or after the RWW low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig).
7. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twP or twZ + tDW to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(8)}$

| Symbol | Parameter | $\begin{aligned} & 70101 \times 25^{(1)} \\ & 70105 \times 25^{(1)} \end{aligned}$ |  | $\begin{aligned} & 70101 \times 35 \\ & 70105 \times 35 \end{aligned}$ |  | $\begin{aligned} & 70101 \times 45 \\ & 70105 \times 45 \end{aligned}$ |  | $\begin{array}{r} 70101 \times 55 \\ 70105 \times 55 \\ \hline \end{array}$ |  | $\begin{aligned} & 70101 \times 70^{(2)} \\ & 70105 \times 70^{(2)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Busy Timing (For Master IDT70101 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | $\overline{\text { BUSY }}$ Access Time to Address | - | 25 | - | 35 | - | 35 | - | 45 | - | 45 | ns |
| tBDA | BUSY Disable Time to Address | - | 20 | - | 30 | - | 35 | - | 40 | - | 40 | ns |
| tBAC | $\overline{B U S Y}$ Access Time to Chip Enable | - | 20 | - | 30 | - | 30 | - | 35 | - | 35 | ns |
| tBDC | $\overline{\text { BUSY }}$ Disable Time to Chip Enable | - | 20 | - | 25 | - | 25 | - | 30 | - | 30 | ns |
| twDD | Write Pulse to Data Delay ${ }^{(3)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 95 | ns |
| tDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| Busy Input Timing (For Slave IDT70105 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| twb | Write to BUSY $\operatorname{Input}{ }^{(6)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After $\overline{\text { BUSY }}^{(7)}$ | 15 | - | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| twDD | Write Pulse to Date Delay ${ }^{(9)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 95 | ns |
| tDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |

## NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY (For MASTER IDT70101 only)".
4. To ensure that the earlier of the two ports wins.
5. tBDD is a calculated parameter and is the greater of 0 , twDD - tWP (actual) or toDD - tDw (actual).

6 . To ensure that a write cycle is inhibited during contention.
7. To ensure that a write cycle is completed after contention.
8. "x" in part numbers indicates power rating ( S or L ):
9. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With $\overline{B U S Y}$ Port-to-port Delay (For SLAVE IDT70105 only)".

TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}^{(1,2,3)}$
(FOR MASTER IDT70101 ONLY)


NOTES:

1. To ensure that the earlier of the two ports wins.
2. Write Cycle parameters should be adhered to, in order to ensure proper writing.
3. Device is continuously enabled for both ports.
4. $\overline{O E}$ at LOW for the reading port.

TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$ (FOR SLAVE IDT70105 ONLY)


1. Assume $\overline{\mathrm{BUSY}}$ input at HIGH for the writing port, and $\overline{\mathrm{OE}}$ at LOW for the reading port.
2. Write Cycle parameters should be adhered to, in order to ensure proper writing.
3. Device is continuously enabled for both ports.

TIMING WAVEFORM OF WRITE WITH BUSY INPUT (FOR SLAVE IDT70105 ONLY)


TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, $\overline{\text { CE }}$ ARBITRATION
$\overline{C E L}$ VALID FIRST:


CER VALD FIRST:


2652 dw 18
TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION ${ }^{(1)}$
LEFT ADDRESS VALID FIRST:


RIGHT ADDRESS VALID FIRST:


NOTE:

1. $\overline{C E L}=\overline{C E} R=V_{L}$

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(3)}$

| Symbol | Parameter | $\begin{aligned} & 70101 \times 25^{(1)} \\ & 70105 \times 25^{(1)} \end{aligned}$ |  | $\begin{array}{r} 70101 \times 35 \\ 70105 \times 35 \\ \hline \end{array}$ |  | $\begin{aligned} & 70101 \times 45 \\ & 70105 \times 45 \end{aligned}$ |  | $\begin{array}{r} 70101 \times 55 \\ 70105 \times 55 \end{array}$ |  | $\begin{aligned} & 70101 \times 70^{(2)} \\ & 70105 \times 70^{(2)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Interrupt Timing |  |  |  |  |  |  |  |  |  |  |  |  |
| tAs | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twn | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tINS | Interrupt Set Time | - | 25 | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| tINR | Interrupt Reset Time | - | 25 | - | 35 | - | 40 | - | 45 | - | 50 | ns |

## NOTES:

1. $0^{\circ} \mathrm{C}$ to $-70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. " $x$ " in part numbers indicates power rating (S or L).

TIMING WAVEFORM OF INTERRUPT MODE ${ }^{(1,2)}$
LEFT SIDE SETS $\overline{I N T}_{\text {r }}$ :


RIGHT SIDE CLEARS $\overline{\text { INTTR: }}$


NOTES:

1. $\overline{\mathrm{CEL}}_{\mathrm{L}}=\overline{\mathrm{CE}}_{\mathrm{R}}=\mathrm{V}_{\mathrm{LL}}$
2. INTL and $\overline{\mathbb{N T}} \mathrm{R}$ are reset (high) during power-up.

TIMING WAVEFORM OF INTERRUPT MODE ${ }^{(1,2)}$
RIGHT SIDE SETS $\overline{\operatorname{INT} L: ~}$


LEFT SIDE CLEARS $\overline{N T T}$ :


NOTES:

1. $\overline{\mathrm{CE}}=\overline{\mathrm{CE}} \mathrm{R}=\mathrm{V}_{\mathrm{IL}}$
2. $\mathbb{I N T}_{R}$ and $\mathbb{I N T L}$ are reset (high) during power-up.

## 18-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



NOTE:

1. No arbitration in IDT70105 (SLAVE). BUSY-IN inhibits write in IDT70105 (SLAVE).

## FUNCTIONAL DESCRIPTION

The IDT70101/70105 provides two ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. The IDT70101/ 70105 has an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{\mathrm{CE}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control $(\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READNRITE conditions are illustrated in Table 1.

The interrupt flag (INT) permits communication between ports or systems. If the user chooses to use the interrupt function, a memory location (mail box or message center) is assigned to each port. The left port interrupt flag (INTL) is set when the right port writes to memory location 3FE (HEX). The left port clears the interrupt by reading address location 3FE. Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location 3FF (HEX) and to clear the interrupt flag (INTR), the right port must read the memory location 3FF. The message (9-bits) at 3FE or a 3FF is user defined. If the interrupt function is not used, address location 3FE and 3FF are not used as mail boxes, but as part of the random access memory. Refer to Table II for the interrupt operation.

## ARBITRATION LOGIC, FUNCTIONAL DESCRIPTION

The arbitration logic will resolve an address match or a chip enable match to 5 ns minimum and determine which port has access. In all cases, an active BUSY flag will be set for the delayed port.

The $\overline{B U S Y}$ flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address and data. It is important to note that the operation is invalid for the port that has $\overline{B U S Y}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{C E}$, on-chip control logic arbitrates between $\overline{C E L}$ and $\overline{\mathrm{CE}}$ R for access; or (2) if the $\overline{\mathrm{CE}}$ s are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table III). In either mode of arbitration, the delayed port's $\overline{B U S Y}$ flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION, MASTER/SLAVE DESCRIPTION

Expanding the data bus width to eighteen-or-more-bits in a dual-port RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its $\overline{B U S Y}$ while another activates its $\overline{B U S Y}_{\mathrm{R}}$ signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid this "Busy Lock-Out"problem, IDT has developed a MASTER/SLAVE approach where only one hardware arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMs in width, the writing of the SLAVE RAMs must be delayed, until after the $\overline{B U S Y}$ input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past BUSY to ensure that a write takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than than one chip is active at the same time.

The write pulse to the SLAVE should by the maximum arbitration time of the MASTER. If, then a contention occurs, the write to the SLAVE will be inherited due to $\overline{B U S Y}$ from the MASTER.

## TRUTH TABLES

TABLE I. NON-CONTENTION
READ/WRITE CONTROL ${ }^{(4)}$

| Left or Right Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R $\bar{W}$ | $\overline{C E}$ | $\overline{\text { OE }}$ | D0-8 |  |
| X | H | X | Z | Port Disabled and in Power Down Mode, IsB2 or ISB4 |
| X | H | X | Z | $\overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{H}$, Power Down Mode, IsB1 or IsB3 |
| L | L | X | DATAIN | Data on Port Written Into Memory ${ }^{(2)}$ |
| H | L | L | DATAOUT | Data in Memory Output on Port ${ }^{(3)}$ |
| H | L | H | Z | High Impedance Outputs |

NOTES:
2652 tbd 16

1. AOL - Ag $\neq A 0 R-A 9 R$
2. If $\overline{B U S Y}=\mathrm{L}$, data is not written.
3. If $\overline{B U S Y}=L$, data may not be valid, see twDD and toDD timing.
4. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=$ LOW, $\mathrm{X}=$ DON'T CARE, $\mathrm{Z}=\mathrm{HIGH}$ IMPEDANCE

TABLE II. INTERRUPT FLAG ${ }^{(1,4)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{R} / \bar{W}_{L}$ | $\overline{\mathrm{CE}} \mathrm{L}^{\text {L }}$ | $\overline{\mathrm{OE}}$. | AOL - AgL | INTL | $\mathrm{R} \bar{W}_{\mathrm{W}}$ | $\overline{\mathrm{CE}}$ R | OER | AOL - AgR | INTR |  |
| L | L | X | 3FF | X | X | X | X | X | $L^{(2)}$ | Set Right INTR Flag |
| X | X | X | X | X | X | L | L | 3FF | $H^{(3)}$ | Reset Right $\overline{\text { NTTR }}$ Flag $^{\text {a }}$ |
| X | X | X | X | $L^{(3)}$ | L | L | X | 3FE | X | Set Left INTL Flag |
| X | L | L | 3FE | $H^{(2)}$ | X | X | X | X | X | Reset Left INTL. Flag |

NOTES:

1. Assumes $\overline{B U S Y L}=\overline{B U S Y R}=H$.
2. If $B U S Y L=L$, then $N C$.
3. If $\overline{B U S Y R}=L$, then $N C$.
4. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=\mathrm{LOW}, \mathrm{X}=$ DON'T CARE, NC $=$ NO CHANGE

TABLE III. ARBITRATION ${ }^{(1)}$

| Left Port |  | Right Port |  | Flags |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E L}$ | A0L - AgL | CER | A0R - A9R | $\overline{\text { BUSYL }}$ | BUSYR |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | $\neq A 0 R-A 9 R$ | L | $\nRightarrow$ AOL - AgL | H | H | No Contention |
| Address Arbitration With $\overline{\mathrm{CE}}$ Low Before Address Match |  |  |  |  |  |  |
| L | LV5R | L | LV5R | H | L | L-Port Wins |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |
| $\overline{\mathrm{CE}}$ Arbltration With Address Match Before $\overline{\mathrm{CE}}$ |  |  |  |  |  |  |
| LL5R | $=A 0 R-A 9 R$ | LL5R | $=\mathrm{AOL}-\mathrm{AgL}$ | H | L | L-Port Wins |
| RL5L | = A0R - A9R | RL5L | $=\mathrm{AOL}$ - AgL | L | H | R-Port Wins |
| LW5R | $=A 0 R-A 9 R$ | LW5R | $=\mathrm{AOL}-\mathrm{AgL}$ | H | L | Arbitration Resolved |
| LW5R | $=\mathrm{AOR}-\mathrm{AgR}$ | LW5R | $=\mathrm{AOL}-\mathrm{AgL}$ | L | H | Arbitration Resolved |

## NOTES:

1. $X=$ DON'T CARE, $L=$ LOW, $H=$ HIGH LV5R $=$ Left Address Valid $\geq 5 \mathrm{~ns}$ before right address. RV5L $=$ Right Address Valid $\geq 5$ ns before left address.

Same $=$ Left and Right Addresses match within 5 ns of each other.
LL5R = Left $\overline{C E}=L O W>5 n s$ before Right $\overline{C E}$.
RL5L $=$ Right $\overline{C E}=L O W \geq 5 n$ s before Left $\overline{C E}$.
LW5R = Left and right $\overline{C E}=$ LOW within 5 ns of each other.

## ORDERING INFORMATION




## FEATURES:

- High-speed access
- Military: 25/30/35/45/55/70/90/100/120ns (max.)
- Commercial: 20/25/30/35/45/55/70/90/100ns (max.)
- Low-power operation
- IDT7132/42SA

Active: 325 mW (typ.)
Standby: 5mW (typ.)

- IDT7132/42LA

Active: 325 mW (typ.)
Standby: 1mW (typ.)

- Fully asynchronous operation from either port
- MASTER IDT7132 easily expands data bus width to 16-or-more bits using SLAVE IDT7142
- On-chip port arbitration logic (IDT7132 only)
- $\overline{\text { BUSY }}$ output flag on IDT7132; $\overline{B U S Y}$ input on IDT7142
- Battery backup operation -2V data retention
- TTL-compatible, single $5 v \pm 10 \%$ power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD, Class B
- Standard Military Drawing \# 5962-87002


## DESCRIPTION:

The IDT7132/IDT7142 are high-speed $2 \mathrm{~K} \times 8$ dual-port static RAMs. The IDT7132 is designed to be used as a standalone 8-bit dual-port RAM or as a "MASTER" dual-port RAM together with the IDT7142 "SLAVE" dual-port in 16-bit-ormore word width systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 16-or-more-bit memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide two independent ports with seperate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power down feature, controlled by $\overline{\mathrm{CE}}$ permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOSTm high-performance technology, these devices typically operate on only 325 mW of power at maximum access times as fast as 20ns. Low-power (LA) versions offer battery backup data retention capability, with each dual-port typically consuming $200 \mu \mathrm{~W}$ from a 2 V battery.

The IDT7132/7142 devices are packaged in a 48 -pin sidebraze or plastic DIPs, 48- or 52-pin LCCs, 52-pin PLCCs, and a 48-lead flatpacks.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



NOTE:

1. IDT7132 (MASTER): BUSY is open output and requires pullup resistor.

IDT7142 (SLAVE): $\overline{B U S Y}$ is input.
CEMOS is a trademark of Integrated Device Technology, Inc.

PIN CONFIGUARATIONS

| $\overline{\mathrm{CE}} \square_{1}$ | 48 | Vcc |
| :---: | :---: | :---: |
| R/ $\bar{W}_{L}{ }^{-1}$ | 47 | CER |
| BUSYL -3 | 46 | R/ $\bar{W}^{\text {a }}$ |
| ATOL -1 | 45 | $\overline{B U S Y}^{\text {d }}$ |
| OEL $\square 5$ | 44 | A10R |
| AOL 5 | 43 | OER |
| $\mathrm{AlL}_{1} \mathrm{C}_{7}$ | 42 | A0R |
| A2L $\square 8$ | 41 | AiR |
| A3L $\square 9$ | P48-1 40 | A2R |
| A4L $\square 10$ | C48-1' 39 | A3R |
| A5L - 11 | $\begin{array}{cc} \text { C48-1 } & 38 \\ \& \end{array}$ | A 4 R |
| A6L $\square 12$ | C48-2 37 | A ${ }^{\text {5 }}$ R |
| A7L -13 | C48-2 36 | A6R |
| A8L $\square 14$ | 35 | A 78 |
| A9L $\square 15$ | 34 | A8R |
| I/Ool 516 | 33 | A9R |
| I/O1L-17 | 32 | $1 / \mathrm{O} 7$ R |
| 1/O2L ¢18 $^{\text {c }}$ | 31 | $1 /{ }^{1} /{ }^{\text {ar }}$ |
| //O3L -19 | 30 | I/O5R |
| I/O4L - 20 | 29 | $1 / \mathrm{O} 4 \mathrm{R}$ |
| I/O5L -21 | 28 | $1 / \mathrm{O} 3 \mathrm{R}$ |
| 1/O6L - 22 | 27 | $\square 1 / O 2 R$ |
| 1/O7L -23 | 26 | $1 / O_{1 R}$ |
| GND-24 | 25 | $1 / \mathrm{OOR}$ |

DIP
TOP VIEW

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

2692 tol 01

1. Stresses greater than thoselistedunder ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.


2692 drw 03


## RECOMMENDED

DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5(1)$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS OVER THE <br> OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE（Vcc $=5.0 \mathrm{~V} \pm 10 \%$ ）

| Symbol | Parameter | Test Conditions | IDT7132SA <br> IDT7142SA <br> Min． Max． |  | IDT7132LA <br> IDT7142LA <br> Max． Max． |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ｜니 | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| ｜lıO｜ | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}$, Vout $=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage $\left(1 / \mathrm{O}-1 / \mathrm{O}_{7}\right)$ | $\mathrm{lOL}=4 \mathrm{~mA}$ | － | 0.4 | － | 0.4 | V |
| Vol | Open Drain Output Low Voltage（ $\overline{\mathrm{BUSY}}$ ） | $\mathrm{loL}=16 \mathrm{~mA}$ | － | 0.5 | － | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{OH}=-4 \mathrm{~mA}$ | 2.4 | － | 2.4 | － | V |

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLE VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Conditions | Version | $\left\|\begin{array}{r} 7132 \times 20(2,6) \\ 7142 \times 20^{(2,6)} \\ \text { Typ. Max. } \end{array}\right\|$ | $\begin{aligned} & 7132 \times 25(6) \\ & 7142 \times 25(6) \\ & \text { Typ. Max. } \end{aligned}$ | $\begin{array}{\|l\|} \hline 7132 \times 30^{(6)} \\ 7142 \times 30(6) \\ \text { Typ. Max. } \end{array}$ | $\begin{aligned} & 7132 x \\ & 7142 x \\ & \text { TVn } \end{aligned}$ | $\begin{aligned} & 35(7) \\ & 35(7) \\ & \text { Max. } \\ & \hline \end{aligned}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC | Dynamic Operating Current（Both Ports Active） | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{VIL} \\ & \text { Outputs Open } \\ & \mathrm{f}=\mathrm{fmAX}^{(4)} \\ & \hline \end{aligned}$ | Mil． SA <br>   | － | $\begin{array}{ll}75 & 300 \\ 75 & 220\end{array}$ | 75 290 <br> 75 210 | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 280 \\ & 200 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | 230 | mA |
|  |  |  | Com＇l．LA | 75 260 <br> 75 190 | $\begin{array}{ll}75 & 250 \\ 75 & 180\end{array}$ | $\begin{array}{ll}75 & 240 \\ 75 & 170\end{array}$ | 75 | 195 | 75 | 190 |  |
| ISB1 | Standby Current （Both Ports－TTL Level Inputs） | $\begin{aligned} & \overline{\mathrm{CEL}} \text { and } \overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH} \\ & \mathrm{f}=\mathrm{MAX}{ }^{(4)} \end{aligned}$ | Mil． <br> SA | － | 25 75 <br> 25 55 | 25.75 $25 \% .55$ | 25 25 | 75 | 25 25 | 65 55 | mA |
|  |  |  | Com＇l．LA | 25 65 <br> 25 45 | $\begin{array}{ll}25 & 65 \\ 25 & 45\end{array}$ | 25. 25.65 25.45 | 25 25 | 65 45 | 25 25 | 65 45 |  |
| ISB2 | Standby Current （One Port－TTL Level Inputs） | $\overline{\mathrm{CE}}$ ．or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH}^{2}$ Active Port Outputs Open，$f=f$ max ${ }^{(4)}$ | Mil．SA | 二 二 | $\begin{array}{ll}50 & 180 \\ 50 & 140\end{array}$ | 46 175 <br> 46 135 | 40 | 170 <br> 130 | 40 | 135 110 | mA |
|  |  |  | Com＇l．LA | 50 180 <br> 50 130 | 50,170 50,120 | 46 155 <br> 46 110 | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | $\begin{gathered} 130 \\ 95 \end{gathered}$ | 40 | 120 85 8 |  |
| ISB3 | Full Standby Current （Both Ports－All CMOS Level Inputs | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ VIN $\geq$ Vcc -0.2 V or $\operatorname{ViN} \leq 0.2 V, t=0^{(5)}$ | Mil． SA | 二 二 |  | 1.2 40 <br> 0.4 10 <br> 1.2  | 1.2 0.4 | 35 10 | 1.0 0.2 | 30 <br> 10 | mA |
|  |  |  | Com＇l．LA | 1.2 15 <br> 0.4 4 | $\begin{array}{ll}1 \% 2 & 15 \\ 0.4 & 4\end{array}$ | $\begin{array}{cc}1.2 & 15 \\ 0.4 & 4\end{array}$ | 1.0 0.2 | 15 4 | 1.0 | 15 4 |  |
| ISB4 | Full Standby Current （One Port－All CMOS Level Inputs $f=0^{(5)}$ ） | One Port $\overline{C E} L$ or $\overline{C E}_{R} \geq$ Vcc－0．2V VIN $\geq$ Vcc -0.2 V or VIn $\leq 0.2 \mathrm{~V}$ Active Port Outputs Open，$f=f$ max $^{(4)}$ | Mil．SA | $\stackrel{\square}{*} \times$ | $\begin{array}{ll}50 & 170 \\ 46 & 135\end{array}$ | 45 160 <br> 42 125 | 45 | 150 115 | 40 35 | 125 95 | mA |
|  |  |  | Com＇l．SA | $\begin{array}{ll}50 * & 160 \\ 46 & 125\end{array}$ | $\begin{array}{ll} \hline 50 & 150 \\ 46 & 115 \end{array}$ | 45 137 <br> 42 105 | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{gathered} \hline 115 \\ 90 \end{gathered}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | 105 80 |  |

## NOTES：

1．$x$ in part numbers indicates power rating（SA or LA）．
2． $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only．
3．$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only．
4．At $f$＝ Max，address and data inputs（except Output Enable）are cycling at the maximum frequency of read cycle of $1 /$ tRc，and using ＂AC TEST CONDITIONS＂of input levels of GND to 3 V ．
5．$f=0$ means no address or control lines change．Applies only to inputs at CMOS level standby．
6．Not available in DIP packages－see 7032／7042 data sheet．
7．DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only－see $7032 / 7042$ data sheet．

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$（Continued）（VCC $=5.0 \mathrm{~V} \pm 10 \%$ ）

| Symbol | Parameter | Test Conditions | Version | $\begin{aligned} & 7132 \times 55 \\ & 7142 \times 55 \\ & \text { Typ. Max. } \\ & \hline \end{aligned}$ | $\begin{aligned} & 7132 \times 70 \\ & 7142 \times 70 \\ & \text { Typ. Max. } \end{aligned}$ | $\begin{aligned} & 7132 \times 90 \\ & 7142 \times 90 \\ & \text { Typ. Max. } \end{aligned}$ | $\begin{array}{r} 7132 \times 100 \\ 7142 \times 100 \\ \text { Typ. Max. } \end{array}$ | $\begin{gathered} 7132 \times 120(3) \\ 7142 \times 120 \\ \mathrm{Typ} . \mathrm{Max} . \end{gathered}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC | Dynamic Operating Current（Both Ports Active | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}} \\ & \text { Outputs Open } \\ & \mathrm{f}=\mathrm{fmAX} \end{aligned}$ | Mil．SA | 65230 65185 | $\begin{array}{lll}65 & 225 \\ 65 & 180\end{array}$ | 65200 65160 | 65 190 <br> 65 155 | 65190 65155 | mA |
|  |  |  | Com＇l．LA | 65180 65140 | $\begin{array}{ll}65 & 180 \\ 65 & 135\end{array}$ | 65180 65130 | （180 $\begin{array}{ll}65 & 180 \\ 65 & 130\end{array}$ |  |  |
| ISB1 | Standby Current （Both Ports－TTL Level Inputs） | $\begin{aligned} & C E L \text { and } C E R \geq V I H \\ & f=f \mathrm{fmax}^{(4)} \end{aligned}$ | Mil．SA | $\begin{array}{ll}25 & 65 \\ 25 & 55\end{array}$ | 25 65 <br> 25 55 | $\begin{array}{lll}25 & 65 \\ 2545\end{array}$ | $\begin{array}{ll}25 & 65 \\ 25 & 45\end{array}$ | 2565 2545 | mA |
|  |  |  | Com＇l．LA | $\begin{array}{ll}25 & 65 \\ 25 & 45\end{array}$ | $\begin{array}{lll}25 & 60 \\ 25 & 40\end{array}$ | $\begin{array}{lll}25 & 55 \\ 25 & 35\end{array}$ | $\begin{array}{ll}25 & 55 \\ 25 & 35\end{array}$ | 二 二 |  |
| ISB2 | Standby Current （One Port－TTL Level Inputs） | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{\mathrm{IH}}$ Active Port Outputs Open，$f=$ fmax ${ }^{(4)}$ | Mil．SA | 40 40 1135 | $\begin{array}{lll}40 & 135 \\ 40 & 110\end{array}$ | 40125 <br> 40 | $\begin{array}{ll}40 & 125 \\ 40 & 100\end{array}$ | 40125 40100 | mA |
|  |  |  | Com＇l．LA | $\begin{array}{lll}40 & 115 \\ 40 & 85\end{array}$ | $\begin{array}{cc}40 & 110 \\ 40 & 85\end{array}$ | 40110 4075 | 40 110 <br> 40 75 | 二 二 |  |
| ISB3 | Full Standby Current （Both Ports－All CMOS Level Inputs） | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and <br> $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> Vin $\geq$ Vcc -0.2 V or <br> $\mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)}$ | Mil．SA | $\begin{array}{lll}1.0 & 30 \\ 0.2 & 10\end{array}$ | $\begin{array}{lll}1.0 & 30 \\ 0.2 & 10\end{array}$ | $\begin{array}{lll}1.0 & 30 \\ 0.2 & 10\end{array}$ | $\begin{array}{ll}1.0 & 30 \\ 0.2 & 10\end{array}$ | 1.030 0.210 | mA |
|  |  |  | Com＇l．LA | $\begin{array}{ll}1.0 & 15 \\ 0.2 & 4\end{array}$ | $\begin{array}{lll}1.0 & 15 \\ 0.2 & 4\end{array}$ | $\begin{array}{lll}1.0 & 15 \\ 0.2 & 4\end{array}$ | $\begin{array}{ll}1.0 & 15 \\ 0.2 & 4\end{array}$ | 二 二 |  |
| ISB4 | Full Standby Current （One Port－All CMOS Level Inputs，$f=0^{(5)}$ ） | One Port $\overline{C E} L$ or <br> $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> VIn $\geq$ Vcc -0.2 V or <br> $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs <br> Open，$f=f$ MAX ${ }^{(4)}$ | Mil．SA | 40120 $35 \quad 90$ | $\begin{array}{ccc}40 & 115 \\ 35 & 85\end{array}$ | 40110 $35 \quad 80$ | 40 110 <br> 35 80 | 40110 <br> 3580 | mA |
|  |  |  | Com＇l．LA | 40100 3575 | $\begin{array}{lll}40 & 100 \\ 35 & 75\end{array}$ | $\begin{array}{ll}40 & 95 \\ 35 & 70\end{array}$ | $\begin{array}{ll}40 & 95 \\ 35 & 70\end{array}$ | 二－ |  |

## NOTES：

1．$x$ in part numbers indicates power rating（ $S A$ or $L A$ ）．
2． $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only．
3．$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only．
4．At $f=f$ max，address and data inputs（except Output Enable）are cycling at the maximum frequency of read cycle of $1 / t \mathrm{Rc}$ ，and using
＂AC TEST CONDITIONS＂of input levels of GND to 3 V ．
5．$f=0$ means no address or control lines change．Applies only to inputs at CMOS level standby．
6．Not available in DIP packages－see 7032／7042 data sheet．
7．DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only－see $7032 / 7042$ data sheet．

DATA RETENTION CHARACTERISTICS（LA Version Only）

| Symbol | Parameter | Test Conditions |  | IDT71 <br> Min． | $\begin{aligned} & \text { A/IDT } \\ & \text { Typ. } \end{aligned}$ | A | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vor | Vcc for Data Retention | $\begin{aligned} & V c c=2.0 \mathrm{~V}, \overline{\mathrm{CE}} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \mathrm{VIN} \leq 0.2 \mathrm{~V} \end{aligned}$ |  | 2.0 | － | 0 | V |
| ICCDR | Data Retention Current |  | Mil． | － | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | Com＇l． | － | 100 | 1500 | $\mu \mathrm{A}$ |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | － | － | ns |
| $t R^{(3)}$ | Operation Recovery Time |  |  | trc ${ }^{(2)}$ | － | － | ns |

## NOTES：

1． $\mathrm{VCC}=2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$
2． $\mathrm{tRC}=$ Read Cycle Time
3．This parameter is guaranteed but not tested．

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND TO 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1,2,3 \& 4$ |
| 2692 ゅt 08 |  |



Figure 1. Output Load


Figure 3. Busy Output Load (IDT7132 only)


Figure 2. Output Load (for thv, tiz, twz, and tow)


Figure 4. $\overline{B U S Y}$
Output Load (for 20ns, 25ns and 30ns versions)

* Including scope and jig


## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (5)| Symbol | Parameter | $\begin{aligned} & 7132 \times 20^{(2,6)} \\ & 7142 \times 20^{(2,6)} \end{aligned}$ |  | $\begin{aligned} & 7132 \times 25^{(6)} \\ & 7142 \times 25^{(6)} \end{aligned}$ |  | $\begin{aligned} & 7132 \times 30^{(6)} \\ & 7142 \times 30^{(8)} \end{aligned}$ |  | $\begin{aligned} & 7132 \times 35(7) \\ & 7142 \times 35^{(7)} \end{aligned}$ |  | $\begin{aligned} & 7132 \times 45 \\ & 7142 \times 45 \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 20 | - | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| tAA | Address Access Time | - | 20 | - | 25 | $\stackrel{+}{*}$ | 30 | - | 35 | - | 45 | ns |
| tace | Chip Enable Access Time | - | 20 | - | 25 | , | 30 | - | 35 | - | 45 | ns |
| taoe | Output Enable Access Time | - | 10 | - | \% 12 | - | 15 | - | 25 | - | 30 | ns |
| tor | Output Hold From Address Change | 0 | - | Q* | ** | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,4)}$ | 0 | 二 | O 0 | - | 0 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 8. | * | 10 | - | 12 | - | 15 | - | 20 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(4)}$ | 0 | \% ${ }_{\text {\% }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(4)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(5)}$ (Continued)

| Symbol | Parameter | $\begin{aligned} & 7132 \times 55 \\ & 7142 \times 55 \end{aligned}$ |  | $\begin{aligned} & 7132 \times 70 \\ & 7142 \times 70 \end{aligned}$ |  | $\begin{aligned} & 7132 \times 90 \\ & 7142 \times 90 \end{aligned}$ |  | $\begin{aligned} & 7132 \times 100 \\ & 7142 \times 100 \end{aligned}$ |  | $\begin{aligned} & 7132 \times 120^{(3)} \\ & 7142 \times 120^{(3)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 55 | - | 70 | - | 90 | - | 100 | - | 120 | - | ns |
| tAA | Address Access Time | - | 55 | - | 70 | - | 90 | - | 100 | - | 120 | ns |
| tace | Chip Enable Access Time | - | 55 | - | 70 | - | 90 | - | 100 | - | 120 | ns |
| taoe | Output Enable Access Time | - | 35 | - | 40 | - | 40 | - | 40 | - | 60 | ns |
| toh | Output Hold From Address Change | 0 | - | 0 | - | 10 | - | 10 | - | 10 | - | ns |
| tLZ | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,4)}$ | - | 30 | - | 35 | - | 40 | - | 40 | - | 40 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time(4) | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1, 2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. " $x$ " in part numbers indicates power rating (SA or LA).
6. Not available in DIP packages - see 7032/7042 data sheet.
7. DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only - see $7032 / 7042$ data sheet.
timing waveform of read cycle no. 1, Either side ${ }^{(1,2,4)}$


2692 drw 07

## TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE $(1,3)$



NOTES:
2692 dww 08

1. $R / \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{O E}=V I L$.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLATAGE RANGE (7)

| Symbol | Parameter | $\begin{array}{\|cc} \hline 7132 \times 20^{(2,8)} \\ 7142 \times 20^{(2,8)} \\ \text { Min. } \quad \text { Max. } \\ \hline \end{array}$ |  | $\begin{aligned} & 7132 \times 25^{(8)} \\ & 7142 \times 25^{(8)} \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{aligned} & 7132 \times 30^{(8)} \\ & 7142 \times 30^{(8)} \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{aligned} & 7132 \times 35^{(9)} \\ & 7142 \times 35^{(9)} \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{aligned} & 7132 \times 45 \\ & 7142 \times 45 \\ & \text { Min. Max. } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time (5) | 20 | - | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| tew | Chip Enable to End of Write | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| taw | Address Valid to End of Write | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twP | Write Pulse Width ${ }^{(6)}$ | 15 | - | 20 | \% | 25 | - | 30 | - | 35 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 \% |  | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data Valid to End of Write | 10 | - | 12\% | - | 15 | - | 20 | - | 20 | - | ns |
| tHZ | Output High Z Time ${ }^{(1,4)}$ | - | 8 8, | - | 10 | - | 12 | - | 15 | - | 20 | ns |
| tDH | Data Hold Time | 0 | $\stackrel{\text { " }}{ }$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High Z ${ }^{(1,4)}$ | - | 8 | - | 10 | - | 12 | - | 15 | - | 20 | ns |
| tow | Output Active From End of Write ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures $1,2,3$ and 4).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. For MASTER/SLAVE combination, twc $=$ tBAA $+t W P$.
6. Specified for $\overline{O E}$ at high (Refer to "Timing Waveform of Write Cycle", Note 7)
7. " $x$ " in part numbers indicates power rating (SA or LA).
8. Not available in DIP packages - see $7032 / 7042$ data sheet.
9. DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only - see $7032 / 7042$ data sheet.

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(7)}$ (Continued)

| Symbol | Parameter | $\begin{aligned} & 7132 \times 55 \\ & 7142 \times 55 \end{aligned}$ |  | $\begin{aligned} & 7132 \times 70 \\ & 7142 \times 70 \end{aligned}$ |  | $\begin{aligned} & 7132 \times 90 \\ & 7142 \times 90 \end{aligned}$Min. Max. |  | $\begin{aligned} & 7132 \times 100 \\ & 7142 \times 100 \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 7132 \times 120^{(3)} \\ 7142 \times 120^{(3)} \\ \text { Min. Max. } \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time ${ }^{(5)}$ | 55 | - | 70 | - | 90 | - | 100 | - | 120 | - | ns |
| tEW | Chip Enable to End of Write | 40 | - | 50 | - | 85 | - | 90 | - | 100 | - | ns |
| taw | Address Valid to End of Write | 40 | - | 50 | - | 85 | - | 90 | - | 100 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(6)}$ | 40 | - | 50 | - | 55 | - | 55 | - | 65 | - | ns |
| twh | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tDw | Data Valid to End of Write | 20 | - | 30 | - | 40 | - | 40 | - | 40 | - | ns |
| thz | Output High Z Time (1,4) | - | 30 | - | 35 | - | 40 | - | 40 | - | 40 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High Z(1,4) | - | 30 | - | 35 | - | 40 | - | 40 | - | 50 | ns |
| tow | Output Active From End of Write (1,4) | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. For MASTER/SLAVE combination, twc $=$ tBAA + twp.
6. Specified for $\overline{O E}$ at high (Refer to "Timing Waveform of Write Cycle", Note 7)
7. "x" in part numbers indicates power rating (SA or LA).

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter (1) | Conditions | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 11 | pF |
| COUT | Output Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2692 tol 13

1. This parameter is sampled and not $100 \%$ tested.

TIMING WAVEFORM OF WRITE CYCLE NO. $1,\left(\mathrm{R} / \overline{\mathrm{W}}\right.$ CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


2692 drw 09

TIMING WAVEFORM OF WRITE CYCLE NO. 2 , ( $\overline{\text { CE }}$ CONTROLLED TIMING) $)^{(1,2,3,5)}$


2692 drw 10
NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. twR is measured from the earlier of $\overline{C E}$ or $R / \bar{W}$ going high to the end of the write cycle.
4. During this period, the l/O pins are in the output state and input signals must not be applied.
5. If the CE low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig).
7. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be larger of twP or (twz + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(8)}$

| Symbol | Parameter | $\begin{array}{\|cc\|} \hline 7132 \times 20(1,10) \\ 7142 \times 20(1,10) \\ \text { Min. } \quad \text { Max. } \\ \hline \end{array}$ |  |  | $\begin{gathered} \hline 25(10) \\ 25^{(10)} \\ \text { Max. } \end{gathered}$ | $\begin{gathered} 7132 x \\ 7142 \times \\ \text { Min. } \end{gathered}$ | $\begin{aligned} & \times 30^{(10)} \\ & \times 30^{(10)} \\ & \text { Max. } \end{aligned}$ | $\begin{aligned} & 7132 x \\ & 7132 x \\ & \text { Min. } \end{aligned}$ | $\begin{gathered} \hline \times 35^{(11)} \\ \times 355^{(11)} \\ \text { Max. } \end{gathered}$ | $\begin{aligned} & 7132 \\ & 7142 \\ & \text { Min. } \end{aligned}$ | $\begin{aligned} & 2 \times 45 \\ & 2 \times 45 \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Busy Timing (For Master IDT7132 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 20 | - | 25 | - | 30 | - | 35 | - | 35 | ns |
| tBDA | BUSY Disable Time to Address | - | 18 | - | 20 | , | . 25 | - | 30 | - | 35 | ns |
| tBac | BUSY Access Time to Chip Enable | - | 20 | - | 20 | $\stackrel{1}{2}$ | 25 | - | 30 | - | 30 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 18 | - | 20 | - | 25 | - | 25 | - | 25 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(3)}$ | - | 45 | - | 50 | - | 55 | - | 60 | - | 70 | ns |
| tDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - | 30 |  | , 33 | - | 33 | - | 35 | - | 45 | ns |
| taps | Arbitration Priority Set-up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 5 |  | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| Busy Input Timing (For Slave IDT7142 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| twB | Write to BUSY Input (6) | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After $\overline{\mathrm{BU}} \mathbf{S} \bar{Y}^{(7)}$ | 12 | $\sim$ | 15 | - | 20 | - | 20 | - | 20 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(9)}$ |  | 45. | - | 50 | - | 55 | - | 60 | - | 70 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - | , 30 | - | 35 | - | 40 | - | 35 | - | 45 | ns |

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(8)}$

| Symbol | Parameter |  | $\begin{gathered} 2 \times 55 \\ 2 \times 55 \\ \text { Max. } \end{gathered}$ |  | $\begin{aligned} & \times 70 \\ & \times 70 \\ & \text { Max. } \end{aligned}$ |  | $\begin{aligned} & \times 90 \\ & \times 90 \\ & \text { Max. } \end{aligned}$ |  | $\begin{array}{r} \times 100 \\ \times 100 \\ \text { Max. } \end{array}$ | $\begin{gathered} 7132 \\ 7142 \\ \text { Min. } \end{gathered}$ | $\begin{aligned} & \times 120(2) \\ & \times 120(2) \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Busy Timing (For Master IDT7132 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 45 | - | 45 | - | 45 | - | 50 | - | 60 | ns |
| tBDA | BUSY Disable Time to Address | - | 40 | - | 40 | - | 45 | - | 50 | - | 60 | ns |
| tBAC | BUSY Access Time to Chip Enable | - | 35 | - | 35 | - | 45 | - | 50 | - | 60 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 30 | - | 30 | - | 45 | - | 50 | - | 60 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(3)}$ | - | 80 | - | 90 | - | 100 | - | 120 | - | 140 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - | 55 | - | 70 | - | 90 | - | 100 | - | 120 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tBDD | BUSY Disable to Valid Data ${ }^{(5)}$ | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| Busy Input Timing (For Slave IDT7142 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| twB | Write to BUSY Input( ${ }^{(6)}$ | - | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After BUSY ${ }^{(7)}$ | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(9)}$ | - | 80 | - | 90 | - | 100 | - | 120 | - | 140 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - | 55 | - | 70 | - | 90 | - | 100 | - | 120 | ns |

## NOTES:

[^8]TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}(1,2,3)$ (FOR MASTER IDT7132 ONLY)


NOTES:
2692 dm 11

1. To ensure that the earlier of the two ports wins.
2. Write Cyde parameters should be adhered to in order to ensure proper writing.
3. Device is continously enabled for both ports.
4. $\overline{O E}$ at LO for the reading port.

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$ (FOR SLAVE IDT7142 ONLY)


NOTES:

1. Assume $\bar{B} U S Y$ input at HI for the writing port, and $\overline{\mathrm{OE}}$ at LO for the reading port.
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuosly enabled for both ports.

TIMING WAVEFORM OF WRITE WITH BUSY INPUT (FOR SLAVE IDT7142 ONLY)


## TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, $\overline{\text { CE ARBITRATION }}$

$\overline{C E L}$ VALID FIRST:


2982 drw 14

## CER VALID FIRST:



2682 drw 15
TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION (1) LEFT ADDRESS VALID FIRST:


2692 drw 16
RIGHT ADDRESS VALID FIRST:


2692 drw 17
NOTE:

1. $\overline{\mathrm{CE}} \mathrm{L}=\overline{\mathrm{CE}}_{\mathrm{R}}=\mathrm{V}_{\mathrm{IL}}$

## 16-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



2692 drw 18
NOTE:

1. No arbitration in IDT7142 (SLAVE). BUSY-IN inhibits write in IDT7142 (SLAVE).

## FUNCTIONAL DESCRIPTION:

The IDT7132/42 provides two ports with separate control, address and $/$ /O pins that permit independent access for reads or writes to any locations in memory. These devices have an automatic power-down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power-down circuitry that permits the respective port to go into a standby mode when not selected (CE high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}}$ ). In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/ WRITE conditions are illustrated in Table 1.

## ARBITRATION LOGIC, FUNCTIONAL DESCRIPTION:

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimum and determine which port has access. In all cases, an active $\overline{B U S Y}$ flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address data. It is important to note that the operation is invalid for the port that has $\overline{B U S Y}$ set LOW. The delayed port will have access when BUSY goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{\mathrm{CE}}$, on-chip control logic arbitrates between $\overline{\mathrm{CE}} \mathrm{L}$
and $\overline{\mathrm{CE}} \mathrm{ffor}$ access; or (2) if the $\overline{\mathrm{CE}}$ s are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's $\overline{B U S Y}$ flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION, MASTER/SLAVE DESCRIPTION:

Expanding the data bus width to sixteen-or-more-bits in a dual-port RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its BUSYL while another acitivates its BUSYR signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid the "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only one arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMs in width, the writing of the SLAVE RAMs must be delayed, until after the BUSY input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past BUSY to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than on chip is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to BUSY from the MASTER.

## TRUTH TABLES

TABLE I - NON-CONTENTION
READ/WRITE CONTROL ${ }^{(4)}$

| Left Or Right Port ${ }^{(1)}$ |  |  |  | Functlon |
| :---: | :---: | :---: | :---: | :---: |
| R/W | $\overline{\mathbf{C E}}$ | $\overline{O E}$ | D 0.7 |  |
| X | H | X | Z | Port Disabled and in Power Down Mode IsB2 or ISB4 |
| x | H | x | Z | $\overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{H}$, Power Down Mode, ISB1 or ISB3 |
| L | L | X | DATAIN | Data on Port Written into Memory ${ }^{(2)}$ |
| H | L | L | DATAOUT | Data in Memory Output on Port(3) |
| H | L | H | Z | High Impedance |

2692 tbl 16
NOTES:

1. $A O L-A_{10 L} \neq A O R-A_{10 R}$
2. If $\overline{B U S Y}=\mathrm{L}$, data is not written
3. If $\overline{B U S Y}=L$, data may not be valid, see twDD and teDD timing.
4. $H=H I G H, L=L O W, X=$ DON'T CARE, $Z=H I G H$ IMPEDANCE

TABLE II - ARBITRATION ${ }^{(1,2)}$

| Left Port |  | Right Port |  | Flags |  | Functlon |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { CEL }}$ | AoL - A10L | $\overline{\text { CEF }}$ | A0R - A10R | $\overline{\text { BUSYL }}$ | $\overline{\text { BUSYR }}$ |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | $\neq \mathrm{A} 0 \mathrm{R}-\mathrm{A} 10 \mathrm{P}$ | L | $\neq$ A0L - ${ }^{\text {a } 10 \mathrm{~L}}$ | H | H | No Contention |
| Address Arbitration With CE Low Before Address Match |  |  |  |  |  |  |
| L | LV5R | L | LV5R | H | L | L-Port Wins |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |
| CE Arbitration With Address Match Before CE |  |  |  |  |  |  |
| LL5R | $=\mathrm{A} 0 \mathrm{R}-\mathrm{A} 10 \mathrm{R}$ | LL5R | $=\mathrm{A} 0 \mathrm{~L}-\mathrm{Al}_{10 \mathrm{~L}}$ | H | L | L-Port Wins |
| RL5L | $=A 0 R-A t O R$ | RL5L | $=\mathrm{A} 0 \mathrm{~L}-\mathrm{A}_{10 \mathrm{~L}}$ | L | H | R-Port Wins |
| LW5R | $=\mathrm{A} 0 \mathrm{R}-\mathrm{A} 10 \mathrm{R}$ | LW5R | $=$ A0L - ${ }^{\text {a }} 10 \mathrm{~L}$ | H | L | Arbitration Resolved |
| LW5R | $=\mathrm{A} 0 \mathrm{R}-\mathrm{A} 10 \mathrm{R}$ | LW5R | $=$ A0L - $\mathrm{AlOL}^{\text {L }}$ | L | H | Arbitration Resolved |

## NOTES:

1. $X=D O N \cdot T$ CARE, $L=L O W, H=H I G H$
2. LV5R $=$ Left Address Valid $\geq 5 \mathrm{~ns}$ before right address.

RV5L $=$ Right Address Valid $\geq 5$ ns before left address.
Same = Left and Right Addresses match within 5 ns of each other.
LL5R $=$ Left $\overline{C E}=L O W \geq 5 n$ s before Right $\overline{C E}$.
RL5L $=$ Right $\overline{C E}=L O W \geq 5$ ns before Left $\overline{C E}$.
LW5R $=$ Left and Right $\overline{C E}=$ LOW within 5 ns of each other.

## ORDERING INFORMATION



CMOS DUAL-PORT RAM 16 K (2K x 8-BIT)

## PRELIMINARY IDT7032SA/LA IDT7042SA/LA

## FEATURES

- High-speed access
-Military: 25/35/45ns (max.)
-Commercial: 20/25/35ns (max.)
- Low-power operation
—IDT7032/42SA
Active: 375mW (typ.)
Standby: 6mW (typ.)
—IDT7032/42LA
Active: 375 mW (typ.)
Standby: 2mW (typ.)
- Fully asynchronous operation from either port
- MASTER IDT7032 easily expands data bus width to 16-or-more-bits using SLAVE IDT7042
- On-chip port arbitration logic (IDT7032 only)
- BUSY output flag on IDT7032; BUSY input on IDT7042
- Battery backup operation -2V data retention
- TTL-compatible, single $5 \mathrm{~V} \pm 10 \%$ power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7032/IDT7042 are high speed $2 \mathrm{Kx8}$ dual-port static RAMs. The IDT7032 is designed to be used as a stand-alone 8-bit dual-port RAM or as a "MASTER" dualport RAM together with the IDT7042 "SLAVE" dual-port in 16-bit-or-more word width systems. Using the IDT MASTER/ SLAVE dual-port RAM approach in 16-or-more-bit memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide two independant ports with separate control, address and I/O pins that permit independent asynchronous access for reads or writes to any location in memory. An automatic power down feature, controlled by $\overline{C E}$, permits the on chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {™ }}$ high-performance technology, these devices typically operate on only 375 mW of power at maximum access times as fast as 20ns. Lowpower (LA) versions offer battery backup data retention capability, with each dual-port typically consuming 200 ww from a 2 V battery.

The IDT7032/7042 devices are packaged in 48-pin sidebraze or plastic DIPs.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



NOTE:

1. IDT7032 (MASTER): $\overline{B U S Y}$ is open drain output and requires pullup resistor.

IDT7042 (SLAVE): BUSY is input.

## PIN CONFIGURATIONS

| $\overline{\mathrm{CE}}$ L 1 | 48 | $\square \overline{\mathrm{CE}}$ |
| :---: | :---: | :---: |
| RNWL 2 | 47 | $口 \bar{W}$ R |
| BUSYLC3 | 46 | BUSYR |
| A10L $\mathrm{Cl}^{4}$ | 45 | A10R |
| OEL 5 | 44 | OER |
| AOL $\square^{6}$ | 43 | $\square \mathrm{A} 0 \mathrm{R}$ |
| A1L ${ }^{\text {c }} 7$ | 42 | A1R |
| A2L C 8 | 41 | คA2R |
| A3L-9 | P48-1 40 | $\square^{\text {A }}$ ¢ |
| A4L-10 | \& ${ }_{\text {- }} 39$ | $\square^{\text {A }}$ AR |
| A5L 11 | C48-2 38 | A5R |
| GND 12 | C48-2 37 | Vcc |
| A6L-13 | 36 | -A6R |
| A7L 14 | 35 | A7R |
| Abl 15 | 34 | A8R |
| A9L-16 | 33 | A9R |
| //Ool ${ }^{\text {- } 17}$ | 32 | 1/O7R |
| /VO1L 18 | 31 | 日lO6R |
| //O2L-19 | 30 | $1 / O 58$ |
| /ООз - 20 | 29 | -1/O4R |
| 1/O4L-21 | 28 | $\mathrm{l}^{1 / O} \mathbf{O}_{\text {\% }}$ |
| I/O5L-22 | 27 | I/O2R |
| 1/O6L $\mathrm{C}^{23}$ | 26 | -1/O1R |
| 1/O7L-24 | 25 | I/OOR |

## ABSOLUTE MAXIMUM RATINGS(1)

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2693 th 01

1. Stresses greater than those listedunderABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED

DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5(1)$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIL}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE（Vcc $=5.0 \mathrm{~V} \pm 10 \%$ ）

| Symbol | Parameter | Test Conditions | IDT7032SA IDT7042SA Min． Max． |  | IDT7032LAIDT7042LAMax．Max． |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ｜니｜ | Input Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| ｜ L 이 | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to VCC | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage （ $/ / \mathrm{O}_{0}-1 / \mathrm{O}_{7}$ ） | $10 \mathrm{~L}=4 \mathrm{~mA}$ | － | 0.4 | － | 0.4 | V |
| VoL | Open Drain Output <br> Low Voltage（ $\overline{\mathrm{BUSY}}$ ） | $\mathrm{lOL}=16 \mathrm{~mA}$ | － | 0.5 | － | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{OH}=-4 \mathrm{~mA}$ | 2.4 | － | 2.4 | － | V |

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Conditions | Version | $\begin{array}{\|l\|} \hline 7032 \times 20^{(2)} \\ 7042 \times 20^{(2)} \\ \hline \end{array}$ | $\begin{aligned} & 7032 \times 25 \\ & 7042 \times 25 \end{aligned}$ | $\begin{aligned} & 7032 \times 35 \\ & 7042 \times 35 \end{aligned}$ | $\begin{array}{\|l\|} \hline 7032 \times 45(3) \\ 7042 \times 45(3) \\ \hline \end{array}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ．Max． | Typ．Max． | Typ．Max． | Typ．Max． |  |
| Icc | Dynamic Operating Current（Both Ports Active） | $\begin{aligned} & \overline{\mathrm{CE}}=\text { VIL } \\ & \text { Outputs Open } \\ & \mathrm{f}=\mathrm{f}_{\text {max }}{ }^{(4)} \end{aligned}$ | MIL．SA <br>  | 二口 | 75 300 <br> 75 220 | 75 280 <br> 75 200 | 75 270 <br> 75 190 | mA |
|  |  |  | COM＇L．${ }_{\text {LA }}$ | $\begin{aligned} & 75 \% 260 \\ & 75 \% 190 \end{aligned}$ | 75 250 <br> 75 180 | 75 240 <br> 75 180 | 二 |  |
| ISB1 | Standby Current （Both Ports－TTL Level Inputs） | $\begin{aligned} & \overline{\mathrm{CE}} . \operatorname{and} \overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{f}=\mathrm{f}_{\text {MAX }}{ }^{(4)} \end{aligned}$ | MIL． $\begin{array}{ll}\text { SA } \\ \text { LA }\end{array}$ | － | $\begin{array}{ll} \hline 25 & 75 \\ 25 & 55 \\ \hline \end{array}$ | $\begin{array}{ll} \hline 25 & 75 \\ 25 & 55 \\ \hline \end{array}$ | $\begin{array}{ll} \hline 25 & 75 \\ 25 & 55 \\ \hline \end{array}$ | mA |
|  |  |  | COM＇L．SA | 25.65 25.45 | $\begin{array}{ll} \hline 25 & 65 \\ 25 & 45 \end{array}$ | $\begin{array}{ll}25 & 65 \\ 25 & 45\end{array}$ | － |  |
| ISB2 | Standby Current （One Port－TTL Level Inputs） | $\overline{\mathrm{CE}}$ ．or $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{V}_{\mathrm{IH}}$ Active Port Outputs Open，$f=$ fmax $^{(4)}$ | $\begin{array}{ll} & \\ \text { MIL．} & \text { SA } \\ \text { LA }\end{array}$ |  | $\begin{array}{ll} \hline 50 & 180 \\ 50 & 140 \\ \hline \end{array}$ | 46 170 <br> 46 130 | 40 160 <br> 40 125 | mA |
|  |  |  | COM＇L．SA | $\begin{aligned} & 50 \quad 180 \\ & 50 \quad 135 \end{aligned}$ | $\begin{array}{ll} 50 & 170 \\ 50 & 120 \\ \hline \end{array}$ | $\begin{array}{ll} \hline 40 & 155 \\ 40 & 110 \\ \hline \end{array}$ | － |  |
| ISB3 | Full Standby Current （Both Ports－All CMOS Level Inputs） | $\begin{aligned} & \text { Both Ports } \overline{C E}_{L} \text { and } \\ & \overline{C E}_{R} \geq V \operatorname{Vcc}-0.2 V \\ & V_{I N} \geq V c c-0.2 V \text { or } \\ & V_{I N} \leq 0.2 V, f=0^{(5)} \end{aligned}$ |   <br> MIL． SA <br> LA  | －－ | $\begin{array}{ll} \hline 1.2 & 40 \\ 0.4 & 10 \\ \hline \end{array}$ | $\begin{array}{ll} \hline 1.2 & 35 \\ 0.4 & 10 \\ \hline \end{array}$ | $\begin{array}{ll} \hline 1.0 & 35 \\ 0.2 & 10 \\ \hline \end{array}$ | mA |
|  |  |  | ${ }^{\text {COM＇L．}}$ LA | $\begin{aligned} & 1.2 .15 \\ & 0.4 \times 4 \end{aligned}$ | $\begin{array}{cc} \hline 1.2 & 15 \\ 0.4 & 4 \\ \hline \end{array}$ | $\begin{array}{cc} 1.0 & 15 \\ 0.2 & 4 \\ \hline \end{array}$ | － |  |
| ISB4 | Full Standby Current （One Port－All CMOS Level Inputs， $f=0^{(5)}$ ） | One Port $\overline{C E L}$ or $\overline{C E}_{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ Vin $\geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or VIN $\leq 0.2 V$ Active Port Outputs Open，$f=$ fmax $^{(4)}$ | MIL． SA | $\xrightarrow{\square}$－ | 50 170 <br> 46 135 | $\begin{array}{ll} \hline 45 & 150 \\ 42 & 115 \\ \hline \end{array}$ | 40 140 <br> 35 105 | mA |
|  |  |  | COM＇L．SA | $\begin{array}{rrr}\text { \％00 } & 160 \\ 46 & 125\end{array}$ | 50 150 <br> 46 115 | $\begin{array}{ll}45 & 135 \\ 42 & 105\end{array}$ | 二－ |  |

## Notes：

1．$x$ in part numbers indicates power rating（SA or LA）．
2． $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only．
3．$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only．
．At $f=f M A x$ ，address and data inputs（except Output Enable）are cycling at the maximum frequency of read cycle of $1 / t R C$ ，and using＂AC TEST CONDITIONS＂of input levels of GND to 3 V ．
5．$f=0$ means no address or control lines change．Applies only to inputs at CMOS level standby．

DATA RETENTION CHARACTERISTICS (LA Version Only)

| Symbol | Parameter | Test Conditions |  | IDT703 Min. | $\begin{aligned} & \text { A/DT } \\ & \text { Typ. } \end{aligned}$ | A Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\begin{aligned} & \mathrm{VCc}=2.0 \mathrm{~V}, \overline{\mathrm{CE}} \geq \mathrm{VCc}-0.2 \mathrm{~V} \\ & \frac{\mathrm{MIL} .}{\mathrm{COM} \cdot} \\ & V I N \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \mathrm{VIN} \leq 0.2 \mathrm{~V} \end{aligned}$ |  | 2.0 | - | 0 | V |
| ICCDR | Data Retention Current |  |  | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  |  | - | 100 | 1500 | $\mu \mathrm{A}$ |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | trc ${ }^{(2)}$ | - | - | ns |

NOTES:
2693 *1 06

1. $V C C=2 V, T A=+25^{\circ} \mathrm{C}$
2. $\operatorname{trC}=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



2693 dw 03

## AC TEST CONDITIONS

| Input Pulse Levels | GND TO 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1,2 \& 3$ |

2693 ゅ 07


Figure 2. Output Load (for thv, tuz, twz, and tow)


Figure 3. $\overline{\text { BUSY }}$ Output Load (IDT7032 only)

- Including scope and jig


## AC ELECTRICAL CHARACTERISTICS OVER THE

## OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(5)}$

| Symbol | Parameter | $\begin{aligned} & 7032 \times 20^{(2)} \\ & 7042 \times 20^{(2)} \end{aligned}$ | $\begin{aligned} & 7032 \times 25 \\ & 7042 \times 25 \end{aligned}$ |  | $\begin{aligned} & 7032 \times 35 \\ & 7042 \times 35 \end{aligned}$ |  | $\begin{aligned} & 7032 \times 45^{(3)} \\ & 7042 \times 45^{(3)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min．Max． | Min． | Max． | Min． | Max． | Min． | Max． |  |
| Read Cycle |  | $\stackrel{ }{*}$ |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | $20 \%$－ | 25 | － | 35 | － | 45 | － | ns |
| tAA | Address Access Time | －\％ 20 | － | 25 | － | 35 | － | 45 | ns |
| tace | Chip Enable Access Time | －$\quad 20$ | － | 25 | － | 35 | － | 45 | ns |
| taoe | Output Enable Access Time | －\％．．． 10 | － | 12 | － | 25 | － | 30 | ns |
| tor | Output Hold From Address Change | 0 \％－ | 0 | － | 0 | － | 0 | － | ns |
| tLZ | Output Low Z Time ${ }^{(1,4)}$ | 0 － | 0 | － | 0 | － | 0 | － | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | 一》》 8 | － | 10 | － | 15 | － | 20 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(4)}$ | 0\％－ | 0 | － | 0 | － | 0 | － | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(4)}$ | $\rightarrow$－ 50 | － | 50 | － | 50 | － | 50 | ns |

## NOTES：

1．Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load（Figures 1,2 and 3）．
2． $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only．
3．$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only．
4．This parameter guaranteed but not tested．
5．＂$x$＂in part numbers indicates power rating（SA or LA）．

## TIMING WAVEFORM OF READ CYCLE NO． 1 ，EITHER SIDE $(1,2,4)$



TIMING WAVEFORM OF READ CYCLE NO．2，EITHER SIDE $(1,3)$


AC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(7)}$

| Symbol | Parameter | $\begin{aligned} & 7032 \times 20^{(2)} \\ & 7042 \times 20^{(2)} \end{aligned}$ | $\begin{aligned} & 7032 \times 25 \\ & 7042 \times 25 \end{aligned}$ |  | $\begin{aligned} & 7032 \times 35 \\ & 7042 \times 35 \end{aligned}$ |  | $\begin{aligned} & 7032 \times 45^{(3)} \\ & 7042 \times 45^{(3)} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |
| twC | Write Cycle Time ${ }^{(5)}$ | 20 * - | 25 | - | 35 | - | 45 | - | ns |
| tEW | Chip Enable to End of Write | 15\%- | 20 | - | 30 | - | 35 | - | ns |
| taw | Address Valid to End of Write | 15, \% | 20 | - | 30 | - | 35 | - | ns |
| tas | Address Set-up Time | 0 . . | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(6)}$ | 15, - - | 20 | - | 30 | - | 35 | - | ns |
| twR | Write Recovery Time | 0, \% - | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data Valid to End of Write | 10. - | 12 | - | 20 | - | 20 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | $\stackrel{*}{*} 8$ | - | 10 | - | 15 | - | 20 | ns |
| tDH | Data Hold Time | 0 - - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High Z ${ }^{(1,4)}$ | $\stackrel{8}{*}$ | - | 10 | - | 15 | - | 20 | ns |
| tow | Output Active From End of Write ${ }^{(1,4)}$ | $0 \times-$ | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3 ).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. For MASTER/SLAVE combination, twc $=$ tBAA + twp.
6. Specified for $\overline{\mathrm{OE}}$ at high (Refer to "Timing Waveform of Write Cycle", Note 7)
7. " $x$ " in part numbers indicates power rating (SA or LA).

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{t}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter(1) | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| COUT | Output Capacitance | V IN $=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2693 thl 10

1. This parameter is sampled and not $100 \%$ tested.

TIMING WAVEFORM OF WRITE CYCLE NO. $1,\left(\mathrm{R} / \overline{\mathrm{W}}\right.$ CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


2693 dw 07

TIMING WAVEFORM OF WRITE CYCLE NO. 2 , ( $\overline{\text { CE }}$ CONTROLLED TIMING) ${ }^{(1,2,3,5)}$


## NOTES:

1. $\mathrm{R} / \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. TWR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of the write cycle.
4. During this period, the I/O pins are in the output state and input signals must not be applied.
5. If the CE low transition occurs simultaneously with or after the R/W low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig).
7. If $\overline{O E}$ is low during a $R / W$ controlled write cycle, the write pulse width must be larger of twP or (twZ + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## AC ELECTRICAL CHARACTERISTICS OVER THE

## OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(8)}$

| Symbol | Parameter | $\begin{aligned} & 7032 \times 20^{(1)} \\ & 7042 \times 20^{(1)} \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{aligned} & 2 \times 25 \\ & 2 \times 25 \\ & \text { Max. } \end{aligned}$ |  | $\begin{array}{r} 2 \times 35 \\ 2 \times 35 \\ \text { Max. } \end{array}$ | $\begin{aligned} & 7032 \\ & 7042 \\ & \text { Min. } \end{aligned}$ | $\begin{aligned} & 2 \times 45^{(2)} \\ & \times 45^{(2)} \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Busy Timing (For Master IDT7032 Only) |  |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | -* 20 | - | 25 | - | 35 | - | 35 | ns |
| tBDA | BUSY Disable Time to Address | -\% 18 | - | 20 | - | 30 | - | 35 | ns |
| tBAC | BUSY Access Time to Chip Enable | - $\%$ \% 20 | - | 20 | - | 30 | - | 30 | ns |
| tBDC | BUSY Disable Time to Chip Enable | 一\% 18 | - | 20 | - | 25 | - | 25 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(3)}$ | -\%. 45 | - | 50 | - | 60 | - | 70 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | -\% 30 | - | 35 | - | 45 | - | 55 | ns |
| taps | Arbitration Priority Set-up Time ${ }^{(4)}$ | 5. | 5 | - | 5 | - | 5 | - | ns |
| tBDD | BUSY Disable to Valid Data ${ }^{(5)}$ | - Note 5 | 二 | Note 5 | - | Note 5 | - | Note 5 | ns |
| Busy Input Timing (For Slave IDT7042 Only) |  |  |  |  |  |  |  |  |  |
| twB | Write to BUSY Input (6) | 0\% - | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After $\overline{\mathrm{BUSY}}{ }^{(7)}$ | 12. | 15 | - | 20 | - | 20 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(9)}$ | $\stackrel{*}{4}$. 45 | - | 50 | - | 60 | - | 70 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - 30 | - | 35 | - | 45 | - | 55 | ns |

NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY (For Master IDT7032 only)".
4. To ensure that the earlier of the two ports wins.
5. tBDD is a calculated parameter and is the greater of 0 , twDD-twp (actual) or tDDD - tDW (actual).
6. To ensure that the write cycle is inhibited during contention.
7. To ensure that a write cycle is completed after contention.
8. " $x$ " in part numbers indicates power rating (SA or LA).
9. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With Port-to-Port Delay (For Slave IDT7042 Only)".

TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}{ }^{(1,2,3)}$ (FOR MASTER IDT7032 ONLY)


NOTES:
2693 drw 09

1. To ensure that the earlier of the two ports wins.
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuously enabled for both ports.
4. $\overline{O E}$ at $L O$ for the reading port.

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY(1,2,3) (FOR SLAVE IDT7042 ONLY)


NOTES:
2683 drw 10

1. Assume $\overline{B U S Y}$ input at HI for the writing port, and $\overline{\mathrm{OE}}$ at LO for the reading port.
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuously enabled for both ports.

TIMING WAVEFORM OF WRITE WITH BUSY INPUT (FOR SLAVE IDT7042 ONLY)

timing waveform of contention cycle no. 1, $\overline{\text { CE ARBITRATION }}$ (FOR MASTER IDT7032 ONLY)

CEL VALID FIRST:


## CER VALID FIRST:



TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION ${ }^{(1)}$ (FOR MASTER IDT7032 ONLY)

LEFT ADDRESS VALID FIRST:


RIGHT ADDRESS VALID FIRST:


2693 dw 15
NOTE:

1. $\overline{C E}_{L}=\overline{C E}_{R}=V_{I L}$

## 16-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



2693 drw 16
NOTE:

1. No arbitration in IDT7042 (SLAVE). BUSY-IN inhibits write in IDT7042 (SLAVE).

## FUNCTIONAL DESCRIPTION

The IDT7032/42 provides two ports with separate control, address and l/O pins that permit independent access for reads or writes to any locations in memory. These devices have an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{\mathrm{CE}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control $(\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/WRITE conditions are illustrated in Table 1.

## ARBITRATION LOGIC <br> FUNCTIONAL DESCRIPTION

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimurn and determine which port has access. In all cases, an active $\overline{B U S Y}$ flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. BUSY is set at speeds that permit the processor to hold the operation and its respective address data. It is important to note that the operation is invalid for the port that has $\overline{\mathrm{BUSY}}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{\mathrm{CE}}$, on-chip control logic arbitrates between $\overline{\mathrm{CE}} \mathrm{L}$ and
$\overline{\text { CERfor }}$ access; or (2) if the $\overline{\mathrm{CE}}$ s are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's BUSY flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION MASTER/SLAVE DESCRIPTION

Expanding the data bus width to sixteen-or-more-bits in a dual-port RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its BUSYL while another acitivates its $\overline{B U S Y} R$ signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid the "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only one arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMS in width, the writing of the SLAVE RAMS must be delayed, until after the BUSY input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{B U S Y}$ to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than on chip is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

## TRUTH TABLES

## TABLE I - NON-CONTENTION

READ/WRITE CONTROL (4)

| Left Or Right Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ | $\overline{\text { CE }}$ | $\overline{\mathrm{OE}}$ | D0.7 |  |
| X | H | X | Z | Port Disabled and in Power Down Mode ISB2 or ISB4 |
| X | H | X | Z | $\overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{H}$, Power Down Mode, ISB1 or IsB3 |
| L | L | X | DATAIN | Data on Port Written into Memory ${ }^{(2)}$ |
| H | L | L | DATAOUT | Data in Memory Output on Port ${ }^{(3)}$ |
| H | L | H | Z | High Impedance Outputs |

## NOTES:

1. $A O L-A 10 L \neq A O R-A 10 R$
2. If $\overline{B U S Y}=L$, data is not written
3. If $\overline{B U S Y}=L$, data may not be valid, see twoD and tDDD timing.
4. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=$ LOW, $\mathrm{X}=$ DON'T CARE, $Z=$ HIGH IMPEDANCE

TABLE II - ARBITRATION ${ }^{(1,2)}$

| Left Port |  | Right Port |  | Flags ${ }^{(2)}$ |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CE}}$ L | AOL - A10L | $\overline{\mathrm{CE}} \mathrm{R}$ | A0R - A10R | $\overline{\text { BUSYL }}$ | BUSYR |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | $\neq A 0 R-A 10 R$ | L | $\neq$ A0L - A10L | H | H | No Contention |
| Address Arbitration With CE Low Before Address Match |  |  |  |  |  |  |
| L | LV5R | L | LV5R | H | L | L-Port Wins |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |
|  |  |  |  |  |  |  |
| LL5R | $=$ A0R - A10R | LL5R | $=$ A0L - A10L | H | L | L-Port Wins |
| RL5L | $=A 0 R-A_{10 R}$ | RL5L | $=A 0 L-A_{10 L}$ | L | H | R-Port Wins |
| LW5R | $=A 0 R-A_{10 R}$ | LW5R | $=\mathrm{AOL}-\mathrm{AlOL}$ | H | L | Arbitration Resolved |
| LW5R | $=A 0 R-A_{10 R}$ | LW5R | $=\mathrm{AOL}-\mathrm{AlOL}^{\text {L }}$ | L | H | Arbitration Resolved |

## NOTES:

1. $X=$ DON'T CARE, $L=L O W, H=H I G H$
2. $L V 5 R=$ Left Address Valid $\geq 5 n s$ before right address.

RV5L $=$ Right Address Valid $\geq 5$ ns before left address.
Same = Left and Right Addresses match within 5 ns of each other.
LL5R $=$ Left $\overline{C E}=L O W \geq 5 n s$ before Right $\overline{C E}$.
$R L 5 L=$ Right $\overline{C E}=L O W \geq 5 n s$ before Left $\overline{C E}$.
LW5R = Left and Right $\overline{C E}=$ LOW within 5 ns of each other.

## ORDERING INFORMATION




Integrated Device Technology, Inc.

CMOS DUAL-PORT RAM 16 K ( $2 \mathrm{~K} \times 8$-BIT) WITH INTERRUPTS

## IDT71321SA/LA

 IDT71421SA/LA
## FEATURES:

- High-speed access
-Military: 25/30/35/45/55/70ns (max.)
-Commercial: 20/25/30/35/45/55ns (max.)
- Low-power operation
—IDT71321/IDT71421SA
Active: 325 mW (typ.)
Standby: 5 mW (typ.)
—IDT71321/421LA
Active: 325 mW (typ.)
Standby: 1mW (typ.)
- Two INT flags for port-to-port communications
- MASTER IDT71321 easily expands data bus width to 16-or-more-bits using SLAVE IDT71421
- On-chip port arbitration logic (IDT71321 only)
- $\overline{B U S Y}$ output flag on IDT71321; $\overline{\text { BUSY }}$ input on IDT71421
- Fully asynchronous operation from either port
- Battery backup operation -2 V data retention
- TTL-compatible, single $5 \mathrm{~V} \pm 10 \%$ power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT71321/IDT71421 are high-speed $2 \mathrm{~K} \times 8$ dualport static RAMs with internal interrupt logic for interprocessor communications. The IDT71321 is designed to be used as a stand-alone 8 -bit dual-port RAM or as a "MASTER" dual-port RAM, together with the IDT71421 "SLAVE" dualport, in 16 -or-more-bit memory systems applications results in full speed, error-free operation without the need for additional discrete logic.

Both devices provide two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power down feature, controlled by $\overline{\mathrm{CE}}$, permits the on chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only 325 mW of power at maximum access times as fast as 20 ns . Lowpower (LA) versions offer battery backup data retention capability, with each dual-port typically consuming $200 \mu \mathrm{w}$ from a 2 V battery.

The IDT71321/IDT71421 devices are packaged in 52-pin LCCs and PLCCs. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



## NOTES:

1. IDT71321 (MASTER): BUSY is open output and requires pullup resistor. IDT71421 (SLAVE): $\overline{\text { BUSY }}$ is input.
2. Open drain output: requires pullup resistor.

CEMOS is a trademark of Integrated Device Technology, Inc.

PIN CONFIGURATIONS


2691 drw 02

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED OPERATING

TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED

## DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input Higḥ Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5(1)$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | $\begin{aligned} & \hline \text { IDT71321SA } \\ & \text { IDT71421SA } \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{aligned} & \text { IDT71321LA } \\ & \text { IDT71421 LA } \\ & \text { Min. Max. } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \|lı| | Input Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to VCC | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lıO| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to VCC | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage ( $/ / \mathrm{O}_{0}-1 / \mathrm{O}_{7}$ ) | $\mathrm{OLL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOL | Open Drain Output Low Voltage (BUSY/INT) | $\mathrm{OL}=16 \mathrm{~mA}$ | - | 0.5 | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{iOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCc}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Conditions | Version |  | $\begin{aligned} & 71321 \times 20^{(2)} \\ & 71421 \times 20^{(2)} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 71321 \times 25 / 30 \\ & 71421 \times 25 / 30 \\ & \hline \end{aligned}$ |  | $\begin{array}{r} 71321 \times 35 \\ 71421 \times 35 \\ \hline \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Typ. | Max. | Typ. | Max. | Typ. | Max. |  |
| IcC | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\overline{\mathrm{CE}}=\mathrm{VIL}} \\ & \text { Outputs Open } \\ & \mathrm{f}=\text { fmax }^{(4)} \end{aligned}$ | Mil. | SA | - | - | $\begin{array}{\|l\|} \hline 75 / 75 \\ 75 / 75 \\ \hline \end{array}$ | $\begin{aligned} & 300 / 290 \\ & 220 / 210 \\ & \hline \end{aligned}$ | 75 | $\begin{array}{r} 280 \\ 200 \\ \hline \end{array}$ | mA |
|  |  |  | Com'l. | SA | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 260 \\ & 190 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 / 70 \\ & 75 / 70 \\ & \hline \end{aligned}$ | $\begin{aligned} & 250 / 240 \\ & 180 / 170 \end{aligned}$ | 75 | $\begin{aligned} & 195 \\ & 155 \end{aligned}$ |  |
| ISB1 | Standby Current (Both Ports - TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CE}} . \text { and } \overline{\mathrm{CE}} \mathrm{~F} \geq \mathrm{VIH}_{\mathrm{IH}} \\ & \mathrm{f}=\mathrm{fMAX}(4) \end{aligned}$ | Mil. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | - | - | $\begin{aligned} & 25 / 25^{\circ} \\ & 25 / 25 \text {. } \end{aligned}$ | $\begin{array}{r} 75 / 75 \\ \hline 55 / 55 \\ \hline \end{array}$ | 25 | $\begin{aligned} & 75 \\ & 55 \\ & \hline \end{aligned}$ | mA |
|  |  |  | Com'l. | $\begin{aligned} & \hline \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 / 25, \\ & 25 / 25 \% \end{aligned}$ | $\begin{array}{r} 65 / 65 \\ \quad 45 / 45 \\ \hline \end{array}$ | 25 25 | $\begin{aligned} & 65 \\ & 45 \\ & \hline \end{aligned}$ | A |
| IsB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V} \mathrm{H}$ Active Port Outputs Open, $f=$ fmax $^{(4)}$ | Mil. | SA | 二 | - | $\begin{array}{r} 50 / 46 \\ 50 / 46 \end{array}$ | $\begin{aligned} & 180 / 175 \\ & 140 / 135 \\ & \hline \end{aligned}$ | 40 | 170 <br> 130 | mA |
|  |  |  | Com'l. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & \hline 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 180 . \\ & 130 . \end{aligned}$ | $\begin{array}{r} 50 / 46 \\ 50 / 46 \end{array}$ | $\begin{aligned} & 170 / 155 \\ & 120 / 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | $\begin{aligned} & 130 \\ & 95 \\ & \hline \end{aligned}$ |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | $\begin{aligned} & \text { Both Ports } \overline{\mathrm{CE}} \mathrm{~L} \text { and } \\ & \mathrm{CE}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \\ & \mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0(5) \end{aligned}$ | Mil. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | - |  | $\begin{aligned} & 1.2 / 1.2 \\ & 0.4 / 0.4 \end{aligned}$ | $\begin{aligned} & 40 / 40 \\ & 10 / 10 \\ & \hline \end{aligned}$ | 1.2 0.4 | $\begin{aligned} & 35 \\ & 10 \\ & \hline \end{aligned}$ | mA |
|  |  |  | Com'l. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ |  | $\begin{array}{r} 15 \\ \hline \end{array}$ | $\begin{aligned} & 1.2 / 1.2 \\ & 0.4 / 0.4 \\ & \hline \end{aligned}$ | $\begin{gathered} 15 / 15 \\ 4 / 4 \\ \hline \end{gathered}$ | 1.0 0.2 | $\begin{array}{r} 15 \\ 4.0 \\ \hline \end{array}$ |  |
| IsB4 | Full Standby Current (One Port - All CMOS Level Inputs, $t=0^{(5)}$ ) | One Port $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ Vin $\geq$ Vcc -0.2 V or Vin $\leq 0.2 \mathrm{~V}$ Active Port Outputs Open, $f=$ fmax $^{(4)}$ | Mil. | SA |  | $\stackrel{\square}{\text { - }}$ | $\begin{array}{\|l\|} \hline 50 / 45 \\ 46 / 42 \\ \hline \end{array}$ | $\begin{aligned} & 170 / 160 \\ & 135 / 125 \\ & \hline \end{aligned}$ | 45 | 150 <br> 115 <br> 115 |  |
|  |  |  | Com'l. | SA | 50 46 | $\begin{aligned} & 160 \\ & 125 \end{aligned}$ | $\begin{aligned} & \hline 50 / 45 \\ & 46 / 42 \end{aligned}$ | $\begin{aligned} & 150 / 137 \\ & 115 / 105 \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{gathered} 115 \\ 90 \end{gathered}$ | mA |

2691 thl 05

## DC.ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Conditions | Version |  | $\begin{aligned} & 71321 \times 45 \\ & 71421 \times 45 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 71321 \times 55 \\ & 71421 \times 55 \\ & \hline \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 71321 \times 7 \alpha^{3} \\ 71421 \times 70^{3(3)} \\ \hline \end{array}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Typ. | Max. | Typ. | Max. | Typ. Max. |  |
| Icc | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\overline{\mathrm{CE}}=\mathrm{VIL}} \\ & \text { Outputs Open } \\ & \mathrm{f}=\mathrm{fmAX}(4) \end{aligned}$ | Mil. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{aligned} & 230 \\ & 185 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 65 \\ & 65 \end{aligned}$ | $\begin{array}{r} 230 \\ 185 \\ \hline \end{array}$ |   <br> 65 225 <br> 65 180 |  |
|  |  |  | Com'l. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 190 \\ & 145 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 60 \\ & 60 \end{aligned}$ | $\begin{array}{r} 180 \\ 140 \\ \hline \end{array}$ | - = |  |
| ISB1 | Standby Current (Both Ports - TTL Level Inputs) | $\begin{aligned} & \overline{C E} L \text { and } \overline{C E R} \geq V_{I H} \\ & f=\mathrm{fmAX}(4) \end{aligned}$ | Mil. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 55 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 55 \end{aligned}$ | 25 65 <br> 25 55 | mA |
|  |  |  | Com'l. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | - = | m |
| ISB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH}$ Active Port Outputs Open, $f=f$ max ${ }^{(4)}$ | Mil. | SA | $\begin{array}{r} 40 \\ 40 \\ \hline \end{array}$ | $\begin{aligned} & 135 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{array}{r} 135 \\ 110 \\ \hline \end{array}$ | 40 135 <br> 40 110 | mA |
|  |  |  | Com'l. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} 120 \\ 85 \\ \hline \end{gathered}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} 115 \\ 85 \\ \hline \end{gathered}$ | 二 - |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{C E R} \geq$ Vcc -0.2 V VIN $\geq$ Vcc -0.2 V or $\mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)}$ | Mil. | $\begin{aligned} & \text { SA } \\ & \mathrm{LA} \end{aligned}$ | $\begin{aligned} & \hline 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{array}{ll} \hline 1.0 & 30 \\ 0.2 & 10 \\ \hline \end{array}$ | mA |
|  |  |  | Com'l. | $\begin{aligned} & \hline \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & \hline 1.0 \\ & 0.2 \end{aligned}$ | $\begin{array}{r} 15 \\ 4.0 \\ \hline \end{array}$ | $\begin{aligned} & 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{array}{r} 15 \\ 4.0 \\ \hline \end{array}$ |  |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs, $f=0^{(5)}$ ) | One Port $\overline{C E}$ L or <br> $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> Vin $\geq$ Vcc -0.2 V or <br> VIN $\leq 0.2 \mathrm{~V}$ <br> Active Port Outputs <br> Open, $\mathfrak{f}=$ fmax $^{(4)}$ | Mil. | $\begin{aligned} & \text { SA } \\ & \text { LA } \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{gathered} 125 \\ 95 \\ \hline \end{gathered}$ | $\begin{aligned} & 40 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{gathered} 120 \\ 90 \\ \hline \end{gathered}$ | $\begin{array}{cc} \hline 40 & 110 \\ 35 & 80 \\ \hline \end{array}$ |  |
|  |  |  | Com'l. | SA | 40 35 | $\begin{gathered} 115 \\ 80 \end{gathered}$ | 40 35 | 100 75 | - - | mA |

## NOTES:

1. " $x$ " in part numbers indicates power rating (SA or LA).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. At $f=$ fmax, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 / t \mathrm{RC}$, and using "AC TEST CONDITIONS" of input levels of GND to 3V.
5. $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby.

DATA RETENTION CHARACTERISTICS (LA Version Only)

| Symbol | Parameter | Test Condition |  | IDT71321LAADT71421LAMin. Typ. |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $V c c=2.0 \mathrm{~V}, \overline{\mathrm{CE}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ |  | 2.0 | - | 0 | V |
| ICCDR | Data Retention Current |  | MIL. | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | 100 | 1500 | $\mu \mathrm{A}$ |
| tCDR(3) | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | trc(2) | - | - | ns |

NOTES:
2691 tbl 07

1. $\mathrm{VCC}=2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$
2. trc = Read Cycle Time
3. This parameter is guaranteed but not tested.

DATA RETENTION WAVEFORM
DATA RETENTION MODE


## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1, 2, 3 and 4 |



Figure 1. Output Load


Figure 3. $\overline{\text { BUSY }}$ and $\overline{\text { INT }}$ Output Load


Figure 2. Output Load (for thz, tiz, twz, and tow)


Figure 4. $\overline{B U S Y}$ and INT Output Load (for 20ns,25ns and 30ns versions)

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE| Symbol | Parameter | $\begin{array}{\|l\|} \hline 71321 \times 20(2) \\ 71421 \times 20(2) \end{array}$ |  | $\begin{aligned} & 71321 \times 25 / 30 \\ & 71421 \times 25 / 30 \end{aligned}$ |  | $\begin{aligned} & 71321 \times 35 \\ & 71421 \times 35 \end{aligned}$ |  | $\begin{aligned} & 71321 \times 45 \\ & 71421 \times 45 \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 71321 \times 55 \\ 71421 \times 55 \end{array}$ |  | $\begin{array}{\|l\|} \hline 71321 \times 70(3) \\ 71421 \times 70(3) \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 20 | - | 25/30 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 20 | - | 25/30 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time | - | 20 |  | 25/30 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| taoe | Output Enable Access Time | - | 10 | $\stackrel{1}{*}$ | 12/15 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tor | Output Hold From Address Change | 0 | - | 0\% | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLz | Output Low Z Time ${ }^{(1,4)}$ | 0 | $\cdots$ | 0/0 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ |  | 8 | - | 10/12 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tPU | Chip Enable to Power Up Time (4) |  |  | 0/0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(4)}$ | - | 50 | - | 50/50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

## NOTES:

2691 th 09

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1, 2, 3 and 4).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. " $x$ " in part numbers indicates power rating (SA or LA).

TIMING WAVEFORM OF READ CYCLE NO. 1 , EITHER SIDE ${ }^{(1,2,4)}$

timing waveform of read cycle no. 2, EITHER SIDE ${ }^{(1,3)}$


## NOTES:

1. RWW is high for Read Cycles.
2. Device is continuously enabled, $\overline{C E}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{O E}=V \mathrm{VI}$.

AC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE

| Symbol | Parameter | $\begin{aligned} & 71321 \times 20^{(2)} \\ & 71421 \times 20^{(2)} \end{aligned}$ | $\begin{aligned} & 71321 \times 25 / 30 \\ & 71421 \times 25 / 30 \end{aligned}$ | $\begin{aligned} & 71321 \times 35 \\ & 71421 \times 35 \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. Max. | Min. | Max. |  |
| Write Cycle |  |  |  |  |  |  |
| twC | Write Cycle Time ${ }^{(5)}$ | 20 | 25/30 | 35 | - | ns |
| tEW | Chip Enable to End of Write | 15 | 20/25 - | 30 | - | ns |
| taw | Address Valid to End of Write | 15 | 20/25\% \% | 30 | - | ns |
| tAS | Address Set-up Time | 0 | 0/0\%, \% | 0 | - | ns |
| twp | Write Pulse Width | 15 | 20/25 | 30 | - | ns |
| twr | Write Recovery Time | 0 | 010 | 0 | - | ns |
| tow | Data Valid to End of Write | $10 \rightarrow$ | 12/15 | 20 | - | ns |
| thz | Output High 2 Time ${ }^{(1,4)}$ | - 8 8 ${ }^{\text {a }}$ | 10/12 | - | 15 | ns |
| tDH | Data Hold Time | 0 \% \% | 0/0 | 0 | - | ns |
| twz | Write Enabled to Output in High Z ${ }^{(1,4)}$ | - 8 | 10/12 | - | 15 | ns |
| tow | Output Active From End of Write ${ }^{(1,4)}$ | 0 | 0/0 | 0 | - | ns |

## AC ELECTRICAL CHARACTERISTICS OVER THE <br> OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (CONTINUED)

| Symbol | Parameter | $\begin{aligned} & 71321 \times 45 \\ & 71421 \times 45 \end{aligned}$ |  | $\begin{aligned} & 71321 \times 55 \\ & 71421 \times 55 \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 71321 \times 70(3) \\ 71421 \times 70^{(3)} \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. |  |  |
| Write Cycle |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time ${ }^{(5)}$ | 45 | - | 55 | - | 70 | - | ns |
| tEW | Chip Enable to End of Write | 35 | - | 40 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 35 | - | 40 | - | 50 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tDw | Data Valid to End of Write | 20 | - | 20 | - | 30 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,4)}$ | - | 20 | - | 30 | - | 35 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High Z ${ }^{(1,4)}$ | - | 20 | - | 30 | - | 35 | ns |
| tow | Output Active From End of Write ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures $1,2,3$ and 4).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. For MASTER/SLAVE combination, $t w c=t B A A+t w p$.
6. " $x$ " in part numbers indicates power rating (SA or LA).

TIMING WAVEFORM OF WRITE CYCLE NO. 1, R/W CONTROLLED TIMING $(1,2,3,7)$


2691 drw 07

TIMING WAVEFORM OF WRITE CYCLE NO. $2, \overline{\text { CE }}$ CONTROLLED TIMING $(1,2,3,5)$


## NOTES:

1. WE must be high during all address transitions.
2. A write occurs during the overlap (tEw or twp) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. twa is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of the write cycle.
4. During this period, the $I / O$ pins are in the output state and input signals must not be applied.
5. If the CE low transition occurs simultaneously with or after the RW low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a $\mathrm{R} \bar{W}$ controlled write cycle, the write pulse width must be larger of twp or (twz + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R / \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE

| Symbol | Parameter | $\begin{aligned} & 71321 \times 20(1) \\ & 71421 \times 20^{(1)} \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & \hline 71321 \times 25 / 30 \\ & 71421 \times 25 / 30 \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & 71321 \times 35 \\ & 71421 \times 35 \\ & \text { Min. Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Busy Timing (For Master IDT71321 Only) |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | 20 | - 25/30 | 35 | ns |
| tBDA | BUSY Disable Time to Address | 18 | - 20/25 | - 30 | ns |
| tBAC | $\overline{\text { BUSY Access Time to Chip Enable }}$ | 20 | -\% 20/25 | 30 | ns |
| tBDC | BUSY Disable Time to Chip Enable | 18 | $\cdots 20 / 25$ | 25 | ns |
| twDD | Write Pulse to Data Delay ${ }^{(3)}$ | 45 | $\cdots$ - $50 / 55$ | 60 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | 30 | $\cdots 33 / 33$ | 35 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(4)}$ | 5 - | 5/5 | 5 - | ns |
| tBDD | BUSY Disable to Valid Data(5) | - Nate 5 | - Note 5 | - Note 5 | ns |
| Busy Timing (For Slave IDT71421 Only) |  | \%ै* |  |  |  |
| twB | Write to $\overline{\text { BUSY }}$ Input (6) | 0 \% ${ }^{+}$ | 0/0 | 0 | ns |
| twh | Write Hold After BUSY ${ }^{(7)}$ | 12\% | 15/20 | 20 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(9)}$ | - 45 | - 50/55 | 60 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | 30 | - 35/35 | - 35 | ns |

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (CONTINUED)

| Symbol | Parameter | $\begin{aligned} & 7132 \\ & 7142 \\ & \text { Min. } \\ & \hline \end{aligned}$ | $1 \times 45$ <br> $1 \times 45$ Max. | $\begin{aligned} & 7132 \\ & 7142 \\ & \text { Min. } \end{aligned}$ | $\begin{gathered} 1 \times 55 \\ 1 \times 55 \\ 1 \times 55 \\ \text { Max. } \end{gathered}$ |  | $\begin{gathered} 1 \times 70^{(2)} \\ 1 \times 70^{(2)} \\ \text { Max. } \end{gathered}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Busy Timing (For Master IDT71321 Only) |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 35 | - | 45 | - | 45 | ns |
| tBDA | BUSY Disable Time to Address | - | 35 | - | 40 | - | 40 | ns |
| tBAC | BUSY Access Time to Chip Enable | - | 30 | - | 35 | - | 35 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 25 | - | 30 | - | 30 | ns |
| twDD | Write Pulse to Data Delay ${ }^{(3)}$ | - | 70 | - | 80 | - | 90 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - | 45 | - | 55 | - | 70 | ns |
| taps | Arbitration Priority Set-up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | ns |
| tBDD | BUSY Disable to Valid Data ${ }^{(5)}$ | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| Busy Timing (For Slave IDT71421 Only) |  |  |  |  |  |  |  |  |
| twB | Write to BUSY Input(6) | 0 | - | 0 | - | - | - | ns |
| tWH | Write Hold After $\overline{\text { BUSY }}{ }^{(7)}$ | 20 | - | 20 | - | 20 | - | ns |
| twDD | Write Pulse to Data Delay ${ }^{(9)}$ | - | 70 | - | 80 | 90 | - | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - | 45 | - | 55 | - | 70 | ns |

NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY (For Master IDT71321 only)".
4. To ensure that the earlier of the two ports wins.
5. tBDD is a calculated parameter and is the greater of 0 , twDD-twp (actual) or tDDD - tow (actual).
6. To ensure that the write cycle is inhibited during contention.
7. To ensure that a write cycle is completed after contention.
8. " $x$ " in part numbers indicates power rating (SA or LA).
9. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With Port-to-Port Delay (For Slave IDT71421 Only)".

## TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}{ }^{(1,2,3)}$ (FOR MASTER IDT71321)



NOTES:

1. To ensure that the earlier of the two ports wins.
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuously enabled for both ports.
4. $\overline{O E}$ at LO for the reading port.

TIM! ING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$ (FOR SLAVE IDT71421 ONLY)


1. Assume $\overline{B U S Y}$ input at HI for the writing port, and $\overline{\mathrm{O} E}$ at LO for the reading port.
2. Write Cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuously enabled for both ports.

TIMING WAVEFORM OF WRITE WITH BUSY (FOR SLAVE IDT71421)


## timing waverorm of contention cycle no. 1, $\overline{\text { CE ARBITRATION }}$ (FOR MASTER IDT71321 ONLY)

$\overline{\text { CEL VALID FIRST: }}$


CER VALID FIRST:
2691 drw 12


## TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION

 (FOR MASTER IDT71321 ONLY)(1)LEFT ADDRESS VALID FIRST:


2691 drw 14
RIGHT ADDRESS VALID FIRST:


NOTE:

1. $\overline{\mathrm{CE}}_{\mathrm{L}}=\overline{\mathrm{CE}}_{\mathrm{R}}=\mathrm{V}_{\mathrm{IL}}$

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE

| Symbol | Parameter | 71321SA/LA20(1) 71421SA/LA20(1) Min. Max. | $\begin{aligned} & \text { 71321SA/LA25/30 } \\ & \text { 71421SA/LA25/30 } \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & 71321 \text { SA/LA35 } \\ & 71421 \text { SA/LA35 } \\ & \text { Min. Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Interrupt Timing |  |  |  |  |  |
| tas | Address Set-up Time | 0 | 0 . $\times$. | 0 | ns |
| tWR | Write Recovery Time | 0 | \% 0 , ${ }^{\text {\% }}$ | 0 | ns |
| tINS | Interrupt Set Time | - $\% 20$ | - 25/30 | 35 | ns |
| tINR | Interrupt Reset Time | - \% 20 | - 25/30 | 35 | ns |

AC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (CONTINUED)

| Symbol | Parameter | 71321SA/LA45 71421SA/LA45 Min. Max. | $\begin{aligned} & \text { 71321SA/LA55 } \\ & \text { 71421SA/LA55 } \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & \text { 71321SA/LA70(2) } \\ & \text { 71421SA/LA70(2) } \\ & \text { Min. Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Interrupt Timing |  |  |  |  |  |
| tas | Address Set-up Time | 0 | 0 | 0 | ns |
| tWR | Write Recovery Time | 0 | 0 | 0 | ns |
| tins | Interrupt Set Time | 40 | 45 | 50 | ns |
| tINR | Interrupt Reset Time | 40 | 45 | 50 | ns |

NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.

## TIMING WAVEFORM OF INTERRUPT MODE (1, 2)

LEFT SIDE SETS $\overline{\text { INTR: }}$


2691 drw 16
RIGHT SIDE CLEARS INTR:

2. $\overline{\operatorname{NNT}}$ and $\sqrt{N T_{R}}$ are reset (HIGH) during power up.

TIMING WAVEFORM OF INTERRUPT MODE (1, 2)
RIGHT SIDE SETS $\overline{\operatorname{NT} T}$ :


LEFT SIDE CLEARS $\overline{\text { INTL: }}$


NOTES:

1. $\overline{\mathrm{CE}} \mathrm{L}=\overline{C E}_{\mathrm{R}}=\mathrm{V}_{\mathrm{L}}$
2. $\overline{\operatorname{INTR}}$ and $\mathbb{I N T L}$ are reset (HIGH) during power up.

## 16-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



NOTE:

1. No arbitration in IDT71421 (SLAVE). $\overline{\text { BUSY}}$-IN inhibits write in IDT71421 (SLAVE).

## FUNCTIONAL DESCRIPTION

The IDT71321/IDT71421 provides two ports with separate control, address and VO pins that permit independent access for reads or writes to any locations in memory. These devices have an automatic power-down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power-down circuitry that permits the respective port to go into a standby mode when not selected (CE high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}}$ ). In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/WRITE conditions are illustrated in Table 1.

The interrupt flag (INT) permits communication between ports or systems. If the user chooses to use the interrupt function, a memory location (mail box or message center) is assigned to each port. The left port interrupt flag ( $\overline{\mathrm{NNTL}}$ ) is set when the right port writes to memory location 7FE (HEX). The left port clears the interrupt by reading address location 7FE. Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location 7FF (HEX) and to clear the interrupt flag (INTR), the right port must read the memory location 7FF. The message ( 8 bits) at 7FE or 7FF is user-defined. If the interrupt function is not used, address locations 7FE and 7FF are not used as mail boxes but as part of the random access memory. Refer to Table II for the interrupt operation.

## ARBITRATION LOGIC FUNCTIONAL DESCRIPTION

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimum and determine which port has access. In all cases, an active BUSY flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. BUSY is set at speeds that permit the processor to hold the operation and its respective address and data. It is important to note that the operation is invalid for the port that has $\overline{B U S Y}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{\mathrm{CE}}$, on-chip control logic arbitrates between $\overline{\mathrm{CEL}}$ and CER for access; or (2) if the CEs are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table III). In either mode of arbitration, the delayed port's $\overline{B U S Y}$ flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION MASTER/SLAVE DESCRIPTION

Expanding the data bus width to sixteen-or-more-bits in a dual-port RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its $\overline{B U S Y} \bar{L}$ while another acitivates its BUSYR signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid the "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only one arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMS in width, the writing of the SLAVE RAMs must be delayed, until after the BUSY input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{B U S Y}$ to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than one chip is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

## TRUTH TABLES

## TABLE I- NON-CONTENTION READ/WRITE CONTROL ${ }^{(4)}$

| Left Or Right Port ${ }^{\text {(1) }}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ | $\overline{C E}$ | $\overline{O E}$ | D0-7 |  |
| X | H | X | Z | Port Disabled and in Power Down Mode IsB2 or ISB4 |
| X | H | X | Z | $\overline{\mathrm{CE}}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{H}$, Power Down Mode, ISB1 or ISB3 |
| L | L | X | DATAIN | Data on Port Written into Memory ${ }^{(2)}$ |
| H | L | L | DATAOUT | Data in Memory Output on Port ${ }^{(3)}$ |
| H | L | H | Z | High Impedance Outputs |

## NOTES:

2691 tbl 16

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter (1) | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| CouT | Output Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |

## NOTE:

1. This parameter is determined by device characterization but is not $100 \%$ tested.
2. AOL-A1OL $\neq A 0 R-A 10 R$
3. If $\overline{B U S Y}=L$, data is not written.
4. If $\overline{B U S Y}=\mathrm{L}$, data may not be valid, see twDD and tedD timing.
5. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=\mathrm{LOW}, \mathrm{X}=$ DON'T CARE, $\mathrm{Z}=\mathrm{HIGH}$ IMPEDANCE

TABLE II - INTERRUPT FLAG(1, 4)

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/ $\overline{\mathrm{W}} \mathrm{L}$ | $\overline{\text { CEL }}$ | $\overline{\mathrm{OE}}$ | A0L-A10L | $\overline{\text { INTL }}$ | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | $\overline{\text { CER }}$ | $\overline{O E}$ | AOL-A10R | INTR |  |
| L | L | X | 7FF | X | X | X | X | X | $\mathrm{L}^{(2)}$ | Set Right $\overline{N T}$ TR Flag |
| X | X | X | X | X | X | L | L | 7FF | $\mathrm{H}^{(3)}$ | Reset Right İNTR Flag |
| X | X | X | X | $L^{(3)}$ | L | L | X | 7FE | $\mathrm{X}^{(2)}$ | Set Left INTL Flag |
| X | L | L | 7FE | $H^{(2)}$ | X | X | X | X | X | Reset Left INTL Flag |

1. Assumes $\overline{B U S Y}=\overline{B U S Y} R=H$
2. If $\overline{B U S Y}=\mathrm{L}$, then NC .
3. If $\overline{B U S Y} R=L$, then $N C$.
4. $H=$ HIGH, $L=$ LOW,$X=$ DON'T CARE,$N C=$ NO CHANGE.

TABLE III - ARBITRATION ${ }^{(1,2)}$

| Left Port |  | Right Port |  | Flags |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E L}$ | AOL-A10L | $\overline{\text { CEF }}$ | A0R-A10R | $\overline{\text { BUSYL }}$ | BUSYR |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | $\neq$ A0R-A10R | L | \# AOL-A10L | H | H | No Contention |
| Address Arbltration With $\overline{\mathrm{CE}}$ Low Before Address Match |  |  |  |  |  |  |
| L | LV5R | L | LV5R | H | L | L-Port Wins |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |
|  |  |  |  |  |  |  |
| LL5R | = A0R-A10R | LL5R | $=\mathrm{AOL}-\mathrm{A}_{10 \mathrm{~L}}$ | H | L | L-Port Wins |
| RL5L | = A0R-A10R | RL5L | = AOL-A10L | L | H | R-Port Wins |
| LW5R | $=$ A0R-A 10 R | LW5R | $=\mathrm{A} 0 \mathrm{~L}-\mathrm{A}_{10 \mathrm{~L}}$ | H | L | Arbitration Resolved |
| LW5R | = A0R-A 10 R | LW5R | $=A 0 L-A_{10 L}$ | L | H | Arbitration Resolved |

## NOTES:

## 1. INT Flags Don't Care.

2. $X=$ DON'T CARE, $L=L O W, H=$ HIGH

LV5R = Left Address Valid $\geq 5$ ns before right address.
RV5L $=$ Right Address Valid $\geq 5$ ns before left address.
Same $=$ Left and Right Addresses match within 5ns of each other.
$\mathrm{LL} 5 \mathrm{R}=\mathrm{Left} \overline{\mathrm{CE}}=\mathrm{LOW} \geq 5$ ns before Right $\overline{\mathrm{CE}}$.
RL5L $=$ Right $\overline{C E}=$ LOW $\geq 5$ ns before Left $\overline{C E}$.
LW5R = Left and Right $\overline{C E}=$ LOW within 5 ns of each other.

## ORDERING INFORMATION



HIGH-SPEED
2K x 9 DUAL-PORT

## STATIC RAM

## FEATURES:

- High-speed access
- Military: 35/45/55/70ns (max.)
- Commercial: 25/35/45/55ns (max.)
- Low-power operation
- IDT7012S

Active: 400 mW (typ.)
Standby: 7mW (typ.)

- IDT7012L

Active: 400 mW (typ.)
Standby: 2mW (typ.)

- Fully asychronous operation from either port
- Each port has a 9-bit wide data path. The 9th bit could be used as the parity bit
- Battery backup operation - 2 V data retention
- TTL compatible, single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7012 is a high-speed $2 \mathrm{~K} \times 9$ dual-port static RAM designed to be used in systems where on-chip hardware port arbitration is not needed. This part lends itself to those systems which cannot tolerate wait states or are designed to be able to externally arbitrate or withstand contention when both sides simultaneously access the same dual-port location.

The IDT7012 provides two independent ports with separate control, address and $1 / O$ pins that permit independent, asychronous access for reads or writes to any location in memory. It is the user's responsibility to ensure data integrity when simultaneously accessing the same memory location from both ports. An automatic power-down feature, controlled by $\overline{C E}$, permits the on-chip circuitry of each port to enter a very low standby power mode.

The IDT7012 utilizes a 9-bit wide data path to allow for control and parity bits at the user's option. This feature is especially useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking.

Fabricated using IDT's CEMOS™ high-performance technology, these devices typically operate on only 400 mW of power at maximum access times as fast as 25ns. Low-power (L) versions offer battery backup data retention capability, with each port typically consuming $200 \mu \mathrm{~W}$ from a 2 V battery.

The IDT7012 is packaged in 48-pin sidebrazed or plastic DIPs, 48-pin LCCs and 48-pin flatpacks. The military devices are processed $100 \%$ in compliance to the test methods of MIL-STD-883, Method 5004.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATIONS

| $\overline{\mathrm{CE}} \mathrm{L}$ | $1 \checkmark 48$ | $\square \overline{C E}^{\text {a }}$ |
| :---: | :---: | :---: |
| R/WW $\square^{2}$ | 2 - 47 | $\square \mathrm{R} / \bar{W}_{R}$ |
| A10L $\square^{3}$ | $3 \quad 46$ | $\square \mathrm{A}^{10 R}$ |
| Agt $\square^{4}$ | 445 | - AgR |
| OEL-5 | 544 | $\square \overline{\text { OER }}$ |
| Aol $\square^{6}$ | 6 - 43 | $\square \mathrm{AOR}$ |
| A1L $\square^{7}$ | $7 \quad 42$ | ( $A 1 R$ |
| A $2 \mathrm{~L} \square^{8}$ | $8 \quad 41$ | $\square \mathrm{A}_{2} \mathrm{R}$ |
| A 3 L $\square^{\circ}$ | $9 \quad 40$ | $\square A^{3}$ |
| A 4L $\square^{10}$ | $10 \quad 39$ | $\square A_{4}$ |
| A $51-{ }^{11} \mathrm{C} 48-2$ | ${ }^{11} \mathrm{C} 48-2^{38}$ | $\square \mathrm{A}_{5 R}$ |
| GND-12 \& | 12 \& 37 | $\square \mathrm{Vcc}$ |
| A6L $1_{13} \mathrm{P}^{\text {8-1 }}$ | 13 P48-1 36 | - $\mathrm{A}_{6 \mathrm{R}}$ |
| $A 71{ }^{14}$ | $14 \quad 35$ | $\square \mathrm{A} 7 \mathrm{R}$ |
| A $8 \mathrm{~L} \square^{15}$ | 15 - 34 | $\square \mathrm{A} 8 \mathrm{R}$ |
| I/O oi- ${ }^{16}$ | $16 \quad 33$ | I/O 8 R |
| I/O iL $\square^{17}$ | $17 \quad 32$ | ] I/O 7R $^{\text {d }}$ |
| I/O $21 \square^{18}$ | $18 \quad 31$ | $1 / O_{6 R}$ |
| I/O 3L- ${ }^{19}$ | 19 30 | $1 / O_{5 R}$ |
| I/O 4L- 20 | 2029 | ] $1 / O_{4 R}$ |
| I/O 5L- 21 | $21 \quad 28$ | I/O 3 R |
| I/O 6L $\square^{22}$ | $22 \quad 27$ | I/O 2 R |
| 1/O 7L- ${ }^{23}$ | $23 \quad 26$ | - I/O 1 R |
| 1/O 8L-24 | $24 \quad 25$ | $1 / \mathrm{OOR}$ |

> DIP
> TOP VIEW


2653 drw 03

## LCC/FLATPACK TOP VIEW

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2653 tbl 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis notimplied. Exposure to absolute maximumrating conditions for extended periods may affect reliabilty.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

2653 \# 02
RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0.0 | V |
| VIH | Input High Votage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2653 tol 03

1. $\mathrm{V}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

CAPACITANCE ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| Cout | Output Capacitance | VOUT $=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2653 tol 13

1. This parameter is sampled and not $100 \%$ tested.

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Condition | 7012 S |  | 7012L |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|lu| | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|ILO| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{ViH}, \mathrm{VOUT}=0 \mathrm{~V}$ to VcC | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{lOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

DC ELECTRICAL CHARACTERISTICS OVER THE OPERATING
TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version | $7012 \times 25^{(2)}$ |  | $7012 \times 35$ |  | $7012 \times 45$ |  | $7012 \times 55$ |  | $7012 \times 70^{(3)}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ. | Max. | Typ. | Max. | Typ. | Max. | Typ. | Max. | Typ. | Max. |  |
| Icc | Dynamic Operating | $\overline{\mathrm{CE}} \leq \mathrm{VIL}$ Outputs Open $\mathfrak{f}=\mathrm{fmax}^{(4)}$ | Mil. $\quad \mathrm{S}$ | - | - | $\begin{aligned} & 80 \\ & 80 \end{aligned}$ | $\begin{aligned} & 300 \\ & 220 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 290 \\ & 210 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 70 \end{aligned}$ | $\begin{aligned} & 285 \\ & 205 \\ & \hline \end{aligned}$ | $65$ | $\begin{aligned} & 275 \\ & 200 \\ & \hline \end{aligned}$ | mA |
|  | Current (Both Ports Active) |  | $\begin{array}{\|cc} \hline \text { Com'l. } & \mathrm{S} \\ & \mathrm{~L} \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{aligned} & 260 \\ & 190 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{aligned} & 250 \\ & 180 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{array}{r} 245 \\ 170 \\ \hline \end{array}$ | $\begin{aligned} & 70 \\ & 70 \\ & \hline \end{aligned}$ | $\begin{aligned} & 235 \\ & 160 \\ & \hline \end{aligned}$ | - | - |  |
| Is81 | Standby Current (Both | $\begin{aligned} & \overline{\overline{\mathrm{CE}} \mathrm{~L}} \text { and } \\ & \overline{\mathrm{CE}} \geq V_{\mathrm{VIH}} \\ & \mathrm{f}=\mathrm{fmax}^{(4)} \end{aligned}$ | $\begin{array}{ll} \hline \text { Mil. } & \mathrm{S} \\ & \mathrm{~L} \\ \hline \end{array}$ | - | - | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \\ & \hline \end{aligned}$ | mA |
|  | Ports-TTL <br> Leve! Inputs) |  | $\begin{array}{\|rl} \hline \text { Com'l. } & \mathrm{S} \\ \mathrm{~L} \end{array}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & \hline 65 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | - | - |  |
| ISB2 | Standby Current (One | $\begin{aligned} & \overline{\mathrm{CE}}_{\mathrm{L}} \text { or } \\ & \overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{V}_{\mathrm{IH}} \end{aligned}$ | Mil. $\quad$S <br>  | 二 | - | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 190 \\ & 145 \end{aligned}$ | $\begin{aligned} & \hline 45 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{aligned} & 180 \\ & 140 \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 170 \\ & 140 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 165 \\ & 135 \\ & \hline \end{aligned}$ | mA |
|  | Port-TTL <br> Level Inputs) | Active Port Outputs Open, $f=f M A X^{(4)}$ | $\begin{aligned} & \hline \text { Com'l. } \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 175 \\ & 125 \end{aligned}$ | $\begin{aligned} & 46 \\ & 46 \end{aligned}$ | $\begin{aligned} & 160 \\ & 115 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 150 \\ & 105 \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | $\begin{gathered} 140 \\ 95 \end{gathered}$ | - | - |  |
| IsB3 | Full Standby Current | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$. and $\overline{C E R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ | $\begin{array}{ll}\text { Mil. } & \mathrm{S} \\ \mathrm{L}\end{array}$ | - | - | $\begin{aligned} & 1.2 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  | (Both Ports-All CMOS Level Inputs) | $\begin{aligned} & V I N \geq V c c-0.2 V \\ & \text { or } V I N \leq 0.2 V, f=0^{(5)} \end{aligned}$ | Com'l. ${ }^{\text {S }} \mathrm{L}$ | $\begin{aligned} & 1.2 \\ & 0.4 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \end{gathered}$ | - | - |  |
| ISB4 | Full Standby Current | One Port $\overline{C E} L$ or $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$, | $\begin{array}{ll}\text { Mil. } & \mathrm{S} \\ \mathrm{L}\end{array}$ | - | - | $\begin{aligned} & 47 \\ & 44 \\ & \hline \end{aligned}$ | $\begin{aligned} & 170 \\ & 130 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \\ & \hline \end{aligned}$ | $\begin{aligned} & 160 \\ & 125 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{aligned} & 155 \\ & 120 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{aligned} & 150 \\ & 115 \end{aligned}$ | mA |
|  | (One Port-All CMOS Level Inputs) | $\begin{aligned} & V I N \geq V c c-0.2 V \text { or } \\ & V I N \leq 0.2 V \\ & \text { Active Port Outputs } \\ & \text { Open, } f=\text { fmax }^{(4)} \end{aligned}$ | Com'l. S | $\begin{aligned} & 50 \\ & 46 \end{aligned}$ | $\begin{aligned} & 155 \\ & 120 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 142 \\ & 110 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 132 \\ & 100 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{gathered} 127 \\ 95 \end{gathered}$ | - | - |  |

## NOTES:

1. " $x$ " in part numbers indicates power rating (S or L).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. At f = fmAx , address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 /$ trc, and using "AC TEST CONDITIONS" of input levels of GND to 3 V .
5. $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby.

DATA RETENTION CHARACTERISTICS (L Version Only)

| Symbol | Parameter | Test Condition |  | 7012L |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Typ. ${ }^{(1)}$ | Max. |  |
| VDR | Vcc for Data Retention | $\mathrm{Vcc}=2.0 \mathrm{~V}, \overline{\mathrm{CE}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ |  | 2 | - | - | V |
| ICCDR | Data Retention Current |  | Mil. | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | Com'l. | - | 100 | 1500 | $\mu \mathrm{A}$ |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time | $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | tRC ${ }^{(2)}$ | - | - | ns |

NOTES:

1. $V C C=2 V, T A=+25^{\circ} \mathrm{C}$.
2. $\mathrm{tRC}=$ Read Cycle Time.
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :--- |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |



Figure 1. Output Load


2653 drw 06
Figure 2. Output Load (for thz, tLz, twz and tow)

[^9]
## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(5)}$

| Symbol | Parameter | $7012 \times 25^{(2)}$ |  | $7012 \times 35$ |  | $7012 \times 45$ |  | $7012 \times 55$ |  | $7012 \times 70^{(3)}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| taide | Output Enable Access Time | - | 12 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tOH | Output Hold From Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tPU | Chip Enable to Power-Up Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | 二 | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power-Down Time ${ }^{(4)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ range only.
4. This parameter guaranteed but not tested.
5. " $x$ " in part numbers indicates power rating ( S or L ).

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


[^10]
## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(6)}$

| Symbol | Parameter | $7012 \times 25^{(2)}$ |  | $7012 \times 35$ |  | $7012 \times 45$ |  | $7012 \times 55$ |  | $7012 \times 70^{(3)}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. |  |  |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tew | Chip Enable to End of Write | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(5)}$ | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| twh | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 12 | - | 20 | - | 20 | - | 20 | - | 30 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| toh | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tow | Output Active From End of Write ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tWDD | Write Pulse to Delay ${ }^{(4)}$ | 50 | - | - | 60 | - | 70 | - | 80 | - | 95 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(4)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |

NOTES:
1.Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested.
5. Specified for $\overline{\mathrm{OE}}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).
6. " $x$ " in part numbers indicates power rating (S or L).

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1)}$


NOTE:

1. Write cycle parameters should be adhered to in order to ensure proper writing.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 , (R/W CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


## TIMING WAVEFORM OF WRITE CYCLE NO. 2, ( $\overline{\text { CE }}$ CONTROLLED TIMING) $)^{(1,2,3,5)}$



NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tew or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. twR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of the write cycle.
4. During this period, the l/O pins are in the output state and input signals must not be applied.
5. If the CE low transition occurs simultaneously with or after the R/W low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig).
7. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twP or (twZ + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tDW. If $\overline{O E}$ is high during a $R / \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## FUNCTIONAL DESCRIPTION

The IDT7012 provides two ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. These devices have an automatic power-down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power-down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{\mathrm{CE}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{O E}$ ). In the read mode, the port's $\overline{O E}$ turns on the output drivers when set LOW. Non-contention READ/ WRITE conditions are illustrated in the truth table below.

TRUTH TABLE
NON-CONTENTION
READ/WRITE CONTROL

| Left or Right Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ | $\overline{\mathrm{CE}}$ | $\overline{O E}$ | D0-8 |  |
| X | H | X | Z | Port Disabled and in PowerDown Mode, ISB2 or ISB4 |
| X | H | X | Z | $\overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{H}$, Power-Down Mode, ISB1 or ISB3 |
| L | L | X | DATAIN | Data on Port Written Into Memory ${ }^{(2)}$ |
| H | L | L | DATAOUT | Data in Memory Output on Port |
| X | X | H | Z | High Impedance Outputs |

NOTES:
2653 tbl 11

1. $A O L-A 10 L \neq A 0 R-A 10 R$
2. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=$ LOW, $\mathrm{X}=$ DON'T CARE, $Z=$ HIGH IMPEDANCE

## ORDERING INFORMATION



## PRELIMINARY <br> IDT70121S/L <br> IDT70125S/L

## FEATURES:

- High-speed access
- Military: 35/45/55/70ns (max.)
- Commercial: 25/35/45/55ns (max.)
- Low-power operation
- IDT70121/70125S

Active: 400 mW (typ.)
Standby: 7mW (typ.)

- IDT70121/70125L

Active: 400 mW (typ.)
Standby: 7mW (typ.)

- Fully asychronous operation from either port
- MASTER IDT70121 easily expands data bus width to 18 bits or more using SLAVE IDT70125 chip
- On-chip port arbitration logic (IDT70121 only)
- BUSY output flag on Master; BUSY input on Slave
- INT flag for port-to-port communication
- Battery backup operation-2V data retention
- TTL compatible, signal 5V ( $\pm 10 \%$ ) power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT70121/IDT70125 are high-speed $2 \mathrm{~K} \times 9$ dual-port static RAMs. The IDT70121 is designed to be used as astandalone 9-bit dual-port RAM or as a "MASTER" dual-port RAM together with the IDT70125 "SLAVE" dual-port in 18-bit-ormore word width systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 18 -bit-or-wider memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power-down feature, controlled by $\overline{C E}$, permits the on-chip circuitry of each port to enter a very low standby power mode.

The IDT70121/IDT70125 utilizes a 9-bit wide data path to allow for Data/Control and parity bits at the user's option. This feature is especially useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance

FUNCTIONAL BLOCK DIAGRAM


## DESCRIPTION (Continued):

technology, these devices typically operate on only 400 mW of power at maximum access times as fast as 25 ns . Low-power (L) versions offer battery backup data retention capability with each port typically consuming $200 \mu \mathrm{~W}$ from a 2 V battery.

The IDT70121/IDT70125 devices are packaged in 52-pin LCCs and 52-pin PLCCs. The military devices are processed $100 \%$ in compliance to the test methods of MIL-STD-883, Method 5004.

## PIN CONFIGURATIONS



## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

2654 tbl 01

1. Stresses greater than those listed under ABSOLUTEMAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

2654 twl 02
RECOMMENDED DC
OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0.0 | V |
| VIH | Input High Votage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2654 tbl 03

1. $\mathrm{VL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Condition | $\begin{aligned} & 70121 S \\ & 70125 S \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { 70121L } \\ & 70125 \mathrm{~L} \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|lı| | Input Leakage Current | $\mathrm{VcC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $1 \mathrm{OL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%)$

| Symbal | Parameter | Test Condition | Version | $\begin{aligned} & 70121 \times 25^{(2)} \\ & 70125 \times 25^{(2)} \end{aligned}$ |  | $\begin{aligned} & 70121 \times 35 \\ & 70125 \times 35 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 70121 \times 45 \\ & 70125 \times 45 \\ & \hline \end{aligned}$ |  | $\begin{array}{\|l\|} 70121 \times 55 \\ 70125 \times 55 \\ \hline \end{array}$ |  | $\begin{aligned} & 70121 \times 70^{(3)} \\ & 70125 \times 70^{(3)} \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ. | Max. | Typ. | Max. | Typ. | Max. | Typ. | Max. | Typ. | Max. |  |
| ICC | Dynamic | $\overline{\mathrm{CE}} \leq \mathrm{VIL}^{\text {l }}$ | Mil. S |  |  | 80 | 300 | 75 | 290 | 70 | 285 | 65 | 275 | mA |
|  | Operating | Outputs Open | L | - | - | 80 | 220 | 75 | 210 | 70 | 205 | 65 | 200 |  |
|  | Current (Both | $f=f m A x{ }^{(4)}$ | Com'l. S | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $260$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 250 \\ & 180 \end{aligned}$ | $75$ | $245$ | $70$ | $235$ | - | - |  |
| ISB1 | Standby Current (Both <br> Ports-TTL <br> Level Inputs) | $\overline{\mathrm{CE}} \mathrm{E}_{\mathrm{L}}$ and $\overline{C E} R \geq V_{I H}$$f=f M A X^{(4)}$ | Mil. S <br>  L | - | - | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 80 \\ & 60 \end{aligned}$ | mA |
|  |  |  | Com'l. ${ }^{\text {S }}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 65 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & \hline 65 \\ & 45 \end{aligned}$ | - | 二 |  |
| ISB2 | Standby <br> Current (One <br> Port-TTL <br> Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH}$ <br> Active Port <br> Outputs Open, $f=f_{\text {MAX }}{ }^{(4)}$ | Mil. S <br>  L | - | - | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 190 \\ & 145 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 180 \\ & 140 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | $\begin{aligned} & 170 \\ & 140 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | $\begin{aligned} & 165 \\ & 135 \end{aligned}$ | mA |
|  |  |  | Com'l. S <br>  $L$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 175 \\ & 125 \\ & \hline \end{aligned}$ | $\begin{aligned} & 46 \\ & 46 \\ & \hline \end{aligned}$ | $\begin{aligned} & 160 \\ & 115 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | $\begin{aligned} & 150 \\ & 105 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} 140 \\ 95 \\ \hline \end{gathered}$ | - | - |  |
| ISB3 | Full Standby Current (Both <br> Ports-CMOS <br> Level Inputs) | Both Ports $\overline{\mathrm{CE}} \mathrm{R}$ and $\overline{\mathrm{CE}} \mathrm{L} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> or $\mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)}$ | Mil. $\quad$ S | - | - | 1.2 0.4 | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | 1.0 0.2 | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  |  |  | Com'l.S  <br>  L | $\begin{aligned} & 1.2 \\ & 0.4 \\ & \hline \end{aligned}$ | $\begin{gathered} 15 \\ 5 \\ \hline \end{gathered}$ | $\begin{aligned} & 1.2 \\ & 0.4 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \\ \hline \end{gathered}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \\ \hline \end{gathered}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{gathered} 15 \\ 5 \\ \hline \end{gathered}$ | - | - |  |
| ISB4 | Full Standby Current (One Port-CMOS Level Inputs) | One Port $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VCC}$ $-0.2 \mathrm{~V}, \mathrm{Vin} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or <br> $\mathrm{Vin} \leq 0.2 \mathrm{~V}$, Active Port Outputs Open, $f=$ fmax $^{(4)}$ | Mil. | - | - | 47 | $\begin{aligned} & 170 \\ & 130 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 160 \\ & 125 \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{aligned} & 155 \\ & 120 \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{aligned} & 150 \\ & 115 \end{aligned}$ | $m A$ |
|  |  |  | Com't. S | $\begin{aligned} & 50 \\ & 45 \end{aligned}$ | $\begin{aligned} & 155 \\ & 120 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 142 \\ & 110 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{aligned} & 132 \\ & 100 \end{aligned}$ | $\begin{aligned} & 45 \\ & 42 \end{aligned}$ | $\begin{array}{l\|} \hline 127 \\ 95 \\ \hline \end{array}$ | - | - |  |

NOTES:

1. " $x$ " in part numbers indicates power rating ( $S$ or $L$ ).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. At $f=$ fmax, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 /$ thc, and using "AC TEST CONDITIONS" of input levels of GND to 3 V .
5. $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby.

DATA RETENTION CHARACTERISTICS (L Version Only)

| Symbal | Parameter | Test Condition |  | 70121L70125L |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Typ. ${ }^{(1)}$ | Max. |  |
| VDR | Vcc for Data Retention | $\mathrm{Vcc}=2.0 \mathrm{~V}, \overline{\mathrm{CE}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ |  | 2 | - | - | V |
| ICCDR | Data Retention Current |  | Mil. | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | Com'l. | - | 100 | 1500 | $\mu \mathrm{A}$ |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time | $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | tRC ${ }^{(2)}$ | - | - | ns |

NOTES:
2654 tbl 06

1. $V C C=2 V, T_{A}=+25^{\circ} \mathrm{C}$.
2. $\mathrm{tRC}=$ Read Cycle Time.
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :--- |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1,2 \& 3$ |

2654 tb 07


2654 dww 04
Figure 1. Output Load


Figure 2. Output Load (for thz, tLz, twz, and tow)


Figure 3. $\overline{\mathrm{BUSY}}$ and $\overline{\mathrm{INT}}$ Output Load

> * Including scope and jig.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(5)}$

| Symbol | Parameter | $\begin{aligned} & 70121 \times 25^{(2)} \\ & 70125 \times 25^{(2)} \end{aligned}$ |  | $\begin{array}{\|l\|} 70121 \times 35 \\ 70125 \times 35 \\ \hline \end{array}$ |  | $\begin{aligned} & 70121 \times 45 \\ & 70125 \times 45 \\ & \hline \end{aligned}$ |  | $\begin{array}{r} 70121 \times 55 \\ 70125 \times 55 \\ \hline \end{array}$ |  | $\begin{aligned} & 70121 \times 70^{(3)} \\ & 70125 \times 70^{(3)} \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| taoe | Output Enable Access Time | - | 12 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tor | Output Hold from Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tPU | Chip Enable to Power-Up Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power-Down Time ${ }^{(4)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3 ).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ range only.
4. This parameter guaranteed but not tested.
5. " $x$ " in part numbers indicates power rating ( S or L ).

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


NOTES:
2654 drw 09

1. $R \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$.
3. Addresses valid prior to, or coincident with, $C \bar{E}$ transition low.
4. $\overline{O E}=V I L$.

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(6)}$

| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twc | Write Cycle Time ${ }^{(5)}$ | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tew | Chip Enable to End of Write | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(7)}$ | 20 | - | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 12 | - | 20 | - | 20 | - | 20 | - | 30 | - | ns |
| thz | Output High Z Time ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enabled to Output in High ${ }^{(1,4)}$ | - | 10 | - | 15 | - | 20 | - | 30 | - | 35 | ns |
| tow | Output Active from End of Write ${ }^{(1,4)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high voltage with load (Figures 1, 2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. This parameter guaranteed but not tested
5. For MASTER/SLAVE combination, twC $=$ tBAA + twp.
6. " $x$ " in part numbers indicates power rating ( S or L ).
7. Specified for $\overline{O E}$ at high (Refer to "Timing Waveform of Write Cycle", Note 7)

TIMING WAVEFORM OF WRITE CYCLE NO. 1, R/W CONTROLLED TIMING ${ }^{(1,2,3,7)}$


2654 drw 10
TIMING WAVEFORM OF WRITE CYCLE NO. 2, $\overline{\text { CE }}$ CONTROLLED TIMING ${ }^{(1,2,3,5)}$


2654 drw 11

## NOTES:

1. R/W must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. Tw is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of the write cycle.
4. During this period, the I/O pins are in the output state and input signals must not be applied.
5. If the $\overline{C E}$ low transition occurs simultaneously with or after the $\mathrm{R} / \bar{W}$ low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a $R / \bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or (twZ + tow) to allow the I/O drivers to turn off data to be placed on the bus for the required tow. If $\overline{O E}$ is high during a $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(8)}$

| Symbol | Parameter | $\begin{aligned} & 70121 \times 25^{(1)} \\ & 70125 \times 25^{(1)} \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 70121 \times 35 \\ 70125 \times 35 \\ \hline \end{array}$ |  | $\begin{array}{\|l\|} 70121 \times 45 \\ 70125 \times 45 \end{array}$ |  | $\begin{array}{\|c\|} 70121 \times 55 \\ 70125 \times 55 \\ \hline \end{array}$ |  | $\begin{aligned} & 70121 \times 70^{(2)} \\ & 70125 \times 70^{12} \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Busy Tlming (For Master IDT70121 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 25 | - | 35 | - | 35 | - | 45 | - | 45 | ns |
| tBDA | BUSY Disable Time to Address | - | 20 | - | 30 | - | 35 | - | 40 | - | 40 | ns |
| tBAC | BUSY Access Time to Chip Enable | - | 20 | - | 30 | - | 30 | - | 35 | - | 35 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 20 | - | 25 | - | 25 | - | 30 | - | 30 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(3)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 95 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(3)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tBDD | BUSY Disable to Valid Data ${ }^{(5)}$ | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | - | Note 5 | ns |
| Busy Timing (For Slave IDT70125 Only) |  |  |  |  |  |  |  |  |  |  |  |  |
| twb | Write to $\overline{\text { BUSY }}$ Input ${ }^{(6)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tWH | Write Hold After $\overline{\text { BUSY }}{ }^{(7)}$ | 15 | - | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(9)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 95 | ns |
| tDD | Write Data Valid to Read Data Delay ${ }^{(9)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |

NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY (For Master IDT70121 Only)."
4. To ensure that the earlier of the two ports wins.
5. tBDD is a calculated parameter and is the greater of 0 , TWDD - TWP (actual) or tDOD - tow (actual).
6. To ensure that a write cycle is inhibited during contention.
7. To ensure that a write cycle is completed after contention.
8. "x" in part numbers indicates power rating (S or L).
9. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY Port-to-Port Delay (For SLAVE IDT70125 Only)."

TIMING WAVEFORM OF READ WITH $\overline{\text { BUSY }}^{(1,2,3)}$ (FOR MASTER IDT70121)


## NOTES:

1. To ensure that the earlier of the two ports wins.
2. Write Cycle parameters should be adhered to, to ensure proper writing.
3. Device is continuously enabled for both ports.
4. $\overline{O E}$ at LOW for the reading port.

## TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$

(FOR SLAVE IDT70125 ONLY)


## NOTES:

1. Assume $\overline{B U S Y}$ input at HIGH for the writing port, and $\overline{O E}$ at LOW for the reading port.
2. Write Cycle parameters should be adhered to, to ensure proper writing.
3. Device is continuously enabled for both ports.

TIMING WAVEFORM OF WRITE WITH BUSY (FOR SLAVE IDT70125 ONLY)


2654 drw 14

TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, $\overline{C E}$ ARBITRATION (FOR MASTER IDT70121 ONLY)
$\overline{C E L}$ VALID FIRST:

$\overline{C E R}$ VALID FIRST:


## TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION (FOR MASTER IDT70121 ONLY) ${ }^{(1)}$

LEFT ADDRESS VALID FIRST:


RIGHT ADDRESS VALID FIRST:


NOTE:

1. $\overline{\mathrm{CE}} \mathrm{E}=\overline{\mathrm{CE}} \mathrm{R}=\mathrm{VIL}$.

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(3)}$| Symbol | Parameter | $\begin{array}{\|l} 70121 \times 25^{(1)} \\ 70125 \times 25^{(1)} \end{array}$ |  | $\begin{aligned} & 70121 \times 35 \\ & 70125 \times 35 \\ & \hline \end{aligned}$ |  | $\begin{array}{l\|} 70121 \times 45 \\ 70125 \times 45 \end{array}$ |  | $\begin{array}{\|l\|} \hline 70121 \times 55 \\ 70125 \times 55 \\ \hline \end{array}$ |  | $\begin{aligned} & 70121 \times 70^{12} \\ & 70125 \times 70^{(2)} \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Interrupt Timing |  |  |  |  |  |  |  |  |  |  |  |  |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tINS | Interrupt Set Time | - | 25 | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| tINR | Interrupt Reset Time | - | 25 | 二 | 35 | - | 40 | - | 45 | - | 50 | ns |

## NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. " X " in part numbers indicates power rating ( S or L ).

## TIMING WAVEFORM OF INTERRUPT MODE ${ }^{(1,2)}$

LEFT SIDE SETS $\overline{N T N}_{\mathrm{R}}$ :


RIGHT SIDE CLEARS $\overline{\operatorname{INT} R: ~}$


NOTES:

1. $\overline{\mathrm{CE}} \mathrm{L}=\overline{\mathrm{CE}} \mathrm{A}=\mathrm{V} \mathrm{L}$.
2. INTL and INTR are reset (high) during power-up.

## TIMING WAVEFORM OF INTERRUPT MODE ${ }^{(1,2)}$

RIGHT SIDE SETS INTL:


## LEFT SIDE CLEARS $\overline{\operatorname{NT} T: ~}$



NOTES:

1. $\overline{\mathrm{CE}}_{\mathrm{L}}=\overline{\mathrm{CE}} \mathrm{R}=\mathrm{VLL}$.
2. $\mathbb{I N T L}$ and $\mathbb{I N T}_{\mathrm{N}}$ are reset to VoH during power-up.

## 18-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



## NOTE:

1. No arbitration in IDT70125 (SLAVE). $\overline{B U S Y}{ }^{\prime} \mathrm{N}$ inhibits write in IDT70125 (SLAVE).

## FUNCTIONAL DESCRIPTION

The IDT70121/IDT70125 provide two ports with separate control, address and $1 / O$ pins that permit independent access for reads or writes to any location in memory. These devices have an automatic power-down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power-down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{\mathrm{CE}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control $(\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/ WRITE conditions are illustrated in Table 1.

The interrupt flag (INT) permits communication between ports or systems. If the user chooses to use the interrupt function, a memory location (mail box or message center) is assigned to each port. The left port interrupt flag ( $\overline{\mathbb{N T}})$ is set when the right port writes to memory location 7FE (HEX). The left port clears the interrupt by reading address location 7FE. Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location 7FF (HEX) and to clear the interrupt flag ( $\overline{\mathbb{N T}} \mathrm{R}$ ), the right port must read the memory location 7FF. The message (9 bits) at 7FE or 7FF is userdefined. If the interrupt function is not used, address locations 7FE and 7FF are not used as mail boxes but as part of the random access memory. Refer to Table II for the interrupt operation.

## ARBITRATION LOGIC, FUNCTIONAL DESCRIPTION

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimum and determine which port has access. In all cases, an active BUSY flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address and data. It is important to note that the operation is invalid for the port that
has $\overline{B U S Y}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{C E}$, on-chip logic arbitrates between $\overline{C E L}$ and $\overline{\text { CER }}$ for access; or (2) if the $\overline{\mathrm{CE}}$ are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table III). In either mode of arbitration, the delayed port's BUSY flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION, MASTER/SLAVE DESCRIPTION

Expanding the data bus width to eighteen-or-more-bits in a dual-port RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its $\overline{B U S Y} L$ while another activates its $\overline{B U S Y} R$ signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid this "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only one hardware arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMs in width, the writing of the SLAVE RAMs must be delayed until after the $\overline{B U S Y}$ input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{\text { BUSY }}$ to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than one chip is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

## TRUTH TABLES

TABLE I. NON-CONTENTION

## READ/WRITE CONTROL ${ }^{(4)}$

| Left or Right Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ | $\overline{\text { CE }}$ | $\overline{\text { OE }}$ | D0-8 |  |
| X | H | X | Z | Port Disabled and in PowerDown Mode, IsB2 or IsB4 |
| X | H | X | Z | $\overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{F}=\mathrm{H}$, Power-Down Mode, IsB1 or IsB3 |
| L | L | X | DATAIN | Data on Port Written Into Memory ${ }^{(2)}$ |
| H | L | L | DATAOUT | Data in Memory Output on Port ${ }^{(3)}$ |
| H | L | H | Z | High Impedance Outputs |

NOTES:
2654 tbl 12

1. $A O L-A 1 O L \neq A O R-A 10 R$.
2. If $\overline{B U S Y}=L$, data is not written.
3. If $\overline{B U S Y}=L$, data may not be valid, see twDD and toDo timing.
4. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=$ LOW, $\mathrm{X}=$ DON'T CARE, $\mathrm{Z}=\mathrm{HIGH}$ IMPEDANCE

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| CoUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2854 t 13

1. This parameter is determined by device characterization but is not production tested.

## TABLE II. INTERRUPT FLAG ${ }^{(1,4)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{R} / \overline{\mathrm{W}} \mathrm{L}$ | $\overline{\text { CEL }}$ | $\overline{\mathrm{OE}} \mathrm{L}$ | AOL - A10L | INTL | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | $\overline{\text { CER }}$ | OER | A0L - A10R | $\overline{\text { INTR }}$ |  |
| L | L | X | 7FF | X | X | X | X | X | $L^{(2)}$ | Set Right INTR Flag |
| X | X | X | X | X | X | L | L | 7FF | $H^{(3)}$ | Reset Right INTR Flag |
| X | X | X | X | $L^{(3)}$ | L | L | X | 7FE | X | Set Left INTL Flag |
| X | L | L | 7FE | $\mathrm{H}^{(2)}$ | X | X | X | X | X | Reset Left INTL Flag |

NOTES:

1. Assumes $\overline{B U S Y}=\overline{B U S Y R}=H$.
2. If $\overline{B U S Y L}=L$, then $N C$.
3. If $\overline{B U S Y R}=L$, then $N C$.
4. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=$ LOW, $\mathrm{X}=$ DON'T CARE, $\mathrm{NC}=$ NO CHANGE

TABLE III. ARBITRATION ${ }^{(2)}$

| Left Port |  | Right Port |  | Flags ${ }^{(1)}$ |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CEL}}$ | AOL - A10L | $\overline{\mathrm{CE}}$ R | A0R - A10R | $\overline{B U S Y}{ }_{\text {L }}$ | BUSYR |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | $\neq A 0 R-A_{10}$ | L | \# AOL - A10L | H | H | No Contention |
| Address Arbitration With CE Low Before Address Match |  |  |  |  |  |  |
| L | LV5R | L | LV5R | H | L | L-Port Wins |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| 1. | Same | L | Same | L | H | Arbitration Resolved |
| $\overline{\mathrm{CE}}$ Arbitration With Address Match Before $\overline{\mathrm{CE}}$ |  |  |  |  |  |  |
| LL5R | $=A 0 R-A_{10 R}$ | LL5R | $=A 0 L-A_{10 L}$ | H | L | L-Port Wins |
| RL5L | $=A 0 R$ - A10R | RL5L | $=A O L-A_{10 L}$ | L | H | R-Port Wins |
| LW5R | $=A 0 R-A_{10 R}$ | LW5R | $=A O L-A_{10 L}$ | H | L | Arbitration Resolved |
| LW5R | $=A_{0 R}-A_{10}{ }^{\text {a }}$ | LW5R | $=A 0 L-A_{10 L}$ | L | H | Arbitration Resolved |

## NOTES:

## 1. INT Flags Don't Care.

2. $\mathrm{X}=\mathrm{DON}$ 'T CARE, $L=$ LOW, $H=$ HIGH

LV5R $=$ Left Address Valid $\geq 5$ ns before right address.
RV5L $=$ Right Address Valid $\geq 5$ ns before left address.

Same $=$ Left and Right Addresses match within 5 ns of each other.
$\mathrm{LL5R}=\mathrm{Left} \overline{\mathrm{CE}}=\mathrm{LOW} \geq 5 \mathrm{~ns}$ before Right $\overline{\mathrm{CE}}$.
RL5L $=$ Right $\overline{C E}=L O W \geq 5$ ns before Left $\overline{C E}$.
LW5R = Left and right $\overline{C E}=$ LOW within 5ns of each other.

## ORDERING INFORMATION



# CMOS DUAL-PORT RAMS 32K (2K x 16-BIT) 

## IDT7133S/L IDT7143S/L

## FEATURES:

- High-speed access
- Military: 55/70/90ns (max.)
- Commercial: 45/55/70/90ns (max.)
- Low-power operation
- IDT7133/43S Active: 375 mW (typ.) Standby: 5mW (typ.)
- IDT7133/43L Active: 375 mW (typ.) Standby: 1mW (typ.)
- Versatile control for write: separate write control for lower and upper byte of each port
- MASTER IDT7133 easily expands data bus width to 32 bits or more using SLAVE IDT7143
- On-chip port arbitration logic (IDT7133 only)
- $\overline{\text { BUSY output flag on IDT7133; } \bar{B} U S Y}$ input on IDT7143
- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL-compatible; single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Available in 68 -pin ceramic or plastic PGA, LCC, PLCC, and Flatpack
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7133/7143 are high-speed $2 \mathrm{~K} \times 16$ dual-port static

RAMs. The IDT7133 is designed to be used as a stand-alone 16-bit dual-port RAM or as a "MASTER" dual-port RAM together with the IDT7143 "SLAVE" dual-port in 32-bit-ormore word width systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 32-bit-or-wider memory system applications results in full-speed, error-free operation without the need for additional dlscrete logic.

Both devices provide two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power downfeature, controlled by $\overline{\mathrm{CE}}$, permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only 375 mW of power at maximum access times as fast as 45ns. Low-power (L) versions offer battery backup data retention capability, with each port typically consuming 1 mW for a 2 V battery.
The IDT7133/7143 devices have identical pinouts. Each is packed on a 68 -pin ceramic or plastic PGA, 68-pin LCC, 68-pin flatpack, and 68-pin PLCC.

Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B, making it ideally suited to military temperature applications demanding the highest level of performance and reliability.

## FUNCTIONAL BLOCK DIAGRAM



## NOTES:

1. IDT7133 (MASTER): BUSY is open drain output and requires pull-up resistor. IDT7143 (SLAVE): BUSY is input.
2. LB = LOWER BYTE
3. $\mathrm{UB}=\mathrm{UPPER} \mathrm{BYTE}$

## PIN CONFIGURATIONS



## PIN CONFIGURATIONS (Continued)



NOTES:

1. Both Vcc pins must be connected to the supply to assure reliable operation.
2. Both GND pins must be connected to the supply to assure reliable operation.
3. $\mathrm{UB}=$ Upper Byte, $\mathrm{LB}=$ Lower Byte.

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power <br> Dissipation | 2.0 | 2.0 | W |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2699 tol

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| CouT | Input/Output <br> Capacitance | V wO $=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2699 * 02

1. This parameter is determined by device characterization but is not production tested.

## RECOMMENDED OPERATING

TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

RECOMMENDED DC OPERATING
CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2699 tbl 04

1. $\operatorname{VIL}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (Either port, Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | IDT7133S <br> IDT7143S |  | $\begin{aligned} & \hline \text { IDT7133L } \\ & \text { IDT7143L } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \||L心| | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|liol | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}$, VOUT $=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage (//Oo-1/O15) | $\mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| Vol | Open Drain Output Low Voltage (BUSY) | $\mathrm{IOL}=16 \mathrm{~mA}$ | - | 0.5 | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

## DC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(3)}$ (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )| Symbol | Parameter | Test Condition | Version |  | $\begin{aligned} & \hline \text { IDT7133x45(1) } \\ & \text { IDT7143×45(1) } \end{aligned}$ |  | $\begin{aligned} & \hline \text { IDT7133x55 } \\ & \text { IDT7143×55 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { IDT7133x70 } \\ & \text { IDT7143×70 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { IDT7133×90 } \\ & \text { IDT7143x90 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. |  |
| ICC | Dynamic Operating Current | $\overline{\mathrm{CE}}=\mathrm{VIL}$ <br> Outputs Open $f=f_{\max }{ }^{(4)}$ | MIL. | S | - | - | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{array}{r} 280 \\ 260 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{array}{r} 260 \\ 240 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{array}{r} 260 \\ 240 \\ \hline \end{array}$ | mA |
|  | (Both Ports Active) |  | COM'L | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | $\begin{aligned} & 260 \\ & 240 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 240 \\ & 220 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 240 \\ & 220 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 235 \\ & 215 \end{aligned}$ |  |
| ISB1 | Standby Current (Both Ports — TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VIH}$ $f=f_{M A X}{ }^{(4)}$ | MIL. | S | - | - | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 70 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 65 \\ & \hline \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 65 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | — | $\begin{aligned} & 75 \\ & 65 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 60 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 60 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{array}{r} 65 \\ 55 \\ \hline \end{array}$ |  |
| ISB2 | Standby Current <br> (One Port - TTL <br> Level Inputs) | Active Port Outputs Open | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | - | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 180 \\ & 160 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 170 \\ & 150 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{r} 170 \\ 150 \\ \hline \end{array}$ | mA |
|  |  |  | COM'L | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | $\begin{aligned} & 160 \\ & 140 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 150 \\ & 130 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 150 \\ & 130 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 145 \\ & 125 \end{aligned}$ |  |
| ISB3 | Full Standby Current (Both Ports CMOS Level Inputs) | $\begin{aligned} & \text { Both Ports } \overline{C E} L \& \\ & \overline{C E} R \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \\ & \mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)} \end{aligned}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | - | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{gathered} 1 \\ 0.2 \end{gathered}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{gathered} 1 \\ 0.2 \end{gathered}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L | S | - | $\begin{gathered} 15 \\ 4 \end{gathered}$ | $\begin{gathered} 1 \\ 0.2 \end{gathered}$ | $\begin{gathered} 15 \\ 4 \\ \hline \end{gathered}$ | $\begin{gathered} 1 \\ 0.2 \\ \hline \end{gathered}$ | $\begin{gathered} 15 \\ 4 \\ \hline \end{gathered}$ | $\begin{gathered} 1 \\ 0.2 \end{gathered}$ | $\begin{gathered} 15 \\ 4 \\ \hline \end{gathered}$ |  |
| ISB4 | Full Standby Current (OnePort - All CMOS Level Inputs$\left.f=0^{(5)}\right)$ | One Port $\overline{C E}$ or $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ $V I N \geq V C C-0.2 V \text { or }$ $\operatorname{VIN} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=$ fmax ${ }^{(4)}$ | MIL. | S <br> L | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{aligned} & 45 \\ & 40 \end{aligned}$ | $\begin{aligned} & 170 \\ & 150 \end{aligned}$ | $\begin{aligned} & 45 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 160 \\ & 140 \\ & \hline \end{aligned}$ | $45$ $40$ | $\begin{aligned} & 155 \\ & 135 \end{aligned}$ | mA |
|  |  |  | COM'L | $\overline{\mathrm{S}}$ <br> L |  | $\begin{array}{r} 150 \\ 130 \\ \hline \end{array}$ | $\begin{aligned} & 45 \\ & 40 \end{aligned}$ | $\begin{aligned} & 140 \\ & 120 \end{aligned}$ | $\begin{aligned} & 45 \\ & 40 \end{aligned}$ | $\begin{aligned} & 140 \\ & 120 \end{aligned}$ | $\begin{aligned} & 45 \\ & 40 \end{aligned}$ | $\begin{aligned} & 135 \\ & 115 \\ & \hline \end{aligned}$ |  |

NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $V C C=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. " $x$ " in part number indicates power rating ( S or L ).
4. At $f=$ fyax, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 / \mathrm{tRc}$, and using "AC Test Conditions" of input levels of GND to 3 V .
5. $\mathrm{f}=0$ means no address or control lines change. Applies only to inputs at CMOS level standby.

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES ${ }^{(1)}$
(L Version Only) VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{VCC}-0.2 \mathrm{~V}$

| Symbol | Parameter | Test Condition |  | IDT7133/IDT7143 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Max. |  |
| VDR | Vcc for Data Retention | $\begin{aligned} & V C C=2 V \\ & \overline{C E} \geq V H C \\ & V I N \geq V H C \text { or } \leq V L C \end{aligned}$ |  | 2.0 | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | 1500 |  |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | $\mathrm{tRC}^{(2)}$ | - | ns |
| $1 \mathrm{LI}{ }^{(3)}$ | Input Leakage Current |  |  | - | 2 | $\mu \mathrm{A}$ |

NOTES:

1. $\mathrm{VCC}=2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$
2. $t R C=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## LOW Vcc DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1,2 \& 3$ |



Figure 1. Output Load


Figure 2. Output Load (for tlz, thz, twz, tow)
*Including scope and jig


Figure 3. $\overline{B U S Y}$ Output Load (IDT7133 only)

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE| Symbol | Parameter | $\begin{aligned} & \text { IDT7133S/L45 } \\ & \text { IDT7143S/L45 } \end{aligned}$ |  | IDT7133S/L55 IDT7143S/L55 |  | IDT7133S/L70IDT7143S/L70 |  | IDT7133S/L.90IDT7143S/L. 90 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 45 | - | 55 | - | 70 | - | 90 | - | ns |
| taA | Address Access Time | - | 45 | - | 55 | - | 70 | - | 90 | ns |
| tace | Chip Enable Access Time | - | 45 | - | 55 | - | 70 | - | 90 | ns |
| taOe | Output Enable Access Time | - | 30 | - | 35 | - | 40 | - | 40 | ns |
| tor | Output Hold from Address Change | 0 | - | 0 | - | 0 | - | 10 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,3)}$ | 0 | - | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,3)}$ | - | 20 | - | 20 | - | 25 | - | 25 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(3)}$ | - | 50 | - | 50 | - | 50 | - | 50 | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3 ).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. This parameter is guaranteed but not tested.

TIMING WAVEFORM OF READ CYCLE NO. 1 , EITHER SIDE ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


NOTES:

1. $\mathrm{R} / \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low
4. $\overline{O E}=V I L$.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Symbol | Parameter | $\begin{aligned} & \text { IDT7133S/L45 } \\ & \text { IDT7143S } / L 45^{(2)} \\ & \hline \end{aligned}$ |  | IDT7133S/L55 IDT7143S/L55 |  | IDT7133S/L70 IDT7143S/L70 |  | IDT7133S/L90 IDT7143S/L90 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time ${ }^{(4)}$ | 45 | - | 55 | - | 70 | - | 90 | - | ns |
| tew | Chip Enable to End of Write | 30 | - | 40 | - | 50 | - | 85 | - | ns |
| taw | Address Valid to End of Write | 30 | - | 40 | - | 50 | - | 85 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twP | Write Pulse Width ${ }^{(6)}$ | 30 | - | 40 | - | 50 | - | 55 | - | ns |
| twh | Write Recovery Time | 5 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 15 | 二 | 20 | - | 25 | - | 30 | - | ns |
| thz | Output High Z Time ${ }^{(1,3)}$ | - | 20 | - | 20 | - | 25 | - | 25 | ns |
| tDH | Data Hold Time ${ }^{(5)}$ | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twz | Write Enable to Output in High $\mathrm{Z}^{(1,3)}$ | - | 20 | - | 20 | - | 25 | - | 25 | ns |
| tow | Output Active from End of Write ${ }^{(1,3,5)}$ | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1, 2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. This parameter is guaranteed but not tested.
4. For MASTER/SLAVE combination, tWC $=t B A A+t W R+t W P$.
5. The specification for tDH must be met by the device supplying write data to the RAM under all operation conditions. Although tDH and tow values will vary over voltage and temperature, the actual tDH will always be smaller than the actual tow.
6. Specified for $\overline{O E}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE| Symbol | Parameter | $\begin{aligned} & \text { IDT7133S/L45 } \\ & \text { IDT7143S/L45 } \\ & \hline \end{aligned}$ |  | IDT7133S/L55 IDT7143S/L55 |  | $\begin{aligned} & \text { IDT7133S/L70 } \\ & \text { IDT7143S/L70 } \end{aligned}$ |  | IDT7133S/L90 <br> IDT7143S/L90 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (FOR MASTER IDT7133) |  |  |  |  |  |  |  |  |  |  |
| teas | $\overline{\text { BUSY Access Time to Address }}$ | - | 45 | - | 50 | - | 55 | - | 55 | ns |
| tBDA | BUSY Disable Time to Address | - | 40 | - | 40 | - | 45 | - | 45 | ns |
| tBAC | $\bar{B} U S Y$ Access Time to Chip Enable | - | 30 | - | 35 | - | 35 | - | 45 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 25 | - | 30 | - | 30 | - | 45 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(2)}$ | - | 80 | - | 80 | - | 90 | - | 100 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(2)}$ | - | 55 | - | 55 | - | 70 | - | 90 | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(3)}$ | - | Note 4 | - | Note 4 | - | Note 4 | - | Note 4 | ns |
| tAPS | Arbitration Priority Set Up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | 10 | - | ns |
| BUSY INPUT TIMING (For SLAVE IDT7143) |  |  |  |  |  |  |  |  |  |  |
| twB | Write to $\overline{\mathrm{BUSY}}^{(5)}$ | 0 | - | - | - | 0 | - | 0 | - | ns |
| tWH | Write Hold After $\overline{\text { BUSY }}^{(6)}$ | 30 | - | 30 | - | 30 | - | 30 | - | ns |
| twDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 80 | - | 80 | - | 90 | - | 100 | ns |
| tDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 55 | - | 55 | - | 70 | - | 90 | ns |

## NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. Port-to-port delay through RAM cells from writing port to reading port, refer to "TIMING WAVEFORM OF READ WITH BUSY (For Master IDT7133)"
3. $t B D D$ is calculated parameter and is greater of 0 , twDD - twP (actual) or toDD - tow (actual).

4 To ensure that the earlier of the two ports wins.
5. To ensure that the write cycle is inhibited during contention.
6. To ensure that a write cycle is completed after contention.
7. Port-to-port delay through RAM cells from writing port to reading port, refer to "TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY (For Slave (DT7143)*

TIMING WAVEFORM OF WRITE CYCLE NO. 1 (R/W CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


## WRITE CYCLE NO. 2 ( $\overline{\text { CE CONTROLLED TIMING) }}{ }^{(1,2,3,5)}$



NOTES:

1. $\mathrm{R} \overline{\mathrm{W}}$ or $\overline{\mathrm{CE}}$ must be high during all address transitions
2. A write occurs during the overlap (tEw or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. twr is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of write cycle.
4. During this period, the $/ / O$ pins are in the output state, and input signals must not be applied.
5. If the $\overline{C E}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a $\mathrm{R} \bar{W}$ controlled write cycle, the write pulse width must be the larger of twP or ( $\mathrm{WZ}+$ tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $\mathrm{R} \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.
8. $R / \bar{W}$ for either upper or lower byte.

## TIMING WAVEFORM OF READ WITH $\overline{\text { BUSY }}{ }^{(1,2,3)}$ (For MASTER IDT7133)



TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$ (For SLAVE IDT7143)


## TIMING WAVEFORM OF WRITE WITH $\overline{B U S Y}$ INPUT (For SLAVE IDT7143)



TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, $\overline{C E}$ ARBITRATION

## $\overline{\text { CEL VALID FIRST: }}$


$\overline{C E}_{R}$ VALID FIRST:
ADDRLAND R


2699 dww 15
TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION ${ }^{(1)}$ LEFT ADDRESS VALID FIRST:


RIGHT ADDRESS VALID FIRST:


NOTE: 1. $\overline{\mathrm{CE}}_{\mathrm{L}}=\overline{\mathrm{CE}}_{\mathrm{R}}=\mathrm{V}_{\mathrm{IL}}$

## FUNCTIONAL DESCRIPTION:

The IDT7133/43 provides two ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. The devices have an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected (CE high). When a port is enabled, access to the entire memory array is pemitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}) \text {. In the read mode, the port's } \overline{\mathrm{OE}} \text { turns on } \mathrm{A}}$ the output drivers when set LOW. Non-contention READ/ WRITE conditions are illustrated in Table 1.

## ARBITRATION LOGIC,

## FUNCTIONAL DESCRIPTION:

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimum and determine which port has access. In all cases, an active $\overline{B U S Y}$ flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address and data. It is important to note that the operation is invalid for the port that has BUSY set LOW. The delayed port will have access when BUSY goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{\mathrm{CE}}$, on-chip control logic arbitrates between $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \mathrm{R}$ for
access; or (2) if the $\overline{\mathrm{CE}}$ are low before an address match, onchip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's $\overline{B U S Y}$ flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION, MASTER/SLAVE DESCRIPTION:

Expanding the data bus width to 32 bits or more in a dualport RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its $\overline{B U S Y} L$ while another activates its $\overline{B U S Y} R$ signal. Both sides are now busy and the CPUs will await indefinately for their port to become free.
To avoid the "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only one hardware arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.
When expanding dual-port RAMs in width, the writing of the SLAVE RAMs must be delayed until after the $\overline{B U S Y}$ input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{B \cup S Y}$ to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than one chip is active at the same time.
The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

TABLE I - NON-CONTENTION READ/WRITE CONTROL ${ }^{(4)}$

| LEFT OR RIGHT PORT ${ }^{(1)}$ |  |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W̄LB | R/W] ${ }^{\text {U }}$ | $\overline{C E}$ | $\overline{O E}$ | 1/00.7 | 1/O8-15 |  |
| X | X | H | X | Z | Z | Port Disabled and in Power Down Mode, ISB2, ISB4 |
| X | X | H | X | Z | Z | $\overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}}=\mathrm{H}$, Power Down Mode, IsB; or IsB3 |
| L | L | L | X | DATAIN | DATAIN | Data on Lower Byte and Upper Byte Written into Memory ${ }^{(2)}$ |
| L | H | L | L | DATAIN | DATAOUT | Data on Lower Byte Written into Memory ${ }^{(2)}$, Data in Memory Output on Upper Byte ${ }^{(3)}$ |
| H | L | L | L | DATAOUT | DATAIN | Data in Memory Output on Lower Byte ${ }^{(3)}$, Data on Upper Byte Written into Memory ${ }^{(2)}$ |
| L | H | L | H | DATAIN | Z | Data on Lower Byte Written into Memory ${ }^{(2)}$ |
| H | L | L | H | Z | DATAIN | Data on Upper Byte Written into Memory ${ }^{(2)}$ |
| H | H | L | L | DATAOUT | DATAOUT | Data in Memory Output on Lower Byte and Upper Byte |
| H | H | L | H | Z | Z | High Impedance Outputs |

NOTES:

1. $A O L-A_{10 L} \neq A 0 R-A_{10 R}$
2. If $\overline{B U S Y}=L O W$, data is not written.
3. If $\overline{B U S Y}=$ LOW, data may not be valid, see twDD and tDOD timing.
4. $H=H I G H, L=L O W, X=$ Don't Care, $Z=$ High Impedance, $L B=$ Lower Byte, UB = Upper Bytle

TABLE II - ARBITRATION

| LEFT PORT |  | RIGHT PORT |  | FLAGS ${ }^{(1)}$ |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E L}$ | A0L - A10L | CER | AOR - A10R | $\overline{\text { BUSYL }}$ | BUSY̌ |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | X | L | Any | H | H | No Contention |
| L | \% A0R - A 10 R | L | \# A0L - A 10 L | H | H | No Contention |
| ADDRESS ARBITRATION WITH $\overline{C E}$ LOW BEFORE ADDRESS MATCH |  |  |  |  |  |  |
| L | LV5R | L | LV5R | H | L | L-Port Wins |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |
| $\overline{C E}$ ARBITRATION WITH ADDRESS MATCH BEFORE CE |  |  |  |  |  |  |
| LL5R | $=A 0 R-A_{10 R}$ | LL5R | $=A 0 L-A 10 L$ | H | L | L-Port Wins |
| RL5L | $=$ A0R - A10R | RL5L | $=$ A0L - A10L | L | H | R-Port Wins |
| LW5R | $=$ A0R - A10R | LW5R | = A0L - A10L | H | L | Arbitration Resolved |
| LW5R | $=$ A0R - A10R | LW5R | = A0L - A10L | $L$ | H | Arbitration Resolved |

## NOTES:

1. $H=H I G H, L=$ LOW, $X=$ Don't Care

LV5R = Left Address Valid $\geq 5$ ns before right address RV5L $=$ Right Address Valid $\geq 5 n$ s before left address Same $=$ Left and Right Address match within 5 ns of each other

LL5R $=$ Left $\overline{C E}=$ LOW $\geq 5$ ns before Right $\overline{C E}$
RL5L $=$ Right $\overline{C E}=L O W \geq 5$ ns before Left $\overline{C E}$
LW5R = Left and Right $\overline{C E}=$ LOW within 5 ns of each other

## 32-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



NOTES:

1. No arbitration in IDT7143 (SLAVE). BUSY-IN inhibits write in IDT7143 (SLAVE).

## ORDERING INFORMATION




## FEATURES:

- High-speed access
- Military: 35/45/55/70ns (max.)
- Commercial: 25/35/45/55/70/ns (max.)
- Low-power operation
- IDT7133/43SA

Active: 500 mW (typ.)
Standby: 5 mW (typ.)

- IDT7133/43LA

Active: 500 mW (typ.)
Standby: 1 mW (typ.)

- Versatile control for write: separate write control for lower and upper byte of each port
- MASTER IDT7133 easily expands data bus width to 32 bits or more using SLAVE IDT7143
- On-chip port arbitration logic (IDT7133 only)
- BUSY output flag on IDT7133; BUSY input on IDT7143
- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL-compatible; single 5 V ( $\pm 10 \%$ ) power supply
- Available in 68 -pin ceramic or plastic PGA, Flatpack, LCC and PLCC
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7133/7143 are high-speed $2 \mathrm{~K} \times 16$ dual-port static

RAMs. The IDT7133 is designed to be used as a stand-alone 16-bit dual-port RAM or as a "MASTER" dual-port RAM together with the IDT7143 "SLAVE" dual-port in 32-bit-ormore word width systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 32-bit-or-wider memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide two independent ports with separate control, address and $1 / O$ pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power downfeature, controlled by $\overline{\mathrm{CE}}$, permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only 500 mW of power at maximum access times as fast as 25 ns . Low-power (LA) versions offer battery backup data retention capability, with each port typically consuming 1 mW for a 2 V battery.
The IDT7133/7143 devices have identical pinouts. Each is packed on a 68 -pin ceramic or plastic PGA, 68 -pin LCC, 68 -pin flatpack, and 68 -pin PLCC.
Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B, making it ideally suited to military temperature applications demanding the highest level of performance and reliability.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATIONS



## NOTES:

1. Both Vcc pins must be connected to the supply to assure reliable operation.
2. Both GND pins must be connected to the supply to assure reliable operation.
3. $\mathrm{UB}=$ Upper Byte, LB $=$ Lower Byte

|  | $\int_{\text {A6L }}^{51}$ | $50$ <br> A5L | 48 <br> A3L | $\begin{gathered} 46 \\ A_{11} \end{gathered}$ | $\overline{44}$ | $\frac{42}{\overline{C E}_{R}}$ | 40 <br> Aor | 38 A2R | 36 <br> A4R |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 53 \\ & \text { A8L } \end{aligned}$ | $\begin{array}{\|r\|} \hline 52 \\ \text { A7L } \end{array}$ | ${ }^{49} \text { A4L }$ | $\int^{47} \text { A2L }$ | $\begin{array}{\|l} \hline 45 \\ \mathrm{AOL} \end{array}$ | ${ }^{43} \overline{\mathrm{CE}} \mathrm{~L}$ | $\left\|\begin{array}{l} 41 \\ \overline{B U S Y}_{R} \end{array}\right\|$ | $39$ <br> A1R | $\begin{aligned} & 37 \\ & \text { A3R } \end{aligned}$ | $\begin{array}{\|l\|} \hline 35 \\ \text { A5R } \end{array}$ | $\begin{array}{\|l\|} \hline 34 \\ A_{66} \end{array}$ |
| 55 <br> A10L | 54 <br> AgL | $\begin{gathered} \text { G68-1 } \\ \& \\ \text { PG68-1 (PPGA) } \end{gathered}$ |  |  |  |  |  |  | 32 <br> A8R | $\begin{array}{\|l\|} \hline 33 \\ \hline \text { A7R } \end{array}$ |
|  | ${ }^{56} \overline{O E L}$ |  |  |  |  |  |  |  | 30 A 10R | $31$ <br> A9R |
| $\begin{aligned} & 59 \\ & \operatorname{Vcc}^{(1)} \end{aligned}$ |  |  |  |  |  |  |  |  | 28 <br> R $\bar{W}$ RLB | $\stackrel{29}{\mathrm{OE}}_{\mathrm{R}}$ |
| $\begin{aligned} & 61 \\ & \text { //O1L } \end{aligned}$ | $\begin{aligned} & 60 \\ & 1 / \mathrm{OoL} \end{aligned}$ |  |  |  |  |  |  |  | $\begin{array}{\|l\|} \hline 26 \\ G N D^{(2)} \end{array}$ | $\begin{array}{\|l\|} \hline 27 \\ R \bar{W}{ }_{R U B} \end{array}$ |
| $\begin{aligned} & 63 \\ & \text { //O3L } \end{aligned}$ | $\begin{array}{\|l\|} \hline 62 \\ 1 / O_{22} \end{array}$ |  |  |  |  |  |  |  | $\begin{aligned} & 24 \\ & 1 / O_{14 R} \end{aligned}$ | $\begin{aligned} & 25 \\ & 1 / O_{15 R} \end{aligned}$ |
| $65$ | $\begin{aligned} & 64 \\ & 1 / O_{4 L} \end{aligned}$ |  |  |  |  |  |  |  | $\begin{aligned} & \hline 22 \\ & 1 / O_{12 R} \end{aligned}$ | $\begin{aligned} & \hline 23 \\ & 1 / O_{13 R} \end{aligned}$ |
| $\begin{aligned} & 67 \\ & \text { I/O7L } \end{aligned}$ | 66 I/O6L. |  |  |  |  |  |  |  | $\begin{aligned} & 20 \\ & \text { I/O } 10 \mathrm{R} \end{aligned}$ | $\begin{aligned} & 21 \\ & 1 / O_{11 R} \end{aligned}$ |
| $\begin{aligned} & 68 \\ & \text { I/OBL } \end{aligned}$ | $\begin{array}{\|l\|} \hline 1 \\ \mathrm{I} / \mathrm{OgL} \\ \hline \end{array}$ | $\begin{aligned} & \hline 3 \\ & 1 / O_{11 \mathrm{~L}} \end{aligned}$ | $\begin{aligned} & 5 \\ & 1 / O_{13 L} \end{aligned}$ | $\begin{aligned} & 7 \\ & 1 / O_{15 L} \end{aligned}$ | $\begin{aligned} & 9 \\ & \text { GND } \end{aligned}$ | $11$ | $\begin{aligned} & 13 \\ & \text { //O3R } \end{aligned}$ | $\begin{aligned} & 15 \\ & 1 / O_{5 R} \end{aligned}$ | 18 I/O8R | $\begin{array}{\|l\|} \hline 19 \\ 1 / \mathrm{O}_{98} \end{array}$ |
|  | $\begin{aligned} & \hline 2 \\ & \mathrm{I} / \mathrm{O}_{10 \mathrm{~L}} \end{aligned}$ | $\begin{aligned} & \hline 4 \\ & \mathrm{I} / \mathrm{O}_{12 \mathrm{~L}} \end{aligned}$ | $\begin{aligned} & 6 \\ & 1 / O_{14 L} \end{aligned}$ | $\begin{array}{\|l\|} \hline 8 \\ V_{c C}(1) \end{array}$ | $\begin{array}{\|l\|} \hline 10 \\ \text { I/OOR } \end{array}$ | $\begin{aligned} & 12 \\ & \mathrm{I} / \mathrm{O}_{2 \mathrm{R}} \end{aligned}$ | $\begin{aligned} & 14 \\ & 1 / O_{4 R} \end{aligned}$ | $\begin{aligned} & \hline 16 \\ & 1 / O_{6 R} \end{aligned}$ | $\begin{aligned} & \hline 17 \\ & \text { l/O7R } \end{aligned}$ |  |
|  | B | c | D | E | F | G | H | J | K | L |
|  | PGA (Ceramic or Plastic) <br> 2746 drw 04 <br> TOP VIEW |  |  |  |  |  |  |  |  |  |

NOTES:

1. Both Vcc pins must be connected to the supply to assure reliable operation.
2. Both GND pins must be connected to the supply to assure reliable operation.
3. $\mathrm{UB}=$ Upper Byte, LB $=$ Lower Byte

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power <br> Dissipation | 2.0 | 2.0 | ${ }^{\mathrm{W}}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2746 tol 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 11 | pF |
| COUT | Input/Output <br> Capacitance | $\mathrm{V}_{\text {/O }}=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2746 tol 02

1. This parameter is determined by device characterization but is not production tested.

## RECOMMENDED OPERATING

TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2746 tb 04

1. $V_{1 L}($ min. $)=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

DC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (Either port, Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | $\begin{aligned} & \text { IDT7133SA } \\ & \text { IDT7143SA } \end{aligned}$ |  | IDT7133LA IDT7143LA |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \||ㄴI| | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lıo| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| VoL | Output Low Voltage (//O0-1/O15) | $\mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VoL | Open Drain Output Low Voltage (BUSY) | $1 \mathrm{OL}=16 \mathrm{~mA}$ | - | 0.5 | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | $\checkmark$ |

## DC ELECTRICAL CHARACTERISTICS OVER THE <br> OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(3)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test <br> Condition | Version |  | $\begin{aligned} & 7133 \times 25^{(1)} \\ & 7143 \times 25^{(1)} \end{aligned}$ |  | $\begin{aligned} & 7133 \times 35 \\ & 7143 \times 35 \end{aligned}$ |  | $\begin{aligned} & 7133 \times 45 \\ & 7143 \times 45 \end{aligned}$ |  | $\begin{aligned} & 7133 \times 55 \\ & 7143 \times 55 \end{aligned}$ |  | $\begin{aligned} & 7133 \times 70 \\ & 7143 \times 70 \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(22}$ | Max. |  |
| ICC | Dynamic Operating Current | $\overline{\mathrm{CE}} \leq \mathrm{VII}$ <br> Outputs Open $f=f \text { MAX }{ }^{(4)}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ |  | - | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|l} 290 \\ 270 \end{array}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{array}{\|l\|} \hline 280 \\ 260 \end{array}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{array}{\|l\|} \hline 280 \\ 260 \end{array}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{array}{\|l\|} \hline 260 \\ 240 \end{array}$ | mA |
|  | (Both Ports Active) |  | COM'L. | S | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{array}{r} 280 \\ 260 \\ \hline \end{array}$ | $\begin{aligned} & 80 \\ & 80 \end{aligned}$ | $\begin{array}{r} 260 \\ 240 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{array}{\|l} 260 \\ 240 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{aligned} & 240 \\ & 220 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{array}{\|l\|} \hline 240 \\ 220 \\ \hline \end{array}$ |  |
| ISB1 | Standby Current (Both Ports - TTL | $\begin{aligned} & \overline{\mathrm{CE} L} \text { and } \overline{\mathrm{CE}} R \geq \mathrm{VIH} \\ & f=\mathrm{fmAX}^{(4)} \end{aligned}$ | MIL. | $\left\lvert\, \begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}\right.$ | 二 | - | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 85 \\ & 75 \\ & \hline \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 80 \\ & 70 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 70 \\ & \hline \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 65 \end{aligned}$ | mA |
|  | Level Inputs) |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & 70 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 65 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 65 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 60 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 60 \end{aligned}$ |  |
| ISB2 | Standby Current <br> (One Port — TTL <br> Level Inputs) | $\begin{gathered} \overline{\overline{C E} L}, \text { or } \overline{\mathrm{CE}} R \geq \mathrm{V}_{\mathrm{IH}} \\ \mathrm{f}=\mathrm{MAX}{ }^{(4)} \end{gathered}$ <br> Active Port Outputs Open | MIL. <br> COM'L. $^{\prime}$ | $\begin{aligned} & \hline S \\ & L \\ & \hline S \\ & L \end{aligned}$ | $\begin{aligned} & - \\ & \frac{-}{50} \\ & 50 \end{aligned}$ | - <br> 170 <br> 150 | $\begin{aligned} & 50 \\ & 50 \\ & \hline 50 \\ & 50 \end{aligned}$ | $\begin{array}{\|l\|} \hline 190 \\ 170 \\ \hline 160 \\ 140 \\ \hline \end{array}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 180 \\ & 160 \\ & \hline \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 180 \\ & 160 \\ & \hline \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 170 \\ & 150 \\ & \hline \end{aligned}$ | mA |
|  |  |  |  |  |  |  |  |  | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 160 \\ 140 \\ \hline \end{array}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 150 \\ 130 \\ \hline \end{array}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 150 \\ 130 \\ \hline \end{array}$ |  |
| ISB3 | Full Standby Current (Both Ports CMOS Level Inputs) | $\begin{aligned} & \text { Both Ports } \overline{\mathrm{CE}} \mathrm{\&} \\ & \overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VCc}-0.2 \mathrm{~V} \\ & \mathrm{~V} I \mathrm{~N} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \\ & \mathrm{V} I \mathrm{~N} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(5)} \end{aligned}$ | MIL. | $\left\|\begin{array}{l} \mathrm{S} \\ \mathrm{~L} \end{array}\right\|$ | - | - | $\begin{gathered} 1 \\ 0.2 \end{gathered}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{gathered} 1 \\ 0.2 \end{gathered}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{gathered} 1 \\ 0.2 \\ \hline \end{gathered}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{gathered} 1 \\ 0.2 \\ \hline \end{gathered}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L. | L | $\begin{gathered} 1 \\ 0.2 \\ \hline \end{gathered}$ | $\begin{gathered} 15 \\ 4 \end{gathered}$ | $\begin{gathered} 1 \\ 0.2 \\ \hline \end{gathered}$ | $15$ | $\begin{gathered} 1 \\ 0.2 \\ \hline \end{gathered}$ | $\begin{gathered} 15 \\ 4 \\ \hline \end{gathered}$ | $\begin{gathered} 1 \\ 0.2 \end{gathered}$ | $\begin{gathered} 15 \\ 4 \\ \hline \end{gathered}$ | $\begin{array}{\|c\|} \hline 1 \\ 0.2 \\ \hline \end{array}$ | $\begin{aligned} & 15 \\ & 4 \\ & \hline \end{aligned}$ |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs) | One Port $\overline{C E}$ L or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ $V I N \geq V c c-0.2 V \text { or }$ $\operatorname{VIN} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=$ fmax $^{(4)}$ | MIL. | S | - | - | 45 40 | 180 160 | 45 40 | 170 150 | 45 40 | 170 150 | 45 40 | 160 140 | $\mathrm{mA}$ |
|  |  |  | COM'L. | S | 45 40 | 160 140 | 45 40 | 150 130 | 45 40 | 140 120 | 45 40 | 140 120 | 45 40 | $\begin{aligned} & 140 \\ & 120 \\ & \hline \end{aligned}$ |  |

## NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $\mathrm{VCC}=5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$.
3. " $x$ " in part number indicates power rating (SA or LA).
4. At $f=f$ fax, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 /$ tre, and using "AC Test Conditions" of input levels of GND to 3 V .
5. $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby.

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES ${ }^{(1)}$
(LA Version Only) VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{Vcc}-0.2 \mathrm{~V}$

| Symbol | Parameter | Test Condition |  | IDT7133LAIDT7143LA |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Max. |  |
| Vor | Vcc for Data Retention | $\begin{aligned} & V C C=2 V \\ & \overline{C E} \geq V H C \\ & V \mathbb{N} \geq V H C \text { or } \leq V L C \end{aligned}$ |  | 2.0 | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | 1500 |  |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | $\mathrm{tRC}^{(2)}$ | - | ns |
| $1 \mathrm{LI}^{(3)}$ | Input Leakage Current |  |  | - | 2 | $\mu \mathrm{A}$ |

NOTES:

1. $V C C=2 V, T_{A}=+25^{\circ} \mathrm{C}$
2. tRC = Read Cycle Time
3. This parameter is guaranteed but not tested.

## LOW Vcc DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1,2 \& 3$ |
| 2746 tol 08 |  |



Figure 1. Output Load


Figure 2. Output Load (for tiz, thz, twz, tow)
*Including scope and jig


Figure 3. BUSY Output Load (IDT7133 only)

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(4)}$| Symbol | Parameter | $\begin{aligned} & \text { IDT7133×25 } \\ & \text { IDT7143 } 25^{(2)} \end{aligned}$ |  | $\begin{aligned} & \hline \text { IDT7133×35 } \\ & \text { IDT7143×35 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7133×45 } \\ & \text { IDT7143×45 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7133×55 } \\ & \text { IDT7143×55 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7133×70 } \\ & \text { IDT7143×70 } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| Lace | Chip Enable Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| haoe | Output Enable Access Time | - | 15 | - | 20 | - | 25 | - | 30 | - | 40 | ns |
| toh | Output Hold from Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,3)}$ | 3 | - | 3 | - | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,3)}$ | - | 15 | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(3)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3 ).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. This parameter is guaranteed but not tested.
4. " $x$ " in part number indicates power rating (SA or LA).

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(7)}$

| Symbol | , Parameter | $\begin{array}{\|l\|} \hline \text { IDT7133 } \times 25^{(2)} \\ \text { IDT7143 } 25^{(2)} \end{array}$ |  | $\begin{aligned} & \text { IDT7133×35 } \\ & \text { IDT7143×35 } \end{aligned}$ |  | IDT7133x45 <br> IDT7143x45 |  | IDT7133×55 IDT7143×55 |  | $\begin{aligned} & \text { IDT7133x70 } \\ & \text { ID } 7143 \times 70 \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |

## WRITE CYCLE

| twC | Write Cycle Time ${ }^{(4)}$ | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tew | Chip Enable to End of Write | 20 | - | 25 | - | 35 | - | 45 | - | 55 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 25 | - | 35 | - | 45 | - | 55 | - | ns |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(6)}$ | 20 | - | 25 | - | 35 | - | 45 | - | 55 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | 一 | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 15 | - | 20 | - | 20 | - | 25 | - | 30 | - | ns |
| thz | Output High Z Time ${ }^{(1,3)}$ | - | 15 | - | 20 | - | 20 | - | 20 | - | 25 | ns |
| tDH | Data Hold Time ${ }^{(5)}$ | 0 | - | 0 | - | 5 | - | 5 | - | 5 | - | ns |
| twz | Write Enable to Output in High ${ }^{(1,3)}$ | - | 15 | - | 20 | - | 20 | - | 20 | - | 25 | ns |
| tow | Output Active from End of Write ${ }^{(1,3,5)}$ | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1,2 and 3).
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. This parameter is guaranteed but not tested
4. For MASTER/SLAVE combination, $t W C=t B A A+t W R+t W P$.
5. The specification for tDH must be met by the device supplying write data to the RAM under all operation conditions. Although tDH and tow values will vary over voltage and temperature, the actual tDH will always be smalier than the actual tow.
6. Specified for $\overline{O E}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).
7. " $x$ " in part number indicates power rating ( $S A$ or $L A$ ).

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(8)}$



| tBAA | BUSY Access Time to Address | - | 25 | - | 35 | - | 45 | - | 50 | - | 55 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| t8DA | $\overline{\text { BUSY }}$ Disable Time to Address | - | 20 | - | 30 | - | 40 | - | 40 | - | 45 | ns |
| tBAC | $\overline{\text { BUSY Access Time to Chip Enable }}$ | - | 20 | - | 25 | - | 30 | - | 35 | - | 35 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 20 | - | 20 | - | 25 | - | 30 | - | 30 | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(2)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 90 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(2)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(3)}$ | - | Note 4 | - | Note 4 | - | Note 4 | - | Note 4 | - | Note 4 | ns |
| tAPS | Arbitration Priority Set Up Time ${ }^{(4)}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| BUSY INPUT TIMING (For SLAVE IDT7143) |  |  |  |  |  |  |  |  |  |  |  |  |
| tWB | Write to $\overline{\mathrm{BUSY}}{ }^{(5)}$ | 0 | - | 0 | - | 0 | - | - | - | 0 | - | ns |
| twh | Write Hold After $\overline{\mathrm{BUSY}}^{(6)}$ | 20 | - | 25 | - | 30 | - | 30 | - | 30 | - | ns |
| twDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 90 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |

NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. Port-to-port delay through RAM cells from writing port to reading port, refer to "TIMING WAVEFORM OF READ WITH BUSY (For Master IDT7133)"
3. tBDD is calculated parameter and is greater of 0 , twDD - twP (actual) or toDD - tow (actual).

4 To ensure that the earlier of the two ports wins.
5. To ensure that the write cycle is inhibited during contention.
6. To ensure that a write cycle is completed after contention.
7. Port-to-port delay through RAM cells from writing port to reading port, refer to "TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY (For Slave IDT7143)"
8. " $x$ " in part number indicates power rating (SA or LA).

## TIMING WAVEFORM OF WRITE CYCLE NO. 1 (R/W CONTROLLED TIMING) ${ }^{(1,2,3,7)}$



WRITE CYCLE NO. 2 ( $\overline{\text { CE }}$ CONTROLLED TIMING) ${ }^{(1,2,3,5)}$


NOTES:

1. $\mathrm{A} / \bar{W}$ or $\overline{C E}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. twR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of write cycle.
4. During this period, the $I / O$ pins are in the output state, and input signals must not be applied.
5. If the $\overline{C E}$ low transition occurs simultaneously with or after the $\mathrm{R} \overline{\mathrm{W}}$ low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a $R / \bar{W}$ controlled write cycle, the write pulse width must be the larger of twP or (twZ + tow) to allow the l/O drivers to turn off and data to be placed on the bus for the required tDW. If $\overline{O E}$ is high during an $R / \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twP.
8. $R / \bar{W}$ for either upper or lower byte.

TIMING WAVEFORM OF READ WITH $\overline{\text { BUSY }}^{(1,2,3)}$ (For MASTER IDT7133)


TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$ (For SLAVE IDT7143)


NOTES:

1. Assume $\overline{\mathrm{BUSY}}$ input at Hl for the writing port, and $\overline{\mathrm{OE}}$ at LO for the reading port.

2746 drw 12
2. Write cycle parameters should be adhered to in order to ensure proper writing
3. Device is continuously enabled for both ports.

## TIMING WAVEFORM OF WRITE WITH $\overline{B U S Y}$ INPUT (For SLAVE IDT7143)



TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, CE ARBITRATION
$\overline{\text { CEL VALID FIRST: }}$


CER VALID FIRST:


TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION ${ }^{(1)}$ LEFT ADDRESS VALID FIRST:


RIGHT ADDRESS VALID FIRST:


NOTE:

1. $\overline{\mathrm{CE}} \mathrm{L}=\overline{\mathrm{CE}} \mathrm{R}=\mathrm{V} \mathrm{L}$

## FUNCTIONAL DESCRIPTION:

The IDT7133/43 provides two ports with separate control, address and $/$ /O pins that permit independent access for reads or writes to any location in memory. The devices have an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected (CE high). When a port is enabled, access to the entire memory array is pemitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}}$ ). In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/ WRITE conditions are illustrated in Table 1.

## ARBITRATION LOGIC, FUNCTIONAL DESCRIPTION:

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimum and determine which port has access. In all cases, an active BUSY flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's BUSY flag. BUSY is set at speeds that permit the processor to hold the operation and its respective address and data. It is important to note that the operation is invalid for the port that has $\overline{B U S Y}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.
Contention occurs when both left and right ports are active and both addresses match. When this occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{\mathrm{CE}}$, on-chip control logic arbitrates between $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \mathrm{R}$ for
access; or (2) if the $\overline{\mathrm{CE}}$ are low before an address match, onchip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's BUSY flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION, MASTER/SLAVE DESCRIPTION:

Expanding the data bus width to 32 bits or more in a dualport RAM system implies that several chips will be active at the same time. If each chip includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its BUSYL while another activates its $\overline{B U S Y R}$ signal. Both sides are now busy and the CPUs will await indefinately for their port to become free.
To avoid the "Busy Lock-Out" problem, IDT has developed a MASTER/SLAVE approach where only one hardware arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.
When expanding dual-port RAMs in width, the writing of the SLAVE RAMs must be delayed until after the BUSY input has settled. Otherwise, the SLAVE chip may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past BUSY to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than one chip is active at the same time.
The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

## TABLE I - NON-CONTENTION READ/WRITE CONTROL ${ }^{(4)}$

| LEFT OR RIGHT PORT ${ }^{(1)}$ |  |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W $\bar{L}^{\text {L }}$ | R/WUB | $\overline{C E}$ | $\overline{O E}$ | 1/00-7 | 1/O8-15 |  |
| X | $X$ | H | X | Z | Z | Port Disabled and in Power Down Mode, ISB2, ISB4 |
| X | X | H | X | Z | Z | $\overline{\mathrm{CE}}_{\mathrm{R}}=\overline{\mathrm{CE}}_{L}=\mathrm{H}$, Power Down Mode, IsB1 or ISB3. |
| L | L | L | X | DATAIN | DATAIN | Data on Lower Byte and Upper Byte Written into Memory ${ }^{(2)}$ |
| L | H | L | L | DATAIN | DATAOUT | Data on Lower Byte Written into Memory ${ }^{(2)}$, Data in Memory Output on Upper Byte ${ }^{(3)}$ |
| H | L | L | L | DATAOUT | DATAIN | Data in Memory Output on Lower Byte ${ }^{(3)}$, Data on Upper Byte Written into Memory ${ }^{(2)}$ |
| L | H | L | H | DATAIN | Z | Data on Lower Byte Written into Memory ${ }^{(2)}$ |
| H | L | L | H | Z | DATAIN | Data on Upper Byte Written into Memory ${ }^{(2)}$ |
| H | H | L | L | DATAOUT | DATAOUT | Data in Memory Output on Lower Byte and Upper Byte |
| H | H | L | H | Z | Z | High Impedance Outputs |

## NOTES:

1. AOL - A1OL $\neq$ AOR - A10R
2. If $\overline{B U S Y}=$ LOW, data is not written.
3. If $\overline{B U S Y}=$ LOW, data may not be valid, see twDD and toDD timing.
4. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=\mathrm{LOW}, \mathrm{X}=$ Don't Care, $\mathrm{Z}=$ High Impedance, $\mathrm{LB}=$ Lower Byte, UB = Upper Bytle

TABLE II - ARBITRATION ${ }^{(1)}$

| LEFT PORT |  | RIGHT PORT |  | FLAGS |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E L}$ | A0L - A10L | $\overline{C E E}_{\text {R }}$ | Aor - A10R | $\overline{\text { BUSYL }}$ | $\overline{\text { BUSYR }}$ |  |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | $X$ | L | Any | H | H | No Contention |
| L | \# A0R - A10R | L | \# A0L - A10L | H | H | No Contention |

ADDRESS ARBITRATION WITH CE LOW BEFORE ADDRESS MATCH

| L | LV5R | L | LV5R | H | L | L-Port Wins |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| L | RV5L | L | RV5L | L | H | R-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |


| $\overline{\mathrm{CE}}$ ARBITRATION WITH ADDRESS MATCH BEFORE $\overline{\mathrm{CE}}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LL5R | $=A O R-A_{10 R}$ | LL5R | $=A 0 L$ - A10L | H | 1 | L-Port Wins |
| RL5L | $=A 0 B-A 10 R$ | RL5L | = A0L - A 10 L | L | H | R-Port Wins |
| LW5R | $=A 0 R-A_{10 R}$ | LW5R | = A0L - A10L | H | L | Arbitration Resolved |
| LW5R | $=$ AOR - A10R | LW5R | $=A 0 L$ - A10L | L | H | Arbitration Resolved |

NOTES:

1. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=\mathrm{LOW}, \mathrm{X}=$ Don't Care

LV5R $=$ Left Address Valid $\geq 5$ ns before right address
RV5L $=$ Right Address Valid $\geq 5$ ns before left address
Same $=$ Left and Right Address match within 5 ns of each other

LL5R $=$ Left $\overline{C E}=L O W \geq 5$ ns before Right $\overline{C E}$
RL5L $=$ Right $\overline{C E}=$ LOW $\geq 5$ ns before Left $\overline{C E}$
LW5R $=$ Left and Right $\overline{C E}=$ LOW within 5 ns of each othor

## 32-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



NOTES:

1. No arbitration in IDT7143 (SLAVE). BUSY-IN inhibits write in IDT7143 (SLAVE).

## ORDERING INFORMATION



|  | CMOS DUAL-PORT RAM 32 K (4K x 8-BIT) | IDT7134S IDT7134L |
| :---: | :---: | :---: |

## FEATURES:

- High-speed access
- Military: 45/55/70ns (max.)
- Commercial: 35/45/55/70ns (max.)
- Low-power operation
- IDT7134S

Active: 500 mW (typ.)
Standby: 5mW (typ.)

- IDT7134L

Active: 500 mW (typ.)
Standby: 1 mW (typ.)

- Fully asynchronous operation from either port
- Battery backup operation- 2 V data retention
- TTL-compatible; single 5V ( $\pm 10 \%$ ) power supply
- Available in several popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7134 is a high-speed $4 \mathrm{~K} \times 8$ dual-port static RAM designed to be used in systems where on-chip hardware port arbitration is not needed. This part lends itself to those systems which cannot tolerate wait states or are designed to be able to externally arbitrate or withstand contention when both sides simultaneously access the same dual-port RAM location.
The IDT7134 provides two independent ports with separate control, address and $1 / O$ pins that permit independent, asynchronous access for reads or writes to any location in memory. It is the user's responsibility to ensure data integrity when simultaneously accessing the same memory location from both ports. An automatic power down feature, controlled by $\overline{\mathrm{CE}}$, permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS™ high-performance technology, these dual-ports typically operate on only 500 mW of power at maximum access times as fast as 35 ns . Low-power (L) versions offer battery backup data retention capability, with each port typically consuming $200 \mu \mathrm{~W}$ from a 2 V battery.
The IDT7134 is packaged on either a sidebraze or plastic 48 -pin DIP, 48 -pin or 52 -pin LCC, and 52 -pin PLCC. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATIONS



## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation | 1.5 | 1.5 | W |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2696 tol 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| CoUT | Output Capacitance | VoUT $=0 \mathrm{~V}$ | 11 | pF |

## NOTE:

2696 tbl 02

1. This parameter is determined by device characterization but is not production tested.


RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| 2696 tb 03 |  |  |  |

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VcC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20ns.

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbal | Parameter | Test Conditions | IDT7134S |  | IDT7134L |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \||ㄴ| | Input Leakage Current | $\mathrm{VcC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|liol | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{IOL}=6 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
|  |  | $1 \mathrm{LL}=8 \mathrm{~mA}$ | - | 0.5 | - | 0.5 |  |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{Vcc}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version |  | IDT7134×35 ${ }^{(4)}$ |  | IDT7134×45 |  | IDT7134x55 |  | IDT7134×70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. |  |
| Icc | Dynamic Operating Current (Both Ports Active) | $\overline{\mathrm{CE}}=\mathrm{VIL}$ <br> Outputs Open $f=f_{\text {max }}{ }^{(3)}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | 二 | - | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 240 \\ & 200 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 230 \\ & 180 \\ & \hline \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 230 \\ & 180 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{array}{r} 220 \\ 180 \\ \hline \end{array}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \\ & \hline \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \\ & \hline \end{aligned}$ |  |
| IsB1 | Standby Current (Both Ports - TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{VIH}_{\mathrm{I}}$$f=f \text { MAX }^{(3)}$ | MIL. | L | - | - | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{array}{r} 70 \\ 50 \\ \hline \end{array}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 70 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 70 \\ & 50 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 75 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ |  |
| ISB2 | Standby Current <br> (One Port — TTL <br> Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V} \mathrm{V}$ <br> Active Port Outputs Open, $f=$ fmax $^{(3)}$ | MIL. | S | - | - | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 160 \\ & 130 \\ & \hline \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 120 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 120 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 140 \\ & 110 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ |  |
| IS83 | Full Standby Current (Both Ports - All CMOS Level Inputs) | Both Ports $\overline{C E L}$ \&$\begin{aligned} & \overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VCC}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{VCC}-0.2 \mathrm{~V} \text { or } \\ & \mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(3)} \end{aligned}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | - | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{array}{r} 15 \\ 4.0 \\ \hline \end{array}$ | $\begin{aligned} & 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{array}{r} 15 \\ 4.0 \\ \hline \end{array}$ | $\begin{aligned} & 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{array}{r} 15 \\ 4.0 \\ \hline \end{array}$ | $\begin{aligned} & 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \\ & \hline \end{aligned}$ |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs) | One Port $\overline{\text { CEL }}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ Vin $\geq$ Vcc -0.2 V or Vin $\leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=$ fmax $^{(3)}$ | MIL. | S | - | - | 50 45 | 130 100 | 50 45 | 120 90 | 50 45 | 120 90 | mA |
|  |  |  | COM'L. | S | 45 45 | 120 100 | 45 45 | 110 90 | 45 45 | 110 90 | 45 45 | 110 90 |  |

## NOTES:

1. " $x$ " in part number indicates power rating ( S or L ).
2. $\mathrm{VCC}=5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$.
3. $f$ max $=1 /$ tRC $=$ All inputs cycling at $f=1 /$ tRC (except Output Enable). $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby ISB3.
4. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range.

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES ${ }^{(1)}$
(L Version Only) VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{Vcc}-0.2 \mathrm{~V}$

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & \overline{\mathrm{CE}} \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \leq \mathrm{VLC} \end{aligned}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | 100 | 1500 |  |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | $\operatorname{trc}^{(2)}$ | - | - | ns |

NOTES:
2696 thl 07

1. $V C C=2 V, T A=+25^{\circ} \mathrm{C}$
2. $\mathrm{tRC}=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

LOW Vcc DATA RETENTION WAVEFORM


## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |



Figure 1. Output Load


Figure 2. Output Load (for tlz, thz, twz, tow)
*Including scope and jig

## AC ELECTRICAL CHARACTERISTICS OVER THE

## OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Symbol | Parameter | $\begin{aligned} & \text { IDT7134S35 }{ }^{(3)} \\ & \text { IDT7134L35 }{ }^{(3)} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7134S45 } \\ & \text { IDT7134L45 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7134S55 } \\ & \text { IDT7134L55 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7134S70 } \\ & \text { IDT7134L70 } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| taoe | Output Enable Access Time | - | 20 | - | 25 | - | 30 | - | 40 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,2)}$ | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tHz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | - | 50 | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$


2696 dww 07

TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


1. $R \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{C E}$ transition low.
4. $\overline{O E}=V \mathrm{IL}$.

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Symbol | Parameter | $\begin{aligned} & \text { IDT7134S355 } \\ & \text { IDT7134L35 } \\ & \hline \end{aligned}$ |  | IDT7134S45 <br> IDT7134L45 |  | IDT7134S55 <br> IDT7134L55 |  | $\begin{aligned} & \text { IDT7134S70 } \\ & \text { IDT7134L70 } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tew | Chip Enable to End of Write | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| taw | Address Valid to End of Write | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| twr | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 20 | - | 20. | - | 25 | - | 30 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tDH | Data Hold Time ${ }^{(3)}$ | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| twz | Write Enabled to Output in High $\mathrm{Z}^{(1,2)}$ | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,3)}$ | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(4)}$ | - | 80 | - | 80 | - | 80 | - | 90 | ns |
| tDD | Write Data Valid to Read Datả Delay ${ }^{(4)}$ | - | 55 | - | 55 | - | 55 | - | 70 | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. The specification for tDH must be met by the device supplying write data to the RAM under all operating conditions. Although toH and tow values will vary over voltage and temperature, the actual toH will always be smaller than the actual tow.
4. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read with Port-to-Port Delay".
5. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
6. Specified for $\overline{O E}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1)}$


NOTES:
2696 drw 09

1. Write cycle parameters should be adhered to in order to ensure proper writing.

TIMING WAVEFORM OF WRITE CYCLE NO. 1, R/ $\bar{W} \operatorname{CONTROLLED~TIMING~}{ }^{(1,2,3,4,6,7)}$


## TIMING WAVEFORM OF WRITE CYCLE NO. 2, $\overline{\text { CE }}$ CONTROLLED TIMING ${ }^{(1,2,3,5)}$



NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEw or twP) of a low $\overline{\mathrm{CE}}$ and a low $R / \bar{W}$.
3. twR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of write cycle
4. During this period, the I/O pins are in the output state, and input signals must not be applied.
5. If the $\overline{C E}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a $\mathrm{R} \bar{W}$ controlled write cycle, the write pulse width must be the larger of twP or (tWZ + tow) to allow the $1 / O$ drivers to turn off data to be placed on the bus for the required tDW. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twP.

## FUNCTIONAL DESCRIPTION:

The IDT7134 provides two ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. These devices have an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into standby mode when not selected (CE high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/ WRITE conditions are illustrated in the table below.

## TABLE I-READ/WRITE CONTROL

| Left or Right Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ | $\overline{C E}$ | $\overline{\mathrm{OE}}$ | D0-7 |  |
| X | H | X | Z | Port Disabled and in Power Down Mode, ISB2 or ISB4 |
| X | H | X | Z | $\overline{C E} R=\overline{C E} L=H$, Power Down Mode, IsB1 or IsB3 |
| L | L | X | DATAIN | Data on port written into memory |
| H | L | L | DATAOUT | Data in memory output on port |
| X | X | H | Z | High impedance outputs |

NOTES:
2696 bl 11

1. $A O L-A 11 L \neq A 0 R-A_{11 R}$

H = HIGH, L = LOW, X = Don't Care, Z = High Impedance

## ORDERING INFORMATION



| Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) |
| :---: |
| Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ Compliant to MIL-STD-883, Class B |
| Sidebraze DIP |
|  |  |
|  |
|  |
| Leadiess Chip Carrier <br> Leadless Chip Carrier |
| Commercial Only |
|  |
| Standard Power |
| 32K (4K $\times 8$-Bit) Dual-Port RAM |

## FEATURES:

- High-speed access
- Military: 35/45/55/70ns (max.)
— Commercial: 25/35/45/55/70ns (max.)
- Low-power operation
- IDT7134SA

Active: 500 mW (typ.)
Standby: 5mW (typ.)

- IDT7134LA

Active: 500 mW (typ.)
Standby: 1mW (typ.)

- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL-compatible; single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Available in several popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7134 is an extremely high-speed $4 \mathrm{~K} \times 8$ dual-port static RAM designed to be used in systems where on-chip hardware port arbitration is not needed. This part lends itself to those systems which cannot tolerate wait states or are designed to be able to externally arbitrate or withstand. contention when both sides simultaneously access the same dual-port RAM location.

The IDT7134 provides two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. It is the user's responsibility to ensure data integrity when simultaneously accessing the same memory location from both ports. An automatic power down feature, controlled by $\overline{\mathrm{CE}}$, permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {m }}$ high-performance technology, these dual-port typically on only 500 mW of power at maximum access times as fast as 25 ns. Low -power (LA) versions offer battery backup data retention capability, with each port typically consuming 1 mW from a 2 V battery.

The IDT7134 is packaged on either a sidebraze or plastic 48-pin DIP, 48-pin or 52-pin LCC, and 52-pin PLCC. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATIONS



ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | MII. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to Ground | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation | 1.5 | 1.5 | W |
| IOUT | DC Output Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than those listedunder ABSOLUTEMAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| COUT | Output Capacitance | VoUT $=0 \mathrm{~V}$ | 11 | pF |

## NOTE:

1. This parameter is determined by device characterization but is not production tested.


2720 drw 03
LCC/PLCC TOP VIEW


2720 drw 04
LCC
TOP VIEW

## RECOMMENDED OPERATING

TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

2720 tbl 03

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | $V$ |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

1. V IL $($ min. $)=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE (VCC = $5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | IDT7134SA |  | IDT7134LA |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|lu| | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lıo| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}$, Vout $=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{IOL}=6 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
|  |  | $\mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.5 | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Conditions | Version | $7134 \times 25^{(4)}$ |  | 7134×35 |  | 7134×45 |  | $7134 \times 55$ |  | $7134 \times 70$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. |  |
| Icc | Dynamic Operating Current <br> (Both Ports Active) | $\begin{aligned} & \overline{C E} \leq V_{\text {IL }} \\ & \text { Outputs Open } \\ & \mathrm{f}=\text { fmax }^{(3)} \end{aligned}$ | $\begin{array}{ll}\text { MIL. } & \text { S } \\ & \text { L }\end{array}$ | 二 | 二 | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 260 \\ & 220 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 240 \\ & 200 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{array}{\|l\|} \hline 230 \\ 180 \end{array}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 230 \\ & 180 \end{aligned}$ | mA |
|  |  |  | COM'L. S | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 240 \\ & 200 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{array}{\|l\|} \hline 200 \\ 160 \end{array}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \end{aligned}$ |  |
| IsB1 | Standby Current (Both Ports-TTL Level Inputs) | $\begin{aligned} & \overline{C E L} \text { and } \overline{C E} R \geq V_{I H} \\ & f=\text { fmax }^{(3)} \end{aligned}$ | $\begin{array}{ll}\text { MIL. } & \text { S } \\ & \text { L }\end{array}$ | - | - | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 75 \\ & 55 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & \hline 70 \\ & 50 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 50 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & \hline 70 \\ & 50 \end{aligned}$ | mA |
|  |  |  | COM'L. S | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 80 \\ & 50 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 75 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ |  |
| IsB2 | Standby Current (One Port-TTL Level Inputs) | $\overline{C E L}$ or $\overline{C E R} \geq \mathrm{VIH}$ Active Port Outputs Open, $f=f$ max ${ }^{(3)}$ | MIL. $\quad$ S | - | - | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 170 \\ & 140 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & \hline 160 \\ & 130 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{array}{\|l\|} \hline 150 \\ 120 \end{array}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 150 \\ & 120 \end{aligned}$ | mA |
|  |  |  | COM'L. ${ }^{\text {S }}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 150 \\ & 120 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 140 \\ & 110 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{array}{\|l\|} \hline 130 \\ 100 \\ \hline \end{array}$ | $\begin{aligned} & \hline 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ |  |
| Is83 | Full Standby Current (Both Ports-All CMOS Level Inputs) | Both Ports $\overline{C E L}$ and $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{Vin} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $V \mathbb{N} \leq 0.2 V, f=0^{(3)}$ | $\begin{array}{ll}\text { MIL. } & \text { S } \\ & \text { L }\end{array}$ | - | - | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  |  |  | COM'L. S | $\begin{aligned} & \hline 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{array}{r} 15 \\ 4.0 \end{array}$ |  |
| ISB4 | Full Standby Current (One Port-All CMOS Level Inputs) | One Port CEL or $\overline{C E}_{\mathrm{A}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or Vin $\leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=$ fmax ${ }^{(3)}$ | $\begin{array}{ll}\text { MIL. } & \text { S } \\ & \text { L }\end{array}$ | - | - | $\begin{aligned} & 50 \\ & 45 \end{aligned}$ | $\begin{aligned} & \hline 140 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 50 \\ & 45 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 50 \\ & 45 \end{aligned}$ | $\begin{array}{\|c} \hline 120 \\ 90 \end{array}$ | $\begin{aligned} & \hline 50 \\ & 45 \\ & \hline \end{aligned}$ | $\begin{gathered} 120 \\ 90 \\ \hline \end{gathered}$ | mA |
|  |  |  | $\begin{array}{\|ll\|} \hline \text { COM'L. } & \mathrm{S} \\ & \mathrm{~L} \end{array}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 130 \\ & 110 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 120 \\ & 100 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{gathered} 110 \\ 90 \end{gathered}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{array}{\|c\|} \hline 110 \\ 90 \end{array}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{gathered} 110 \\ 90 \end{gathered}$ |  |

NOTES:

1. " $x$ " in part number indicates power rating (SA or LA).
2. $\mathrm{VCC}=5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$.
3. $f$ 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. Applies only to inputs at CMOS level standby lsB3.
4. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range.

## DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES ${ }^{(1)}$

(LA Version Only) VLc $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{Vcc}-0.2 \mathrm{~V}$

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | VCC for Data Retention | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & C E \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \mathrm{VLC} \end{aligned}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | 100 | 1500 |  |
| $\operatorname{tcDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $t R^{(3)}$ | Operation Recovery Time |  |  | tRC ${ }^{(2)}$ | - | - | ns |

## NOTES:

1. $V C c=2 V, T A=+25^{\circ} \mathrm{C}$.
2. tRC = Read Cycle Time.
3. This parameter is guaranteed but not tested.

## LOW Vcc DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


2720 drw 06
Figure 2. Output Load (for tLz, thz, twz, tow)
*Including scope and jig

## aC ELECTRICAL CHARACTERISTICS OVER THE

## OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(4)}$

| Symbol | Parameter | 7134X25 ${ }^{(3)}$ |  | 7134X35 |  | 7134X45 |  | 7134X55 |  | 7134X70 |  | Unlt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| taOE | Output Enable Access Time | - | 15 | - | 20 | - | 25 | - | 30 | - | 40 | ns |
| toh | Output Hold from Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLz | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | 0 | - | 0 | - | 5 | - | 5 | - | 5 | - | ns |
| tHz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | - | 20 | - | 25 | - | 30 | - | 40 | ns |
| tPu | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2 ).
2. This parameter is guaranteed but not tested.
3. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
4. " $X$ " in part number indicates power rating (SA or LA).

## TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$



2720 dww 07
TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


2720 drw 08

## NOTES:

1. $\mathrm{R} / \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{O E}=$ VIL.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(7)}$

| Symbol | Parameter | $7134 \times 25^{(5)}$ |  | 7134X35 |  | 7134X45 |  | 7134X55 |  | 7134X70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| twC | Write Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tew | Chip Enable to End of Write | 20 | - | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 20 | - | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| twR | Write RecoveryTime | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 15 | - | 20 | - | 20 | - | 25 | - | 30 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | - | 15 | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tDH | Data Hold Time ${ }^{(3)}$ | 0 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tWZ | Write Enabled to Output in High $\mathrm{Z}^{(1,2)}$ | - | 15 | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,3)}$ | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| twDD | Write Pulse to Data Delay ${ }^{(4)}$ | - | 50 | - | 60 | - | 70 | - | 80 | - | 90 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(4)}$ | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. The specification for toH must be met by the device supplying write data to the RAM under all operating conditions. Although ton and tow values will vary over voltage and temperature, the actual tor will always be smaller than the actual tow.
4. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read with Por-to-Port Delay"
5. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
6. Specified for $\overline{\mathrm{OE}}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).
7. " $X$ " in part number indicates power rating (SA or LA).

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1)}$


## NOTE:

1. Write cycle parameters should be adhered to, in order to ensure proper writing.

TIMING WAVEFORM OF WRITE CYCLE NO. 1, R/ $\bar{W}$ CONTROLLED $^{\operatorname{TIMING}}{ }^{(1,2,3,4,6,7)}$


2720 drw 10

TIMING WAVEFORM OF WRITE CYCLE NO. $1, \overline{\operatorname{CE}}$ CONTROLLED TIMING ${ }^{(1,2,3,5)}$


NOTE:S

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEw or twP) of a low $\overline{C E}$ and a $R / \bar{W}$.
3. twr is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ going high to the end of write cycle.
4. During this period, the $I / O$ pins are in the output state, and input signals must not be applied.
5. If the $\overline{\mathrm{CE}}$ low transition occurs simultaneously with or after the RW low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a RW controlled write cycle, the write pulse width must be the larger of WP or (WZ + tDW) to allow the I/O drivers to turn off data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## FUNCTIONAL DESCRIPTION

The IDT7134 provides two ports with separate control, address and $I / O$ pins that permit independent access for reads or writes to any location in memory. These devices have an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into standby mode when not selected ( $\overline{\mathrm{CE}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/ WRITE conditions are illustrated in the table below.

TABLE I-READ/WRITE CONTROL

| Left or Right Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ | $\overline{\text { CE }}$ | $\overline{\text { OE }}$ | D0.7 |  |
| X | H | x | Z | Port Disabled and in Power Down Mode, IsB2 or ISB4 |
| x | H | x | z | $\overline{C E}_{R}=\overline{\mathrm{CEL}}=\mathrm{H}$, Power Down Mode, IsB1 or IsB3 |
| L | L | x | DATAIN | Data on port written into memory |
| H | L | L | DATAOUT | Data in memory output on port |
| X | x | H | z | High impedance outputs |

NOTE:

1. Aol - A11L $\neq$ Aor - Alir
$\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=$ LOW, $\mathrm{X}=$ Don't Care, $\mathrm{Z}=$ High Impedance

## ORDERING INFORMATION



CMOS DUAL-PORT RAM
32K (4K x 8-BIT) WITH SEMAPHORE

## FEATURES

- High-speed access
- Military: 45/55/70ns (max.)
- Commercial: 35/45/55/70ns (max.)
- Low-power operation
- IDT71342S

Active: 500 mW (typ.)
Standby: 5mW (typ.)

- IDT71342L

Active: 500 mW (typ.)
Standby: 1mW (typ.)

- Fully asynchronous operation from either port
- Full on-chip hardware support of semaphore signalling between ports
- Battery backup operation-2V data retention
- TTL-compatible; single $+5 \mathrm{~V}( \pm 10 \%$ ) power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION

The IDT71342 is an extremely high-speed $4 \mathrm{~K} \times 8$ dual-port static RAM with full on-chip hardware support of semaphore signalling between the two ports.
The IDT71342 provides two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads and writes to any location in memory. To assist in arbitrating between ports, a fully independent semaphore logic block is provided. This block contains unassigned flags which can be accessed by either side; however, only one side can control the flag at any time. An automatic power down feature, controlled by $\overline{C E}$ and $\overline{\text { SEM, }}$, permits the on-chip circuitry of each port to enter a very low standby power mode (both $\overline{\mathrm{CE}}$ and $\overline{\mathrm{SEM}}$ high).
Fabricated using IDT's CEMOS ${ }^{\text {T }}$ high-performance technology, this device typically operates on only 500 mW of power at maximum access times as fast as 35 ns . Low-power (L) versions offer battery backup data retention capability, with each port typically consuming $200 \mu \mathrm{~W}$ from a 2 V battery. The device is packaged in either a hermetic 52-pin leadless chip carrier or a 52 -pin PLCC.
The IDT 71342 military devices are manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION



LCC/PLCC
TOP VIEW

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation | 1.5 | 1.5 | W |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2695 tb 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| COUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2695 tb 02

1. This parameter is determined by device characterization but is not production tested.

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

2695 か 03

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL $^{\text {In }}$ | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2695 tbl 04

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY

VOLTAGE RANGE (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | IDT71342S |  | IDT71342L |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|l니 | Input Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|iLO| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}$, VOUT $=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $1 \mathrm{LL}=6 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
|  |  | $\mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.5 | - | 0.5 |  |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

DC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version |  | IDT71342x35 ${ }^{(4)}$ |  | IDT71342x45 |  | IDT71342x55 |  | IDT71342x70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Typ. ${ }^{\text {(2) }}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. |  |
| ICC | Dynamic Operating Current | $\overline{\mathrm{CE}} \leq \mathrm{VII}^{\prime}$ <br> Outputs Open | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | - | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 240 \\ & 200 \\ & \hline \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 230 \\ & 180 \\ & \hline \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 230 \\ & 180 \\ & \hline \end{aligned}$ | mA |
|  | (Both Ports Active) | $\begin{aligned} & \overline{S E M} \geq V_{I H} \\ & f=\text { fMAX }^{(3)} \end{aligned}$ | COM'L. | S | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \\ & \hline \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | $\begin{aligned} & 200 \\ & 160 \end{aligned}$ |  |
| ICC1 | Dynamic Operation Current | $\begin{aligned} & \overline{\mathrm{CE}} \geq \mathrm{V}_{\mathrm{IH}} \\ & \overline{\mathrm{SEM}} \leq \mathrm{V}_{\mathrm{V}} \end{aligned}$ | MIL. | $\begin{array}{\|l} \hline \mathrm{S} \\ \mathrm{~L} \\ \hline \end{array}$ | - | - | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{aligned} & 130 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{aligned} & 130 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{aligned} & 130 \\ & 110 \\ & \hline \end{aligned}$ | mA |
|  | (Semaphores Both Sides) | Outputs Open $f=\operatorname{MAX}^{(3)}$ | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{aligned} & 145 \\ & 115 \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ |  |
| ISB1 | Standby Current (Both Ports — TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CE} L} \text { and } \overline{\mathrm{CE}} \mathrm{P} \geq \mathrm{VIH} \\ & \overline{S E M L}=\overline{\mathrm{SEM}} \mathrm{~V} \geq \mathrm{VIH} \\ & f=\mathrm{fmax}^{(3)} \end{aligned}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | - | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 70 \\ & 50 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 50 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 75 \\ & 45 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 70 \\ & 40 \end{aligned}$ |  |
| ISB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CE}} . \mathrm{or} \overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{VIH}_{\mathrm{I}}$ Active Port Outputs <br> Open, $\mathfrak{f}=\mathrm{fmax}{ }^{(3)}$ <br> $\overline{\text { SEML }}=\overline{\text { SEM }} \mathrm{R} \geq \mathrm{VIH}_{\mathrm{H}}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \\ & \hline \end{aligned}$ | - | - | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{array}{r} 160 \\ 130 \\ \hline \end{array}$ | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{array}{r} 150 \\ 120 \\ \hline \end{array}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 120 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 140 \\ & 110 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \end{aligned}$ |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | $\begin{aligned} & \text { Both Ports } \overline{\mathrm{CE}} \mathrm{~L} \& \\ & \overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \\ & \mathrm{VIN} \leq 0.2 \mathrm{~V} \\ & \overline{\mathrm{SEM}}=\overline{\operatorname{SEM}} \mathrm{R} \geq \\ & \mathrm{Vcc}-0.2 \mathrm{~V}, \mathrm{f}=0^{(3)} \end{aligned}$ | MIL. | S L | - | - | 1.0 0.2 | 30 10 | 1.0 0.2 | 30 10 | 1.0 0.2 | 30 10 | mA |
|  |  |  | COM'L. | S | $1$ $0.2$ | 15 4.0 | 1.0 0.2 | 15 4.0 | 1.0 0.2 | 15 4.0 | 1.0 0.2 | $\begin{array}{r} 15 \\ 4.0 \\ \hline \end{array}$ |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs) | One Port $\overline{C E L}$ or <br> $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> Vin $\geq$ Vcc -0.2 V or <br> $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs <br> Open, $f=$ fmax $^{(3)}$ | MIL. | S | - | - | 50 45 | 130 100 | 50 45 | 120 90 | 50 45 | 120 90 | mA |
|  |  |  | COM'L. | S | 45 45 | 120 100 | 45 45 | 110 90 | 45 45 | 110 90 | 45 45 | $\begin{aligned} & 110 \\ & 90 \end{aligned}$ |  |

NOTES:

1. " $x$ " in part number indicates power rating ( S or L ).
2. $V C C=5 V, T_{A}=+25^{\circ} \mathrm{C}$.
3. fMAX $=1 /$ RRC $=$ All inputs cycling at $f=1 /$ RRC (except Output Enable). $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby ISB3.
4. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES ${ }^{(1)}$
(L Version Only) VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{Vcc}-0.2 \mathrm{~V}$

| Symbol | Parameter | Test Condlition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | - |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & \overline{\mathrm{CE}} \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \leq \mathrm{VLC} \end{aligned}$ | MIL. | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | 100 | 1500 |  |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $t R^{(3)}$ | Operation Recovery Time |  |  | $\mathrm{tRC}^{(2)}$ | - | - | ns |

NOTES:

1. $V C c=2 V, T A=+25^{\circ} \mathrm{C}$
2. tRC $=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## LOW Vcc DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |
| 2696 tol 08 |  |



Figure 1. Output Load
*Including scope and jig


Figure 2. Output Load (for tiz, thz, twz, tow)

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE| Symbol | Parameter | $\begin{aligned} & \hline \text { IDT71342S35(5) } \\ & \text { IDT71342L35(5) } \\ & \hline \end{aligned}$ |  | IDT71342S45 <br> 1DT71342L45 |  | IDT71342S55 IDT71342L55 |  | $\begin{aligned} & \hline \text { IDT71342S70 } \\ & \text { IDT71342L70 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |


| tRC | Read Cycle Time | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| tAA | Address Access Time | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| tACE | Chip Enable Access Time ${ }^{(3)}$ | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| taOE | Output Enable Access Time | - | 20 | - | 25 | - | 30 | - | 40 | ns |
| tOH | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,2)}$ | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tHZ | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tPU | Chip Enable to Power Up Time $^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | - | 50 | ns |
| tSOP | SEM Flag Update Pulse $\overline{\text { OE or SEM })}$ | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| twDD | Write Pulse to Data Delay ${ }^{(4)}$ | - | 80 | - | 80 | - | 80 | - | 90 | ns |
| tDDD | Write Data Valid to Read Data <br> Delay $^{(4)}$ | - | 55 | - | 55 | - | 55 | - | 70 | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2 ).
2. This parameter is guaranteed but not tested.
3. To access RAM, $\overline{C E}=V_{I L}, \overline{S E M}=V_{I H}$. To access semaphore, $\overline{C E}=V_{I H}, \overline{S E M}=V_{I L}$.
4. Port to Port delay through RAM cells from writing port to a reading port.
5. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.

## TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$



2695 dww 05
TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER $\operatorname{SIDE}^{(1,3)}$


NOTES:
2695 drw 06

1. $R \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=$ VIL. This waveform cannot be used for semaphore reads.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. To access RAM, $\overline{C E}=V_{I H}, \overline{S E M}=V_{i H}$. To access semaphore, $\overline{C E}=V_{I H}, \overline{S E M}=V_{I L}$.

## TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2)}$



NOTES:
2695 drw 07

1. Write cycle parameters should be adhered to, to ensure proper writing.
2. Device is continously enabled for both ports.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE

| Symbol | Parameter | $\begin{aligned} & \text { IDT71342S35 } \\ & \text { IDT71342L35 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT71342S45 } \\ & \text { IDT71342L45 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT71342S55 } \\ & \text { IDT71342L55 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT71342S70 } \\ & \text { IDT71342L70 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tEW | Chip Enable to End of Write ${ }^{(3)}$ | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| taw | Address Valid to End of Write | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Puise Width | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 20 | - | 20 | - | 25 | - | 30 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| toh | Data Hold Time ${ }^{(4)}$ | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| twz | Write Enabled to Output in High Z ${ }^{(1,2)}$ | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tswR | SEM Flag Write to Read Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tSPS | SEM Flag Contention Window | 10 | - | 10 | - | 10 | - | 10 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. To access RAM, $\overline{C E}=V I L, \overline{S E M}=V I H$. To access semaphore, $\overline{C E}=V_{I H}, \overline{S E M}=V_{I L}$. This condition must be valid for the entire tEW time.
4. The specification for tDH must be met by the device supplying data to the RAM under all operating conditions. Although toH and tow values will vary over voltage and temperature, the actual tDH will always be smaller than the actual tow.
5. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.

## TIMING WAVEFORM OF WRITE CYCLE NO. $1, \mathrm{R} / \overline{\mathrm{W}}$ CONTROLLED $\operatorname{TIMING}{ }^{(1,2,3,7)}$



TIMING WAVEFORM OF WRITE CYCLE NO. $2, \overline{\mathrm{CE}}$ CONTROLLED TIMING ${ }^{(1,2,3,5)}$


NOTES:

1. RWW must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ or $\overline{S E M}$ and a low $R / \bar{W}$.
3. twR is measured from the earlier of $\overline{C E}$ or $R / \bar{W}$ (or $\overline{S E M}$ or $R \bar{W}$ ) going high to the end of write cycle.
4. During this period, the I/O pins are in the output state, and input signals must not be applied.
5. If the $\overline{C E}$ or $\overline{S E M}$ low transition occurs simultaneously with or after the $\mathrm{R} \overline{\mathrm{W}}$ low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twP or (tWZ + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tDw. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp
8. To access $R A M, \overline{C E}=V I L, \overline{S E M}=V I H$. To access semaphore, $\overline{C E}=V_{I H}, \overline{S E M}=V_{I L}$. Either condition must be valid for the entire tEW time.
timing waveform of semaphore read after write timing, EITHER SIDE ${ }^{(1)}$


NOTE:

1. $\overline{C E}=V_{I H}$ for the duration of the above timing (both write and read cycle).

## TIMING WAVEFORM OF SEMAPHORE CONTENTION ${ }^{(1,3,4)}$



NOTE:

1. $\operatorname{DOR}=\mathrm{DOL}_{=}=\mathrm{VII}^{\prime}, \overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{V}_{\mathrm{IH}}$, Semaphore Flag is released from both sides (reads as ones from both sides) at cycle start.
2. Either side " $A$ " = left and side " $B$ " = right, or side " $A$ " = right and side " $B$ " = left.
3. This parameter is measured from the point where $\mathrm{R}_{\bar{W}} A$ or $\overline{S E M}_{A}$ goes high until $\mathrm{R} \overline{W_{B}}$ or $\overline{S E M} B$ goes high.
4. If tSPS is violated, the semaphore will fall positively to one side or the other,but there is no guarantee which side will obtain the flag.

## FUNCTIONAL DESCRIPTION

The IDT71342 is an extremely fast dual-port $4 \mathrm{~K} \times 8$ CMOS static RAM with an additional 8 address locations dedicated to binary semaphore flags. These flags allow either processor on the left or right side of the dual-port RAM to claim a privilege over the other processor for functions defined by the system designer's software. As an example, the semaphore can be used by one processor to inhibit the other from accessing a portion of the dual-port RAM or any other shared resource.

The dual-port RAM features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Both ports are identical in function to standard CMOS static RAMs and can be read from or written to at the same time, with the only possible conflict arising from the simultaneous writing of, or a simultaneous READ/ WRITE of, a non-semaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the non-semaphore portion of the dual-port RAM. These devices have an automatic power-down feature controlled by $\overline{C E}$, the dual-port RAM enable, and $\overline{S E M}$, the semaphore enable. The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{SEM}}$ pins control on-chip power down circuitry that permits the repective port to go into standby mode when not selected. This is the condition which is shown in Table 1 where $\overline{\mathrm{CE}}$ and $\overline{\mathrm{SEM}}$ are both high.

Systems which can best use the IDT71342 contain multiple processors or controllers and are typically very high-speed systems which are software controlled or software intensive. These systems can benefit from a performance increase offered by the IDT71342's hardware semaphores, which provide a lockout mechanism without requiring complex programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be allocated in varying configurations. The IDT71342 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture.

An advantage of using semaphores rather than the more common methods of hardware arbitration is that wait states are never incurred in either processor. This can prove to be a major advantage in very high-speed systems.

## HOW THE SEMAPHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independent of the dual-port RAM. These latches can be used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment method called "Token Passing Aliocation." In this method, the state of a semaphore latch is used as a token indicating that a shared resource is in use. If the left processor wants to use this resource, it requests the token by setting the latch. This processor then verifies its success in setting the latch by reading it. If it was successful, it proceeds to assume control
over the shared resource. If it was not successful in setting the latch, it determines that the right side processor had set the latch first, has the token and is using the shared resource. The left processor can then either repeatedly request that semaphore's status or remove its request for that semaphore to perform another task and occasionally attempt again to gain control of the token via the set and test sequence. Once the right side has relinquished the token, the left side should succeed in gaining control.
The semaphore flags are active low. A token is requested by writing a zero into a semaphore latch and is released when the same side writes a one to that latch.

The eight semaphore flags reside within the IDT71342 in a separate memory space from the dual-port RAM. This address space is accessed by placing a low input on the SEM pin (which acts as a chip select for the semaphore flags) and using the other control pins (Address, $\overline{\mathrm{OE}}$, and $\mathrm{R} / \overline{\mathrm{W}}$ ) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through address pins A0-A2. When accessing the semaphores, none of the other address pins has any effect.
When writing to a semaphore, only data pin Do is used. If a low level is written into an unused semaphore location, that flag will be set to a zero on that side and a one on the other (see Table II). That semaphore can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be set to a one for both sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. (A thorough discussion on the use of this feature follows shortly.) A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.
When a semaphore flag is read, its value is spread into all data bits so that a flag that is a one reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE}}$ ) signals go active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal ( $\overline{\mathrm{SEM}}$ or $\overline{\mathrm{OE}}$ ) to go inactive or the output will never change.
A sequence of WRITE/READ must be used by the semaphore in order to guarantee that no system level contention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as a one, a fact which the processor will verify by the subsequent read (see Table II). As an example, assume a
processor writes a zero the the left prot at a free semaphore location. On a subsequent read, the processor will verify that it has written successfully to that location and will assume control over the resource in question. Meanwhile, if a processor on the right side attempts to write a zero to the same semaphore flag it will fail, as will be verified by the fact that a one will be read from that semaphore on the right side during a subsequent read. Had a seqence of READ/WRITE been used instead, system contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed by either repeated reads or by writing a one into the same location. The reason for this is easily understood by looking at the simple logic diagram of the semaphore flag
in Figure 3. Two semaphore request latches feed into a semaphore flag. Whichever latch is first to present a zero to the semaphore flag will force its side of the semaphore flag low and the other side high. This condition will continue until a one is written to the same semaphore request latch. Should the other side's semaphore request latch have been written to a zero in the meantime, the semaphore flag will flip over to the other side as soon as a one is written into the first side's request latch. The second side's flag will now stay low until its semaphore request latch is written to a one. Fromthis it is easy to understand that, if a semaphore is requested and the processor which requested it no longer needs the resource, the entire system can hang up until a one is written into that semaphore request latch.

TABLEI-NON-CONTENTION READ/WRITE CONTROL

| Left or Right Port ${ }^{(1)}$ |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :--- |
| R $\bar{W}$ | $\overline{\text { CE }}$ | $\overline{\text { SEM }}$ | $\overline{\mathrm{OE}}$ | D0.7 |  |
| X | H | H | X | Z | Port Disabled and in Power Down Mode |
| H | H | L | L | DATAOUT | Data in Semaphore Flag Output on Port |
| X | X | X | H | Z | Output Disabled |
| - | H | L | X | DATAIN | Port Data Bit Do Written Into Semaphore Flag |
| H | L | H | L | DATAOUT | Data in memory output on port |
| L | L | H | X | DATAin | Data on port written into memory |
| X | L | L | X | - | Not Allowed |

## NOTES:

2695tbl 11

1. $A 0 L-A 10 L \neq A 0 R-A 10 R$

H = HIGH, L = LOW, X = Don't Care, Z = High Impedance
S Low-to-High transition.

## TABLE II - EXAMPLE SEMAPHORE PROCUREMENT SEQUENCE

| Function | Do - D7 Left | Do - D7 Right |  |
| :--- | :---: | :---: | :--- |
| 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 side 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 |

NOTE:
2695 형 12

1. This table denotes a sequence of events for only one of the eight semaphores on the IDT71342.

The critical case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is specially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side is earlier than the other in making the request, the first side to make the request will receive the token. If both requests arrive at the same time, the assignment will be arbitrarily made to one port or the other.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, if semaphores are misused or misinterpreted, a software error can easily happen. Code integrity is of the utmost importance when semaphores are used instead of slower, more restrictive hardware intensive schemes.

Initialization of the semaphores is not automatic and must be handled via the initialization program at power up. Since any semaphore request flag which contains a zero must be reset to a one, all semaphores on both sides should have a one written into them at initialization from both sides to assure that they will be free when needed.

## USING SEMAPHORES - Some examples

Perhaps the simplest application of semaphores is their application as resource markers for the IDT71342's dualport RAM. Say the $4 \mathrm{~K} \times 8$ RAM was to be divided into two $2 \mathrm{~K} \times 8$ blocks which were to be dedicated at any one time to servicing either the left or right port. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of memory.

To take a resource, in this example the lower 2 K of dualport RAM, the processor on the left port could write and then read a zero into Semaphore 0. If this task were successfully completed (a zero was read back rather than a one), the left processor would assume control of the lower 2 K . Meanwhile, the right processor would attempt to perform the same function. Since this processor was attempting to gain control of the resource after the left processor, it would read back a one in response to the zero it had attempted to write into Semaphore 0. At this point, the software could choose to try and gain control of the second 2 K section by writing, then reading a zero into Semaphore 1 . If it succeeded in gaining control, it would lock out the left side.

Once the left side was finished with its task, it would write a one to Semaphore 0 and may then try to gain access to Semaphore 1. If Semaphore 1 was still occupied by the right side, the left side could undo its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1. If the right processor performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 2 K blocks of dual-port RAM with each other.
The blocks do not have to by any particular size and can even be variable, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphores can even be assigned different meanings on different sides rather than being given a common meaning as was shown in the example above.
Semaphores are a useful form of arbitration in systems like disk interfaces where the CPU must be locked out of a section of memory during a transfer and the I/O device cannot tolerate any wait states. With the use of semaphores, once the two devices had determined which memory area was "off limits" to the CPU, both the CPU and the I/O devices could access their assigned portions of memory continuously without any wait states.
Semaphores are also useful in applications where no memory "WAIT" state is available on one or both sides. Once a semaphore handshake has been performed, both processors can access their assigned RAM segments at full speed.
Another application is in the area of complex data structures. In this case, block arbitration is very important. For this application one processor may be responsible for building and updating a data structure. The other processor then reads and interprets that data structure. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the two different processors. The building processor arbitrates for the block, locks it and then is able to go in and update the data structure. When the update is completed, the data structure block is released. This allows the interpreting processor to come back and read the complete data structure, thereby guaranteeing a consistent data structure.


2695 drw 12
Figure 3. IDT71342 Semaphore Logic

## ORDERING INFORMATION



CMOS DUAL-PORT RAM
32K (4K x 8-BIT)
WITH SEMAPHORE

## PRELIMINARY <br> IDT71342SA IDT71342LA

## FEATURES:

- High-speed access
- Military: 35/45/55/70ns (max.)
- Commercial: 25/35/45/55/70ns (max.)
- Low-power operation
- IDT71342SA

Active: 500 mW (typ.)
Standby: 5mW (typ.)

- IDT71342LA

Active: 500 mW (typ.)
Standby: 1 mW (typ.)

- Fully asynchronous operation from either port
- Full on-chip hardware support of semaphore signalling between ports
- Battery backup operation-2V data retention
- TTL-compatible; single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Available in popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT71342 is an extremely high-speed $4 \mathrm{~K} \times 8$ dual-port static RAM with full on-chip hardware support of semaphore signalling between the two ports.

The IDT71342 provides two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. To assist in arbitrating between ports, a fully independent semaphore logic block is provided. This block contains unassigned flags which can be accessed by either side; however, only one side can control the flag at any time. An automatic power down feature, controlled by $\overline{C E}$ and $\overline{S E M}$, permits the on-chip circuitry of each port to enter a very low standby power mode (both $\overline{\mathrm{CE}}$ and $\overline{\mathrm{SEM}}$ high).

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, this device typically operates on only 500 mW of power at maximum access times as fast as $25 n$ n. Low -power (LA) versions offer battery backup data retention capability, with each port typically consuming 1 mW from a 2 V battery. The device is packaged in either a hermetic 52 -pin leadless chip carrier or a 52-pin PLCC.

The IDT71342 military devices are manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION



ABṠOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | MII. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to Ground | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation | 1.5 | 1.5 | W |
| IOUT | DC Output Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than those listedunder ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 11 | pF |
| Cour | Output Capacitance | VouT $=0 \mathrm{~V}$ | 11 | pF |

NOTE:

1. This parameter is determined by device characterization but is not production tested.

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE (Vcc = $5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | IDT71342SA |  | IDT71342LA |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|lu| | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lion | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}$, Vout $=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{IOL}=6 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
|  |  | $\mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.5 | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{lOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Conditions | Version | $71342 \times 25^{(4)}$ |  | 71342×35 |  | 71342x45 |  | 71342×55 |  | 71342x70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{\text {(2) }}$ | Max. | Typ. ${ }^{(2)}$ | Max. | Typ. ${ }^{(2)}$ | Max. |  |
| Icc | Dynamic Operating Current | $\overline{\mathrm{CE}} \leq \mathrm{VIL}$ Outputs Open | MIL. S <br>   | - | - | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{array}{r} 260 \\ 220 \\ \hline \end{array}$ | $\begin{array}{r} 100 \\ 100 \\ \hline \end{array}$ | $\begin{array}{r} 240 \\ 200 \\ \hline \end{array}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 230 \\ 180 \\ \hline \end{array}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 230 \\ & 180 \\ & \hline \end{aligned}$ | mA |
|  | (Both Ports Active) | $\begin{aligned} & \overline{\text { SEM }}=\text { Don't Care } \\ & f=\text { fmax }^{(3)} \end{aligned}$ | COM'L. S | $\begin{array}{r} 100 \\ 100 \\ \hline \end{array}$ | $\begin{array}{r} 240 \\ 200 \\ \hline \end{array}$ | $\begin{array}{r} 100 \\ 100 \\ \hline \end{array}$ | $\begin{aligned} & 220 \\ & 180 \\ & \hline \end{aligned}$ | $\begin{array}{r} 100 \\ 100 \\ \hline \end{array}$ | $\begin{array}{r} 200 \\ 160 \\ \hline \end{array}$ | $\begin{array}{r} 100 \\ 100 \\ \hline \end{array}$ | $\begin{array}{\|r} 200 \\ 160 \\ \hline \end{array}$ | $\begin{array}{r} 100 \\ 100 \\ \hline \end{array}$ | $\begin{array}{r} 200 \\ 160 \\ \hline \end{array}$ |  |
| 1 cc 1 | Dynamic Operating Current | $\overline{C E} \geq V_{H}$ Outputs Open | MIL. $\begin{array}{r}\text { S } \\ \\ \hline\end{array}$ |  | - | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 130 \\ & \hline \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{aligned} & 130 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} 130 \\ 110 \\ \hline \end{array}$ | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{aligned} & 130 \\ & 110 \\ & \hline \end{aligned}$ | mA |
|  | (Semaphores Both Sides) | $\begin{aligned} & \overline{S E M} \leq V L \\ & f=\text { fMAX }^{(3)} \end{aligned}$ | COM'L. S | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{array}{r} 160 \\ 130 \\ \hline \end{array}$ | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{aligned} & 145 \\ & 115 \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \end{aligned}$ | $\begin{aligned} & 130 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 85 \\ & 85 \\ & \hline \end{aligned}$ | $\begin{array}{\|l} 130 \\ 100 \\ \hline \end{array}$ | 85 <br> 85 | 130 <br> 100 |  |
| Isal | Standby Current (Both Ports-TTL Level Inputs) | $\left\lvert\, \begin{aligned} & \overline{\mathrm{CE}} \text { and } \overline{\mathrm{CE}}_{\mathrm{F}} \geq \mathrm{V}_{I H} \\ & \overline{\mathrm{SEML}}=\overline{\mathrm{SEM}} \geq \mathrm{V}_{1 H} \\ & \mathrm{f}=\mathrm{FMAX}^{(3)} \end{aligned}\right.$ | $\begin{array}{ll} \text { MIL. } & \mathrm{S} \\ & \mathrm{~L} \\ \hline \end{array}$ | - | - | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{array}{r} 75 \\ 55 \\ \hline \end{array}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{array}{r} 70 \\ 50 \\ \hline \end{array}$ | $\begin{array}{r} 25 \\ -25 \\ \hline \end{array}$ | $\begin{array}{r} 70 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{array}{r} 70 \\ 50 \\ \hline \end{array}$ | mA |
|  |  |  | COM'L. S | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{aligned} & 80 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 45 \end{aligned}$ | $\begin{array}{r} 25 \\ 25 \\ \hline \end{array}$ | $\begin{array}{r} 70 \\ 40 \\ \hline \end{array}$ | $\begin{array}{r} 25 \\ 25 \end{array}$ | $\begin{array}{r} 70 \\ 40 \\ \hline \end{array}$ | 25 25 | 70 40 |  |
| IsB2 | Standby Current (One Port-TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}_{\text {or }} \overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{V}_{\mathrm{IH}}$ Active Port Outputs <br> Open, $f=f$ max ${ }^{(3)}$ $\overline{S E M}=\overline{S E M} \geq V_{I H}$ | MIL. <br>  | - | - | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & 170 \\ & 140 \\ & \hline \end{aligned}$ | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & 160 \\ & 130 \\ & \hline \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{\|l} 150 \\ 120 \\ \hline \end{array}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{r} 150 \\ 120 \\ \hline \end{array}$ | mA |
|  |  |  | $\begin{array}{r} \text { COM'L. S } \\ \mathrm{L} \\ \hline \end{array}$ | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{array}{r} 150 \\ 120 \\ \hline \end{array}$ | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & 140 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & 130 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{\|l} 130 \\ 100 \\ \hline \end{array}$ | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{array}{r} 130 \\ 100 \\ \hline \end{array}$ |  |
| ISB3 | Full Standby Current (Both Ports-All CMOS Level Inputs) | Both Ports $\overline{\mathrm{CE}}$. and $\overline{C E}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\operatorname{Vin} \geq V c c-0.2 V$ or $\operatorname{Vin} \leq 0.2 \mathrm{~V}$ SEML $=\overline{\text { SEMR }} \geq$ $\mathrm{Vcc}-0.2 \mathrm{~V}, \mathrm{f}=0^{(3)}$ | MIL.S <br>  | - | - | $\begin{array}{r} 1.0 \\ 0.2 \\ \hline \end{array}$ | $\begin{array}{r} 30 \\ 10 \\ \hline \end{array}$ | $\begin{aligned} & 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{array}{r} 1.0 \\ 0.2 \\ \hline \end{array}$ | 30 10 | mA |
|  |  |  | COM'L. S | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{array}{r} 15 \\ 4.0 \end{array}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 1.0 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 15 \\ & 4.0 \end{aligned}$ |  |
| ISE4 | Full Standby Current (One Port-All CMOS Level Inputs) | One Port CEL or $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{Vin} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or <br> $\operatorname{Vin} \leq 0.2 \mathrm{~V}$ <br> $\overline{\operatorname{SEM}} \mathrm{L}=\overline{\mathrm{SEM}} \mathrm{Z} \geq$ <br> Vcc - 0.2 V <br> Active Port Outputs <br> Open, $f=\mathrm{f}$ max ${ }^{(3)}$ | MIL <br>  | - | - | $\begin{array}{r} 50 \\ 45 \\ \hline \end{array}$ | $\begin{aligned} & 140 \\ & 110 \\ & \hline \end{aligned}$ | $\begin{array}{r} 50 \\ 45 \\ \hline \end{array}$ | $\begin{array}{r} 130 \\ 100 \\ \hline \end{array}$ | $\begin{array}{r} 50 \\ 45 \\ \hline \end{array}$ | $\begin{array}{\|c} 120 \\ 90 \\ \hline \end{array}$ | $\begin{array}{r} 50 \\ 45 \\ \hline \end{array}$ | $\begin{aligned} & 120 \\ & 90 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L. S | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 130 \\ & 110 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 120 \\ & 100 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 110 \\ & 90 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 110 \\ & 90 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 110 \\ & 90 \end{aligned}$ |  |

NOTES:

1. " $x$ " in part number indicates power rating (SA or LA).
2. $\mathrm{VcC}=5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$.
3. fMAX $=1 /$ RRC $=$ All inputs cycling at $f=1 /$ trc (except Output Enable). $f=0$ means no address or control lines change. Applies only to inputs at CMOS level standby lsB3.
4. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range.

## data retention Characteristics over all temperature ranges ${ }^{(1)}$

(LA Version Only) VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{Vcc}-0.2 \mathrm{~V}$

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | VCC for Data Retention | - |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current | $\mathrm{VCC}=2 \mathrm{~V}$ | MIL. | - | 100 | 4000 | $\mu \mathrm{A}$ |
|  |  | $\overline{\mathrm{CE}} \geq \mathrm{VHC}$ | COM'L. | - | 100 | 1500 |  |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time | VIN $\geq$ VHC or $\leq$ VLC |  | 0 | - | - | ns |
| $t R^{(3)}$ | Operation Recovery Time |  |  | tRC ${ }^{(2)}$ | - | - | ns |

## NOTES:

1. $V C C=2 V, T A=+25^{\circ} \mathrm{C}$.
2. $\mathrm{tRC}=$ Read Cycle Time.
3. This parameter is guaranteed but not tested.

## LOW Vcc DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


2721 drw 04
Figure 2. Output Load (for tlex, thz, twz, tow)
*Including scope and jig

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(6)}$

| Symbol | Parameter | $71342 \times 25^{(5)}$ |  | 71342x35 |  | 71342×45 |  | 71342x55 |  | 71342x70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 25 | - | 35 | - | 45 | - | 55 | -- | 70 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 25 | - | 35 | - | 45 | - | 55 | - | 70 | ns |
| taoe | Output Enable Access Time | - | 15 | - | 20 | - | 25 | - | 30 | - | 40 | ns |
| toh | Output Hold from Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,2)}$ | 0 | - | 0 | - | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | - | 20 | - | 25 | - | 30 | - | 40 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |
| tsop | SEM Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\mathrm{SEM}}$ ) | 10 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tWDD | Write Pulse to Data Delay ${ }^{(4)}$ | - | 80 | - | 80 | - | 70 | - | 80 | - | 90 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(4)}$ | - | 55 | - | 55 | - | 55 | - | 65 | - | 80 | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. To access $R A M, \overline{C E}=V_{I L}, \overline{S E M}=V_{I H}$. To access semaphore, $\overline{C E}=V_{I H}, \overline{S E M}=V_{I L}$.
4. Port to Port delay through RAM cells from writing port to a reading port.
5. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
6. " $x$ " in part number indicates power rating (SA or LA).

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER $\operatorname{SIDE}^{(1,3)}$


## NOTES:

2721 dmw 06

1. $\mathrm{R} \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$. This waveform cannot be used for semaphore reads.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. To access RAM, $\overline{C E}=V_{\text {ILL }}, \overline{S E M}=V_{I H}$. To access semaphore, $\overline{C E}=V_{I H}, \overline{S E M}=V_{I L}$.

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2)}$


NOTES:

1. Write cycle parameters should be adhered to, in order to ensure proper writing.
2. Device is continuously enabled for both ports.

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(6)}$| Symbol | Parameter | 7134X25 ${ }^{(5)}$ |  | 7134X35 |  | 7134X45 |  | 7134X55 |  | 7134X70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |  | . |
| twc | Write Cycle Time | 25 | - | 35 | - | 45 | - | 55 | - | 70 | - | ns |
| tew | Chip Enable to End of Write ${ }^{(3)}$ | 20 | - | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 20 | - | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| twr | Write RecoveryTime | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data Valid to End of Write | 15 | - | 20 | - | 20 | - | 25 | - | 30 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | - | 15 | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tDH | Data Hold Time ${ }^{(4)}$ | 0 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| twz | Write Enabled to Output in High $\mathbf{Z}^{(1,2)}$ | - | 15 | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tswn | SEM Flag Write to Read Time | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tSPS | SEM Flag Contention Window | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. To access RAM, $\overline{C E}=V_{I L}, \overline{S E M}=V I H$. To access semaphore, $\overline{C E}=V I H, \overline{S E M}=$ VIL. This condition must be valid for the entire tEw time.
4. The specification for toH must be met by the device supplying write data to the RAM under all operating conditions. Although tDH and tow values will vary over voltage and temperature, the actual toH will always be smaller than the actual tow.
5. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
6. " $X$ " in part number indicates power rating (SA or LA).

TIMING WAVEFORM OF WRITE CYCLE NO. 1, R/ $\bar{W}$ CONTROLLED TIMING ${ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 1, $\overline{\operatorname{CE}}$ CONTROLLED TIMING ${ }^{(1,2,3,5)}$


NOTES:

1. $R / \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ or $\overline{S E M}$ and a low $R / \bar{W}$.
3. TWR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ (or $\overline{S E M}$ or $R \bar{W}$ ) going high to the end of write cycle.
4. During this period, the l/O pins are in the output state, and input signals must not be applied.
5. If the $\overline{C E}$ or $\overline{S E M}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twP or (twZ + tow) to allow the $I / O$ drivers to turn off data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twP.
8. To access $R A M, \overline{C E}=V_{I L}, \overline{S E M}=V_{I H}$. To access semaphore, $\overline{C E}=V_{I H}, \overline{S E M}=V_{I L}$. Either condition must be valid for the entire tew time.

TIMING WAVEFORM OF SEMAPHORE READ AFTER WRITE TIMING, EITHER SIDE ${ }^{(1)}$


NOTE:

1. $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{I}}$ for the duration of the above timing (both write and read cycle).

TIMING WAVEFORM OF SEMAPHORE CONTENTION ${ }^{(1,3,4)}$


## NOTES:

1. $\mathrm{DOR}^{2}=\mathrm{DOL}=\mathrm{VIL}_{\mathrm{IL}}, \overline{\mathrm{CE}}_{\mathrm{R}}=\overline{\mathrm{CEL}}=\mathrm{V}_{\mathrm{IH}}$, Semaphore Flag is released from both sides (reads as ones from both sides) at cycle start.
2. Either side " A " = left and side " B " = right, or side " A " = right and side " B " = left.
3. This parameter is measured from the point where R $\bar{W}_{A}$ or $\overline{S E M A}_{A}$ goes high until R $\bar{W} B$ or $\overline{S E M}$ goes high.
4. If tsps is violated, the semaphore will fall positively to one side or the other, but there is no guarantee which side will obtain the flag.

## FUNCTIONAL DESCRIPTION

The IDT71342 is an exiremely fast dual-port $4 \mathrm{~K} \times 8$ CMOS static RAM with an additional 8 address locations dedicated to binary semaphore flags. These flags allow either processor on the left or right side of the duai-port RAM to claim a privilege over the other processor for functions defined by the system designer's software. As an example, the semaphore can be used by one processor to inhibit the other from accessing a portion of the dual-port RAM or any other shared resource.

The dual-port RAM features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Both ports are identical infunctionto standard CMOS static RAMs and can be read from or written to at the same time, with the only possible conflict arising from the simultaneous writing of, or a simultaneous READ/WRITE of, anon-semaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the non-semaphore portion of the dual-port RAM. These devices have an automatic power-down feature controlled by $\overline{C E}$, the dual-port RAM enable, and $\overline{S E M}$, the semaphore enable. The $\overline{C E}$ and $\overline{S E M}$ pins control on-chip power down circuitry that permits the respective port to go into standby mode when not selected. This is the condition which is shown in Table 1 where $\overline{\mathrm{CE}}$ and $\overline{S E M}$ are both high.

Systems which can best use the IDT71342 contain multiple processors or controllers and are typically very high-speed systems which are software controlled or software intensive. These systems can benefit from a performance increase offered by the IDT71342's hardware semaphores, which provide a lockout mechanism without requiring complex programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be aliocated in varying configurations. The IDT71342 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture.

An advantage of using semaphores rather than the more common methods of hardware arbitration is that wait states are never incurred in either processor. This can prove to be a major advantage in very high-speed systems.

## HOW THE SEMAPHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independent of the dual-port RAM. These latches can be used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment method called "Token Passing Allocation." In this method, the state of a semaphore latch is used as a token indicating that a shared resource is in use. If the left processorwants to use this resource, it requests the token by setting the latch. This processor then verifies its success in setting the latch by reading it. If it was successful, it proceeds to assume control over the shared resource. If it
was not successful in setting the latch, it determines that the right side processor had set the latch first, has the token and is using the shared resource. The left processor can then either repeatedly request that semaphore's status or remove its request for that semaphore to perform another task and occasionally attempt again to gain control of the token via the set and test sequence. Once the right side has relinquished the token, the left side should succeed in gaining control.

The semaphore flags are active low. A token is requested by writing a zero into a semaphore latch and is released when the same side writes a one to that latch.

The eight semaphore flags reside within the IDT71342 in a separate memory spacefrom the dual-port RAM. This address space is accessed by placing a low input on the SEM pin (which acts as a chip select for the semaphore flags) and using the other control pins (Address, $\overline{O E}$, and $\mathrm{R} / \bar{W}$ ) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through the address pins A0-A2. When accessing the semaphores, none of the other address pins has any effect.

When writing to a semaphore, only data pin Do is used. If a low level is written into an unused semaphore location, that flag will be setto a zero on that side and a one on the other (see Table il). That semaphore can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be set to a one for both sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. (A thorough discussion on the use of this feature follows shorly.) A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.

When a semaphore flag is read, its value is spread into all data bits so that a flag that is a one reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE}}$ ) signals go active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal (SEM or $\overline{\mathrm{OE}}$ ) to go inactive or the output will never change.

A sequence of WRITE/READ must be used by the semaphore in order to guarantee that no system level contention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as a one, a fact which the processor will verify by the subsequent read (see Table III. As an example, assume a processor writes a zero in the left port at a free semaphore location. On a subsequent read, the processor will verify that it has written successfully to that location and will assume
control overthe resource inquestion. Meanwhile, if a processor on the right side attempts to write a zero to the same semaphore flag it will fail, as will be verified by the fact that a one will be read from that semaphore on the right side during a subsequent read. Had a sequence of READ/WRITE been used instead, system contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed by either repeated reads or by writing a one into the same location. The reason for this is easily understood by looking at the simple logic diagram of the semaphore flag in Figure 3. Two semaphore request latches feed into a semaphore flag. Whichever latch is first to present a zero to the semaphore flag will force its side of the semaphore flag low and the other side high. This condition will continue until a one is written to the same semaphore request latch. Should the
other side's semaphore request latch have been written to a zero in the meantime, the semaphore flag will now stay low until its semaphore request latch is written to a one. From this it is easy to understand that, if a semaphore is requested and the processorwhich requested it no longer needs the resource, the entire can hang up untila one is written into that semaphore request latch.

The critical case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is specially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side is earlier than the other in making the request, the first side to make the request will receive the token. If both requests arrive at the same time, the assignment will be arbitrarily made to one port or the other.

## TABLE I - NON-CONTENTION READ/WRITE CONTROL

| Left or Right Port ${ }^{(1)}$ |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ | $\overline{\mathbf{C E}}$ | $\overline{\text { SEM }}$ | $\overline{\text { OE }}$ | D0-7 |  |
| X | H | H | X | Z | Port Disabled and in Power Down Mode |
| H | H | L | L | DATAOUT | Data in Semaphore Flag Output on Port |
| X | X | X | H | Z | Output Disabled |
| 5 | H | L | X | DATAIN | Port Data Bit Do Written Into Semaphore Flag |
| H | L | H | L | DATAout | Data in Memory Output on Port |
| L | L | H | X | DATAIN | Data on Port Written Into Memory |
| X | L | L | X | - | Not Allowed |

## NOTE:

1. $A O L=A 10 L \neq A O R-A_{10 R}$

H = HIGH, L = LOW, X = Don't Care, $Z=$ High Impedance
$\Gamma=$ Low-to-High transition.

## TABLE II - EXAMPLE SEMAPHORE PROCUREMENT SEQUENCE ${ }^{(1)}$

| Function | Do - D7 Left | Do - D7 Right |  |
| :--- | :---: | :---: | :--- |
| 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 side 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 |

## NOTE:

1. This table denotes a sequence of events for only one of the eight semaphores on the IDT71342.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, if semaphores are misused or misinterpreted, a software error can easily happen. Code integrity is of the utmost importance when semaphores are used instead of slower, more restrictive hardware intensive schemes.

Initialization of the semaphores is not automatic and must be handled via the initialization program at power up. Since any semaphore request flag which contains a zero must be reset to a one, all semaphores on both sides should have a one written into them at initialization from both sides to assure that they will be free when needed.

## USING SEMAPHORES-Some examples

Perhaps the simplest application of semaphores is their application as resource markers for the IDT71342's dual-port RAM. Say the $4 \mathrm{~K} \times 8$ RAM was to be divided into two $2 \mathrm{~K} \times 8$ blocks which were to be dedicated at any one time to servicing either the left or right port. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of the memory.

To take a resource, in this example the lower 2 K of dual-port RAM, the processor on the left port could write and then read a zero into Semaphore 0 . If this task were successfully completed (a zero was read back rather than a one), the left processor would assume control of the lower 2K. Meanwhile, the right processor would attempt to perform the same function. Since this processor was attempting to gain control of the resource after the left processor, it would read back a one in response to the zero it had attempted to write into Semaphore 0 . At this point, the software could choose to try and gain control of the second 2 K section by writing, then reading a zero into Semaphore 1. If it succeeded in gaining control, it would lock out the left side.

Once the left side was finished with its task, it would write a one to Semaphore 0 and may then try to gain access to

Semaphore 1. If Semaphore 1 was still occupied by the right side, the left side could undo its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1. If the right processor performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 2K blocks of dual-port RAM with each other.

The blocks do not have to by any particular size and can even be variable, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphorescan even be assigned different meanings on different sides rather than being given a common meaning as was shown in the example above.

Semaphores are a useful form of arbitration in systems like disk interfaces where the CPU must be locked out of a section of memory during a transfer and the $1 / O$ device cannot tolerate any wait states. With the use of semaphores, once the two devices had determined which memory area was "off limits" to the CPU, both the CPU and the I/O devices could access their assigned portions of memory continuously without any wait states.

Semaphores are also useful in applications where no memory "WAIT" state is available on one or both sides. Once a semaphore handshake has been performed, both processors can access their assigned RAM segments at full speed.

Another application is in the area of complex datastructures. In this case, block arbitration is very important. For this application one processor may be responsible for building and updating a data structure. The other processor then reads and interprets that data structure. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the two different processors. The building processor arbitrates for the block, locks it and then is able to go in and update the data structure. When the update is completed, the data structure block is released. This allows the interpreting processor to come back and read the complete data structure, thereby guaranteeing a consistent data structure.


2721 dw 12
Figure 3. IDT71342 Semaphore Logic

## ORDERING INFORMATION




## FEATURES:

- High-speed access
- Military: 20/25/35/45ns (max.)
- Commercial: 15/20/25/35ns (max.)
- Low-power operation
- IDT7014S

Active: 375 mW (typ.)
Standby: 5mW (typ.)

- IDT7134L

Active: 375 mW (typ.)
Standby: 1 mW (typ.)

- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL-compatible; single 5V ( $\pm 10 \%$ ) power supply
- Available in several popular hermetic and plastic packages
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7014 is an extremely high-speed $4 \mathrm{~K} \times 9$ dual-port static RAM designed to be used in systems where on-chip hardware port arbitration is not needed. This part lends itself to those systems which cannot tolerate wait states or are designed to be able to externally arbitrate or withstand contention when both sides simultaneously access the same dual-port RAM location.
The IDT7014 provides two independent ports with separate control, address and $I / O$ pins that permit independent, asynchronous access for reads or writes to any location in memory. It is the user's responsibility to ensure data integrity when simultaneously accessing the same memory location fromboth ports. An automatic power down feature, controlled by $\overline{\mathrm{CE}}$, permits the on-chip circuitry of each port to enter a very low standby power mode.
The IDT 7014 utilities a 9 -bit wide data path to allow for control and parity bits at the user's option. This feature is especiall useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking.
Fabricated using IDT's BiCEMOS ${ }^{\text {M }}$ high-performance technology, these dual-ports typically operate on only 375 mW of power at maximum access times as fast as 15 ns . Lowpower (L) versions offer battery backup data retention capability, with each port typically consuming $300 \mu \mathrm{~W}$ from a 2 V battery.
The IDT7014 is packaged on a 52 -pin LCC or 52 -pin PLCC. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM


more than one device

- $M / \bar{S}=H$ for $\overline{B U S Y}$ output flag on Master

$$
M / \bar{S}=L \text { for } \overline{B U S Y} \text { input on Slave }
$$

- Interrupt Flag
- On-chip port arbitration logic
- Full on-chip hardware support of semaphore signaling between ports
- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL compatible, single 5 V ( $\pm 10 \%$ ) power supply
- Available in 84-pin PGA, quad flatpack and PLCC


## DESCRIPTION:

The IDT7024 is a high-speed $4 \mathrm{~K} \times 16$ dual-port static RAM. The IDT7024 is designed to be used as a stand-alone 64 K -bit dual-port RAM or as a combination MASTER/SLAVE dualport RAM for 32-bit-or-more word systems. Using the IDT

FUNCTIONAL BLOCK DIAGRAM


MASTER/SLAVE dual-port RAM approach in 32-bit or wider memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

This device provides two independent ports with separate control, address and $1 / O$ pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power down feature controlled by $\overline{\mathrm{CE}}$ permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only - mW or power at maximum access times as fast as 25 ns. Low-power (L) versions offer battery backup data retention capability with each port typically consuming -mW from a 2V battery.

The IDT7024 is packaged in plastic as well as ceramic 84pin PGA and 84 -pin quad flatpack and PLCC. The military devices are processed $100 \%$ in compliance to the test methods of MIL-STD-883, Method 5004.

## PIN CONFIGURATIONS



## NOTES:

1. All Vcc pins must be connected to power supply.
2. All GND pins must be connected to ground supply.

## PIN CONFIGURATIONS (Continued)

| 63 $\mathrm{I} / \mathrm{O}_{7 \mathrm{~L}}$ | $\begin{aligned} & 61 \\ & \mathrm{I} / \mathrm{O}_{5 \mathrm{~L}} \end{aligned}$ | $\left.\right\|^{60}$ | $58$ | $\begin{aligned} & 55 \\ & \mathrm{I} / \mathrm{O}_{\mathrm{oL}} \end{aligned}$ | ${ }^{54} \overline{O_{L}}$ | $\frac{51}{\overline{S E M}_{\mathrm{L}}}$ | ${ }^{48} \overline{\mathrm{LB}} \mathrm{~L}$ | 46 <br> $\mathrm{A}_{11 \mathrm{~L}}$ | 45 <br> A 10 L | $\int_{\text {A7L }}^{42}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 66 \\ & \mathrm{I} / \mathrm{O}_{10 \mathrm{~L}} \end{aligned}$ | $\begin{aligned} & 64 \\ & 1 / \mathrm{O}_{8 \mathrm{~L}} \end{aligned}$ | $\begin{aligned} & \hline 62 \\ & \mathrm{~V} / \mathrm{O}_{6 \mathrm{~L}} \end{aligned}$ | $\begin{aligned} & 59 \\ & 1 / O_{3 L} \end{aligned}$ | $\begin{aligned} & 56 \\ & 1 / O_{11} \end{aligned}$ | $\overline{4 B}_{L}$ | $5 \overline{\mathrm{CE}}_{\mathrm{L}}$ | $\begin{array}{\|r\|} \hline 47 \\ N C \end{array}$ | $\begin{array}{\|l\|} \hline 44 \\ \text { AgL } \end{array}$ | $43$ <br> AsL | $\begin{array}{\|l\|} \hline 40 \\ A_{5} \end{array}$ |
| $\begin{aligned} & 67 \\ & \mathrm{~V} / \mathrm{O}_{11 \mathrm{~L}} \end{aligned}$ | 65 I/O 9L |  |  | 57 GND | $\begin{aligned} & 53 \\ & V_{c c} \end{aligned}$ | $\begin{aligned} & 52 \\ & R / \bar{W}_{\mathrm{L}} \end{aligned}$ |  |  | $\begin{array}{\|r\|} \hline 41 \\ A_{6 L} \end{array}$ | $\begin{array}{\|c\|} \hline 39 \\ \mathrm{~A}_{4 \mathrm{~L}} \end{array}$ |
| $\begin{array}{\|l\|} \hline 69 \\ \mathrm{~V} / \mathrm{O}_{13 \mathrm{~L}} \end{array}$ | $\begin{array}{\|l\|} \hline 68 \\ 1 / O_{12 L} \end{array}$ |  |  |  |  |  |  |  | $\begin{array}{\|l} \hline 38 \\ \text { A3L } \end{array}$ | ${ }^{37} \mathrm{~A} 2 \mathrm{~L} .$ |
| $7_{1 / O_{15 L}}^{72}$ | ${ }^{71} / O_{14 L}$ | $\begin{array}{\|l\|} \hline 73 \\ V_{c c} \end{array}$ |  |  |  |  |  | $\frac{33}{\overline{B U S Y}}$ | $135$ <br> Aol | $\begin{aligned} & 34 \\ & \mathrm{INT}_{\mathrm{L}} \\ & \hline \end{aligned}$ |
| $\begin{array}{\|l\|} \hline 75 \\ \\ \hline \end{array}$ | $70$ | $\begin{aligned} & 74 \\ & \text { GND } \end{aligned}$ |  |  | IDT7024 |  |  | $\begin{aligned} & 32 \\ & \text { GND } \end{aligned}$ | $\begin{array}{\|l\|} \hline 31 \\ M / \bar{S} \end{array}$ | $\begin{array}{\|l\|} \hline 36 \\ A_{11} \end{array}$ |
| $\begin{array}{\|l\|} \hline 76 \\ / / O_{1 R} \end{array}$ | $\begin{aligned} & 77 \\ & 1 / O_{2 R} \end{aligned}$ | $\begin{aligned} & 78 \\ & V_{C C} \end{aligned}$ |  |  |  |  |  | $\begin{array}{\|l\|} \hline 28 \\ \text { AoR } \end{array}$ | $29$ | $\begin{aligned} & 30 \\ & \mathrm{BUSY}_{\mathrm{R}} \end{aligned}$ |
| $\begin{aligned} & 79 \\ & \mathrm{l} / \mathrm{O}_{3 \mathrm{R}} \\ & \hline \end{aligned}$ | $80$ |  |  |  |  |  |  |  | $26$ <br> A2R | $\begin{aligned} & 27 \\ & A_{1 R} \end{aligned}$ |
| $\begin{array}{\|l\|} \hline 81 \\ \\ \hline \end{array} \mathrm{O}_{5 \mathrm{R}}$ | $\begin{array}{\|l\|} 83 \\ 1 / O_{7 R} \end{array}$ |  |  | $\begin{aligned} & 7 \\ & \text { GND } \end{aligned}$ |  | $\frac{12}{S_{R E M}}$ |  |  | $23$ <br> A5R | $\begin{aligned} & 25 \\ & A_{3 R} \end{aligned}$ |
| $\begin{array}{\|l\|} \hline 82 \\ 1 / O_{6 R} \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 1 / O_{9 R} \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 / O_{10 R} \end{aligned}$ | $\begin{aligned} & 5 \\ & 1 / O_{13 R} \end{aligned}$ | $\begin{array}{\|l\|} \hline 8 \\ \\ \hline \end{array} \mathrm{O}_{155}$ | $\begin{aligned} & 10 \\ & R \bar{W}_{R} \end{aligned}$ | $\overline{14}_{\overline{U B}_{\mathrm{R}}}$ | $17$ <br> A11R | ${ }^{20} \mathrm{ABR}$ | $22$ <br> A6R | ${ }^{24} \mathrm{~A}_{4}$ |
| $\begin{array}{\|l\|} \hline 84 \\ 1 / O_{8 R} \\ \hline \end{array}$ | $\begin{aligned} & 3 \\ & 1 / O_{11 R} \end{aligned}$ | $\begin{aligned} & 4 \\ & 1 / O_{12 R} \end{aligned}$ | $\begin{aligned} & 6 \\ & \mathrm{I} / \mathrm{O}_{14 \mathrm{R}} \end{aligned}$ | ${ }^{9} \overline{O E}_{R}$ | ${ }^{15} \overline{\overline{L B}_{\mathrm{R}}}$ | ${ }^{13} \overline{\mathrm{CE}}_{\mathrm{R}}$ |  |  | $19$ <br> A9R | $\begin{aligned} & 21 \\ & A_{7 R} \end{aligned}$ |
| A | B | C | D | E | F | G | H | J | K | L |
| t be connected to power supply. |  |  |  |  |  |  |  |  |  |  |

## NOTES:

1. All Vcc pins must be connected to power supply.
2. All GND pins must be connected to ground supply.

84-PIN PGA TOP VIEW

PIN NAMES

| Left Port | Right Port | Names |
| :---: | :---: | :---: |
| $\overline{\mathrm{CE}} \mathrm{L}$ | $\overline{\text { CER }}$ | Chip Enable |
| $\mathrm{R} / \overline{\mathrm{W}}$ L | $\mathrm{R} \bar{W}_{\text {¢ }}$ | Read/Write Enable |
| $\overline{O E L}$ | $\overline{O E}_{R}$ | Output Enable |
| AOL - A 11 L | A0R - A11R | Address |
| I/OoL - //O15L | I/O0R - //O 15R $^{\text {R }}$ | Data Input/Output |
| $\overline{\text { SEML }}$ | $\overline{\text { SEM }}$ R | Semaphore Enable |
| UBL | $\overline{\text { UBR }}$ | Upper Byte Select |
| $\overline{L B L}$ | $\overline{\mathrm{LB}} \mathrm{R}$ | Lower Byte Select |
| $\overline{\text { INTL }}$ | INTR | Interrupt Flag |
| $\overline{B U S Y}^{\text {B }}$ | BUSYR | Busy Flag |
| M/ $\bar{S}$ |  | Master or Slave Select |
| Vcc |  | Power |
| GND |  | Ground |

TRUTH TABLE: NON-CONTENTION READ/WRITE CONTROL

| Inputs ${ }^{(1)}$ |  |  |  |  |  | Outputs |  | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathbf{C E}}$ | R/ $\bar{W}$ | $\overline{O E}$ | UB | $\overline{\text { LB }}$ | $\overline{\text { SEM }}$ | I/O8-15 | V/O0-7 |  |
| H | X | $X$ | X | X | H | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ | Deselected: Power Down |
| X | X | X | H | H | H | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ | Both Bytes Deselected: Power Down |
| L | L | X | L | H | H | DATAIN | $\mathrm{Hi}-\mathrm{Z}$ | Write to Upper Byte Only |
| L | 1 | X | H | L | H | $\mathrm{Hi}-\mathrm{Z}$ | DATAIN | Write to Lower Byte Only |
| 1 | $L$ | X | L | L | H | DATAIN | DATAIN | Write to Both Bytes |
| L | H | L | L | H | H | DATAOUT | Hi-Z | Read Upper Byte Only |
| $L$ | H | L | H | L | H | $\mathrm{Hi}-\mathrm{Z}$ | DATAOUT | Read Lower Byte Only |
| L | H | L | L | L | H | DATAOUT | DATAOUT | Read Both Bytes |
| X | X | H | X | X | X | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ | Outputs Disabled |

NOTE:
2740 tol 01

1. $A 0 L-A_{11 L} \neq A_{0 R}-A_{11} R$

## TRUTH TABLE: SEMAPHORE READ/WRITE CONTROL

| Inputs |  |  |  |  |  | Outputs |  | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E}$ | R/W | $\overline{O E}$ | $\overline{\text { UB }}$ | $\overline{\text { LB }}$ | SEM | //O8-15 | I/O0.7 |  |
| H | H | L | X | X | L | DATAOUT | DATAOUT | Read Data in Semaphore Flag |
| X | H | L | H | H | L | DATAOUT | DATAOUT | Read Data in Semaphore Flag |
| H | - | X | X | X | L | DATAIN | DATAIN | Write Dino into Semaphore Flag |
| X | - | X | H | H | L | DATAIN | DATAIN | Write Dino into Semaphore Flag |
| L | X | X | L | X | L | - | - | Not Allowed |
| L | X | X | X | L | L | - | - | Not Allowed |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unlt |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2740 tbl 06

1. VILZ -3.0 V for pulse width less than $20 n \mathrm{~s}$.

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 11 | pF |
| Cout | Output <br> Capacitance | VouT $=0 \mathrm{~V}$ | 11 | pF |

NOTE:

1. This parameter is determined by device characterization but is not production tested

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | IDT7024S |  | IDT7024L |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|l니| | Input Leakage Current ${ }^{(5)}$ | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{Vin}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lLO] | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| VOL | Output Low Vottage | $\mathrm{OL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

2740 5107

## DC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$ (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )| Symbol | Parameter | Test Condition | Version |  | X25 <br> ONLY <br> Max. | $\begin{array}{\|c} 7024 \\ \text { com'L } \\ \text { Typ. }{ }^{(2)} \\ \hline \end{array}$ | X30 ONLY Max. |  | $\begin{aligned} & \text { X35 } \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Icc | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\mathrm{CE}} \leq V_{I L}, \text { Outputs Open } \\ & \overline{S E M} \geq V_{\text {VH }} \\ & f=f M A X^{(3)} \end{aligned}$ | MIL. S <br>  L | - | - | - | - | - | $\begin{aligned} & 400 \\ & 340 \end{aligned}$ | mA |
|  |  |  | COM'L. $\begin{aligned} & \text { S } \\ & \\ & \text { L }\end{aligned}$ |  | $\begin{aligned} & 360 \\ & 310 \end{aligned}$ | - | $\begin{aligned} & 350 \\ & 300 \end{aligned}$ | - | $\begin{aligned} & 340 \\ & 290 \end{aligned}$ |  |
| IsB1 | Standby Current (Both Ports — TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{~L} \geq \mathrm{V}_{I H} \\ & \overline{\mathrm{SEM}} \mathrm{R}=\overline{\mathrm{SEM} L} \geq \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{f}=\mathrm{f}_{\mathrm{MAX}}{ }^{(3)} \end{aligned}$ | MIL.S  <br>  L | - | - | - | - | - | $\begin{aligned} & 85 \\ & 65 \end{aligned}$ | mA |
|  |  |  | COM'L. $\begin{aligned} & \text { S } \\ & \\ & \text { L }\end{aligned}$ |  | $\begin{aligned} & 70 \\ & 50 \end{aligned}$ | - | $\begin{aligned} & 70 \\ & 50 \end{aligned}$ | - | $\begin{aligned} & 70 \\ & 50 \end{aligned}$ |  |
| ISB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{\mathrm{I}}$ Active Port Outputs Open$\begin{aligned} & f=f M A X^{(3)} \\ & \overline{S E M R}=\overline{S E M L} \geq V_{I H} \end{aligned}$ | MIL. S <br>  L | - | - | - | - | - | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | mA |
|  |  |  | $\begin{array}{ll}\text { COM'L. } & \mathrm{S} \\ & \mathrm{L}\end{array}$ | - | $\begin{aligned} & 250 \\ & 220 \end{aligned}$ | - | $\begin{aligned} & 250 \\ & 215 \end{aligned}$ | - | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) |  | MIL. $\quad \mathrm{S}$ | - | 二 | - | - | - | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  |  |  | $\begin{array}{ll}\text { COM'L. } & \mathrm{S} \\ & \mathrm{L}\end{array}$ | - | $\begin{gathered} 15 \\ 5 \end{gathered}$ | - | 15 5 | - | $\begin{gathered} \hline 15 \\ 5 \end{gathered}$ |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs) | One Port $\overline{C E L}$ or <br> $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\overline{S E M} \mathrm{~F}=\overline{\mathrm{SEM}} \mathrm{Z} \geq \mathrm{VcC}-0.2 \mathrm{~V}$ <br> VIN $\geq$ Vcc - 0.2 V or <br> Vin $\leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=f \text { MAX }{ }^{(3)}$ | MIL. S <br>  L | - | - | - | 230 | - | $\begin{aligned} & 260 \\ & 215 \end{aligned}$ | mA |
|  |  |  | $\begin{array}{\|ll\|} \hline \text { COM'L. } & \mathrm{S} \\ & \mathrm{~L} \\ & \end{array}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{aligned} & 230 \\ & 190 \end{aligned}$ | - | $\begin{aligned} & 230 \\ & 190 \end{aligned}$ | - | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ |  |

## NOTES:

1. $X$ in part numbers indicates power rating ( S or L )
2. $\mathrm{VcC}=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
 of input levels of GND to 3V.
3. $\mathrm{f}=0$ means no address or control lines change.
4. At Vcc $\leq 1.0 \mathrm{~V}$ input leakages are undefined.

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$（Continued）（Vcc $=5.0 \mathrm{~V} \pm 10 \%$ ）

| Symbol | Parameter | Test Condition | Version | $\begin{array}{r} 702 \\ \text { Typ. }{ }^{(2)} \\ \hline \end{array}$ | X45 | $\begin{array}{r} 7024 \\ \text { Typ. }{ }^{(2)} \\ \hline \end{array}$ | X55 <br> Max． |  | $\begin{aligned} & \hline \text { X70 } \\ & \text { SNLY } \\ & \text { Max. } \\ & \hline \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Icc | Dynamic Operating Current （Both Ports Active） | $\begin{aligned} & \overline{\mathrm{CE}} \leq V_{I L}, \text { Outputs Open } \\ & \mathrm{SEM} \geq V_{I H} \\ & f=f_{m A X}{ }^{(3)} \end{aligned}$ | MIL．S <br>  | － | $\begin{aligned} & 400 \\ & 340 \end{aligned}$ | － | $\begin{aligned} & 395 \\ & 335 \end{aligned}$ | 二 | $\begin{aligned} & 390 \\ & 330 \end{aligned}$ | mA |
|  |  |  | COM＇L． $\begin{aligned} & \text { S } \\ & \\ & \\ & \text { L }\end{aligned}$ | － | 340 290 | － | 335 285 | － | － |  |
| ISB1 | Standby Current （Both Ports－TTL Level Inputs） | $\begin{aligned} & \overline{\mathrm{CE}}_{\mathrm{L}}=\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{1 H} \\ & \overline{\mathrm{SEM}} \mathrm{~F}=\overline{\mathrm{SEM}} \mathrm{~L} \geq \mathrm{V}_{I H} \\ & \mathrm{f}=\mathrm{fMAx}^{(3)} \end{aligned}$ | MIL．S <br>  | － | $\begin{aligned} & 85 \\ & 65 \end{aligned}$ | － | $\begin{aligned} & 85 \\ & 65 \end{aligned}$ | 二 | 85 | mA |
|  |  |  | COM＇L．${ }^{\text {S }}$ | － | 70 50 | 二 | 70 50 | － | － |  |
| ISB2 | Standby Current （One Port — TTL Level Inputs） | $\overline{\mathrm{CE}} \mathrm{R}$ or $\overline{\mathrm{CE}} \mathrm{L} \geq \mathrm{V}_{\mathrm{H}}$ Active Port Outputs Open$\begin{aligned} & f=f_{M A X}^{(3)} \\ & \operatorname{SEM} R=\overline{S E M} L \geq V_{I H} \end{aligned}$ | MIL．S <br>  | － | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | － | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | 二 | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | mA |
|  |  |  | COM＇L．S <br>  <br>  | － | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ | 二 | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ | 二 | － |  |
| ISB3 | Full Standby Current （Both Ports－All CMOS Level Inputs） | Both Ports $\overline{C E}$ and $\overline{\mathrm{C} E} \mathrm{R} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ | MIL． $\begin{array}{ll}\text { S } \\ & \text { L }\end{array}$ | － | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | － | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | － | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  |  | $\begin{aligned} & V I N \geq V c c-0.2 V \text { or } \\ & V \mathbb{N} \leq 0.2 V, t=0^{(4)} \\ & \text { SEMR }=\text { SEM } \geq V C c-0.2 V \\ & \hline \end{aligned}$ | COM＇L．S <br>  <br>  | － | $\begin{gathered} 15 \\ 5 \end{gathered}$ | － | $\begin{gathered} 15 \\ 5 \end{gathered}$ | 二 | － |  |
| ISB4 | Full Standby Current （One Port－All CMOS Level Inputs） | One Port $\overline{\mathrm{CE}} \mathrm{L}$ or <br> $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ $\overline{\mathrm{SEMR}}=\overline{\mathrm{SEM}} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ <br> VIn $\geq$ Vcc -0.2 V or $\operatorname{VIN} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open， $f=f M A X^{(3)}$ | MIL．$\quad$ S | － | 260 215 | － | 260 215 | － | $\begin{aligned} & 260 \\ & 215 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM＇L． S | － | 220 180 | － | 220 180 | － | － |  |

NOTES：
1．$X$ in part numbers indicates power rating（ $S$ or $L$ ）
2．$V c C=5 V, T A=+25^{\circ} \mathrm{C}$ ．
3．At $f=f$ max，address and data inputs（excepi Output Enable）are cycling at the maximum frequency of read cycle of $1 /$ trc，and using＂AC Test Conditions＂ of input levels of GND to 3 V ．
4． $\mathfrak{f}=0$ means no address or control lines change．
5．At $\mathrm{Vcc} \leq 1.0 \mathrm{~V}$ input leakages are undefined．

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES (L Version Only) (VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{VCC}-0.2 \mathrm{~V}$ )

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & \overline{\mathrm{CE}} \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \leq \mathrm{VLC} \end{aligned}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | - | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | - | 1500 |  |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $t \mathrm{R}^{(3)}$ | Operation Recovery Time |  |  | $\mathrm{tRC}^{(2)}$ | - | - | ns |

## NOTES:

2740 क109

1. $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{Vcc}=2 \mathrm{~V}$
2. the = Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



2740 drw 04

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | $5 \mathrm{~ns} \mathrm{Max}$. |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |
| 2740 +ol 10 |  |



Figure 1. Output Load


Figure 2. Output Load (for tIz, thz, twz, tow)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS OVER THE <br> OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(4)}$

| Symbol | Parameter | $\begin{aligned} & \text { IDT7024X25 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7024X30 } \\ & \text { COM'L ONLY } \\ & \hline \end{aligned}$ |  | IDT7024X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | ns |
| tAA | Address Access Time | - | 25 | - | 30 | - | 35 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 25 | - | 30 | - | 35 | ns |
| tABE | Byte Enable Access Time ${ }^{(3)}$ | - | 25 | - | 30 | - | 35 | ns |
| taje | Output Enable Access Time | - | 13 | - | 15 | - | 20 | ns |
| tOH | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | ns |
| tLZ | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | 3 | - | 3 | - | 3 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | ns |
| tSOP | Semaphore Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\mathrm{SEM}}$ ) | 12 | - | 15 | - | 15 | - | ns |


| Symbol | Parameter | IDT7024X45 |  | IDT7024X55 |  | $\begin{aligned} & \text { IDT7024X70 } \\ & \text { MIL ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| taA | Address Access Time | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 45 | - | 55 | - | 70 | ns |
| tabe | Byte Enable Access Time ${ }^{(3)}$ | - | 45 | - | 55 | - | 70 | ns |
| taie | Output Enable Access Time | - | 25 | - | 30 | - | 35 | ns |
| toh | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,2)}$ | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | ns |
| tSOP | Semaphore Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\text { SEM }}$ ) | 15 | - | 15 | - | 15 | - | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (figures 1 and 2 ).
2. This parameter is guaranteed but not tested.
3. To access RAM, $\overline{C E}=L, \overline{\mathrm{JB}}$ or $\overline{\mathrm{LB}}=\mathrm{L}, \overline{\mathrm{SEM}}=\mathrm{H}$.
4. $X$ in part numbers indicates power rating ( S or L ).

WAVEFORM OF READ CYCLES ${ }^{(5)}$


## NOTES:

1. Timing depends on which signal is asserted last, $\overline{\mathrm{OE}}, \overline{\mathrm{CE}}, \overline{\mathrm{LB}}$, or $\overline{\mathrm{UB}}$.
2. Timing depends on which signal is de-asserted firs $\overline{\mathrm{CE}}, \overline{\mathrm{OE}}, \overline{\mathrm{LB}}$, or $\overline{\mathrm{UB}}$.
3. Required only if busy logic is being used to preventread data corruption, during simultaneous accesses to the same location, in masters and master-slave width expansions.
4. Start of valid data depends on which timing becomes effective last tabe, taOE, lace, taA or tadD.
5. $\overline{S E M}=H$.

TIMING OF POWER-UP POWER-DOWN


## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(5)}$

| Symbol | Parameter | $\begin{aligned} & \text { IDT7024X25 } \\ & \text { COM'L ONLY } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7024X30 } \\ & \text { COM'L ONL.Y } \end{aligned}$ |  | IDT7024X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twe | Write Cycle Time | 25 | - | 30 | - | 35 | - | ns |
| tew | Chip Enable to End of Write ${ }^{(3)}$ | 20 | - | 25 | - | 30 | - | ns |
| LAW | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | ns |
| tAS | Address Set-up Time ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 20 | - | 25 | - | 30 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data Valid to End of Write | 15 | - | 20 | - | 25 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | ns |
| tDH | Data Hold Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tWZ | Write Enable to Output in High $\mathbf{Z}^{(1,2)}$ | - | 15 | - | 15 | - | 15 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tSWRD | SEM Flag Write to Read Time | 10 | - | 10 | - | 10 | - | ns |
| tSPS | $\overline{\text { SEM }}$ Flag Contention Window | 10 | - | 10 | - | 10 | - | ns |


| Symbol | Parameter | IDT7024X45 |  | IDT7024X55 |  | $\begin{aligned} & \text { IDT7024X70 } \\ & \text { MIL. ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twC | Write Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| tEW | Chip Enable to End of Write ${ }^{(3)}$ | 40 | - | 45 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 40 | - | 45 | - | 50 | - | ns |
| tas | Address Set-up Time ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| twh | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data Valid to End of Write | 25 | - | 30 | - | 40 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tDH | Data Hold Time ${ }^{(4)}$. | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enable to Output in High $\mathrm{Z}^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tSWRD | SEM Flag Write to Read Time | 10 | - | 10 | - | 10 | - | ns |
| tSPS | $\overline{\text { SEM }}$ Flag Contention Window | 10 | - | 10 | - | 10 | - | ns |
| NOTES: |  |  |  |  |  |  |  |  |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2 ).
2. This parameter is guaranteed but not tested.
3. To access $R A M, \overline{C E}=L, \overline{U B}$ or $\overline{L 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 tixw time.
4. The specification for tDH must be met by the device supplying write data to the RAM under all operating conditions. Although tDH and tow values will vary over voltage and temperature, the actual tDH will always be smaller than the actual tow.
5. $X$ in part numbers indicates power rating ( S or L ).

TIMING WAVEFORM OF WRITE CYCLE NO. 1, R/W CONTROLLED TIMING ${ }^{(1,3,5,8)}$


TIMING WAVEFORM OF WRITE CYCLE NO. $2, \overline{\mathrm{CE}}, \overline{\mathrm{UB}}, \overline{\mathrm{LB}}$ CONTROLLED $\operatorname{TIMING}(1,3,5,8)$


NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or tWP) of a low $\overline{U B}$ or $\overline{L B}$ and a low $\overline{C E}$ and a low $R \bar{W}$ for memory array writing cycle.
3. tw is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ (or $\overline{S E M}$ or $R \bar{W}$ ) going high to the end of write cycle.
4. During this period, the $I / O$ pins are in the output state and input signals must not be applied.
5. If the $\overline{\mathrm{CE}}$ or $\overline{\mathrm{SEM}}$ low transition occurs simultaneously with or after the $\mathrm{R} / \overline{\mathrm{W}}$ low transition, the outputs remain in the high impedance state.
6. Timing depends on which enable signal is asserted last.
7. Timing depends on which enable signal is de-asserted first.
8. If $\overline{O E}$ is low during R $\bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or (twz + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. 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 twp.

## timing waveform of semaphore read after write timing, Either Side ${ }^{(1)}$



NOTE:

1. $\overline{C E}=\mathrm{H}$ for the duration of the above timing (both write and read cycle).

## TIMING WAVEFORM OF SEMAPHORE WRITE CONTENTION ${ }^{(1,3,4)}$



NOTES:

1. $D O R=D O L=L, \overline{C E} R=\overline{C E} L=H$, Semaphore Flag is released from both sides (reads as ones from both sides) at cycle start.
2. " $A$ " may be either left or right port. " $B$ " is the opposite port from " $A$ ".
3. This parameter is measured from $R / \bar{W}_{A}$ or $\overline{S E M}_{A}$ going high to $R / \bar{W}_{B}$ or $\overline{S E M}_{B}$ going high.
4. If tsps is violated, the semaphore will fall positively to one side or the other, but there is not guarantee which side will obtain the flag.

## AC ELECTRICAL CHARACTERISTICS OVER THE

## OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(6)}$

| Symbol | Parameter | $\begin{aligned} & \text { IDT7024X25 } \\ & \text { COM'L ONLY } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7024X30 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | IDT7024X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (M/ $\bar{S}=H$ ) |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 25 | - | 30 | - | 35 | ns |
| tBda | BUSY Disable Time to Address | - | 20 | - | 25 | - | 30 | ns |
| tbac | $\overline{\text { BUSY }}$ Access Time to Chip Enable or Byte Enable | - | 20 | - | 25 | - | 30 | ns |
| tBDC | BUSY Disable Time to Chip Enable or Byte Disable | - | 17 | - | 20 | - | 25 | ns |
| taps | Arbitration Priority Set-up Time ${ }^{(2)}$ | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 3 | - | Note 3 | - | Note 3 | ns |
| BUSY TIMING (M/ $\bar{S}=\mathrm{L}$ ) |  |  |  |  |  |  |  |  |
| twB | $\overline{\text { BUSY }}$ Input to Write ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tWH | Write Hold After $\overline{\text { BUSY }}{ }^{(5)}$ | 17 | - | 20 | - | 25 | - | ns |
| PORT-TO-PORT DELAY TIMING |  |  |  |  |  |  |  |  |
| tWDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 50 | - | 55 | - | 60 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 35 | - | 40 | - | 45 | ns |


| Symbol | Parameter | IDT7024X45 |  | IDT7024X55 |  | $\begin{aligned} & \text { IDT7024X70 } \\ & \text { MIL. ONLY } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (M/S $=\mathbf{H}$ ) |  |  |  |  |  |  |  |  |
| tBaA | BUSY Access Time to Address | - | 35 | - | 45 | - | 45 | ns |
| tBDA | BUSY Disable Time to Address | - | 30 | - | 40 | - | 40 | ns |
| tbac | $\overline{\text { BUSY }}$ Access Time to Chip Enable or Byte Enable | - | 30 | - | 40 | - | 40 | ns |
| tBDC | BUSY Disable Time to Chip Enable or Byte Disable | - | 25 | - | 35 | - | 35 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(2)}$ | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 3 | - | Note 3 | - | Note 3 | ns |
| BUSY TIMING ( $M / \bar{S}=\mathrm{L}$ ) |  |  |  |  |  |  |  |  |
| twB | $\overline{\text { BUSY }}$ Input to Write ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tWH | Write Hold After $\overline{\text { BUSY }}{ }^{(5)}$ | 25 | - | 25 | - | 25 | - | ns |
| PORT-TO-PORT DELAY TIMING |  |  |  |  |  |  |  |  |
| twDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 70 | - | 80 | - | 95 | ns |
| tDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 55 | - | 65 | - | 80 | ns |

[^11]TIMING WAVEFORM OF READ WITH $\overline{B U S Y}{ }^{(2)}$ (M/ $\overline{\mathbf{S}}=\mathrm{H}$ )


NOTES:
2740 drw 13

1. To ensure that the earlier of the two ports wins.
2. $\overline{\mathrm{CE}}_{\mathrm{L}}=\overline{\mathrm{CE}}_{\mathrm{R}}=\mathrm{L}$
3. $\overline{O E}=\mathrm{L}$ for the reading port.

TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DELAY ${ }^{(1,2)}(M / \bar{S}=L)$

2. $\overline{\mathrm{CE}}_{\mathrm{L}}=\overline{\mathrm{CE}}_{\mathrm{R}}=\mathrm{L}$

TIMING WAVEFORM OF SLAVE WRITE (M/ $\overline{\mathbf{S}}=\mathrm{L}$ )


## WAVEFORM OF BUSY ARBITRATION CONTROLLED BY $\overline{C E} \operatorname{TIMING}{ }^{(1)}(\mathbf{M} / \overline{\mathbf{S}}=\mathbf{H})$



WAVEFORM OF BUSY ARBITRATION CYCLE CONTROLLED BY ADDRESS MATCH $\operatorname{TIMING}^{(1)}(\mathbf{M} / \overline{\mathbf{S}}=\mathbf{H})$


NOTES:

1. All timing is the same for left and right ports. Port " A " may be either the left or right port. Port " B " is the port opposite from " A ".
2. If taps is violated, the busy signal will be asserted on one side or another but there is no guarantee on which side busy will be asserted.

## AC ELECTRICAL CHARACTERISTICS OVER THE

## OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$

| Symbol | Parameter | $\begin{aligned} & \text { IDT7024X25 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7024X30 } \\ & \text { COM'L ONLY } \\ & \hline \end{aligned}$ |  | IDT7024X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| INTERRUPT TIMING |  |  |  |  |  |  |  |  |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twr | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tins | Interrupt Set Time | - | 20 | - | 25 | - | 30 | ns |
| tiNR | Interrupt Reset Time | - | 20 | - | 25 | - | 30 | ns |


| Symbol | Parameter | IDT7024X45 |  | IDT7024X55 |  | $\begin{aligned} & \text { IDT7024X70 } \\ & \text { MIL. ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| INTERRUPT TIMING |  |  |  |  |  |  |  |  |
| tAs | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twn | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tins | Interrupt Set Time | - | 35 | - | 40 | - | 50 | ns |
| ting | Interrupt Reset Time | - | 35 | - | 40 | - | 50 | ns |
| NOTE: <br> 1. " $x$ " in part numbers indicates power rating ( S or L ). |  |  |  |  |  |  | 2740 tid 14 |  |

## WAVEFORM OF INTERRUPT TIMING ${ }^{(1)}$




NOTES:

1. All timing is the same for left and right ports. Port " $A$ " may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. See Interrupt truth table.
3. Timing depends on which enable signal is asserted last.
4. Timing depends on which enable signal is de-asserted first.

## TRUTH TABLES

TRUTH TABLE I - INTERRUPT FLAG ${ }^{(1)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{R} / \bar{W}_{L}$ | $\overline{\mathrm{CE}} \mathrm{L}$ | $\overline{O E}_{L}$ | AOL-A11L | INTL | $R \bar{W}_{R}$ | $\overline{C E E}^{\text {R }}$ | OER | A0R-A11R | INTR |  |
| L | L | X | FFF | X | X | X | X | X | $L^{(2)}$ | Set Right $\overline{N T T}^{\text {R Flag }}$ |
| X | X | X | X | X | X | L | L | FFF | $\mathrm{H}^{(3)}$ | Reset Right INTR Flag |
| X | X | X | X | $\mathrm{L}^{(3)}$ | L | L | X | FFE | X | Set Left $\overline{\text { NTL }}$ Flag |
| X | L | L | FFE | $\mathrm{H}^{(2)}$ | X | X | X | X | X | Reset Left INTL Flag |

NOTES:

1. Assumes $\overline{B U S Y L}=\overline{B U S Y R}=H$.
2. If $\overline{B U S Y} L=L$, then no change.
3. If $\operatorname{BUSY}_{\mathrm{A}}=\mathrm{L}$, then no change.

## TRUTH TABLE II - ADDRESS BUSY

## ARBITRATION

| Inputs |  |  | Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E L}$ | $\overline{\text { CER }}$ | AoL-A11L Aor-A11R | $\overline{B U S Y}^{(1)}$ | $\overline{\text { BUSY }}^{\text {a }}{ }^{\text {(1) }}$ |  |
| X | X | NO MATCH | H | H | Normal |
| H | X | MATCH | H | H | Normal |
| X | H | MATCH | H | H | Normal |
| L | L | MATCH | (2) | (2) | Write Inhibit ${ }^{(3)}$ |

NOTES: 2740 tol 16

1. Pins $\overline{B U S Y} \bar{L}$ and $\overline{B U S Y} \bar{B}$ are both outputs when the part is configured as a master. Both are inputs when configured as a slave. $\overline{\mathrm{BUSY}} \mathrm{x}$ outputs on the IDT7024 are push pull, not open drain outputs. On slaves the BUSYx input internally inhibits writes.
2. Lif the inputs to the opposite port were stable prior to the address and enable inputs of this port. H if the inputs to the opposite port became stable after the address and enable inputs of this port. If taps is not met, either BUSYL or BUSYR = Low will result. BUSYL and BUSYR outputs cannot be low simultaneouly.
3. Writes to the left port are internally ignored when BUSYL outputs are driving low regardless of actual logic level on the pin. Writes to the right port are internally ignored when BUSYR outputs are driving low regardless of actual logic level on the pin.

## TRUTH TABLE III - EXAMPLE OF SEMAPHORE PROCUREMENT SEQUENCE ${ }^{(1)}$

| Functions | Do - D15 Left | Do - D15 Right $^{\prime}$ |  |
| :--- | :---: | :---: | :--- |
| No Action | 1 | 1 | Status |
| 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 | Right port has semaphore token |
| Left Port Writes "1" to Semaphore | 1 | 1 | Semaphore free |

## NOTE:

1. This table denotes a sequence of events for only one of the eight semaphores on the IDT7024.


Flgure 3. Busy and chip enable routing for both width and depth expansion with IDT7024 RAMs.

## FUNCTIONAL DESCRIPTION

The IDT7024 provides two ports with separate control, address and $1 / O$ pins that permit independent access for reads or writes to any location in memory. The IDT7024 has an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected (CE high). When a port is enabled, access to the entire memory array is permitted.

## INTERRUPTS

If the user chooses to use the interrupt function, a memory location (mailbox or message center) is assigned to eachport. The left port interrupt flag ( $\overline{\mathrm{INT}} \mathrm{)}$ ) is set when the right port writes to memory location FFE (HEX). The left port clears the interrupt by reading address location FFE. Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location FFF (HEX) and to clear the interrupt flag (INTR), the right port must read the memory location FFF. The message (16 bits) at FFE or FFF is user-defined. If the interrupt function is not used, address locations FFE and FFF are not used as mail boxes, but as part of the random access memory. Refer to Table I for the interrupt operation.

## BUSY LOGIC

Busy Logic provides a hardware indication that both ports of the RAM have accessed the same location at the same time. It also allows one of the two accesses to proceed and signals the other side that the RAM is "busy". The busy pin can then be used to stallthe access until the operation on the other side is completed. If a write operation has been attempted from the side that receives a busy indication, the write signal is gated internally to prevent the write from proceeding.

The use of busy logic is not required or desirable for all applications. In some cases it may be useful to logically OR the busy outputs together and use any busy indication as an interrupt source to flag the event of an illegal or illogical
operation. If the write inhibit function of busy logic is not desirable, the busy logic can be disabled by placing the part in slave mode with the M/S pin. Once in slave mode the BUSY pin operates solely as a write inhibit input pin. Normal operation can be programmed by tying the BUSY pins high. If desired, unintended write operations can be prevented to a port by tying the busy pin for that port low.

The busy outputs on the IDT 7024 RAM in master mode, are push-pull type outputs and do not require pull up resistors to operate. If these RAMs are being expanded in depth, then the busy indication for the resulting array requires the use of an external AND gate.

## WIDTH EXPANSION WITH BUSY LOGIC MASTER/SLAVE ARRAYS

When expanding an IDT7024 RAM array in width while using busy logic, one master part is used to decide which side of the RAM array will receive a busy indication, and to output that indication. Any number of slaves to be addressed in the same address range as the master, use the busy signal as a write inhibit signal. Thus on the IDT7024 RAM the busy pin is an output if the part is used as a master $(\mathrm{M} / \overline{\mathrm{S}} \mathrm{pin}=\mathrm{H})$, and the

## SEMAPHORES

The IDT7024 is an extremely fast dual-port $4 \mathrm{~K} \times 16$ CMOS static RAM with an additional 8 address locations dedicated to binary semaphore flags. These flags allow either processor on the left or right side of the dual-port RAM to claim a privilege over the other processor for functions defined by the system designer's software. As an example, the semaphore can be used by one processor to inhibit the other from accessing a portion of the dual-port RAM or any other shared resource.

The dual-port RAM features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Both ports are identical in functionto standard CMOS static RAM and can be read from, or written to, at the same time with the only possible conflict arising from the simultaneous writing of, or a simultaneous READ/WRITE of, a non-semaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the non-semaphore portion of the dual-port RAM. These devices have an automatic power-down feature controlled by $\overline{C E}$, the dual-port RAM enable, and $\overline{\text { SEM }}$, the semaphore enable. The $\overline{\mathrm{CE}}$ and $\overline{\text { SEM }}$ pins control on-chip power down circuitry that permits the respective port to go into standby mode when not selected. This is the condition which is shown in Truth Table where $\overline{C E}$ and $\overline{\text { SEM }}$ are both high.

Systems which can best use the IDT7024 contain multiple processors or controllers and are typically very high-speed systems which are software controlled or software intensive. These systems can benefit from a performance increase offered by the IDT7024's hardware semaphores, which provide a lockout mechanism without requiring complex programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be allocated in varying configurations. The IDT7024 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture.

An advantage of using semaphores rather than the more common methods of hardware arbitration is that wait states are never incurred in either processor. This can prove to be a major advantage in very high-speed systems.

## HOW THE SEMAPHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independentof the dual-port RAM. These latches canbe used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment method called "Token Passing Allocation." In this method, the state of a semaphore latch is used as a token indicating that shared resource is in use. If the left processorwants to use this resource, it requests the token by setting the latch. This processor then verifies its success in setting the latch by reading it. If it was successful, it proceeds to assume control over the shared resource. If it was not successful in setting the latch, it determines that the
right side processor has set the latch first, has the token and is using the shared resource. The left processor can then either repeatedly request that semaphore's status or remove its request for that semaphore to perform another task and occasionally attempt again to gain control of the token via the set and test sequence. Once the right side has relinquished the token, the left side should succeed in gaining control.

The semaphore flags are active low. A token is requested by writing a zero into a semaphore latch and is released when the same side writes a one to that latch.

The eight semaphore flags reside within the IDT7024 in a separate memory space from the dual-port RAM. This address space is accessed by placing a low input on the $\overline{\text { SEM }}$ pin (which acts as a chip select for the semaphore flags) and using the other control pins (Address, $\overline{O E}$, and $R \bar{W}$ ) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through address pins A0-A2. When accessing the semaphores, none of the other address pins has any effect.

When writing to a semaphore, only data pin Do is used. If a low level is written into an unused semaphore location, that flag will be setto a zero on that side and a one on the other side (see Table III). That semaphore can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be setto a one for both sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. (A thorough discussing on the use of this feature follows shorly.) A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.

When a semaphore flag is read, its value is spread into all data bits so that a flag that is a one reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE}}$ ) signals go active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal (SEM or $\overline{\mathrm{OE}}$ ) to go inactive or the output will never change.

A sequence WRITE/READ must be used by the semaphore in order to guarantee that no system levelcontention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as one, a fact which the processor will verify by the subsequent read (see Table III). As an example, assume a processor writes a zero to the left port at a free semaphore location. On a subsequent read, the processor will verify that it has written successfully to that location and will assume control over the resource in question. Meanwhile, if a processor on the right side attempts to write a zero to the same semaphore flag it will fail, as will be verified by the fact that a one will be read from
that semaphore on the right side during subsequent read. Had a sequence of READ/WRITE been used instead, system contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed by either repeated reads or by writing a one into the same location. The reason for this is easily understood by looking at the simple logic diagram of the semaphore flag in Figure 4. Two semaphore request latches feed into a semaphore flag. Whichever latch is first to present a zero to the semaphore flag will force its side of the semaphore flag low and the other side high. This condition will continue until a one is written to the same semaphore request latch. Should the other side's semaphore request latch have been written to a zero in the meantime, the semaphore flag will flip over to the other side as soon as a one is written into the first side's request latch. The second side's flag will now stay low until its semaphore request latch is written to a one. From this it is easy to understand that, if a semaphore is requested and the processor which requested it no longer needs the resource, the entire system can hang up until a one is written into that semaphore request latch.

The critical case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is specially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side is earlier than the other in making the request, the first side to make the request will receive the token. If both requests arrive at the same time, the assignment will be arbitrarily made to one port or the other.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, if semaphores are misused or misinterpreted, a software error can easily happen.

Initialization of the semaphores is not automatic and must be handled via the initialization program at power-up. Since any semaphore request flag which contains a zero must be reset to a one, all semaphores on both sides should have a one written into them at initialization from both sides to assure that they will be free when needed.

## USING SEMAPHORES-SOME EXAMPLES

Perhaps the simplest application of semaphores is their application as resource markers for the IDT7024's dual-port RAM. Say the $4 \mathrm{~K} \times 16$ RAM was to be divided into two $2 \mathrm{~K} x$ 16 blocks which were to be dedicated at any one time to servicing either the left or right port. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of memory.

To take a resource, in this example the lower 2 K of dual-port RAM, the processor on the left port could write and
then read a zero in to Semaphore 0 . If this task were successfully completed (a zero was read back rather than a one), the left processor would assume control of the lower 2 K . Meanwhile the right processor was attempting to gain control of the resource after the left processor, it would read back a one in response to the zero it had attempted to write into Semaphore 0. At this point, the software could choose to try and gain control of the second 2 K section by writing, then reading a zero into Semaphore 1. If it succeeded in gaining control, it would lock out the left side.

Once the left side was finished with its task, it would write a one to Semaphore 0 and may then try to gain access to Semaphore 1. If Semaphore 1 was still occupied by the right side, the left side could undo its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1. If the right processor performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 2K blocks of dual-port RAM with each other.

The blocks do not have to be any particular size and can even be variable, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphores can even be assigned different meanings on different sides rather than being given a common meaning on different sides rather than being given a common meaning as was shown in the example above.

Semaphores are a useful form of arbitration in systems like disk interfaces where the CPU must be locked out of a section of memory during a transfer and the I/O device cannot tolerate any wait states. With the use of semaphores, once the two devices has determined which memory area was "off-limits" to the CPU, both the CPU and the I/O devices could access their assigned portions of memory continuously without any wait states.

Semaphores are also useful in applications where no memory "WAIT" state is available on one or both sides. Once a semaphore handshake has been performed, both processors can access iheir assigned RAM segments at full speed.

Another application is in the area of complex data structures. In this case, block arbitration is very important. For this application one processormay be responsible for building and updating a data structure. The other processorthen reads and interprets that data structure. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the two different processors. The building processor arbitrates for the block, locks it and then is able to go in and update the data structure. When the update is completed, the data structure block is released. This allows the interpreting processor to come back and read the complete data structure, thereby guaranteeing a consistent data structure.


Figure 4. IDT7024 Semaphore Logic

## ORDERING INFORMATION



2740 drw 22

## FEATURES:

- True dual-ported memory cells which allow simultaneous reads of the same memory location
- High-speed access
- Military: 45/55/70ns (max.)
- Commercial: 35/45/55ns (max.)
- Low-power operation
- IDT7005S

Active: 500 mW (typ.)
Standby: 5mW (typ.)

- IDT7005L

Active: 500 mW (typ.)
Standby: 1 mW (typ.)

- IDT7005 easily expands data bus width to 16 bits or more using the Master/Slave select when cascading more than one device
- $M / \bar{S}=H$ for $\overline{B U S Y}$ output flag on Master
$M / \bar{S}=L$ for $\overline{B U S Y}$ input on Slave
- Interrupt Flag
- On-chip port arbitration logic
- Full on-chip hardware support of semaphore signaling between ports
- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL compatible, single 5V ( $\pm 10 \%$ ) power supply
- Available in 68-pin PGA, quad flatpack, LCC and PLCC


## DESCRIPTION:

The IDT7005 is a high-speed $8 \mathrm{~K} \times 8$ dual-port static RAM. The IDT7005 is designed to be used as a stand-alone 64K-bit dual-port RAM or as a combination MASTER/SLAVE dualport RAM for 16 -bit-or-more word systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 16-bit or wider memory system applications results in full-speed, error-free

## FUNCTIONAL BLOCK DIAGRAM


operation without the need for additional discrete logic.
This device provides two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power down feature controlled by $\overline{\mathrm{CE}}$ permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only 500 mW or
power at maximum access times as fast as 35ns. Low-power (L) versions offer battery backup data retention capability with each port typically consuming $500 \mu \mathrm{~W}$ from a 2 V battery.

The IDT7005 is packaged in plastic as well as ceramic 68pin PGA and 68-pin quad flatpack, LCC and PLCC. The military devices are processed $100 \%$ in compliance to the test methods of MIL-STD-883, Method 5004.

## PIN CONFIGURATIONS



NOTES:

1. All Vcc pins must be connected to power supply.
2. All GND pins must be connected to ground supply.

## PIN CONFIGURATIONS (Continued)

| 11 |  | 51 <br> A5L | $\begin{aligned} & 50 \\ & A_{4 L} \end{aligned}$ | 48 <br> A $2 L$ | 46 <br> AOL | $\begin{array}{\|l\|} \hline \frac{44}{B U S Y} \\ \hline \end{array}$ | $\begin{aligned} & 42 \\ & M \bar{S} \end{aligned}$ | $\frac{40}{\overline{I N T}_{R}}$ | 38 A1R | 36 <br> A3R |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 10 | $\int_{A \pi}^{53}$ |  | ${ }^{49} \quad \text { A3L }$ | A1L | $\frac{45}{\mathrm{INTL}^{2}}$ | $43$ | $\text { \| } 41$ | 39 <br> Aor | 37 <br> A2R | 35 <br> A4R | 34 <br> A5R |
| 09 | ${ }^{55} \mathrm{AgL}^{2}$ | $54$ <br> AsL | $\begin{gathered} \text { IDT7005 } \\ \text { 8K } \times 8 \text { DPR } \\ \text { IN } 68-\text { PIN PGA } \end{gathered}$ |  |  |  |  |  |  | 32 <br> A7R | 33 <br> A6R |
| 08 | $57$ <br> A11L | $56$ <br> A10L |  |  |  |  |  |  |  | 30 <br> AgR | $31$ <br> A8R |
| 07 | $\begin{aligned} & 59 \\ & V_{c c} \end{aligned}$ | 58 <br> A12L |  |  |  |  |  |  |  | $\begin{aligned} & 28 \\ & A_{11 R} \end{aligned}$ | $\begin{aligned} & 29 \\ & \mathrm{~A}_{10 \mathrm{R}} \end{aligned}$ |
| 06 | ${ }^{61} \mathrm{NC}$ | $\begin{gathered} 60 \\ \mathrm{NC} \end{gathered}$ |  |  |  |  |  |  |  | 26 GND | $\begin{aligned} & 27 \\ & A_{12 R} \end{aligned}$ |
| 05 | $\frac{63}{\overline{S E M} \mathrm{~L}}$ | $\begin{array}{\|c} \hline 62 \\ \overline{C E}_{L} \end{array}$ |  |  |  |  |  |  |  | $\begin{array}{r} 24 \\ \text { NC } \end{array}$ | $\begin{gathered} 25 \\ \mathrm{NC} \end{gathered}$ |
| 04 | ${ }^{65} \overline{O E}$ | 64 $\mathrm{R} / \overline{\mathrm{W}} \mathrm{L}$ |  |  |  |  |  |  |  | $\begin{aligned} & 22 \\ & \overline{S E M}_{R} \end{aligned}$ | ${\stackrel{23}{\overline{C E}_{R}}}^{\text {n }}$ |
| 03 | $\begin{aligned} & \hline 67 \\ & \mathrm{I} / \mathrm{O}_{\mathrm{OL}} \end{aligned}$ | $\begin{array}{\|c\|} \hline 66 \\ \text { NC } \end{array}$ |  |  |  |  |  |  |  | ${ }^{20} \overline{O E}_{\mathrm{R}}$ | $\begin{aligned} & { }^{21} \\ & \mathrm{R} \bar{W}_{\mathrm{R}} \end{aligned}$ |
| 02 | $\begin{aligned} & \hline 68 \\ & 1 / O_{11} \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 / O_{2 L} \end{aligned}$ | $\begin{aligned} & 3 \\ & \\ & V / O_{4} \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 5 \\ & \text { GND } \end{aligned}$ | $\begin{aligned} & 7 \\ & 1 / O_{7} . \end{aligned}$ | $9$ | $\begin{aligned} & 11 \\ & 1 / O_{1 R} \end{aligned}$ | $\begin{aligned} & 13 \\ & V c c \end{aligned}$ | $\begin{aligned} & 15 \\ & 1 / O_{4 R} \end{aligned}$ | $\begin{array}{\|l\|} \hline 18 \\ 1 / O_{7 R} \end{array}$ | $\begin{aligned} & 19 \\ & \mathrm{NC} \end{aligned}$ |
| 01 |  | $\begin{aligned} & 2 \\ & 1 / O_{3 L} \end{aligned}$ |  | $6$ | 8 <br> Vcc | 10 <br> I/O OR | $\begin{aligned} & 12 \\ & 1 / \mathrm{O}_{2 \mathrm{R}} \end{aligned}$ | $\begin{aligned} & 14 \\ & 1 / O_{3 R} \end{aligned}$ | $\begin{aligned} & 16 \\ & 1 / O_{5 R} \end{aligned}$ | $\begin{aligned} & 17 \\ & 1 / O_{6 R} \end{aligned}$ |  |
|  | A | B | C | D | E | F | G | H | J | K | L |

NOTES:

1. All Vcc pins must be connected to power supply.

PIN NAMES

| Left Port | Right Port | Names |
| :---: | :---: | :---: |
| $\overline{\mathrm{CE}} \mathrm{L}$ | $\overline{\mathrm{CE}}$ R | Chip Enable |
| $\mathrm{R} \bar{W} \mathrm{~L}$ | $\mathrm{R} / \bar{W}^{\text {R }}$ | Read/Write Enable |
| $\overline{\mathrm{OEL}}$. | $\overline{\mathrm{OE}} \mathrm{R}$ | Output Enable |
| AOL - A12L | AOR - A12R | Address |
| 1/OOL - 1/O7L | 1/OOR - 1/O7R | Data Input/Output |
| $\overline{\text { SEML }}$ | $\overline{\text { SEMR }}$ | Semaphore Enable |
| INTL | $\overline{\text { INTR }}$ | Interrupt Flag |
| $\overline{B U S Y L}$ | $\overline{B U S Y}^{\text {B }}$ | Busy Flag |
| M/S |  | Master or Slave Select |
| Vcc |  | Power |
| GND |  | Ground |

IDT7005S/L

TRUTH TABLE: NON-CONTENTION READ/WRITE CONTROL

| Inputs ${ }^{(1)}$ |  |  |  | Outputs | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E}$ | R $\bar{W}$ | $\overline{O E}$ | $\overline{\text { SEM }}$ | I/O-7 |  |
| H | X | X | H | Hi-Z | Deselected: Power Down |
| L | L | X | H | DATAIN | Write to Memory |
| L | H | L | H | DATAOUT | Read Memory |
| X | X | H | X | Hi-Z | Outputs Disabled |

NOTE:

1. $A O L-A_{12 L} \neq A 0 R-A_{12 R}$

TRUTH TABLE: SEMAPHORE READ/WRITE CONTROL

| Inputs |  |  |  | Outputs | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { CE }}$ | R/W | $\overline{\text { OE }}$ | $\overline{\text { SEM }}$ | I/Oo7 |  |
| H | H | L | L | DATAOUT | Read Data in Semaphore Flag |
| H | S | X | L | DATAIN | Write Dino into Semaphore Flag |
| L | X | X | L | - | Not Allowed |

2738 t| 02

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2738 bl 04

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.
CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 11 | pF |
| CouT | Output <br> Capacitance | $\mathrm{VOUT}=\mathrm{OV}$ | 11 | pF |

NOTE:
2738 tb 03

1. This parameter is determined by device characterization but is not production tested.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VcC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2738 \$106

1. $V_{i L} \geq-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Condltions | IDT7005S |  | IDT7005L |  | UnIt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \||L| | Input Leakage Current ${ }^{(5)}$ | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lLO) | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}$, VOUT $=0 \mathrm{~V}$ to VCC | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Voi | Output Low Voltage | $\mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $1 \mathrm{OH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | $V$ |

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IcC | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\mathrm{CE}} \leq V_{I I}, \text { Outputs Open } \\ & \overline{\mathrm{SE}} \geq \mathrm{V}_{\text {IH }} \\ & \mathrm{f}=\mathrm{fMAX}^{(3)} . \end{aligned}$ | MIL. S | - | - | mA |
|  |  |  | COM'L. S | - | 340 290 |  |
| ISB1 | Standby Current (Both Ports — TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CE}} \mathrm{R}=\overline{\mathrm{CE}} \mathrm{~L} \geq \mathrm{V}_{\mathrm{V}} \\ & \overline{\mathrm{SEM}} \mathrm{R}=\overline{\mathrm{SEM} L} \geq \mathrm{VIH}^{2} \\ & \mathrm{f}=\mathrm{f}_{\mathrm{MAX}}{ }^{(3)} \end{aligned}$ | MIL. $\quad \mathrm{S}$ | - | - | mA |
|  |  |  | COM'L. | - | 70 50 |  |
| ISB2 | Standby Current <br> (One Port — TTL <br> Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{V} \mathrm{V}$ Active Port Outputs Open$\begin{aligned} & f=f_{M A X}{ }^{(3)} \\ & \overline{S E M R}=\overline{\text { SEM }} \mathrm{L} \geq \mathrm{V} I H \end{aligned}$ | MIL. S | - | - | mA |
|  |  |  | COM'L. | - | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | Both Ports $\overline{C E} L$ and $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> VIN $\geq$ Vcc - 0.2 V or $\mathrm{V} \ln \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(4)}$ <br> $\overline{S E M R}=\overline{S E M} L \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ | MIL. | - | $\overline{10}$ | mA |
|  |  |  | COM'L. ${ }^{\text {S }}$ | 二 | 15 5 |  |
| ISB4 | Full Standby Current (One Port — All CMOS Level Inputs) | One Port $\overline{C E} L$ or $\overline{C E} \mathrm{R} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ <br> $\overline{\mathrm{SEM}} \mathrm{R}=\overline{\mathrm{SEM}} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ <br> VIN $\geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{IN}} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=f M A X^{(3)}$ | MIL. $\quad \mathrm{S}$ | - | - | mA |
|  |  |  | COM'L. $\begin{array}{ll}\text { S } \\ & \\ & L\end{array}$ | - | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ |  |

NOTES:
2738 tol 08

1. $X$ in part numbers indicates power rating ( $S$ or $L$ )
2. $V c c=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. At $f=$ fmax, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 /$ trc, and using "AC Test Conditions" of input levels of GND to 3 V .
4. $f=0$ means no address or control lines change.
5. At $\mathrm{VCC} \leq 1.0 \mathrm{~V}$ input leakages are undefined.

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$（Continued）（VCC $=5.0 \mathrm{~V} \pm 10 \%$ ）

| Symbol | Parameter | Test Condition | Version | 700 Typ．${ }^{(2)}$ | X45 Max． | $\begin{array}{r} 7005 \\ \text { Typ. }{ }^{(2)} \\ \hline \end{array}$ | $\begin{aligned} & \text { X55 } \\ & \text { Max. } \end{aligned}$ |  | X70 NLY Max． | Unlt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC | Dynamic Operating Current （Both Ports Active） | $\begin{aligned} & \overline{\mathrm{CE}} \leq V_{\text {IL }}, \text { Outputs Open } \\ & \mathrm{SEM} \geq V_{I H} \\ & f=\mathrm{fMAX}^{(3)} \end{aligned}$ | $\begin{array}{\|ll} \hline \text { MIL. } & \mathrm{S} \\ & \\ \hline \end{array}$ | － | $\begin{aligned} & 400 \\ & 340 \end{aligned}$ | － | $\begin{aligned} & 395 \\ & 335 \end{aligned}$ | 二 | $\begin{aligned} & 390 \\ & 330 \end{aligned}$ | mA |
|  |  |  | COM＇L． $\begin{array}{ll}\text { S } \\ & \text { L }\end{array}$ | － | $\begin{aligned} & 340 \\ & 290 \end{aligned}$ | － | $\begin{aligned} & 335 \\ & 285 \end{aligned}$ | － | － |  |
| ISB1 | Standby Current （Both Ports — TTL Level Inputs） | $\begin{aligned} & \overline{\mathrm{CE} L}=\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{I H} \\ & \overline{\mathrm{SEM}}=\overline{\mathrm{SEML}} \geq \mathrm{V}_{I H} \\ & \mathrm{f}=\mathrm{f} M A \mathrm{X}^{(3)} \end{aligned}$ | MIL．  <br>  S | 二 | 85 | － | 85 | 二 | 85 | mA |
|  |  |  | COM＇L． $\begin{array}{r}\text { S } \\ \\ \hline\end{array}$ | 三－ | 70 50 | － | 70 50 | － | － |  |
| ISB2 | Standby Current （One Port — TTL Level Inputs） | $\overline{\mathrm{CE}} \mathrm{R}$ or $\overline{\mathrm{CE}} \mathrm{L} \geq \mathrm{VIH}_{\mathrm{I}}$ Active Port Outputs Open$\frac{f=f M A X}{}{ }^{(3)} \overline{S E M}=\overline{S E M} L \geq V_{I H}$ | $\begin{array}{\|ll} \hline \text { MIL. } & \mathrm{S} \\ & \mathrm{~L} \end{array}$ | － | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | 二 | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | － | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | mA |
|  |  |  | COM＇L． S | － | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ | － | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ | － | － |  |
| IsB3 | Full Standby Current （Both Ports－All CMOS Level Inputs） | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and <br> $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> VIN $\geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or <br> $\mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(4)}$ <br> $\overline{S E M R}=\overline{S E M} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ | MIL．$\quad$ S | － | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | － | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | － | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  |  |  | $\begin{array}{ll}\text { COM＇L．} & \mathrm{S} \\ & \mathrm{L}\end{array}$ | － | $\begin{gathered} \hline 15 \\ 5 \end{gathered}$ | － | $\begin{gathered} 15 \\ 5 \end{gathered}$ | － | － |  |
| ISB4 | Full Standby Current （One Port－All CMOS Level Inputs） | One Port CEL or <br> $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ <br> $\overline{S E M} \bar{R}=\overline{S E M} \geq V C c-0.2 V$ <br> $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or <br> $\mathrm{V} \mathbb{N} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open， $f=f_{\text {MAX }}{ }^{(3)}$ | MIL． $\begin{array}{ll}\text { S } \\ & \\ & \text { L }\end{array}$ | － | $\begin{aligned} & 260 \\ & 215 \end{aligned}$ | － | $\begin{aligned} & 260 \\ & 215 \end{aligned}$ | － | $\begin{aligned} & 260 \\ & 215 \end{aligned}$ | mA |
|  |  |  | $\begin{array}{ll}\text { COM＇L．} & \mathrm{S} \\ & \\ & \text { L }\end{array}$ | － | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ | － | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ | － | － |  |

## NOTES：

2738 ы 08
1．$X$ in part numbers indicates power rating（ $S$ or $L$ ）
2．$V c c=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ ．
3．At $f$＝fMAX，address and data inputs（except Output Enable）are cycling at the maximum frequency of read cycle of $1 /$ thc，and using＂AC Test Conditions＂ of input levels of GND to 3 V ．
4．$f=0$ means no address or control lines change．
5．At Vcc $\leq 1.0 \mathrm{~V}$ input leakages are undefined．

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES (L Version Only) (VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{VCC}-0.2 \mathrm{~V}$ )

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & \overline{\mathrm{CE}} \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \leq \mathrm{VLC} \end{aligned}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | - | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | - | 1500 |  |
| tCDR ${ }^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | tRC ${ }^{(2)}$ | - | - | ns |

NOTES:
2738 th 09

1. $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{Vcc}=2 \mathrm{~V}$
2. $\operatorname{tRC}=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | $5 \mathrm{~ns} \mathrm{Max}$. |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |
| 2738 |  |



Figure 1. Output Load


Figure 2. Output Load (for thz, thz, twz, tow)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(4)}$| Symbol | Parameter | IDT7005X35 COM'L ONLY |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| READ CYCLE |  |  |  |  |
| trC | Read Cycle Time | 35 | - | ns |
| tAA | Address Access Time | - | 35 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 35 | ns |
| taoe | Output Enable Access Time | - | 20 | ns |
| tor | Output Hold from Address Change | 3 | - | ns |
| tLz | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | 3 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | ns |
| tPu | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | ns |
| tSop | Semaphore Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\text { SEM }}$ ) | 15 | - | ns |


| Symbol | Parameter | IDT7005X45 |  | IDT7005X55 |  | $\begin{aligned} & \text { IDT7005X70 } \\ & \text { MIL ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 45 | - | 55 | - | 70 | ns |
| taoe | Output Enable Access Time | - | 25 | - | 30 | - | 35 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | ns |
| tLz | Output Low Z Time ${ }^{(1,2)}$ | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | ns |
| tSOP | Semaphore Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\mathrm{SEM}}$ ) | 15 | - | 15 | - | 15 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. To access RAM, $\overline{C E}=L, \overline{S E M}=H$.
4. $X$ in part numbers indicates power rating ( $S$ or $L$ ).

## WAVEFORM OF READ CYCLES ${ }^{(5)}$



## NOTES:

1. Timing depends on which signal is asserted last, $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
2. Timing depends on which signal is de-asserted first $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$.
3. Required only if busy logic is being used to prevent read data corruption, during simultaneous accesses to the same location, in masters and master-slave width expansions.
4. Start of valid data depends on which timing becomes effective last tABE, tAOE, LACE, tAA or tBDD.
5. $S E M=H$.

TIMING OF POWER-UP POWER-DOWN


## AC ELECTRICAL CHARACTERISTICS OVER THE

## OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(5)}$

| Symbol | Parameter | IDT7005X35 COM'L ONLY |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |
| twe | Write Cycle Time | 35 | - | ns |
| tEW | Chip Enable to End of Write ${ }^{(3)}$ | 30 | - | ns |
| taw | Address Valid to End of Write | 30 | - | ns |
| tAS | Address Set-up Time ${ }^{(3)}$ | 0 | - | ns |
| twp | Write Pulse Width | 30 | - | ns |
| twR | Write Recovery Time | 0 | - | ns |
| tDW | Data Valid to End of Write | 25 | - | ns |
| thz | Output High Z Time ${ }^{(1 ; 2)}$ | - | 15 | ns |
| tDH | Data Hold Time ${ }^{(4)}$ | 0 | - | ns |
| twz | Write Enable to Output in High $\mathbf{Z}^{(1,2)}$ | - | 15 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 0 | - | ns |
| tSWRD | $\overline{\text { SEM }}$ Flag Write to Read Time | 10 | - | ns |
| tSPS | $\overline{\text { SEM }}$ Flag Contention Window | 10 | - | ns |


| Symbol | Parameter | IDT7005X45 |  | IDT7005X55 |  | $\begin{aligned} & \text { IDT7005X70 } \\ & \text { MIL. ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twe | Write Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| tEW | Chip Enable to End of Write ${ }^{(3)}$ | 40 | - | 45 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 40 | - | 45 | - | 50 | - | ns |
| tAS | Address Set-up Time ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| twn | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data Valid to End of Write | 25 | - | 30 | - | 40 | - | ns |
| t HZ | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tDH | Data Hold Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enable to Output in High $\mathbf{Z}^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tSWRD | $\overline{\text { SEM Flag Write to Read Time }}$ | 10 | - | 10 | - | 10 | - | ns |
| tSPS | $\overline{\text { SEM }}$ Flag Contention Window | 10 | - | 10 | - | 10 | - | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. To access RAM, $\overline{C E}=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 tEw time.
4. The specification for toh must be met by the device supplying write data to the RAM under all operating conditions. Although toH and tow values will vary over voltage and temperature, the actual toH will always be smaller than the actual tow.
5. X in part numbers indicates power rating ( S or L ).

TIMING WAVEFORM OF WRITE CYCLE NO. $1, \mathrm{R} / \overline{\mathrm{W}}$ CONTROLLED TIMING ${ }^{(1,3,5,8)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2, $\overline{\text { CE }}$ CONTROLLED TIMING ${ }^{(1,3,5,8)}$


## NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R \bar{W}$ for memory array writing cycle.
3. twR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ (or $\overline{S E M}$ or $R \bar{W}$ ) going high to the end of write cycle.
4. During this period, the $I / O$ pins are in the output state and input signals must not be applied.
5. If the $\overline{C E}$ or $\overline{\text { SEM }}$ low transition occurs simultaneously with or after the $\mathrm{R} \bar{W}$ low transition, the outputs remain in the high impedance state.
6. Timing depends on which enable signal is asserted last.
7. Timing depends on which enable signal is de-asserted first.
8. If $\overline{O E}$ is low during $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or ( $\mathrm{twZ}+$ tow) to allow the $I / O$ drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ 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 tw.

## TIMING WAVEFORM OF SEMAPHORE READ AFTER WRITE TIMING, EITHER SIDE ${ }^{(1)}$



NOTE:

1. $\overline{\mathrm{CE}}=\mathrm{H}$ for the duration of the above timing (both write and read cycle).

TIMING WAVEFORM OF SEMAPHORE WRITE CONTENTION ${ }^{(1,3,4)}$


NOTES:

1. $\operatorname{DOR}=\mathrm{DoL}=\mathrm{L}, \overline{C E}_{\mathrm{R}}=\overline{\mathrm{CE}} \mathrm{L}=\mathrm{H}$, Semaphore Flag is released from both sides (reads as ones from both sides) at cycle start.
2. " $A$ " may be either left or right port. " $B$ " is the opposite port from " $A$ ".
3. This parameter is measured from $R / \bar{W}_{A}$ or SEMA going high to $R \bar{W}_{B}$ or $\overline{S E M B}$ going high.
4. If tsps is violated, the semaphore will fall positively to one side or the other, but there is not guarantee which side will obtain the flag.

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(6)}$

| Symbol | Parameter | $\begin{aligned} & \text { IDT7005X35 } \\ & \text { COM'L ONLY } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| BUSY TIMING (M/ $\bar{S}=\mathrm{H}$ ) |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 35 | ns |
| tBDA | BUSY Disable Time to Address | - | 30 | ns |
| tBac | $\overline{\text { BUSY Access Time to Chip Enable }}$ | - | 30 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 25 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(2)}$ | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 3 | ns |
| BUSY TIMING (M/ $\bar{S}=\mathrm{L}$ ) |  |  |  |  |
| twb | $\overline{\text { BUSY }}$ Input to Write ${ }^{(4)}$ | 0 | - | ns |
| twh | Write Hold After $\overline{\text { BUSY }}^{(5)}$ | 25 | - | ns |
| PORT-TO-PORT DELAY TIMING |  |  |  |  |
| twDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 60 | ns |
| tDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 45 | ns |


| Symbol | Parameter | IDT7005X45 |  | IDT7005X55 |  | IDT7005X70MILL. ONLY |  | Unlt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (M/ $\bar{S}=\mathrm{H})$ |  |  |  |  |  |  |  |  |
| tBAA | $\overline{\text { BUSY Access Time to Address }}$ | - | 35 | - | 45 | - | 45 | ns |
| tBDA | BUSY Disable Time to Address | - | 30 | - | 40 | - | 40 | ns |
| tBAC | $\overline{\text { BUSY }}$ Access Time to Chip Enable | - | 30 | - | 40 | - | 40 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 25 | - | 35 | - | 35 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(2)}$ | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 3 | - | Note 3 | - | Note 3 | ns |
| BUSY TIMING (M/ $\bar{S}=\mathrm{L}$ ) |  |  |  |  |  |  |  |  |
| tWB | $\overline{\text { BUSY }}$ Input to Write ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tWH | Write Hold After $\overline{\text { BUSY }}{ }^{(5)}$ | 25 | - | 25 | - | 25 | - | ns |
| PORT-TO-PORT DELAY TIMING |  |  |  |  |  |  |  |  |
| tWDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 70 | - | 80 | - | 95 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 55 | - | 65 | - | 80 | ns |

## NOTES:

1. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With $\overline{\mathrm{BUS}} \overline{\mathrm{Y}}(\mathrm{M} \overline{\mathrm{S}}=\mathrm{H})$ ".
2. To ensure that the earlier of the two ports wins.
3. tBDD is a calculated parameter and is the greater of 0 , tWDD - tWP (actual) or tDDD - tDW (actual).
4. To ensure that the write cycle is inhibited during contention.
5. To ensure that a write cycle is completed after contention.
6. " $x$ " is part numbers indicates power rating ( S or L ).
7. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With $\overline{B U S Y}(M \bar{S}=L)$ ".

TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}{ }^{(2)}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{H})$


NOTES:

1. To ensure that the earlier of the two ports wins.
2. $\overline{\mathrm{CE}}_{\mathrm{L}}=\overline{\mathrm{CE}} \mathrm{R}=\mathrm{L}$
3. $\overline{\mathrm{OE}}=\mathrm{L}$ for the reading port.

TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DELAY ${ }^{(1,2)}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{L})$


NOTES
2. $\overline{C E} L=\overline{C E} R=L$

TIMING WAVEFORM OF SLAVE WRITE (M/ $\overline{\mathbf{S}}=\mathrm{L})$


## WAVEFORM OF BUSY ARBITRATION CONTROLLED BY $\overline{C E} \operatorname{TIMING}{ }^{(1)}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{H})$



## WAVEFORM OF BUSY ARBITRATION CYCLE CONTROLLED BY ADDRESS MATCH TIMING ${ }^{(1)}(\mathrm{M} / \mathrm{S}=\mathrm{H})$



## NOTES:

1. All timing is the same for left and right ports. Port " $A$ " may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. If taps is violated, the busy signal will be asserted on one side or another but there is no guarantee on which side busy will be asserted.

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$| Symbol | Parameter | IDT7005X35 COM'L ONLY |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| INTERRUPT TIMING |  |  |  |  |
| tas | Address Set-up Time | 0 | - | ns |
| twR | Write Recovery Time | 0 | - | ns |
| tins | Interrupt Set Time | - | 30 | ns |
| tINR | Interrupt Reset Time | - | 30 | ns |



## WAVEFORM OF INTERRUPT TIMING ${ }^{(1)}$



## NOTES:

1. All timing is the same for left and right ports. Port "A" may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. See Interrupt truth table.
3. Timing depends on which enable signal is asserted last.
4. Timing depends on which enable signal is de-asserted first.

## TRUTH TABLES

TRUTH TABLE I - INTERRUPT FLAG ${ }^{(1)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{R} / \bar{W}$ L | $\overline{\mathrm{CE}} \mathrm{L}$ | $\overline{\mathrm{OE}}$ | AOL-A12L | $\overline{\text { INTL }}$ | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | $\overline{\text { CEF }}$ | $\overline{\mathrm{OE}}_{\mathrm{R}}$ | Aor-A12R | $\overline{\mathrm{INT}}_{\text {R }}$ |  |
| L | L | X | 1FFF | X | X | X | X | X | $L^{(2)}$ | Set Right $\overline{N T T R}$ Flag |
| X | X | $x$ | X | X | X | L | L | 1FFF | $\mathrm{H}^{(3)}$ | Reset Right INTR Flag |
| X | X | X | X | $L^{(3)}$ | L | L | X | 1FFE | X | Set Left INTL Flag |
| X | L | L | 1FFE | $\mathbf{H}^{(2)}$ | X | X | X | X | X | Reset Left $\overline{\text { NTL }}$ Flag |

NOTES:
2738 tbl 15

1. Assumes $\overline{B U S Y} L=\overline{B U S Y} \bar{R}=H$.
2. If $\overline{B U S Y L}=L$, then no change.
3. If $\mathrm{BUSY}_{\mathrm{R}}=\mathrm{L}$, then no change.

## TRUTH TABLE II - ADDRESS BUSY <br> ARBITRATION

| Inputs |  |  | Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E L}$ | $\overline{\mathrm{CE}}$ R | $\begin{aligned} & \text { AoL-A12L } \\ & \text { AoR-A12R } \end{aligned}$ | $\overline{\text { BUSYL }}{ }^{(1)}$ | $\overline{B U S Y}^{(1)}$ |  |
| X | X | NO MATCH | H | H | Normal |
| H | X | MATCH | H | H | Normal |
| X | H | MATCH | H | H | Normal |
| L | L | MATCH | (2) | (2) | Write Inhibit ${ }^{(3)}$ |

NOTES:
2738 bt 16

1. Pins $\overline{B U S Y L}$ and $\overline{B U S Y} \bar{R}$ are both outputs when the part is configured as a master. Both are inputs when configured as a slave. $\overline{B U S Y} \times$ outputs on the IDT7005 are push pull, not open drain outputs. On slaves the BUSYx input internally inhibits writes.
2. Lif the inputs to the opposite port were stable prior to the address and enable inputs of this port. H if the inputs to the opposite port became stable after the address and enable inputs of this port. If taPs is not met, either $\overline{B U S Y L}$ or $\overline{B U S Y}=$ Low will result. BUSYL and BUSYR outputs cannot be low simultaneouly.
3. Writes to the left port are internally ignored when $\overline{B U S Y}$ L outputs are driving low regardless of actual logic level on the pin. Writes to the right port are internally ignored when BUSYR outputs are driving low regardless of actual logic level on the pin.

TRUTH TABLE III - EXAMPLE OF SEMAPHORE PROCUREMENT SEQUENCE ${ }^{(1)}$

| Functions | Do - D7 Left | Do - D7 Right |  |
| :--- | :---: | :---: | :--- |
| 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 | Right port has semaphore token |
| Left Port Writes "1" to Semaphore | 1 | 1 | Semaphore free |

NOTE:

1. This table denotes a sequence of events for only one of the eight semaphores on the IDT7005.


Figure 3. Busy and chip enable routing for both width and depth expansion with IDT7005 RAMs.

## FUNCTIONAL DESCRIPTION

The IDT7005 provides two ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. The IDT7005 has an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{\mathrm{CE}}$. high). When a port is enabled, access to the entire memory array is permitted.

## INTERRUPTS

If the user chooses to use the interrupt function, a memory location (mail box ormessage center) is assigned to each port. The left port interrupt flag ( $\overline{\mathrm{NT}}$ ) is set when the right port writes to memory location 1FFE (HEX). The left port clears the interrupt by reading address location 1FFE. Likewise, the right port interrupt flag ( $\overline{\mathrm{NT}_{R}}$ ) is set when the left port writes to memory location 1FFF (HEX) and to clear the interrupt flag (INTR), the right port must read the memory location 1 FFF . The message ( 8 bits) at 1FFE or 1 FFF is user-defined. If the interrupt function is not used, address locations 1FFE and 1FFF are not used as mail boxes, but as part of the random access memory. Refer to Table I for the interrupt operation.

## BUSY LOGIC

Busy Logic provides a hardware indication that both ports of the RAM have accessed the same location at the same time. It also allows one of the two accesses to proceed and signals the other side that the RAM is "busy". The busy pin can then be usedto stalit the access until the operation on the other side is completed. If a write operation has been attempted from the side that receives a busy indication, the write signal is gated internally to prevent the write from proceeding.

The use of busy logic is not required or desirable for all applications. In some cases it may be useful to logically OR the busy outputs together and use any busy indication as an interrupt source to flag the event of an illegal or illogical
operation. If the write inhibit function of busy logic is not desirable, the busy logic can be disabled by placing the part in slave mode with the $M / \bar{S}$ pin. Once in slave mode the $\overline{B U S Y}$ pin operates solely as a write inhibit input pin. Normal operation can be programmed by tying the BUSY pins high. If desired; unintended write operations can be prevented to a port by tying the busy pin for that port low.

The busy outputs on the IDT 7005 RAM in master mode, are push-pull type outputs and do not require pull up resistors to operate. If these RAMs are being expanded in depth, then the busy indication for the resulting array requires the use of an external AND gate.

## WIDTH EXPANSION WITH BUSY LOGIC MASTER/SLAVE ARRAYS

When expanding an IDT7005 RAM array in width while using busy logic, one master part is used to decide which side of the RAM array will receive a busy indication, and to output that indication. Any number of slaves to be addressed in the same address range as the master, use the busy signal as a write inhibit signal. Thus on the IDT7005 RAM the busy pin is an output if the part is used as a master ( $\mathrm{M} / \overline{\mathrm{S}} \mathrm{pin}=\mathrm{H}$ ), and the busy pin is an input if the part used as a slave ( $M / \bar{S}$ pin $=\mathrm{L}$ ).

If two or more master parts were used when expanding in width, a split decision could result with one master indicating busy on one side of the array and another master indicating busy on one other side of the array. This would inhibit the write operations from one port for part of a word and inhibit the write operations from the other port for the other part of the word.

The busy arbitration, on a master, is based on the chip enable and address signals only. It ignores whether an access is a read or write. In a master/slave array, both address and chip enable must be valid long enough for abusy flag to be output from the master before the actual write pulse can be initiated with the $\mathrm{R} / \overline{\mathrm{W}}$ signal. Failure to observe this timing can result in a glitched internal write inhibit signal and corrupted data in the slave.

## SEMAPHORES

The IDT7005 is an extremely fast dual-port $8 \mathrm{~K} \times 8$ CMOS static RAM with an additional 8 address locations dedicated to binary semaphore flags. These flags allow either processor on the left or right side of the dual-port RAM to claim a privilege over the other processor for functions defined by the system designer's software. As an example, the semaphore can be used by one processor to inhibit the other from accessing a portion of the dual-port RAM or any other shared resource.

The dual-port RAM features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Both ports are identical in function to standard CMOS static RAM and can be read from, or written to, at the same time with the only possible conflict arising from the simultaneous writing of, or a simultaneous READ/WRITE of, a non-semaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the non-semaphore portion of the dual-port RAM. These devices have an automatic power-down feature controlled by $\overline{C E}$, the dual-port RAM enable, and $\overline{S E M}$, the semaphore enable. The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{SEM}}$ pins control on-chip power down circuitry that permits the respective port to go into standby mode when not selected. This is the condition which is shown in Truth Table where $\overline{\mathrm{CE}}$ and $\overline{\text { SEM }}$ are both high.

Systems which can best use the IDT7005 contain multiple processors or controllers and are typically very high-speed systems which are software controlled or software intensive. These systems can benefit from a performance increase offered by the IDT7005's hardware semaphores, which provide a lockout mechanism without requiring complex, programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be allocated in varying configurations. The IDT7005 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture.

An advantage of using semaphores rather than the more common methods of hardware arbitration is that wait states are never incurred in either processor. This can prove to be a major advantage in very high-speed systems.

## HOW THE SEMAPHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independent of the dual-port RAM. These latches can be used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment method called "Token Passing Allocation." In this method, the state of a semaphore latch is used as a token indicating that shared resource is in use. If the left processorwants to use this resource, it requests the token by setting the latch. This processor then verifies its success in setting the latch by reading it. If it was successful, it proceeds to assume control over the shared resource. If it was not successful in setting the latch, it determines that the
right side processor has set the latch first, has the token and is using the shared resource. The left processor can then either repeatedly request that semaphore's status or remove its request for that semaphore to perform another task and occasionally attempt again to gain control of the token via the set and test sequence. Once the right side has relinquished the token, the left side should succeed in gaining control.

The semaphore flags are active low. A token is requested by writing a zero into a semaphore latch and is released when the same side writes a one to that latch.

The eight semaphore flags reside within the IDT7005 in a separate memory space from the dual-port RAM. This address space is accessed by placing a low input on the $\overline{\text { SEM }}$ pin (which acts as a chip select for the semaphore flags) and using the other control pins (Address, $\overline{O E}$, and $R / \bar{W}$ ) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through address pins A0-A2. When accessing the semaphores, none of the other address pins has any effect.

When writing to a semaphore, only data pin Do is used. If a low level is written into an unused semaphore location, that flag will be set to a zero on that side and a one on the other side (see Table III). That semaphore can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be set to a one for both sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. (A thorough discussing on the use of this feature follows shortly.) A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.

When a semaphore flag is read, its value is spread into all data bits so that a flag that is a one reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE}}$ ) signals go active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal (SEM or $\overline{\mathrm{OE}}$ ) to go inactive or the output will never change.

A sequence WRITE/READ must be used by the semaphore in order to guarantee that no systemlevel contention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as one, a fact which the processor will verify by the subsequent read (see Table III). As an example, assume a processor writes a zero to the left port at a free semaphore location. On a subsequent read, the processor will verify that it has written successfully to that location and will assume control over the resource in question. Meanwhile, if a processor on the right side attempts to write a zero to the same semaphore flag it will fail, as will be verified by the fact that a one will be read from
that semaphore on the right side during subsequent read. Had a sequence of READ/WRITE been used instead, system contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed by either repeated reads or by writing a one into the same location. The reason for this is easily understood by looking at the simple logic diagram of the semaphore flag in Figure 4. Two semaphore request latches feed into a semaphore flag. Whichever latch is first to present a zero to the semaphore flag will force its side of the semaphore flag low and the other side high. This condition will continue until a one is written to the same semaphore request latch. Should the other side's semaphore request latch have been written to a zero in the meantime, the semaphore flag will flip over to the other side as soon as a one is written into the first side's request latch. The second side's flag will now stay low until its semaphore request latch is written to a one. From this it is easy to understand that, if a semaphore is requested and the processor which requested it no longer needs the resource, the entire system can hang up until a one is written into that semaphore request latch.

The critical case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is specially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side is earlier than the other in making the request, the first side to make the request will receive the token. If both requests arrive at the same time, the assignment will be arbitrarily made to one port or the other.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, it semaphores are misused or misinterpreted, a software error can easily happen.

Initialization of the semaphores is not automatic and must be handled via the initialization program at power-up. Since any semaphore request flag which contains a zero must be reset to a one, all semaphores on both sides should have a one written into them at initialization from both sides to assure that they will be free when needed.

## USING SEMAPHORES-SOME EXAMPLES

Perhaps the simplest application of semaphores is their application as resource markers for the IDT7005's dual-port RAM. Say the $8 \mathrm{~K} \times 8$ RAM was to be divided into two $4 \mathrm{~K} \times 8$ blocks which were to be dedicated at any one time to servicing either the left or right port. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of memory.

To take a resource, in this example the lower 4 K of dual-port RAM, the processor on the left port could write and
then read a zero in to Semaphore 0 . If this task were successfully completed (a zero was read back rather than a one), the left processor would assume control of the lower 4 K . Meanwhile the right processor was attempting to gain control of the resource after the left processor, it would read back a one in response to the zero it had attempted to write into Semaphore 0. At this point, the software could choose to try and gain control of the second 4 K section by writing, then reading a zero into Semaphore 1. If it succeeded in gaining control, it would lock out the left side.

Once the left side was finished with its task, it would write a one to Semaphore 0 and may then try to gain access to Semaphore 1. If Semaphore 1 was still occupied by the right side, the left side could undo its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1. If the right processor performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 4 K blocks of dual-port RAM with each other.

The blocks do not have to be any particular size and can even be variable, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphores can even be assigned different meanings on different sides rather than being given a common meaning on different sides rather than being given a common meaning as was shown in the example above.

Semaphores are a useful form of arbitration in systems like disk interfaces where the CPU must be locked out of a section of memory during a transfer and the I/O device cannot tolerate any wait states. With the use of semaphores, once the two devices has determined which memory area was "off-limits" to the CPU, both the CPU and the I/O devices could access their assigned portions of memfory continuously without any wait states.

Semaphores are also useful in applications where no memory "WAIT" state is available on one or both sides. Once a semaphore handshake has been performed, both processors can access their assigned RAM segments at full speed.

Another application is in the area of complex data structures. In this case, block arbitration is very important. For this application one processor may be responsible for building and updating a data structure. The other processor then reads and interprets that data structure. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the two different processors. The building processor arbitrates for the block, locks it and then is able to go in and update the data structure. When the update is completed, the data structure block is released. This allows the interpreting processor to come back and read the complete data structure, thereby guaranteeing a consistent data structure.


2738 dnw 21
Figure 4. IDT7005 Semaphore Logle

ORDERING INFORMATION


HIGH-SPEED
PRELIMINARY
8K x 16 DUAL-PORT STATIC RAM
more than one device

- $M / \bar{S}=H$ for $\overline{B U S Y}$ output flag on Master $M / \bar{S}=L$ for $\overline{B U S Y}$ input on Slave
- Interrupt Flag
- On-chip port arbitration logic
- Full on-chip hardware support of semaphore signaling between ports
- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL compatible, single $5 \mathrm{~V}( \pm 10 \%)$ power supply.
- Available in 84-pin PGA, quad flatpack and PLCC


## DESCRIPTION:

The IDT7025 is a high-speed $8 \mathrm{~K} \times 16$ dual-port static RAM. The IDT7025 is designed to be used as a stand-alone 128Kbit dual-port RAM or as a combination MASTER/SLAVE dualport RAM for 32-bit-or-more word systems. Using the IDT

## FUNCTIONAL BLOCK DIAGRAM



MASTER/SLAVE dual-port RAM approach in 32-bit or wider memory system applications results in full-speed, error-free operation without the need for additional discrete logic.

This device provides two independent ports with separate control, address and $1 / O$ pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power down feature controlled by $\overline{\mathrm{CE}}$ permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only 500 mW or power at maximum access times as fast as 25 ns . Low-power (L) versions offer battery backup data retention capability with each port typically consuming $500 \mu \mathrm{~W}$ from a 2 V battery.

The IDT7025 is packaged in plastic as well as ceramic 84pin PGA and 84-pin quad flatpack and PLCC. The military devices are processed $100 \%$ in compliance to the test methods of MIL-STD-883, Method 5004.

## PIN CONFIGURATIONS



NOTES:

1. All Vcc pins must be connected to power supply.
2. All GND pins must be connected to ground supply.

## PIN CONFIGURATIONS (Continued)

| $\begin{aligned} & 63 \\ & 1 / O_{7 L} \end{aligned}$ | $\begin{aligned} & 61 \\ & 1 / O_{5 L} \end{aligned}$ | 60 I/O 4L | $\begin{aligned} & 58 \\ & \\ & \mathrm{I} / \mathrm{O}_{2 \mathrm{~L}} \\ & \hline \end{aligned}$ | 55 I/O OL | $\overline{\mathrm{OE}}_{\mathrm{L}}$ | $\frac{51}{S_{S E M}}$ | 48 <br> $\overline{\mathrm{LB}} \mathrm{L}$ | 46 A11L | 45 A 10 L | $\begin{array}{\|r\|} \hline 42 \\ A 7 L \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{\|l\|} \hline 66 \\ \mathrm{I} / \mathrm{O}_{10 \mathrm{~L}} \end{array}$ | 64 I/O 8 L | $\begin{aligned} & 62 \\ & 1 / O_{6 L} \end{aligned}$ | $\begin{array}{\|l\|l} 59 \\ 1 / O_{3 L} \end{array}$ | $\begin{aligned} & 56 \\ & 1 / O_{1 L} \end{aligned}$ | ${ }^{49} \overline{U B} L$ | ${ }^{50} \overline{\mathrm{CE}}$ | 47 <br> A 12 L | 44 <br> AgL | $43$ <br> A8L | $\mathrm{A}^{40} \mathrm{~A}$ |
| $\begin{aligned} & 67 \\ & \mathrm{I} / \mathrm{O}_{11 \mathrm{~L}} \end{aligned}$ | $\begin{aligned} & \hline 65 \\ & \mathrm{I} / \mathrm{O}_{9 \mathrm{~L}} \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & 57 \\ & \text { GND } \end{aligned}$ | $\begin{array}{\|l\|} \hline 53 \\ V_{c c} \end{array}$ | 52 $\mathrm{R} / \bar{W}_{\mathrm{L}}$ |  |  | 41 <br> A6L | $39$ <br> A4L |
| $\begin{array}{\|l\|} \hline 69 \\ 1 / O_{13 L} \end{array}$ | $\begin{aligned} & \hline 68 \\ & 1 / O_{12 L} \end{aligned}$ |  |  |  |  |  |  |  | 38 <br> A3L | $37$ <br> A2L. |
| $\begin{array}{\|l\|} \hline 72 \\ 1 / O_{15 L} \end{array}$ | ${ }_{71}^{71} \mathrm{O}_{14 \mathrm{~L}}$ | $\begin{array}{\|l\|} \hline 73 \\ V_{c c} \end{array}$ |  |  |  |  |  | $\frac{33}{\text { BUSY }}$ | 35 <br> Aol. |  |
| $\begin{array}{\|l\|} \hline 75 \\ \\ \hline \end{array} \mathrm{O}_{\mathrm{OR}}$ | $70$ | $\begin{aligned} & 74 \\ & \text { GND } \end{aligned}$ |  |  | IDT702 |  |  | 32 <br> GND | $31$ $M / \bar{S}$ | $36$ <br> A1L |
| $\begin{array}{\|l\|} \hline 76 \\ 1 / O_{1 R} \end{array}$ | $\begin{aligned} & \hline 77 \\ & 1 / O_{2 R} \end{aligned}$ | $\begin{aligned} & 78 \\ & V_{c c} \end{aligned}$ |  |  |  |  |  | 28 <br> AoR | $\frac{29}{\overline{N N T}_{R}}$ | $\left[\begin{array}{l} 30 \\ B_{B U S Y} \end{array}\right.$ |
| $\begin{array}{\|l\|} \hline 79 \\ 1 / O_{3 R} \end{array}$ | $\begin{aligned} & 80 \\ & 1 / O_{4 R} \end{aligned}$ |  |  |  |  |  |  |  | 26 <br> A2R | $\begin{aligned} & 27 \\ & A_{1 R} \end{aligned}$ |
| $\begin{aligned} & 81 \\ & 1 / O_{5 R} \end{aligned}$ | $\begin{aligned} & 83 \\ & / / O_{7 R} \end{aligned}$ |  |  | 7 <br> GND | $\begin{aligned} & 11 \\ & \text { GND } \end{aligned}$ | $\overline{\text { SEM }}^{12}$ |  |  | 23 <br> A5R | 25 <br> A3R |
| $\begin{array}{\|l\|} \hline 82 \\ 1 / O_{6 R} \end{array}$ | $\begin{aligned} & 1 \\ & 1 / O_{9 R} \end{aligned}$ | $\begin{aligned} & 2 \\ & \mathrm{I} / \mathrm{O}_{10 \mathrm{R}} \end{aligned}$ | $\begin{aligned} & 5 \\ & 1 / \mathrm{O}_{13 \mathrm{R}} \end{aligned}$ | $\begin{aligned} & \hline 8 \\ & 1 / O_{15 R} \end{aligned}$ | 10 $\mathrm{R} \bar{W}_{\mathrm{W}}$ | $\begin{aligned} & 14 \\ & \overline{U B}_{R} \end{aligned}$ | 17 <br> A11R | 20 <br> A8R | 22 <br> A6R | $24$ |
| $\begin{array}{\|l\|} \hline 84 \\ \mathrm{I} / \mathrm{O}_{8 \mathrm{R}} \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 3 \\ \\ \hline / / O_{11 R} \end{array}$ | $\begin{aligned} & 4 \\ & 1 / O_{12 R} \end{aligned}$ | $\begin{array}{ll} 6 \\ 1 / O_{14 R} \end{array}$ | $\overline{\mathrm{OE}}_{\mathrm{R}}$ | ${ }^{15} \overline{L B} \mathrm{R}$ | ${ }^{13} \overline{\mathrm{CE}}_{\mathrm{R}}$ | $16$ <br> A12R | 18 <br> A10R | 19 <br> AgR | 21 <br> A7R |
| A | B | - C | D | E | F | G | H | $J$ | K | L |
|  |  |  |  |  |  |  |  |  |  |  |

PIN NAMES

| Left Port | Right Port | Names |
| :---: | :---: | :---: |
| $\overline{\mathrm{CE}} \mathrm{L}$ | $\overline{\mathrm{CE}}$ R | Chip Enable |
| $\mathrm{R} \overline{\mathrm{W}} \mathrm{L}$ | $\mathrm{R} / \bar{W}_{\mathrm{B}}$ | Read/Write Enable |
| $\overline{O E L}$ | $\overline{\mathrm{OE}} \mathrm{R}$ | Output Enable |
| AOL - A12L | A0R - A12R | Address |
| I/OOL - I/O15L | I/OOR - I/O15R | Data Input/Output |
| $\overline{\text { SEML }}$ | $\overline{\text { SEM }}$ R | Semaphore Enable |
| $\overline{\text { UBL }}$ | $\overline{\mathrm{UB}} \mathrm{R}$ | Upper Byte Select |
| $\overline{\mathrm{LB}} \mathrm{L}$ | $\overline{\mathrm{LB}} \mathrm{R}$ | Lower Byte Select |
| INTL | INTR | Interrupt Flag |
| BUSYL | BUSYR | Busy Flag |
| M/ $\bar{S}$ |  | Master or Slave Select |
| Vcc |  | Power |
| GND |  | Ground |

## TRUTH TABLE: NON-CONTENTION READ/WRITE CONTROL

| Inputs ${ }^{(1)}$ |  |  |  |  |  | Outputs |  | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CE}}$ | R/W | $\overline{O E}$ | $\overline{\text { UB }}$ | $\overline{\text { LB }}$ | $\overline{\text { SEM }}$ | 1/O8-15 | V/OO-7 |  |
| H | X | X | X | X | H | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ | Deselected: Power Down |
| X | X | X | H | H | H | Hi-Z | $\mathrm{Hi}-\mathrm{Z}$ | Both Bytes Deselected: Power Down |
| L | L | X | L | H | H | DATAIN | Hi-Z | Write to Upper Byte Only |
| L | L | X | H | L | H | Hi-Z | DATAIN | Write to Lower Byte Only |
| L | L | X | L | L | H | DATAIN | DATAIN | Write to Both Bytes |
| L | H | L | L | H | H | DATAOUT | $\mathrm{Hi}-\mathrm{Z}$ | Read Upper Byte Only |
| L | H | L | H | L | H | $\mathrm{Hi}-\mathrm{Z}$ | DATAOUT | Read Lower Byte Only |
| L | H | L | L | L | H | DATAOUT | DATAOUT | Read Both Bytes |
| X | X | H | X | X | X | Hi-Z | $\mathrm{Hi}-\mathrm{Z}$ | Outputs Disabled |

NOTE:

1. $A O L-A_{12 L} \neq A_{0 R}-A_{12 R}$

TRUTH TABLE: SEMAPHORE READ/WRITE CONTROL

| Inputs |  |  |  |  |  | Outputs |  | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E}$ | R/ $\bar{W}$ | $\overline{O E}$ | $\overline{\text { UB }}$ | $\overline{\text { LB }}$ | SEM | I/O8-15 | 1/00-7 |  |
| H | H | L | X | X | L | DATAOUT | DATAOUT | Read Data in Semaphore Flag |
| X | H | L | H | H | L | DATAOUT | DATAOUT | Read Data in Semaphore Flag |
| H | $\sim$ | X | X | X | L | DATAIN | DATAIN | Write Dino into Semaphore Flag |
| X | - | X | H | H | L | DATAIN | DATAIN | Write Dino into Semaphoro Flag |
| L | X | X | L | X | L | - | - | Not Allowed |
| L | X | X | X | L | L | - | - | Not Allowed |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

2683 bl 04

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.
CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 11 | pF |
| CouT | Output <br> Capacitance | VouT $=0 \mathrm{~V}$ | 11 | pF |

## NOTE:

1. This parameter is determined by device characterization production tested.

## RECOMMENDED OPERATING

 TEMPERATURE AND SUPPLY VOLTAGE| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2683 tol 06

1. $V i L \geq-3.0 \mathrm{~V}$ for pulse width less than $20 n \mathrm{~s}$.

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE（ $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%$ ）

| Symbol | Parameter | Test Conditions | IDT7025S |  | IDT7025L |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min． | Max． | Min． | Max． |  |
| ｜ 1 Lu｜ | Input Leakage Current ${ }^{(5)}$ | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| ｜llol | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to Vcc | － | 10 | － | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{OL}=4 \mathrm{~mA}$ | － | 0.4 | － | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{OH}=-4 \mathrm{~mA}$ | 2.4 | － | 2.4 | － | V |

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version |  | X25 ONLY <br> Max． |  | X30 ONLY Max． | Typ．${ }^{(2)}$ | X35 Max． | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Icc | Dynamic Operating Current （Both Ports Active） | $\begin{aligned} & \overline{\mathrm{CE}} \leq V \mathbb{V}, \text {, Outputs Open } \\ & \mathrm{SEM} \geq V_{I H} \\ & f=\mathrm{fmax}^{(3)} \end{aligned}$ | MIL． S <br>  L | － | － | 二 | － | － | 400 340 | mA |
|  |  |  | COM＇L．S | － | $360$ | － | 350 300 | － | 340 290 |  |
| IS81 | Standby Current （Both Ports — TTL <br> Level Inputs） |  | MIL． S <br>  L | － | － | － | － | 二 | 85 | mA |
|  |  |  | COM＇L． $\begin{aligned} & \text { S } \\ & \\ & \text { L }\end{aligned}$ | － | 70 50 | － | 70 50 | － | 70 50 |  |
| IS8̣2 | Standby Current （One Port－TTL Level Inputs） | $\overline{\mathrm{CE}} \mathrm{or}$ or $\overline{\mathrm{CE}} \mathrm{Z} \geq \mathrm{VIH}^{\mathrm{C}}$ Active Port Outputs Open$\frac{f=f M A X^{(3)}}{\overline{S E M R}=\overline{S E M} \mathrm{~L} \geq V_{I H}}$ | MIL．$\quad \mathrm{S}$ | － | － | － | － | 二 | 290 | mA |
|  |  |  | $\begin{array}{ll}\text { COM＇L．} & \mathrm{S} \\ & \mathrm{L}\end{array}$ | － | $\begin{aligned} & 250 \\ & 220 \end{aligned}$ | － | $\begin{aligned} & 250 \\ & 215 \end{aligned}$ | － | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ |  |
| ISB3 | Full Standby Current （Both Ports－All CMOS Level Inputs） | $\begin{array}{\|l\|} \hline \text { Both Ports } \overline{C E L} \text { and } \\ \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 / \geq \leq 0.2 V, f=0^{(4)} \\ \overline{S E M} R=\overline{S E M} \geq V c c-0.2 \mathrm{~V} \\ \hline \end{array}$ | MIL． S <br>  L <br> COM＇L． S <br>  L <br>   | － | － | － | － | － | 30 10 | mA |
|  |  |  |  | － | $\begin{gathered} 15 \\ 5 \end{gathered}$ | － | 15 5 | － | 15 5 |  |
| ISB4 | Full Standby Current （One Port－All CMOS Level Inputs） | One Port $\overline{C E L}$ or <br> $\overline{\mathrm{CE}}_{\mathrm{R}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\overline{\mathrm{SEM}} \mathrm{R}=\overline{\mathrm{SEM}} \mathrm{L} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ <br> VIN $\geq$ Vcc－ 0.2 V or <br> Vin $\leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open， $f=f_{\text {MAX }}{ }^{(3)}$ | MIL． S <br>  $L$ <br>   <br> COM＇L． S <br>   <br>   | － | － | － | － | － | 260 <br> 215 <br> 220 | $\overline{m A}$ |
|  |  |  |  | － | 230 190 | － | 230 190 | － - | 220 180 |  |

## NOTES：

1．$X$ in part numbers indicates power rating（ $S$ or $L$ ）
2．$V C C=5 V, T_{A}=+25^{\circ} \mathrm{C}$ ．
3．At $f=f m a x$ ，address and data inputs（except Output Enable）are cycling at the maximum frequency of read cycle of $1 /$ thc，and using＂AC Test Conditions＂ of input levels of GND to 3 V ．
4．$f=0$ means no address or control lines change．
5．At Vcc $\leq 1.0 \mathrm{~V}$ input leakages are undefined．

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$ (Continued) (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Condition | Version | 7025 Typ. ${ }^{(2)}$ | X45 Max. | Typ. ${ }^{(2)}$ | $\begin{aligned} & \mathrm{X} 55 \\ & \text { Max. } \end{aligned}$ |  | X70 ONLY Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\mathrm{CE}} \leq \text { VIL, Outputs Open } \\ & \overline{\mathrm{SEM}} \geq \mathrm{VIH}^{\prime} \\ & f=\mathrm{fmax}^{(3)} \end{aligned}$ | MIL. $\begin{array}{ll}\text { S } \\ & \text { L }\end{array}$ | - | $\begin{aligned} & 400 \\ & 340 \end{aligned}$ | - | $\begin{aligned} & 395 \\ & 335 \end{aligned}$ | - | $\begin{aligned} & 390 \\ & 330 \end{aligned}$ | mA |
|  |  |  | COM'L. $\begin{array}{ll}\text { S } \\ & \text { L }\end{array}$ | - | $\begin{aligned} & 340 \\ & 290 \end{aligned}$ | - | $\begin{aligned} & 335 \\ & 285 \end{aligned}$ | - | - |  |
| ISB1 | Standby Current (Both Ports — TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CE}} \mathrm{~L}=\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{I H} \\ & \overline{\mathrm{SEM}} \mathrm{R}=\overline{\mathrm{SEMM} L \geq V_{I H}} \\ & \mathrm{f}=\mathrm{fmax}{ }^{(3)} \end{aligned}$ | $\begin{array}{ll}\text { MIL. } & \text { S } \\ & \text { L }\end{array}$ | - | $\begin{aligned} & 85 \\ & 65 \end{aligned}$ | - | $\begin{aligned} & 85 \\ & 65 \end{aligned}$ | - | 85 | mA |
|  |  |  | COM'L. $\begin{array}{ll}\text { S } \\ \\ \text { L }\end{array}$ | - | $\begin{aligned} & 70 \\ & 50 \end{aligned}$ | - | 70 50 | - | - |  |
| ISB2 | Standby Current (One Port — TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{R}$ or $\overline{\mathrm{CE}} \mathrm{L} \geq \mathrm{V}_{\mathrm{IH}}$ Active Port Outputs Open$\frac{f=f M A X}{} \frac{(3)}{S E M R}=\overline{S E M L} \geq V_{I H}$ | $\begin{array}{ll} \hline \text { MIL. } & \mathrm{S} \\ & \text { L } \end{array}$ | - | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | - | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | - | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | mA |
|  |  |  | COM'L. ${ }^{\text {S }}$ | - | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ | 二 | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ | - | - |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ | MIL. S <br>  L | - | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | mA |
|  |  | $\begin{aligned} & V I N \geq V c c-0.2 V \text { or } \\ & V I N \leq 0.2 V, f=0^{(4)} \\ & S E M R=\overline{S E M} L \geq V C C-0.2 V \end{aligned}$ | COM'L. $\begin{array}{ll}\text { S } \\ & \text { L }\end{array}$ | - | $\begin{gathered} 15 \\ 5 \end{gathered}$ | - | 15 5 | - | - |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs) | One Port $\overline{\mathrm{CE}} \mathrm{L}$ or <br> $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\overline{S E M R}=\overline{S E M} L \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or <br> VIN $\leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=f \text { MAX } x^{(3)}$ | $\begin{array}{ll}\text { MIL. } & \text { S } \\ & \\ & \text { L }\end{array}$ | - | $\begin{aligned} & 260 \\ & 215 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 260 \\ & 215 \end{aligned}$ | - | 260 215 | mA |
|  |  |  | $\begin{array}{ll}\text { COM'L. } & \mathrm{S} \\ & \\ & \text { L }\end{array}$ | - | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ | - | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ | - | - |  |

NOTES:
2683 tol 08

1. $X$ in part numbers indicates power rating ( $S$ or $L$ )
2. $V C C=5 V, T A=+25^{\circ} \mathrm{C}$.
3. At $\mathbf{f}=\mathrm{fuAx}$, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 /$ tre, and using "AC Test Conditions" of input levels of GND to 3 V .
4. $\mathbf{f}=0$ means no address or control lines change.
5. At $\mathrm{V} c \mathrm{~s} \leq 1.0 \mathrm{~V}$ input leakages are undefined.

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES (L Version Only)
(VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{Vcc}-0.2 \mathrm{~V}$ )

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unlt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & \overline{\mathrm{CE}} \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \leq \mathrm{VLC} \end{aligned}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | - | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | - | 1500 |  |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $t \mathrm{R}^{(3)}$ | Operation Recovery Time |  |  | tRC ${ }^{(2)}$ | - | - | ns |

NOTES:
2683 t 09

1. $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{Vcc}=2 \mathrm{~V}$
2. tRC = Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5ns Max. |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ | 2683 か 10



Figure 1. Output Load


Figure 2. Output Load (for tLz, thz, twz, tow)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(4)}$

| Symbol | Parameter | $\begin{aligned} & \text { IDT7025X25 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7025X30 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | IDT7025X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |

## READ CYCLE

| tRC | Read Cycle Time | 25 | 一 | 30 | - | 35 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tAA | Address Access Time | - | 25 | - | 30 | - | 35 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 25 | - | 30 | - | 35 | ns |
| tABE | Byte Enable Access Time ${ }^{(3)}$ | - | 25 | - | 30 | - | 35 | ns |
| taid | Output Enable Access Time | - | 13 | - | 15 | - | 20 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,2)}$ | 3 | - | 3 | - | 3 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | ns |
| tSOP | Semaphore Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{S E M}$ ) | 12 | - | 15 | - | 15 | - | ns |


| Symbol | Parameter | IDT7025X45 |  | IDT7025X55 |  | $\begin{aligned} & \text { IDT7025X70 } \\ & \text { MIL ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 45 | - | 55 | - | 70 | ns |
| tabe | Byte Enable Access Time ${ }^{(3)}$ | - | 45 | - | 55 | - | 70 | ns |
| taie | Output Enable Access Time | - | 25 | - | 30 | - | 35 | ns |
| tOH | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | ns |
| tLz | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | ns |
| tSOP | Semaphore Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\mathrm{SEM}}$ ) | 15 | - | 15 | - | 15 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. To access $\mathrm{RAM}, \overline{\mathrm{CE}}=L, \overline{\mathrm{UB}}$ or $\overline{\mathrm{LB}}=L, \overline{\mathrm{SEM}}=H$.
4. $X$ in part numbers indicates power rating ( $S$ or $L$ ).

## WAVEFORM OF READ CYCLES ${ }^{(5)}$



NOTES:

1. Timing depends on which signal is asserted last, $\overline{\mathrm{OE}}, \overline{\mathrm{CE}}, \overline{\mathrm{LB}}$, or $\overline{U B}$.
2. Timing depends on which signal is de-asserted first $\overline{C E}, \overline{O E}, \overline{\mathrm{LB}}$, or $\overline{\mathrm{UB}}$.
3. Required only if busy logic is being used to prevent read data corruption, during simultaneous accesses to the samelocation, in masters and master-slave width expansions.
4. Start of valid data depends on which timing becomes effective last tabe, taOE, tace, tAA or tadD.
5. $\overline{S E M}=H$.

TIMING OF POWER-UP POWER-DOWN


## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Symbol | Parameter | $\begin{aligned} & \text { IDT7025X25 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7025X30 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | IDT7025X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 25 | - | 30 | - | 35 | - | ns |
| tew | Chip Enable to End of Write ${ }^{(3)}$ | 20 | - | 25 | - | 30 | - | ns |
| LAW | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | ns |
| tAS | Address Set-up Time ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 20 | - | 25 | - | 30 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 15 | - | 20 | - | 25 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | ns |
| tDH | Data Hold Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enable to Output in High $\mathbf{Z}^{(1,2)}$ | - | 15 | - | 15 | - | 15 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tSWRD | $\overline{\text { SEM }}$ Flag Write to Read Time | 10 | - | 10 | - | 10 | - | ns |
| tSPS | $\overline{\text { SEM }}$ Flag Contention Window | 10 | - | 10 | - | 10 | - | ns |


| Symbol | Parameter | IDT7025X45 |  | IDT7025X55 |  | $\begin{aligned} & \text { IDT7025X70 } \\ & \text { MIL. ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twe | Write Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| tew | Chip Enable to End of Write ${ }^{(3)}$ | 40 | - | 45 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 40 | - | 45 | - | 50 | - | ns |
| tAS | Address Set-up Time ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| twr | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tDw | Data Valid to End of Write | 25 | - | 30 | - | 40 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tDH | Data Hold Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | 二 | ns |
| twz | Write Enable to Output in High $\mathbf{Z}^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tSWRD | SEM Flag Write to Read Time | 10 | - | 10 | - | 10 | - | ns |
| tSPS | $\overline{\text { SEM }}$ Flag Contention Window | 10 | - | 10 | - | 10 | - | ns |

NOTES

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2 ).
2. This parameter is guaranteed but not tested.
3. To access $R A M, \overline{C E}=L, \overline{U B}$ or $\overline{L 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 tew time.
4. The specification for toh must be met by the device supplying write data to the RAM under all operating conditions. Although toh and tow values will vary over voltage and temperature, the actual toH will always be smaller than the actual tow.
5. X in part numbers indicates power rating ( S or L ).

TIMING WAVEFORM OF WRITE CYCLE NO. $1, \mathrm{R} / \overline{\mathrm{W}}$ CONTROLLED TIMING ${ }^{(1,3,5,8)}$


TIMING WAVEFORM OF WRITE CYCLE NO. $2, \overline{\mathrm{CE}}, \overline{\mathrm{UB}}, \overline{\mathrm{LB}}$ CONTROLLED TIMING ${ }^{(1,3,5,8)}$


## NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{U B}$ or $\overline{L B}$ and a low $\overline{C E}$ and a low $R \bar{W}$ for memory array writing cycle.
3. TwR is measured from the earier of $\overline{C E}$ or $R \bar{W}$ (or SEM or $R \bar{W}$ ) going high to the end of write cycle.
4. During this period, the $I / O$ pins are in the output state and input signals must not be applied.
5. If the $\overline{C E}$ or $\overline{S E M}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. Timing depends on which enable signal is asserted last.
7. Timing depends on which enable signal is de-asserted first.
8. If $\overline{O E}$ is low during $\mathrm{R} \bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or (twz + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ 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 twp.

## timing waveform of semaphore read after write timing, Either side ${ }^{(1)}$



NOTE:

1. $\overline{C E}=H$ for the duration of the above timing (both write and read cycle).

## TIMING WAVEFORM OF SEMAPHORE WRITE CONTENTION ${ }^{(1,3,4)}$



## NOTES:

1. $D O R=D O L=L, \overline{C E} R=\overline{C E} L=H$, Semaphore Flag is released from both sides (reads as ones from both sides) at cycle start.
2. " A " may be either left or right port. " B " is the opposite port from " A ".
3. This parameter is measured from $\mathrm{R} / \bar{W}_{A}$ or $\overline{\text { SEMA }}^{2}$ going high to $\mathrm{R} \dot{\bar{W} B}$ or $\overline{\text { SEMB }}$ going high.
4. If tsps is violated, the semaphore will fall positively to one side or the other, but there is not guarantee which side will obtain the flag.

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(6)}$| Symbol | Parameter | $\begin{aligned} & \text { IDT } 7025 \times 25 \\ & \text { COM'L ONLY } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7025X30 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | IDT7025X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (M/S = H) |  |  |  |  |  |  |  |  |
| tBAA | $\overline{\text { BUSY Access Time to Address }}$ | - | 25 | - | 30 | - | 35 | ns |
| tBDA | BUSY Disable Time to Address | - | 20 | - | 25 | - | 30 | ns |
| tBAC | BUSY Access Time to Chip Enable or Byte Enable | - | 20 | - | 25 | - | 30 | ns |
| tBDC | $\overline{\text { BUSY }}$ Disable Time to Chip Enable or Byte Disable | - | 17 | - | 20 | - | 25 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(2)}$ | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 3 | - | Note 3 | - | Note 3 | ns |
| BUSY TIMING (M/5 = L) |  |  |  |  |  |  |  |  |
| twb | $\overline{\text { BUSY }}$ Input to Write ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After $\overline{\mathrm{BUSY}}{ }^{(5)}$ | 17 | - | 20 | - | 25 | - | ns |
| PORT-TO-PORT DELAY TIMING |  |  |  |  |  |  |  |  |
| tWDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 50 | - | 55 | - | 60 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 35 | - | 40 | - | 45 | ns |


| Symbal | Parameter | IDT7025X45 |  | IDT7025X55 |  | $\begin{aligned} & \text { IDT7025X70 } \\ & \text { MIL. ONLY } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (M/S = H) |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 35 | - | 45 | - | 45 | ns |
| tBDA | BUSY Disable Time to Address | - | 30 | - | 40 | - | 40 | ns |
| tBAC | BUSY Access Time to Chip Enable or Byte Enable | - | 30 | - | 40 | - | 40 | ns |
| tBDC | BUSY Disable Time to Chip Enable or Byte Disable | - | 25 | - | 35 | - | 35 | ns |
| taps | Arbitration Priority Set-up Time ${ }^{(2)}$ | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 3 | - | Note 3 | - | Note 3 | ns |
| BUSY TIMING (M/S = L) |  |  |  |  |  |  |  |  |
| twb | $\overline{\text { BUSY }}$ Input to Write ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After $\overline{\text { BUSY }}^{(5)}$ | 25 | - | 25 | - | 25 | - | ns |
| PORT-TO-PORT DELAY TIMING |  |  |  |  |  |  |  |  |
| tWDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 70 | - | 80 | - | 95 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 55 | - | 65 | - | 80 | ns |

## NOTES:

1. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With $\overline{\mathrm{BUSY}}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{H})$ ".
2. To ensure that the earlier of the two ports wins.
3. tBDD is a calculated parameter and is the greater of 0 , tWDD - tDW (actual) or tDDD - tWP (actual).
4. To ensure that the write cycle is inhibited during contention.
5. To ensure that a write cycle is completed after contention.
6. " $x$ " is part numbers indicates power rating ( S or L ).
7. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With $\overline{\mathrm{BUSY}}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{L})$ ".

## TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}^{(2)}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{H})$



NOTES:
2683 dmw 13

1. To ensure that the earlier of the two ports wins.
2. $\overline{\mathrm{CEL}}=\overline{\mathrm{CE}} \mathrm{R}=\mathrm{L}$
3. $\overline{O E}=L$ for the reading port.

TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DEL.AY ${ }^{(1,2)}$ (M/S = L)

2. BUSY input equal $\overline{\mathrm{C}} \mathrm{E}=\mathrm{L}$

TIMING WAVEFORM OF SLAVE WRITE (M/ $\overline{\mathbf{S}}=\mathrm{L}$ )


WAVEFORM OF BUSY ARBITRATION CONTROLLED BY $\overline{C E} \operatorname{TIMING}{ }^{(1)}(\mathbf{M} / \overline{\mathbf{S}}=\mathrm{H})$


WAVEFORM OF BUSY ARBITRATION CYCLE CONTROLLED BY ADDRESS MATCH $\operatorname{TIMING}{ }^{(1)}(\mathbf{M} / \mathbf{S}=H)$


## NOTES:

1. All timing is the same for left and right ports. Port " $A$ " may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. If taps is violated, the busy signal will be asserted on one side or another but there is no guarantee on which side busy will be asserted.

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$

| Symbol | Parameter | $\begin{aligned} & \text { IDT7025X25 } \\ & \text { COM'L ONLY } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7025X30 } \\ & \text { COM'L ONLY } \end{aligned}$ |  | IDT7025X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| INTERRUPT TIMING |  |  |  |  |  |  |  |  |
| tAs | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tins | Interrupt Set Time | - | 20 | - | 25 | - | 30 | ns |
| tINR | Interrupt Reset Time | - | 20 | - | 25 | - | 30 | ns |


| Symbol | Parameter | IDT7025X45 |  | ID77025X55 |  | $\begin{aligned} & \text { IDT7025X70 } \\ & \text { MIL. ONLY } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| INTERRUPT TIMING |  |  |  |  |  |  |  |  |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tins | Interrupt Set Time | - | 35 | - | 40 | - | 50 | ns |
| ting | Interrupt Reset Time | - | 35 | - | 40 | - | 50 | ns |

NOTE:

1. " $x$ " in part numbers indicates power rating (S or L).

## WAVEFORM OF INTERRUPT TIMING ${ }^{(1)}$




NOTES:

1. All timing is the same for left and right ports. Port " $A$ " may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. See Interrupt truth table.
3. Timing depends on which enable signal is asserted last.
4. Timing depends on which enable signal is de-asserted first.

## TRUTH TABLES

TRUTH TABLE I - INTERRUPT FLAG ${ }^{(1)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}_{\text {L }}$ | $\overline{C E L}$ | $\overline{O E L}$ | AOL-A12L | INTL | $\mathrm{R} / \bar{W}_{\mathrm{F}}$ |  | $\overline{O E}_{R}$ | AOR-A12R | INTR |  |
| L | L | X | 1FFF | X | X | X | X | X | $L^{(2)}$ | Set Right $\overline{\mathrm{NT}} \mathrm{T}$ R Flag |
| X | X | X | X | X | X | L | L | 1FFF | $H^{(3)}$ | Reset Right INTR Flag |
| X | X | X | X | $L^{(3)}$ | L | $L$ | X | 1FFE | X | Set Left INTLL Flag |
| X | L | L | 1FFE | $\mathrm{H}^{(2)}$ | X | X | X | X | X | Reset Left INTTL Flag |

## NOTES:

1. Assumes $\overline{B U S Y} L=\overline{B U S Y} R=H$.
2. If $\overline{B U S Y}=L$, then no change.
3. If $\overline{B U S Y} \bar{R}=L$, then no change.

## TRUTH TABLE II - ADDRESS BUSY

ARBITRATION

| Inputs |  |  | Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CE}} \mathrm{L}$ | $\overline{\text { CEER }}$ | AOL-A12L <br> AOR-A12R | $\overline{\mathrm{BUSY}}{ }^{(1)}$ | $\overline{\text { BUSYR }}^{\text {(1) }}$ |  |
| X | X | NO MATCH | H | H | Normal |
| H | X | MATCH | H | H | Normal |
| X | H | MATCH | H | H | Normal |
| L | L | MATCH | (2) | (2) | Write Inhibit ${ }^{(3)}$ |

NOTES:

1. Pins $\overline{B U S Y}$ and $\overline{B U S} \bar{Y}_{R}$ are both outputs when the part is configured as a master. Both are inputs when configured as a slave. $\overline{B U S Y} x$ outputs on the IDT7025 are push pull, not open drain outputs. On slaves the BUSYx input internally inhibits writes.
2. L if the inputs to the opposite port were stable prior to the address and enable inputs of this port. H if the inputs to the opposite port became stable after the address and enable inputs of this port. If taps is not met, either $\overline{B U S Y} L$ or $\overline{B U S Y} R=L o w ~ w i l l ~ r e s u l t . ~ \overline{B U S Y L}$ and $\overline{B U S Y R}$ outputs cannot be low simultaneouly.
3. Writes to the left port are internally ignored when $\overline{B U S Y} L$ outputs are driving low regardless of actual logic level on the pin. Writes to the right port are internally ignored when $\overline{B U S Y}$ R outputs are driving low regardless of actual logic level on the pin.

TRUTH TABLE III - EXAMPLE OF SEMAPHORE PROCUREMENT SEQUENCE ${ }^{(1)}$

| Functlons | Do - D15 Left | Do - D15 Right |  |
| :--- | :---: | :---: | :--- |
| 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 | Right port has semaphore token |
| Left Port Writes "1" to Semaphore | 1 | 1 | Semaphore free |

## NOTE:

1. This table denotes a sequence of events for only one of the eight semaphores on the IDT7025.


Figure 3. Busy and chlp enable routing for both width and depth expansion with IDT7025 RAMs.

## FUNCTIONAL DESCRIPTION

The IDT7025 provides two ports with separate control, address and l/O pins that permit independent access for reads or writes to any location in memory. The IDT7025 has an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{C E}$ high). When a port is enabled, access to the entire memory array is permitted.

## INTERRUPTS

If the user chooses to use the interrupt function, a memory location (mail box ormessage center) is assigned to each port. The left port interrupt flag ( $\overline{\mathrm{INT}} \mathrm{L}$ ) is set when the right port writes to memory location 1FFE (HEX). The left port clears the interrupt by reading address location 1FFE. Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location 1FFF (HEX) and to clear the interrupt flag (INTR), the right port must read the memory location 1FFF. The message ( 16 bits) at 1 FFE or 1 FFF is user-defined. If the interrupt function is not used, address locations 1FFE and 1FFF are not used as mail boxes, but as part of the random access memory. Refer to Table I for the interrupt operation.

## BUSY LOGIC

Busy Logic provides a hardware indication that both ports of the RAM have accessed the same location at the same time. It also allows one of the two accesses to proceed and signals the other side that the RAM is "busy". The busy pin can then be used to stall the access until the operation on the other side is completed. If a write operation has been attempted from the side that receives a busy indication, the write signal is gated internally to prevent the write from proceeding.

The use of busy logic is not required or desirable for all applications. In some cases it may be useful to logically OR the busy outputs together and use any busy indication as an interrupt source to flag the event of an illegal or illogical
operation. If the write inhibit function of busy logic is not desirable, the busy logic can be disabled by placing the part in slave mode with the $M / \bar{S}$ pin. Once in slave mode the $\overline{B U S Y}$ pin operates solely as a write inhibit input pin. Normal operation can be programmed by tying the $\overline{B U S Y}$ pins high. If desired, unintended write operations can be prevented to a port by tying the busy pin for that port low.

The busy outputs on the IDT 7025 RAM in master mode, are push-pull type outputs and do not require pull up resistors to operate. If these RAMs are being expanded in depth, then the busy indication for the resulting array requires the use of an external AND gate.

## WIDTH EXPANSION WITH BUSY LOGIC MASTER/SLAVE ARRAYS

When expanding an IDT7025 RAM array in width while using busy logic, one master part is used to decide which side of the RAM array will receive a busy indication, and to output that indication. Any number of slaves to be addressed in the same address range as the master, use the busy signal as a write inhibit signal. Thus on the IDT7025 RAM the busy pin is an output if the part is used as a master ( $\mathrm{M} / \overline{\mathrm{S}} \mathrm{pin}=\mathrm{H}$ ), and the busy pin is an input if the part used as a slave ( $M / \overline{\mathrm{S}}$ pin $=\mathrm{L}$ ).

If two or more master parts were used when expanding in width, a split decision could result with one master indicating busy on one side of the array and another master indicating busy on one other side of the array. This would inhibit the write operations from one port for part of a word and inhibit the write operations from the other port for the other part of the word.

The busy arbitration, on a master, is based on the chip enable and address signals only. It ignores whether an access is a read or write. In a master/slave array, both address and chip enable must be valid long enough for a busy flag to be output from the master before the actual write pulse can be initiated with either the R/W signal or the byte enables. Failure to observe this timing can result in a glitched internal write inhibit signal and corrupted data in the slave.

## SEMAPHORES

The IDT7025 is an extremely fast dual-port $8 \mathrm{~K} \times 16 \mathrm{CMOS}$ static RAM with an additional 8 address locations dedicated to binary semaphore flags. These flags allow either processor on the left or right side of the dual-port RAM to claim a privilege over the other processor for functions defined by the system designer's software. As an example, the semaphore can be used by one processor to inhibit the other from accessing a portion of the dual-port RAM or any other shared resource.

The dual-port RAM features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Bothports are identical in function to standard CMOS static RAM and can be read from, or written to, at the same time with the only possible conflict arising from the simultaneous writing of, or a simultaneous READ/WRITE of, a non-semaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the non-semaphore portion of the dual-port RAM. These devices have an automatic power-down feature controlled by $\overline{C E}$, the dual-port RAM enable, and $\overline{S E M}$, the semaphore enable. The $\overline{C E}$ and $\overline{S E M}$ pins control on-chip power down circuitry that permits the respective port to go into standby mode when not selected. This is the condition which is shown in Truth Table where $\overline{\mathrm{CE}}$ and $\overline{S E M}$ are both high.

Systems which can best use the IDT7025 contain multiple processors or controllers and are typically very high-speed systems which are software controlled or software intensive. These systems can benefit from a performance increase offered by the IDT7025's hardware semaphores, which provide a lockout mechanism without requiring complex programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be allocated in varying configurations. The IDT7025 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture.

An advantage of using semaphores rather than the more common methods of hardware arbitration is that wait states are never incurred in either processor. This can prove to be a major advantage in very high-speed systems.

## HOW THE SEMAPHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independent of the dual-port RAM. These latches canbe used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment method called "Token Passing Allocation." In this method, the state of a semaphore latch is used as a token indicating that shared resource is in use. If the left processorwants to use this resource, it requests the token by setting the latch. This processor then verifies its success in setting the latch by reading it. If it was successful, it proceeds to assume control over the shared resource. If it was not successful in setting the latch, it determines that the
right side processor has set the latch first, has the token and is using the shared resource. The left processor can then either repeatedly request that semaphore's status or remove its request for that semaphore to perform another task and occasionally attempt again to gain control of the token via the set and test sequence. Once the right side has relinquished the token, the left side should succeed in gaining control.

The semaphore flags are active low. A token is requested by writing a zero into a semaphore latch and is released when the same side writes a one to that latch.

The eight semaphore flags reside within the IDT7025 in a separate memory space from the dual-port RAM. This address space is accessed by placing a low input on the $\overline{\text { SEM }}$ pin (which acts as a chip select for the semaphore flags) and using the other control pins (Address, $\overline{O E}$, and $R \bar{W}$ ) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through address pins $A 0-A 2$. When accessing the semaphores, none of the other address pins has any effect.

When writing to a semaphore, only data pin Do is used. If a low level is written into an unused semaphore location, that flag will be set to a zero on that side and a one on the other side (see Table III). That semaphore can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be set to a one forboth sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. (A thorough discussing on the use of this feature follows shortly.) A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.

When a semaphore flag is read, its value is spread into all data bits so that a flag that is a one reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE} \text { ) signals go }}$ active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal (SEM or $\overline{\mathrm{OE}}$ ) to go inactive or the output will never change.

A sequence WRITE/READ must be used by the semaphore in order to guarantee that no system level contention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as one, a fact which the processor will verify by the subsequent read (see Table III). As an example, assume a processor writes a zero to the left port at a free semaphore location. On a subsequent read, the processor will verify that it has written successfully to that location and will assume control over the resource in question. Meanwhile, if a processor on the right side attempts to write a zero to the same semaphore flag it will fail, as will be verified by the fact that a one will be read from
that semaphore on the right side during subsequent read. Had a sequence of READ/WRITE been used instead, system contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed by either repeated reads or by writing a one into the same location. The reason for this is easily understood by looking at the simple logic diagram of the semaphore flag in Figure 4. Two semaphore request latches feed into a semaphore flag. Whichever latch is first to present a zero to the semaphore flag will force its side of the semaphore flag low and the other side high. This condition will continue until a one is written to the same semaphore request latch. Should the other side's semaphore request latch have been written to a zero in the meantime, the semaphore flag will flip over to the other side as soon as a one is written into the first side's request latch. The second side's flag will now stay low until its semaphore request latch is written to a one. From this it is easy to understand that, if a semaphore is requested and the processor which requested it no longer needs the resource, the entire system can hang up until a one is written into that semaphore request latch.

The critical case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is specially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side is earlier than the other in making the request, the first side to make the request will receive the token. If both requests arrive at the same time, the assignment will be arbitrarily made to one port or the other.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, if semaphores are misused or misinterpreted, a software error can easily happen.

Initialization of the semaphores is not automatic and must be handled via the initialization program at power-up. Since any semaphore request flag which contains a zero must be reset to a one, all semaphores on both sides should have a one written into them at initialization from both sides to assure that they will be free when needed.

## USING SEMAPHORES-SOME EXAMPLES

Perhaps the simplest application of semaphores is their application as resource markers for the IDT7025's dual-port RAM. Say the $8 \mathrm{~K} \times 16$ RAM was to be divided into two $4 \mathrm{~K} x$ 16 blocks which were to be dedicated at any one time to servicing either the left or right port. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of memory.

To take a resource, in this example the lower 4 K of dual-port RAM, the processor on the left port could write and
then read a zero in to Semaphore 0 . If this task were successfully completed (a zero was read back rather than a one), the left processor would assume control of the lower 4 K . Meanwhile the right processor was attempting to gain control of the resource after the left processor, it would read back a one in response to the zero it had attempted to write into Semaphore 0. At this point, the software could choose to try and gain control of the second 4 K section by writing, then reading a zero into Semaphore 1. If it succeeded in gaining control, it would lock out the left side.

Once the left side was finished with its task, it would write a one to Semaphore 0 and may then try to gain access to Semaphore 1. If Semaphore 1 was still occupied by the right side, the left side could undo its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1. If the right processor performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 4K blocks of dual-port RAM with each other.

The blocks do not have to be any particular size and can even be variable, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphores can even be assigned different meanings on different sides rather than being given a common meaning on different sides rather than being given a common meaning as was shown in the examplo above.

Semaphores are a useful form of arbitration in systems like disk interfaces where the CPU must be locked out of a section of memory during a transfer and the I/O device cannot tolerate any wait states. With the use of semaphores, once the two devices has determined which memory area was "off-limits" to the CPU, both the CPU and the I/O devices could access their assigned portions of memory continuously without any wait states.

Semaphores are also useful in applications where no memory "WAIT" state is available on one or both sides. Once a semaphore handshake has been performed, both processors can access their assigned RAM segments at full speed.

Another application is in the area of complex data structures. In this case, block arbitration is very important. For this application one processor may be responsible for building and updating a data structure. The other processor then reads and interprets that data structure. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the two different processors. The building processor arbitrates for the block, locks it and then is able to go in and update the data structure. Whenthe update is completed, the data structure block is released. This allows the interpreting processor to come back and read the complete data structure, thereby guaranteeing a consistent data structure.


Figure 4. IDT7025 Semaphore Logic

## ORDERING INFORMATION



## HIGH-SPEED <br> 16K x 8 DUAL-PORT STATIC RAM

## FEATURES:

- True dual-ported memory cells which allow simultaneous reads of the same memory location
- High-speed access
- Military: 45/55/70ns (max.)
- Commercial: 35/45/55ns (max.)
- Low-power operation
- IDT7006S

Active: 500 mW (typ.)
Standby: 5mW (typ.)

- IDT7006L

Active: 500 mW (typ.)
Standby: 1mW (typ.)

- IDT7006 easily expands data bus width to 16 bits or more using the Master/Slave select when cascading more than one device
- $M / \bar{S}=H$ for $\overline{B U S Y}$ output flag on Master
$M / \bar{S}=L$ for $\overline{B U S Y}$ input on Slave
- Interrupt Flag
- On-chip port arbitration logic
- Full on-chip hardware support of semaphore signaling between ports
- Fully asynchronous operation from either port
- Battery backup operation-2V data retention
- TTL compatible, single 5 V ( $\pm 10 \%$ ) power supply
- Available in 68-pin PGA, quad flatpack, LCC and PLCC


## DESCRIPTION:

The IDT7006 is a high-speed $16 \mathrm{~K} \times 8$ dual-port static RAM. The IDT7006 is designed to be used as a stand-alone 128Kbit dual-port RAM or as a combination MASTER/SLAVE dualport RAM for 16 -bit-or-more word systems. Using the IDT MASTER/SLAVE dual-port RAM approach in 16 -bit or wider memory system applications results in full-speed, error-free

## FUNCTIONAL BLOCK DIAGRAM



CEMOS is a tradernark of Integrated Device Technology, Inc.
operation without the need for additional discrete logic.
This device provides two independent ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in memory. An automatic power down feature controlled by $\overline{\mathrm{CE}}$ permits the on-chip circuitry of each port to enter a very low standby power mode.

Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, these devices typically operate on only 500 mW or
power at maximum access times as fast as 35ns. Low-power (L) versions offer battery backup data retention capability with each port typically consuming $500 \mu \mathrm{~W}$ from a 2 V battery.

The IDT7006 is packaged in plastic as well as ceramic 68pin PGA and 68-pin quad flatpack, LCC and PLCC. The military devices are processed $100 \%$ in compliance to the test methods of MIL-STD-883, Method 5004.

## PIN CONFIGURATIONS



## LCC/PLCC/FLATPACK

TOP VIEW

## NOTES:

1. All Vcc pins must be connected to power supply.
2. All GND pins must be connected to ground supply.

PIN CONFIGURATIONS (Continued)

| 11 |  | 51 <br> A5L | 50 A4L | 48 <br> A 2 L | $46$ <br> AOL | $\left\|\frac{44}{B U S Y L}\right\|$ | $\begin{gathered} 42 \\ M \bar{S} \end{gathered}$ | $\frac{40}{\overline{1 N T}^{2}}$ | 38 A1R | 36 A3R |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 10 | 53 A7L | 52 <br> A6L | 49 <br> A3L | ${ }^{47} A_{1 L}$ | $\frac{45}{\mathrm{INT}_{\mathrm{L}}}$ | $43$ | $\begin{array}{\|l\|} \hline \frac{41}{B U S Y} \\ R \end{array}$ | 39 <br> Aor | $\begin{aligned} & 37 \\ & A_{2 R} \end{aligned}$ | 35 <br> A4R | 34 A5R |
| 09 | 55 <br> Agl | 54 <br> AsL |  |  |  |  |  |  |  | ${ }^{32} A_{7 R}$ | 33 A6R |
| 08 | 57 <br> A11L | 56 <br> A 10 L |  |  |  |  |  |  |  | 30 <br> AgR | 31 <br> A8R |
| 07 | 59 Vcc | 58 <br> A12L |  |  |  |  |  |  | $\cdots$ | $\begin{aligned} & \hline 28 \\ & A_{11 R} \end{aligned}$ | 29 <br> A10R |
| 06 | 61 <br> NC | 60 A13L |  |  |  | IDT7006 $6 \mathrm{~K} \times 8 \mathrm{DF}$ |  |  |  | 26 GND | 27 <br> A12R |
| 05 | $\overline{63} \overline{\mathrm{SEM}} \mathrm{~L}$ | ${ }^{62} \overline{\mathrm{CE}}$ |  |  |  |  |  |  |  | ${ }^{24} \mathrm{NC}$ | $\begin{aligned} & 25 \\ & A_{13 R} \end{aligned}$ |
| 04 | $\frac{65}{\overline{O E} .}$ | 64 $R \bar{W} L$ |  |  |  |  |  |  |  | $\frac{22}{\overline{S E} \bar{M}_{R}}$ | $\frac{23}{\overline{C E}}$ |
| 03 | $\begin{aligned} & 67 \\ & 1 / \mathrm{OLL} \end{aligned}$ | $\begin{aligned} & 66 \\ & \mathrm{NC} \end{aligned}$ |  |  |  |  |  |  |  | ${ }^{20} \overline{\mathrm{OE}}_{\mathrm{R}}$ | $\begin{aligned} & 21 \\ & \mathrm{R} \bar{W}_{\mathrm{R}} \end{aligned}$ |
| 02 | $\begin{aligned} & \hline 68 \\ & 1 / O_{1 L} \end{aligned}$ | $\begin{aligned} & \hline 1 \\ & 1 / O_{2 L} \end{aligned}$ | $\begin{aligned} & 3 \\ & 1 / O_{4 L} \end{aligned}$ | $\begin{aligned} & 5 \\ & \text { GND } \end{aligned}$ | $\begin{aligned} & 7 \\ & 1 / O_{7} \end{aligned}$ | $9$ | $\begin{aligned} & 11 \\ & 1 / O_{1 R} \end{aligned}$ | $\begin{aligned} & 13 \\ & V c c \end{aligned}$ | $\begin{aligned} & 15 \\ & 1 / O_{4 R} \end{aligned}$ | $\begin{aligned} & 18 \\ & 1 / O_{7 R} \end{aligned}$ | $\begin{array}{\|l\|} \hline 19 \\ \mathrm{NC} \end{array}$ |
| 01 |  | $\begin{aligned} & 2 \\ & 1 / O_{3 L} \end{aligned}$ | $\begin{array}{\|l\|} \hline 4 \\ 1 / \mathrm{O}_{5 \mathrm{~L}} \end{array}$ | $\begin{aligned} & 6 \\ & 1 / O_{6 L} \end{aligned}$ | $\begin{aligned} & 8 \\ & V C c \end{aligned}$ | $\begin{array}{\|l\|} \hline 10 \\ 1 / O_{O R} \end{array}$ | $\begin{aligned} & 12 \\ & 1 / O_{2 R} \end{aligned}$ | $\begin{aligned} & 14 \\ & 1 / O_{3 R} \end{aligned}$ | $\begin{aligned} & 16 \\ & 1 / O_{5 R} \end{aligned}$ | $\begin{aligned} & 17 \\ & 1 / 0_{6 R} \end{aligned}$ |  |
|  | A | B | C | D | E | F | G | H | $J$ | K | L |

NOTES:

1. All Vcc pins must be connected to power supply
2. All GND pins must be connected to ground supply.

68-PIN PGA
TOP VIEW

PIN NAMES

| Left Port | Right Port | Names |
| :---: | :---: | :---: |
| $\overline{\mathrm{CE}} \mathrm{L}$ | $\overline{\mathrm{CE}}$ R | Chip Enable |
| $\mathrm{R} \overline{\mathrm{W}} \mathrm{L}$ | $\mathrm{R} \bar{W}_{\text {R }}$ | Read/Write Enable |
| $\overline{\mathrm{OE}}$ | $\overline{\text { OER }}$ | Output Enable |
| A0L - A13L | AOR - A13R | Address |
| I/OOL - I/O7L | 1/OOR - 1/O7R | Data Input/Output |
| $\overline{S E M}{ }_{1}$ | $\overline{\text { SEM }}$ R | Semaphore Enable |
| $\overline{\mathrm{NT}} \mathrm{L}$ | $\overline{\text { INTR }}$ | Interrupt Flag |
| $\overline{\text { BUSYL }}$ | $\overline{\text { BUSYR }}$ | Busy Flag |
| M/S |  | Master or Slave Select |
| Vcc |  | Power |
| GND |  | Ground |

TRUTH TABLE: NON-CONTENTION READ/WRITE CONTROL

| Inputs ${ }^{(1)}$ |  |  |  | Outputs | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E}$ | R/W | $\overline{O E}$ | SEM | 1/O0-7 |  |
| H | X | X | H | $\mathrm{Hi}-\mathrm{Z}$ | Deselected: Power Down |
| L | L | X | H | DATAIN | Write to Memory |
| L | H | L | H | DATAOUT | Read Memory |
| X | X | H | X | $\mathrm{Hi}-\mathrm{Z}$ | Outputs Disabled |

NOTE:
2739 tol 01

1. $A O L-A_{13 L} \neq A O R-A_{13 R}$

## TRUTH TABLE: SEMAPHORE READ/WRITE CONTROL

| Inputs |  |  |  | Outputs | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C E}$ | R/W | $\overline{\mathrm{OE}}$ | SEM | I/O0-7 |  |
| H | H | L | L | DATAOUT | Read Data in Semaphore Flag |
| H | - | X | L | DATAIN | Write Dino into Semaphore Flag |
| L | X | X | L | - | Not Allowed |

2739 tbi 02

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.
CAPACITANCE ( $T \mathrm{~A}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 11 | pF |
| CouT | Output <br> Capacitance | Vout $=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2739 か1 03

1. This parameter is determined by device characterization but is not production tested.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| $2739 \pm 105$ |  |  |  |

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2733 แल

1. Vil -3.0V for pulse width less than $20 n \mathrm{~ns}$.

IDT7006S/L

## DC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE (Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )| Symbol | Parameter | Test Conditions | IDT7006S |  | IDT7006L |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|lu| | Input Leakage Current ${ }^{(5)}$ | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|liol | Output Leakage Current | $\overline{C E}=\mathrm{VIH}, \mathrm{VOUT}=0 \mathrm{~V}$ to VCC | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathrm{OL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version |  | X35 ONLY <br> Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Icc | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\mathrm{CE}} \leq V_{I L}, \text { Outputs Open } \\ & \mathrm{SEM} \geq \mathrm{V}_{\text {IH }} \\ & \mathrm{f}=\mathrm{fMAX}^{(3)} \end{aligned}$ | MIL. $\quad \begin{aligned} & \text { S } \\ & \\ & \text { L }\end{aligned}$ | - | - | mA |
|  |  |  | COM'L. | 二 | 340 290 |  |
| ISB1 | Standby Current (Both Ports — TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CE} R}=\overline{\mathrm{CE} L} \geq V_{I H} \\ & \overline{\mathrm{SEM}}=\overline{\mathrm{SEM}} \mathrm{~L} \geq \mathrm{V}_{1} \\ & f=\mathrm{fmax}^{(3)} \end{aligned}$ | MIL. $\quad$S <br>  | - | - | mA |
|  |  |  | COM'L. | - | 70 50 |  |
| ISB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{L}$ or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{\mathrm{IH}}$ Active Port Outputs Open$\begin{aligned} & f=f M A x^{(3)} \\ & \overline{S E M} R=\overline{S E M} L \geq V_{I H} \end{aligned}$ | MIL. $\quad$S <br>  | - | - | mA |
|  |  |  | COM'L. | - | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ |  |
| ISB3 | Full Standby Current (Both Ports - All CMOS Level Inputs) | $\begin{aligned} & \text { Both Ports } \overline{C E} L \text { and } \\ & \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 / \geq \leq 0.2 V, t=0^{(4)} \\ & \overline{S E M}=\overline{S E M} \geq V C C-0.2 \mathrm{~V} \end{aligned}$ | MIL. S <br> L <br> COM'L. S <br>  L | - | - | mA |
|  |  |  |  | - | 15 5 |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs) | One Port $\overline{C E}$ or <br> $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ <br> $\overline{S E M} R=\overline{S E M} L \geq V C C-0.2 V$ <br> VIN $\geq$ Vcc -0.2 V or $V_{\mathbb{N}} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=f \text { MAX }^{(3)}$ | MIL. $\quad$ S | - | - | mA |
|  |  |  | COM'L. | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ |  |

## NOTES:

2739 \#108

1. $X$ in part numbers indicates power rating ( $S$ or $L$ )
2. $V C C=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. At $f=f$ MAX, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 / t \mathrm{RC}$, and using "AC Test Conditions" of input levels of GND to 3 V .
4. $f=0$ means no address or control lines change.
5. At $V c c \leq 1.0 \mathrm{~V}$ input leakages are undefined.

## DC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$ (Continued) (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )| Symbol | Parameter | Test Condition | Version |  | X45 |  | X55 |  | $\overline{x \times 70}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Icc | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \overline{\mathrm{CE}} \leq V_{I L}, \text { Outputs Open } \\ & \mathrm{SEM} \geq V_{I H} \\ & \mathrm{f}=\mathrm{fmax}^{(3)} \end{aligned}$ | MIL. $\quad \begin{array}{ll}\text { S } \\ & \text { L }\end{array}$ | - | $\begin{aligned} & 400 \\ & 340 \end{aligned}$ | - | $\begin{aligned} & 395 \\ & 335 \end{aligned}$ | - | 390 330 | mA |
|  |  |  | COM'L. ${ }^{\text {S }}$ | - | 340 290 | - | 335 285 | - | - |  |
| ISB1 | Standby Current (Both Ports — TTL <br> Level Inputs) | $\begin{aligned} & \overline{\mathrm{CE}} \mathrm{~L}=\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{V}_{\mathrm{I}} \\ & \overline{S E M}=\overline{\mathrm{SEM}} \mathrm{~L} \geq \mathrm{V}_{\mathrm{H}} \\ & \mathrm{t}=\mathrm{f} \mathrm{max}^{(3)} \end{aligned}$ | MIL. $\quad$ S | - | $\begin{aligned} & 85 \\ & 65 \end{aligned}$ | - | $\begin{aligned} & 85 \\ & 65 \end{aligned}$ | - | 85 | mA |
|  |  |  | COM'L. ${ }^{\text {S }}$ | - | 70 50 | - | 70 | - | - |  |
| ISB2 | Standby Current (One Port - TTL Level Inputs) | $\overline{\mathrm{CE}} \mathrm{R}$ or $\overline{\mathrm{CE}} \mathrm{Z} \geq \mathrm{V}_{\mathrm{I}} \mathrm{H}$ <br> Active Port Outputs Open $\frac{f=f M A X^{(3)}}{S E M R}=\overline{S E M L} \geq V_{I H}$ | MIL. $\quad$ S | - | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | - | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | - | $\begin{aligned} & 290 \\ & 250 \end{aligned}$ | mA |
|  |  |  | COM'L. S <br>  L | - | $\begin{aligned} & 240 \\ & 210 \end{aligned}$ | - | $\begin{aligned} & 240 \\ & 210 \\ & \hline \end{aligned}$ | - | - |  |
| ISB3 | Full Standby Current (Both Ports — All CMOS Level Inputs) | Both Ports $\overline{\mathrm{CE}} \mathrm{L}$ and $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> VIN $\geq$ VCC -0.2 V or $\mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=\mathrm{O}^{(4)}$ <br> $\overline{S E M} \mathrm{R}=\overline{\mathrm{SEM}} \mathrm{L} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ | MIL. S <br>  L | - | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | mA |
|  |  |  | COM'L. S <br>  L | 二 | $\begin{gathered} 15 \\ 5 \end{gathered}$ | - | 15 5 | - | - |  |
| ISB4 | Full Standby Current (One Port - All CMOS Level Inputs) | One Port CEL or $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ $\overline{S E M}=\overline{S E M L} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ <br> VIN $\geq$ Vcc -0.2 V or $\operatorname{VIN} \leq 0.2 \mathrm{~V}$ <br> Active Port Outputs Open, $f=f \text { MAX }{ }^{(3)}$ | $\begin{array}{ll}\text { MIL. } & \text { S } \\ & \\ & \text { L }\end{array}$ | - | 260 | - | 260 215 | - | 260 215 | mA |
|  |  |  | $\begin{array}{ll}\text { COM'L. } & \mathrm{S} \\ & \mathrm{L}\end{array}$ | - | $\begin{aligned} & 220 \\ & 180 \end{aligned}$ | - | 220 180 | - | - |  |

NOTES:

1. $X$ in part numbers indicates power rating ( $S$ or $L$ )
2. $V C C=5 V, T A=+25^{\circ} \mathrm{C}$.
3. At $f=f$ max, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycie of $1 / t \mathrm{tac}$, and using "AC Test Conditions" of input levels of GND to 3 V .
4. $f=0$ means no address or control lines change.
5. At Vcc $\leq 1.0 \mathrm{~V}$ input leakages are undefined.

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES (L Version Only) (VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{VCC}-0.2 \mathrm{~V}$ )

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vor | Vcc for Data Retention | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & \overline{C E} \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \leq \mathrm{VLC} \end{aligned}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | - | 4000 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | - | 1500 |  |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | $\mathrm{tRc}^{(2)}$ | - | - | ns |

NOTES:

1. $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{Vcc}=2 \mathrm{~V}$
2. $\mathrm{t} \mathrm{t} \mathrm{C}=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | $5 n s$ Max. |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |



Figure 1. Output Load


Figure 2. Output Load (for tlz, thz, twz, tow)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(4)}$| Symbol | Parameter | IDT7006X35 COM'L ONLY |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| READ CYCLE |  |  |  |  |
| tRC | Read Cycle Time | 35 | - | ns |
| taA | Address Access Time | - | 35 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 35 | ns |
| taie | Output Enable Access Time | - | 20 | ns |
| tor | Output Hold from Address Change | 3 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,2)}$ | 3 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | ns |
| tSOP | Semaphore Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\text { SEM }}$ ) | 15 | - | ns |


| Symbol | Parameter | IDT7006X45 |  | IDT7006X55 |  | $\begin{aligned} & \text { IDT7006X70 } \\ & \text { MIL ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| taA | Address Access Time | - | 45 | - | 55 | - | 70 | ns |
| tace | Chip Enable Access Time ${ }^{(3)}$ | - | 45 | - | 55 | - | 70 | ns |
| taie | Output Enable Access Time | - | 25 | - | 30 | - | 35 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | ns |
| tLZ | Output Low Z Time ${ }^{(1,2)}$ | 5 | - | 5 | - | 5 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tPu | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 50 | - | 50 | - | 50 | ns |
| tSOP | Semaphore Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{\mathrm{SEM}}$ ) | 15 | - | 15 | - | 15 | - | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2 ).
2. This parameter is guaranteed but not tested.
3. To access $R A M, \overline{C E}=L, \overline{S E M}=H$.
4. X in part numbers indicates power rating ( S or L ).

## WAVEFORM OF READ CYCLES ${ }^{(5)}$



NOTES:

1. Timing depends on which signal is asserted last, $\overline{O E}$ or $\overline{C E}$.
2. Timing depends on which signal is de-asserted first $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$.
3. Required only if busy logic is being used to prevent read data corruption, during simultaneous accesses to the same location, in masters and master-slavo width expansions.
4. Start of valid data depends on which timing becomes effective last taBE, tAOE, tACE, tAA or tBDD.
5. $\mathrm{SEM}=\mathrm{H}$.

TIMING OF POWER-UP POWER-DOWN


## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE ${ }^{(5)}$

| Symbol | Parameter | IDT7006X35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |
| twc | Write Cycle Time | 35 | - | ns |
| tew | Chip Enable to End of Write ${ }^{(3)}$ | 30 | - | ns |
| taw | Address Valid to End of Write | 30 | - | ns |
| tAS | Address Set-up Time ${ }^{(3)}$ | 0 | - | ns |
| twp | Write Pulse Width | 30 | - | ns |
| twR | Write Recovery Time | 0 | - | ns |
| tow | Data Valid to End of Write | 25 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 15 | ns |
| tDH | Data Hold Time ${ }^{(4)}$ | 0 | - | ns |
| twz | Write Enable to Output in High $\mathbf{Z}^{(1,2)}$ | - | 15 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 0 | - | ns |
| tSWRD | $\overline{\text { SEM }}$ Flag Write to Read Time | 10 | - | ns |
| tSPS | $\overline{\text { SEM }}$ Flag Contention WindoW | 10 | - | ns |


| Symbol | Parameter | IDT7006X45 |  | IDT7006X55 |  | IDT7006X70 MIL. ONLY |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| tEW | Chip Enable to End of Write ${ }^{(3)}$ | 40 | - | 45 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 40 | - | 45 | - | 50 | - | ns |
| tAS | Address Set-up Time ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | ns |
| twP | Write Pulse Width | 35 | - | 40 | - | 50 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 25 | - | 30 | - | 40 | - | ns |
| thz | Output High Z Time ${ }^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tDH | Data Hold Time ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| twz | Write Enable to Output in High $\mathrm{Z}^{(1,2)}$ | - | 20 | - | 25 | - | 30 | ns |
| tow | Output Active from End of Write ${ }^{(1,2,4)}$ | 0 | - | 0 | - | 0 | - | ns |
| tSWRD | $\overline{\text { SEM Flag Write to Read Time }}$ | 10 | - | 10 | - | 10 | - | ns |
| tSPS | $\overline{\text { SEM }}$ Flag Contention Window | 10 | - | 10 | - | 10 | - | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. To access $R A M, \overline{C E}=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 tEw time.
4. The specification for tDH must be met by the device supplying write data to the RAM under all operating conditions. Although tDH and tow values will vary over voltage and temperature, the actual toH will always be smaller than the actual tow.
5. $X$ in part numbers indicates power rating ( $S$ or $L$ ).

TIMING WAVEFORM OF WRITE CYCLE NO. 1, R//W CONTROLLED TIMING ${ }^{(1,3,5,8)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2, $\overline{\text { CE }}$ CONTROLLED TIMING ${ }^{(1,3,5,8)}$


NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (tEW or twP) of a low $\overline{C E}$ and a low $R \bar{W}$ for memory array writing cycle.
3. twR is measured from the earlier of $\overline{C E}$ or $R \bar{W}$ (or $\overline{S E M}$ or $R \bar{W}$ ) going high to the end of write cycle.
4. During this period, the l/O pins are in the output state and input signals must not be applied.
5. If the $\overline{C E}$ or $\overline{S E M}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. Timing depends on which enable signal is asserted last.
7. Timing depends on which enable signal is de-asserted first.
8. If $\overline{O E}$ is low during $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twP or (twZ + tDW) to allow the l/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## TIMING WAVEFORM OF SEMAPHORE READ AFTER WRITE TIMING, EITHER SIDE ${ }^{(1)}$



## NOTE:

1. $\overline{\mathrm{CE}}=\mathrm{H}$ for the duration of the above timing (both write and read cycle).

TIMING WAVEFORM OF SEMAPHORE WRITE CONTENTION ${ }^{(1,3,4)}$


NOTES:

1. $D O R=D O L=L, \overline{C E} R=\overline{C E} L=H$, Semaphore Flag is released from both sides (reads as ones from both sides) at cycle start.
2. "A" may be either left or right port. "B" is the opposite port from "A".
3. This parameter is measured from $R / \bar{W}_{A}$ or $\overline{S E M}_{A}$ going high to $R \bar{W} B$ or $\overline{S E M B}$ going high.
4. If tSPS is violated, the semaphore will fall positively to one side or the other, but there is not guarantee which side will obtain the flag.

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE(6)

| Symbol | Parameter | $\begin{aligned} & \text { IDT7006X35 } \\ & \text { COM'L ONLY } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| BUSY TIMING (M/ $\bar{S}=\mathrm{H}$ ) |  |  |  |  |
| tBAA | $\overline{\text { BUSY }}$ Access Time to Address | - | 35 | ns |
| tBDA | BUSY Disable Time to Address | - | 30 | ns |
| tBAC | BUSY Access Time to Chip Enable | - | 30 | ns |
| tBDC | BUSY Disable Time to Chip Enable | - | 25 | ns |
| tAPS | Arbitration Priority Set-up Time ${ }^{(2)}$ | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 3 | ns |
| BUSY TIMING (M/ $\bar{S}=\mathrm{L}$ ) |  |  |  |  |
| tWB | $\overline{\text { BUSY }}$ Input to Write ${ }^{(4)}$ | 0 | - | ns |
| twh | Write Hold After $\overline{B U S Y}^{(5)}$ | 25 | - | ns |
| PORT-TO-PORT DELAY TIMING |  |  |  |  |
| tWDD | Write Pulse to Data Delay ${ }^{(7)}$ | - | 60 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 45 | ns |


| Symbol | Parameter | IDT7006X45 |  | IDT7006X55 |  | $\begin{aligned} & \text { IDT7006X70 } \\ & \text { MlL_ ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max | Min. | Max. | Min. | Max. |  |
| BUSY TIMING (M/ $\widetilde{S}=\mathrm{H}$ ) |  |  |  |  |  |  |  |  |
| tBAA | $\overline{\text { BUSY Access Time to Address }}$ | - | 35 | - | 45 | - | 45 | ns |
| t8DA | $\overline{\text { BUSY }}$ Disable Time to Address | - | 30 | - | 40 | - | 40 | ns |
| tBAC | $\overline{\text { BUSY }}$ Access Time to Chip Enable | - | 30 | - | 40 | - | 40 | ns |
| tBDC | $\overline{\text { BUSY }}$ Disable Time to Chip Enable | - | 25 | - | 35 | - | 35 | ns |
| taps | Arbitration Priority Set-up Time ${ }^{(2)}$ | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data ${ }^{(5)}$ | - | Note 3 | - | Note 3 | - | Note 3 | ns |
| BUSY TIMING (M/ $\bar{S}=\mathrm{L}$ ) |  |  |  |  |  |  |  |  |
| twB | BUSY Input to Write ${ }^{(4)}$ | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After $\overline{\text { BUSY }}{ }^{(5)}$ | 25 | - | 25 | - | 25 | - | ns |
| PORT-TO-PORT DELAY TIMING |  |  |  |  |  |  |  |  |
| tWDD | Write Pulse to Data Delay ${ }^{(7)}$. | - | 70 | - | 80 | - | 95 | ns |
| tDDD | Write Data Valid to Read Data Delay ${ }^{(7)}$ | - | 55 | - | 65 | - | 80 | ns |

## NOTES:

1. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY $(M \bar{S}=H)^{*}$.
2. To ensure that the earlier of the two ports wins.
3. $t$ BDD is a calculated parameter and is the greater of 0, tWDD - tWP (actual) or tDDD - tDW (actual).
4. To ensure that the write cycle is inhibited during contention.
5. To ensure that a write cycle is completed after contention.
6. " $x$ " is part numbers indicates power rating ( S or L ).
7. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With $\overline{B U S Y}(M / \overline{\mathbf{S}}=\mathrm{L})$ ".

## TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}^{(2)}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{H})$



NOTES:
2739 drw 13

1. To ensure that the earlier of the two ports wins.
2. $\overline{\mathrm{CE}} \mathrm{L}=\overline{\mathrm{CE}}=\mathrm{L}$
3. $\overline{O E}=\mathrm{L}$ for the reading port.

TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DELAY ${ }^{(1,2)}(M / \overline{\mathbf{S}}=\mathrm{L})$


1. $\overline{\mathrm{BUSY}}$ input equals H for the writing port.

2739 dw 14
2. $\overline{C E} \mathrm{~L}=\overline{\mathrm{CE}} \mathrm{R}=\mathrm{L}$

TIMING WAVEFORM OF SLAVE WRITE (M/ $\overline{\mathbf{S}}=\mathrm{L}$ )


WAVEFORM OF BUSY ARBITRATION CONTROLLED BY $\overline{C E} \operatorname{TIMING}{ }^{(1)}(\mathbf{M} / \overline{\mathbf{S}}=\mathrm{H})$


WAVEFORM OF BUSY ARBITRATION CYCLE CONTROLLED BY ADDRESS MATCH $\operatorname{TIMING}^{(1)}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{H})$


NOTES:

1. All timing is the same for left and right ports. Port "A" may be eithèr the left or right port. Port "B" is the port opposite from "A".
2. If taps is violated, the busy signal will be asserted on one side or another but there is no guarantee on which side busy will be asserted.

## AC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1)}$

| Symbol | Parameter | IDT7006X35 COM'L ONLY |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| INTERRUPT TIMING |  |  |  |  |
| tas | Address Set-up Time | 0 | - | ns |
| twr | Write Recovery Time | 0 | - | ns |
| tins | Interrupt Set Time | - | 30 | ns |
| tINR | Interrupt Reset Time | - | 30 | ns |


| Symbol | Parameter | IDT7006X45 |  | IDT7006X55 |  | $\begin{aligned} & \text { IDT7006X70 } \\ & \text { MIL. ONLY } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| INTERRUPT TIMING |  |  |  |  |  |  |  |  |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| tins | Interrupt Set Time | - | 35 | - | 40 | - | 50 | ns |
| tINR | Interrupt Reset Time | - | 35 | - | 40 | - | 50 | ns |

NOTE:

1. " $x$ " in part numbers indicates power rating ( $S$ or $L$ ).

## WAVEFORM OF INTERRUPT TIMING ${ }^{(1)}$



NOTES:

1. All timing is the same for left and right ports. Port " $A$ " may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. See Interrupt truth table.
3. Timing depends on which enable signal is asserted last.
4. Timing depends on which enable signal is de-asserted first.

## TRUTH TABLES

TRUTH TABLE I - INTERRUPT FLAG ${ }^{(1)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W $/$ | $\overline{C E}$ | $\overline{O E L}$ | A0L-A13L | INTL | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | $\overline{C E R}$ | OEF | A0R-A13R | INTR |  |
| L | L | X | 3FFF | X | X | X | X | X | $\mathrm{L}^{(2)}$ | Set Right $\overline{\text { NTTR Flag }}$ |
| X | X | X | X | X | X | L | L | 3FFF | $H^{(3)}$ | Reset Right INTR Flag |
| $x$ | X | X | X | $L^{(3)}$ | L | L | X | 3FFE | X | Set Left INTL Flag |
| X | L | L | 3FFE | $H^{(2)}$ | X | X | X | X | X | Reset Left INTL Flag |

NOTES:

1. Assumes $\overline{B U S Y} \bar{L}=\overline{B U S Y}_{R}=H$.
2. If $\overline{B U S Y}=\mathrm{L}$, then no change.
3. If $\overline{\mathrm{BUSY}_{R}}=\mathrm{L}$, then no change.

TRUTH TABLE II - ADDRESS BUSY

## ARBITRATION

| Inputs |  |  | Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CE}} \mathrm{L}$ | CER | $\begin{aligned} & \text { AoL-A13L } \\ & \text { A0R-A13R } \end{aligned}$ | $\overline{\text { BUSY }}{ }^{(1)}$ | $\overline{\text { BUSY }}^{\text {(1) }}$ |  |
| X | X | NO MATCH | H | H | Normal |
| H | X | MATCH | H | H | Normal |
| X | H | MATCH | H | H | Normal |
| L | L | MATCH | (2) | (2) | Write Inhibit ${ }^{(3)}$ |

NOTES:
2739 th 16

1. Pins $\overline{B U S Y} \bar{l}$ and $\overline{B U S Y} \bar{R}$ are both outputs when the part is configured as a master. Both are inputs when configured as a slave. $\overline{B U S Y} x$ outputs on the IDT7006 are push pull, not open drain outputs. On slaves the $\overline{B U S Y} x$ input internally inhibits writes.
2. Lif the inputs to the opposite port were stable prior to the address and enable inputs of this port. H if the inputs to the opposite port became stable after the address and enable inputs of this port. If taps is not met, either $\overline{B U S Y} L$ or $\overline{B U S Y R}=$ Low will result. $\overline{B U S Y L}$ and $\overline{B U S Y R}$ outputs cannot be low simultaneouly.
3. Writes to the left port are internally ignored when $\overline{B U S Y}$ L outputs are driving low regardless of actual logic level on the pin. Writes to the right port are internally ignored when $\overline{B U S Y} R$ outputs are driving low regardless of actual logic level on the pin.

TRUTH TABLE III - EXAMPLE OF SEMAPHORE PROCUREMENT SEQUENCE ${ }^{(1)}$

| Functions | Do - D7 Left | D0 - D7 Right |  |
| :--- | :---: | :---: | :--- |
| 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 Por 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 | Right port has semaphore token |
| Left Port Writes "1" to Semaphore | 1 | 1 | Semaphore free |

1. This table denotes a sequence of events for only one of the eight semaphores on the IDT7006.


2739 drw 20

Figure 3. Busy and chip enable routing for both width and depth expansion with IDT7006 RAMs.

## FUNCTIONAL DESCRIPTION

The IDT7006 provides two ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. The IDT7006 has an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected (CE.high). When a port is enabled, access to the entire memory array is permitted.

## INTERRUPTS

If the user chooses to use the interrupt function, a memory location (mailbox or message center) is assigned to each port. The left port interrupt flag (INTL) is set when the right port writes to memory location 3FFE (HEX). The left port clears the interrupt by reading address location 3FFE. Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location 3FFF (HEX) and to clear the interrupt flag (INTR), the right port must read the memory location 3FFF. The message ( 8 bits) at 3FFE or 3FFF is user-defined. If the interrupt function is not used, address locations 3FFE and 3FFF are not used as mail boxes, but as part of the random access memory. Refer to Table 1 for the interrupt operation.

## BUSY LOGIC

Busy Logic provides a hardware indication that both ports of the RAM have accessed the same location at the same time. It also allows one of the two accesses to proceed and signals the other side that the RAM is "busy". The busy pin can then be used to stall the access until the operation on the other side is completed. If a write operation has been attempted from the side that receives a busy indication, the write signal is gated internally to prevent the write from proceeding.

The use of busy logic is not required or desirable for all applications. In some cases it may be useful to logically OR the busy outputs together and use any busy indication as an interrupt source to flag the event of an illegal or illogical
operation. If the write inhibit function of busy logic is not desirable, the busy logic can be disabled by placing the part in slave mode with the $M / \bar{S}$ pin. Once in slave mode the $\overline{B U S Y}$ pin operates solely as a write inhibit input pin. Normal operation can be programmed by tying the BUSY pins high. If desired, unintended write operations can be prevented to a port by tying the busy pin for that port low.

The busy outputs on the IDT 7006 RAM in master mode, are push-pull type outputs and do not require pull up resistors to operate. If these RAMs are being expanded in depth, then the busy indication for the resulting array requires the use of an external AND gate.

## WIDTH EXPANSION WITH BUSY LOGIC MASTER/SLAVE ARRAYS

When expanding an IDT7006 RAM array in width while using busy logic, one master part is used to decide which side of the RAMs array will receive a busy indication, and to output that indication. Any number of slaves to be addressed in the same address range as the master, use the busy signal as a write inhibit signal. Thus on the IDT7006 RAM the busy pin is an output if the part is used as a master ( $\mathrm{M} / \overline{\mathrm{S}} \mathrm{pin}=\mathrm{H}$ ), and the busy pin is an input if the part used as a slave ( $\mathrm{M} / \overline{\mathrm{S}}$ pin $=\mathrm{L}$ ).

If two or more master parts were used when expanding in width, a split decision could result with one master indicating busy on one side of the array and another master indicating busy on one other side of the array. This would inhibit the write operations from one port for part of a word and inhibit the write operations from the other port for the other part of the word.

The busy arbitration, on a master, is based on the chip enable and address signals only. It ignores whether an access is a read or write. In a master/slave array, both address and chip enable must be valid long enough for a busy flag to be output from the master before the actual write pulse can be initiated with the $R / \bar{W}$ signal. Failure to observe this timing can result in a glitched internal write inhibit signal and corrupted data in the slave.

## SEMAPHORES

The IDT7006 is an extremely fast dual-port $16 \mathrm{~K} \times 8$ CMOS static RAM with an additional 8 address locations dedicated to binary semaphore flags. These flags allow either processor on the left or right side of the dual-port RAM to claim a privilege over the other processor for functions defined by the system designer's software. As an example, the semaphore can be used by one processor to inhibit the other from accessing a portion of the dual-port RAM or any other shared resource.

The dual-port RAM features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Both ports are identical in function to standard CMOS static RAM and can be read from, or written to, at the same time with the only possible conflict arising from the simultaneous writing of, or a simultaneous READ/WRITE of, a non-semaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the non-semaphore portion of the dual-port RAM. These devices have an automatic power-down feature controlled by $\overline{C E}$, the dual-port RAM enable, and $\overline{\text { SEM }}$, the semaphore enable. The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{SEM}}$ pins control on-chip power down circuitry that permits the respective port to go into standby mode when not selected. This is the condition which is shown in Truth Table where $\overline{\mathrm{CE}}$ and $\overline{S E M}$ are both high.

Systems which can best use the IDT7006 contain multiple processors or controllers and are typically very high-speed systems which are software controlled or software intensive. These systems can benefit from a performance increase offered by the IDT7006s hardware semaphores, which provide a lockout mechanism without requiring complex. programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be allocated in varying configurations. The IDT7006 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture.

An advantage of using semaphores rather than the more common methods of hardware arbitration is that wait states are never incurred in either processor. This can prove to be a major advantage in very high-speed systems.

## HOW THE SEMAPHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independent of the dual-port RAM. These latches can be used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment method called "Token Passing Allocation." In this method, the state of a semaphore latch is used as a token indicating that shared resource is in use. If the left processorwants to use this resource, it requests the token by setting the latch. This processor then verifies its success in setting the latch by reading it. If it was successful, it proceeds to assume control over the shared resource. If it was not successful in setting the latch, it determines that the
right side processor has set the latch first, has the token and is using the shared resource. The left processor can then either repeatedly request that semaphore's status or remove its request for that semaphore to perform another task and occasionally attempt again to gain control of the token via the set and test sequence. Once the right side has relinquished the token, the left side should succeed in gaining control.

The semaphore flags are active low. A token is requested by writing a zero into a semaphore latch and is released when the same side writes a one to that latch.

The eight semaphore flags reside within the IDT7006 in a separate memory space from the dual-port RAM. This address space is accessed by placing a low input on the $\overline{\text { SEM }}$ pin (which acts as a chip select for the semaphore flags) and using the other control pins (Address, $\overline{O E}$, and $R \bar{W}$ ) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through address pins A0-A2. When accessing the semaphores, none of the other address pins has any effect.

When writing to a semaphore, only data pin Do is used. If a low level is written into an unused semaphore location, that flag will be set to a zero on that side and a one on the other side (see Table III). That semaphore can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be set to a one for both sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. (A thorough discussing on the use of this feature follows shortly.) A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.

When a semaphore flag is read, its value is spread into all data bits so that a flag that is a one reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE}}$ ) signals go active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal (SEM or $\overline{\mathrm{OE}}$ ) to go inactive or the output will never change.

A sequence WRITE/READ must be used by the semaphore in orderto guarantee that no system level contention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as one, a fact which the processor will verify by the subsequent read (see Table III). As an example, assume a processor writes a zero to the left port at a free semaphore location. On a subsequent read, the processor will verify that it has written successfully to that location and will assume control over the resource in question. Meanwhile, if a processor on the right side attempts to write a zero to the same semaphore flag it will fail, as will be verified by the fact that a one will be read from
that semaphore on the right side during subsequent read. Had a sequence of READ/WRITE been used instead, system contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed by either repeated reads or by writing a one into the same location. The reason for this is easily understood by looking at the simple logic diagram of the semaphore flag in Figure 4. Two semaphore request latches feed into a semaphore flag. Whichever latch is first to present a zero to the semaphore flag will force its side of the semaphore flag low and the other side high. This condition will continue until a one is written to the same semaphore request latch. Should the other side's semaphore request latch have been written to a zero in the meantime, the semaphore flag will flip over to the other side as soon as a one is written into the first side's request latch. The second side's flag will now stay low until its semaphore request latch is written to a one. From this it is easy to understand that, if a semaphore is requested and the processor which requested it no longer needs the resource, the entire system can hang up until a one is written into that semaphore request latch.

The critical case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is specially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side-is earlier than the other in making the request, the first side to make the request will receive the token. If both requests arrive at the same time, the assignment will be arbitrarily made to one port or the other.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, if semaphores are misused or misinterpreted, a software error can easily happen.

Initialization of the semaphores is not automatic and must be handled via the initialization program at power-up. Since any semaphore request flag which contains a zero must be reset to a one, all semaphores on both sides should have a one written into them at initialization from both sides to assure that they will be free when needed.

## USING SEMAPHORES—SOME EXAMPLES

Perhaps the simplest application of semaphores is their application as resource markers for the IDT7006's dual-port RAM. Say the $16 \mathrm{~K} x 8$ RAM was to be divided into two $8 \mathrm{~K} x$ 8 blocks which were to be dedicated at any one time to servicing either the left or right port. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of memory.

To take a resource, in this example the lower 8 K of dual-port RAM, the processor on the left port could write and
then read a zero in to Semaphore 0. If this task were successfully completed (a zero was read back rather than a one), the left processor would assume control of the lower 8 K . Meanwhile the right processor was attempting to gain control of the resource after the left processor, it would read back a one in response to the zero it had attempted to write into Semaphore 0. At this point, the software could choose to try and gain control of the second 8 K section by writing, then reading a zero into Semaphore 1. If it succeeded in gaining control, it would lock out the left side.

Once the left side was finished with its task, it would write a one to Semaphore 0 and may then try to gain access to Semaphore 1. If Semaphore 1 was still occupied by the right side, the left side could undo its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1. If the right processor performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 8K blocks of dual-port RAM with each other.

The blocks do not have to be any particular size and can even be variable, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphores can even be assigned different meanings on different sides rather than being given a common meaning on different sides rather than being given a common meaning as was shown in the example above.

Semaphores are a useful form of arbitration in systems like disk interfaces where the CPU must be locked out of a section of memory during a transfer and the I/O device cannot tolerate any wait states. With the use of semaphores, once the two devices has determined which memory area was "off-limits" to the CPU, both the CPU and the I/O devices could access their assigned portions of memory continuously without any wait states.

Semaphores are also useful in applications where no memory "WAIT" state is available on one or both sides. Once a semaphore handshake has been performed, both processors can access their assigned RAM segments at full speed.

Another application is in the area of complex data structures. In this case, block arbitration is very important. For this application one processor may be responsible for building and updating a data structure. The other processor then reads and interprets that data structure. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the two different processors. The building processor arbitrates for the block, locks it and then is able to go in and update the data structure. When the update is completed, the data structure block is released. This allows the interpreting processor to come back and read the complete data structure, thereby guaranteeing a consistent data structure.


Figure 4. IDT7006 Semaphore Logic

## ORDERING INFORMATION



2739 drw 22


## FEATURES:

- High-speed access
- Military: $30 / 35 / 45$ ns (max.)
- Commercial: 25/30/35/45ns (max.)
- Low-power operation
—. IDTT050S
Active: 750 mW (typ.)
Standby: 10 mW (typ.)
- IDT7050L

Active: 750 mW (typ.)
Standby: 1.5 mW (typ.)

- Fully asynchronous operation from each of the four ports: P1, P2, P3, P4
- Versatile control for write-inhibit: separate $\overline{B U S Y}$ input to control write-inhibit for each of the four ports
- Battery backup operation-2V data retention
- TTL-compatible; single 5 V ( $\pm 10 \%$ ) power supply
- Available in several popular hermetic and plastic packages for both through-hole and surface mount
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7050 is a high-speed $1 \mathrm{~K} \times 8$ FourPort static RAM designed to be used in systems where multiple access in a common RAM is required. This FourPort static RAM offers increased system performance in multiprocessed systems that have a need to communicate in real time and also offers
added benefit for high-speed systems in which multiple access is required in the same cycle.
The IDT7050 is also an extremely high-speed $1 \mathrm{~K} \times 8$ FourPort static RAM designed to be used in systems where on-chip hardware port arbitration is not needed. This part lends itself to those systems which cannot tolerate wait states or are designed to be able to externally arbitrate or withstand contention when all ports simultaneously access the same FourPort RAM location.
The IDT7050 provides four independent ports with separate control, address and $/ / O$ pins that permit independent, asynchronous access for reads or writes to any location in memory. It is the user's responsibility to ensure data integrity when simultaneously accessing the same memory location fromall ports. An automatic power down feature, controlled by $\overline{\mathrm{CE}}$, permits the on-chip circuitry of each port to enter a very low power standby power mode.
Fabricated using IDT's CEMOS ${ }^{\text {™ }}$ high-performance technology, this four port RAM typically operates on only 750 mW of power at maximum access times as fast as 25 ns . Low-power (L) versions offer battery backup data retention capability, with each port typically consuming $50 \mu \mathrm{~W}$ froma 2 V battery.
The IDT7050 is packaged in either a ceramic or plastic 108 -pin PGA and 132 -pin quad flatpack. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

FUNCTIONAL BLOCK DIAGRAM


2698 drw 01

| $\underbrace{81}_{\mathrm{R}} \mathrm{R} \bar{W}$ $\mathrm{P} 2$ | $\begin{array}{\|c} 80 \\ N C \end{array}$ | $\begin{array}{r} 77 \\ \text { A7 } \\ \text { P2 } \end{array}$ | $\begin{array}{\|r\|} \hline 74 \\ \text { A5 } \\ \text { P2 } \end{array}$ | $\begin{array}{\|c} \hline 72 \\ A_{3} \\ P 2 \end{array}$ | $\begin{array}{\|r\|} \hline 69 \\ \text { A0 } \\ \text { P2 } \end{array}$ | $\begin{array}{\|l\|} \hline 68 \\ A_{0} \\ P_{3} \end{array}$ | $\begin{array}{\|r} 65 \\ A_{3} \\ \mathrm{P}_{3} \end{array}$ | $\begin{aligned} & 63 \\ & A_{5} \\ & P_{3} \end{aligned}$ | $\begin{array}{r} 60 \\ \text { A7 } \\ \text { P3 } \end{array}$ |  | $\begin{aligned} & 54 \\ & \mathrm{R} / \bar{W} \\ & \mathrm{P} 3 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{\|c} 84 \\ \hline \mathrm{BUSY} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c\|} \hline 83 \\ \overline{\mathrm{OE}} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|r\|} \hline 78 \\ \text { A8 } \\ \text { P2 } \end{array}$ | $\begin{gathered} 76 \\ N C \end{gathered}$ | $\begin{array}{\|r\|} \hline 73 \\ \mathrm{~A}_{4} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{r} 70 \\ \text { A1 }^{2} \\ P_{2} \end{array}$ | $\begin{array}{\|r\|} \hline 67 \\ A_{1} \\ \mathrm{P}_{3} \end{array}$ | $\begin{array}{r} 64 \\ A_{4} \\ P_{3} \end{array}$ | $\begin{array}{\|l\|} \hline 61 \\ \mathrm{NC} \end{array}$ | $\begin{array}{\|l\|} \hline 59 \\ \mathrm{AB} \\ \mathrm{P3} \end{array}$ | $\begin{array}{\|c\|} \hline 56 \\ \hline \mathrm{OE} \\ \mathrm{~PB} \end{array}$ | $\begin{aligned} & \overline{53} \\ & \overline{\mathrm{BUSY}} \\ & \mathrm{P} 3 \end{aligned}$ |
| $\begin{array}{\|c} 87 \\ \mathrm{~A}_{2} \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|c} \hline 86 \\ A_{1} \\ P_{1} \end{array}$ | $\begin{array}{\|c\|} \hline 82 \\ \overline{C E} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c\|} \hline 79 \\ \mathrm{~A} 9 \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|r\|} \hline 75 \\ \mathrm{~A}_{6} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|r\|} \hline 71 \\ \mathrm{~A}_{2} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c\|} \hline 66 \\ \hline \mathrm{~A}_{2} \\ \mathrm{P} 3 \end{array}$ | $\begin{array}{\|r\|} \hline 62 \\ \mathrm{~A}_{6} \\ \mathrm{P} 3 \end{array}$ | $\begin{array}{\|l\|} \hline 58 \\ \hline \text { A9 } \\ \text { P3 } \end{array}$ | $\begin{array}{\|c\|} \hline 55 \\ \overline{\mathrm{CE}} \\ \mathrm{P} 3 \end{array}$ | $\begin{array}{\|l} \hline 51 \\ \text { A1 } \\ \text { P4 } \end{array}$ | $\begin{array}{r} 50 \\ A_{2} \\ P_{4} \end{array}$ |
| $\begin{array}{\|c} 90 \\ \mathrm{~A}_{5} \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|c\|} \hline 88 \\ \mathrm{~A}_{3} \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|c\|} \hline 85 \\ \text { A0 } \\ \text { P1 } \end{array}$ | $\begin{aligned} & \text { IDT7050 } \\ & 108 \text { Pin PGA } \\ & \text { TOP VIEW } \end{aligned}$ |  |  |  |  |  | $\begin{array}{r} 52 \\ A_{0} \\ P_{4} \end{array}$ | $\begin{array}{\|r\|} \hline 49 \\ \mathrm{A3} \\ \mathrm{P} 4 \end{array}$ | $\begin{aligned} & 47 \\ & A_{5} \\ & P_{4} \end{aligned}$ |
| $\begin{gathered} 92 \\ \mathrm{NC} \end{gathered}$ | 91 <br> A6 P1 | $\begin{array}{\|r} 89 \\ \\ \hline \end{array}$ |  |  |  |  |  |  | $\begin{array}{\|r\|} \hline 48 \\ \hline \mathrm{~A}_{4} \\ \mathrm{P}_{4} \end{array}$ | $\begin{array}{\|r\|} \hline 46 \\ \mathrm{~A}_{6} \\ \mathrm{P} 4 \end{array}$ | ${ }^{45} \mathrm{NC}$ |
| $\begin{array}{\|c} \hline 95 \\ \mathrm{~A}_{8} \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|c\|} \hline 94 \\ \mathrm{~A} 7 \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|cc} 93 \\ \mathrm{Vcc} \end{array}$ |  |  |  |  |  |  | $\begin{aligned} & 44 \\ & \text { GND } \end{aligned}$ | $\begin{array}{\|r\|} \hline 43 \\ \hline \mathrm{~A} 7 \\ \mathrm{P} 4 \end{array}$ | $\begin{array}{\|r\|} \hline 42 \\ \mathrm{~A}_{8} \\ \mathrm{P} 4 \end{array}$ |
| $\begin{array}{\|c\|} \hline 96 \\ \mathrm{~A}_{9} \\ \mathrm{P} 1 \end{array}$ | 97 NC | $\begin{array}{\|c\|} \hline 98 \\ \hline \\ \hline \mathrm{CE} \\ \mathrm{P} 1 \end{array}$ |  |  |  |  |  |  | 39 $\overline{C E}$ P4 | ${ }^{40} \mathrm{NC}$ | $\begin{array}{\|r\|} \hline 41 \\ \hline \mathrm{Ag} \\ \mathrm{P} 4 \end{array}$ |
| ${ }_{\substack{99 \\ \mathrm{P}_{1} \bar{W} \\ \hline \\ \hline}}$ | $\begin{gathered} 100 \\ \overline{\mathrm{OE}} \\ \mathrm{P} 1 \end{gathered}$ | $\begin{array}{\|c\|} \hline 102 \\ 1 / \mathrm{OO}_{2} \\ \mathrm{P} \end{array}$ |  |  |  |  |  |  | ${ }^{35} \mathrm{~V}_{\mathrm{ss}}$ | 37 <br> $\overline{\mathrm{OE}}$ P 4 | 38 <br> $\mathrm{R} \bar{W}$ P4 |
| $\frac{101}{\substack{\text { BUSY } \\ P_{1}}}$ | $\begin{gathered} 103 \\ 1 / O_{1} 1 \\ P_{1} \end{gathered}$ |  |  |  |  |  |  |  | $\begin{array}{\|l\|} \hline 31 \\ \text { GND } \end{array}$ | $\begin{array}{\|c\|} \hline 34 \\ 1 / \mathrm{O}_{7} \\ \mathrm{P} 4 \end{array}$ | $\overline{\mathrm{BUSY}} \mathrm{P4}$ |
| 104 I/O2 P1 | $\begin{array}{\|c\|} \hline 105 \\ 1 / \mathrm{O}_{3} \\ \mathrm{P}_{1} \end{array}$ | $\begin{array}{\|c\|} \hline 1 \\ 1 / \mathrm{O}_{6} \\ \mathrm{P} 1 \end{array}$ | ${ }^{4} \mathrm{Vcc}$ | $8$ <br> GND | $\begin{aligned} & 12 \\ & \mathrm{Vcc} \\ & \hline \end{aligned}$ | $\int_{V C C}^{17}$ | $\begin{array}{\|c} 21 \\ \text { GND } \end{array}$ | ${ }^{25} \mathrm{Vcc}$ | $\begin{gathered} 28 \\ \mathrm{I}_{1} \mathrm{O}_{2} \\ \mathrm{P} 4 \end{gathered}$ | $\begin{array}{\|c} 32 \\ 1 / \mathrm{O}_{5} \\ \mathrm{P} 4 \end{array}$ | $\begin{array}{\|c\|} \hline 33 \\ 1 / \mathrm{O}_{6} \\ \mathrm{P} 4 \end{array}$ |
| $\begin{gathered} 107 \\ \mathrm{I} / \mathrm{O}_{4} \\ \mathrm{P} 1 \end{gathered}$ | $\begin{array}{\|c\|} \hline 2 \\ { }^{1 / O_{7}} \\ \mathrm{P}_{1} \end{array}$ | $\begin{array}{\|c\|} \hline 5 \\ 1 / O_{0} \\ P 2 \end{array}$ | $\begin{array}{\|c\|} \hline 7 \\ \mathrm{I} / \mathrm{O}_{2} \\ \mathrm{P} 2 \end{array}$ | $\begin{gathered} 10 \\ 1 / O_{4} \\ P 2 \end{gathered}$ | $\begin{array}{\|c\|} \hline 13 \\ 1 / \mathrm{O}_{6} \\ \mathrm{P} 2 \end{array}$ | $16$ <br> I/O1 P3 | $\begin{array}{\|c\|} \hline 19 \\ 1 / \mathrm{O}_{3} \\ \mathrm{P} 3 \end{array}$ | $\begin{array}{\|c\|} \hline 22 \\ 1 / \mathrm{O}_{5} \\ \mathrm{P} 3 \end{array}$ | $\begin{gathered} 24 \\ 1 / O_{7} \\ P_{3} \end{gathered}$ | $\begin{gathered} 29 \\ {\mathrm{I} / \mathrm{O}_{3}}_{\mathrm{P} 4} \end{gathered}$ | $\begin{array}{\|c} \hline 30 \\ \mathrm{I} / \mathrm{O}_{4} \\ \mathrm{P} 4 \end{array}$ |
| $\begin{gathered} \hline 108 \\ \mathrm{I} / \mathrm{O}_{5} \\ \mathrm{P} 1 \end{gathered}$ | ${ }^{3} \mathrm{NC}$ | $\begin{array}{\|l\|} \hline 6 \\ \\ \hline \\ \text { I/O1 } 1 \\ \text { P2 } \end{array}$ | $\begin{array}{\|c\|} \hline 9 \\ \mathrm{I}_{1} \mathrm{O}_{3} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c} \hline 11 \\ \mathrm{I}_{2} / \mathrm{O}_{5} \end{array}$ | $\begin{array}{\|c\|} \hline 14 \\ 1 / \mathrm{O}_{7} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c\|} \hline 15 \\ 1 / O_{0} \\ P 3 \end{array}$ | $\begin{array}{\|c\|} \hline 18 \\ 1 / \mathrm{O}_{2} \\ \mathrm{P} 3 \end{array}$ | $\begin{gathered} 20 \\ 1 / \mathrm{O}_{4} \\ \mathrm{P} 3 \end{gathered}$ | $\begin{array}{\|c} \hline 23 \\ 1 / \mathrm{O}_{6} \\ \mathrm{P}_{3} \end{array}$ | $\begin{array}{\|c} \hline 26 \\ 1 / \mathrm{O}_{0} \\ \mathrm{P} 4 \end{array}$ | $\begin{array}{\|c\|} \hline 27 \\ 1 / \mathrm{O}_{1} \\ \mathrm{P} 4 \end{array}$ |
| A | B | C | D | E | F | G | H | J | K | L | M <br> 2698 drw 02 |

NOTES:

1. All Vcc pins must be connected to the power supply.
2. All GND pins must be connected to the ground supply.
3. NC denotes no-connect pin.


NOTES:

1. All Vcc pins must be connected to the power supply.
2. All GND pins must be connected to the ground supply.
3. NC denotes no-connect pin.

## PIN CONFIGURATIONS

| Symbol | Pin Name |
| :---: | :---: |
| $\mathrm{A}_{0} \mathrm{P} 1$ - A9 P1 | Address Lines - Port 1 |
| A0 P2-A9 P2 | Address Lines - Port 2 |
| $\mathrm{A}_{0} \mathrm{P} 3-\mathrm{A}_{9} \mathrm{P} 3$ | Address Lines - Port 3 |
| A0 P4-A9 P4 | Address Lines - Port 4 |
| $\mathrm{l} / \mathrm{O}_{0} \mathrm{P} 1-\mathrm{l} / \mathrm{O}_{7} \mathrm{P}_{1}$ | Data I/O - Port 1 |
| I/O0 P2-I/O7 P2 | Data I/O-Port 2 |
| I/O0 P3-l/O7 P3 | Data I/O - Port 3 |
| I/O0 P4-I/O7 P4 | Data I/O - Port 4 |
| $\mathrm{R} \bar{W}$ P1 | Read/Write - Port 1 |
| $\mathrm{R} / \overline{\mathrm{W}}$ P2 | Read/Write - Port 2 |
| $\mathrm{R} \bar{W}$ P3 | Read/Write - Port 3 |
| $\mathrm{R} \bar{W}$ P4 | Read/Write - Port 4 |
| GND | Ground |
| $\overline{C E}$ P1 | Chip Enable - Port 1 |
| CE P2 | Chip Enable - Port 2 |
| $\overline{\text { CE P3 }}$ | Chip Enable - Port 3 |
| $\overline{\text { CE P4 }}$ | Chip Enable - Port 4 |
| OEP1 | Output Enable - Port 1 |
| $\overline{O E}$ P2 | Output Enable - Port 2 |
| $\overline{\mathrm{OE}}$ P3 | Output Enable - Port 3 |
| $\overline{\mathrm{OE}}$ P4 | Output Enable - Port 4 |
| BUSY P1 | Write Disable - Port 1 |
| BUSY P2 | Write Disable - Port 2 |
| BUSY P3 | Write Disable - Port 3 |
| BUSY P4 | Write Disable - Port 4 |
| Vcc | Power |
| GND | Ground |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 11 | pF |
| CouT | Output Capacitance | $\mathrm{VOUT}=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2698 tbl 03

1. This parameter is determined by device characterization but is not production tested.

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

## NOTE:

$2698 \pm 05$

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

DC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE (VCC $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | IDT7050S |  | IDT7050L |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|| 1 || | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|iLO| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{ViH}$, Vout $=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| Vol | Oütput Low Voltage | $\mathrm{OL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1,2,6)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version |  | IDT7050x25 ${ }^{(3)}$ |  | IDT7050x30 |  | IDT7050x35 |  | IDT7050x45 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Typ. | Max. | Typ. | Max. | Typ. | Max. | Typ. | Max. |  |
| IcC1 | Operating Power Supply Current <br> (All Ports Active) | $\overline{\mathrm{CE}} \leq \mathrm{VIL}_{\mathrm{IL}}$ Outputs Open$f=0^{(4)}$ | MIL. | S | - | - | $\begin{aligned} & 150 \\ & 150 \end{aligned}$ | $\begin{aligned} & 360 \\ & 300 \end{aligned}$ | $\begin{array}{\|l\|} \hline 150 \\ 150 \end{array}$ | $\begin{aligned} & 360 \\ & 300 \end{aligned}$ | $\begin{aligned} & 150 \\ & 150 \end{aligned}$ | $\begin{aligned} & 360 \\ & 300 \end{aligned}$ | mA |
|  |  |  | COM'L. | S | $\begin{aligned} & 150 \\ & 150 \\ & \hline \end{aligned}$ | $\begin{array}{r} 300 \\ 250 \\ \hline \end{array}$ | $\begin{array}{r} 150 \\ 150 \\ \hline \end{array}$ | $\begin{aligned} & 300 \\ & 250 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 150 \\ & \hline \end{aligned}$ | $\begin{array}{r} 300 \\ 250 \\ \hline \end{array}$ | $\begin{array}{\|l\|l} 150 \\ 150 \\ \hline \end{array}$ | $\begin{array}{r} 300 \\ 250 \\ \hline \end{array}$ |  |
| ICC2 | Dynamic Operating Current (All Ports Active) | $\overline{\mathrm{CE}} \leq \mathrm{V}_{\mathrm{IL}}$ Outputs Open$f=f \max x^{(5)}$ | MIL. | S | - | - | $\begin{array}{r} 220 \\ 190 \\ \hline \end{array}$ | $\begin{aligned} & 400 \\ & 335 \end{aligned}$ | $\begin{array}{\|l} 210 \\ 180 \\ \hline \end{array}$ | $\begin{array}{r} 395 \\ 330 \\ \hline \end{array}$ | $\begin{array}{\|l} 195 \\ 170 \\ \hline \end{array}$ | $\begin{array}{r} 390 \\ 325 \\ \hline \end{array}$ | mA |
|  |  |  | COM'L. | S | $\begin{array}{\|l} 225 \\ 195 \\ \hline \end{array}$ | $\begin{array}{r} 350 \\ 305 \\ \hline \end{array}$ | $\begin{array}{r} 220 \\ 190 \\ \hline \end{array}$ | $\begin{array}{r} 340 \\ 295 \\ \hline \end{array}$ | $\begin{array}{\|l} 210 \\ 180 \\ \hline \end{array}$ | $\begin{array}{r} 335 \\ 290 \\ \hline \end{array}$ | $\begin{array}{\|r} 195 \\ 170 \\ \hline \end{array}$ | $\begin{array}{r} 330 \\ 285 \\ \hline \end{array}$ |  |
| ISB | Standby Current (All Ports — TTL Level Inputs) | $\begin{aligned} & \overline{C E} \geq V_{H} \\ & f=f M A X^{(5)} \end{aligned}$ | MIL. | S | - | - | $\begin{aligned} & 45 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} 115 \\ 85 \\ \hline \end{gathered}$ | $\begin{aligned} & 40 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{gathered} 110 \\ 80 \\ \hline \end{gathered}$ | $\begin{aligned} & 35 \\ & 30 \\ & \hline \end{aligned}$ | $\begin{array}{r} 105 \\ 75 \\ \hline \end{array}$ | mA |
|  |  |  | COM'L. | S | $\begin{aligned} & 60 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 85 \\ & 70 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 40 \end{aligned}$ | $\begin{aligned} & 80 \\ & 65 \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{array}{r} 75 \\ 60 \\ \hline \end{array}$ | $\begin{aligned} & 35 \\ & 30 \\ & \hline \end{aligned}$ | $\begin{aligned} & 70 \\ & 55 \end{aligned}$ |  |
| ISB1 | Full Standby Current (All Ports - All CMOS Level Inputs) | $\begin{aligned} & \text { All Ports } \\ & \overline{C E} \geq V c c-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \\ & \mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0^{(4)} \\ & \hline \end{aligned}$ | MIL. | S | - | - | $\begin{gathered} 1.5 \\ .3 \\ \hline \end{gathered}$ | $\begin{array}{r} 30 \\ 4.5 \\ \hline \end{array}$ | $\begin{aligned} & 1.5 \\ & .3 \\ & \hline \end{aligned}$ | $\begin{array}{r} 30 \\ 4.5 \\ \hline \end{array}$ | $\begin{gathered} 1.5 \\ .3 \\ \hline \end{gathered}$ | $\begin{aligned} & 30 \\ & 4.5 \\ & \hline \end{aligned}$ | mA |
|  |  |  | COM'L. | S | $\begin{gathered} 1.5 \\ .3 \end{gathered}$ | $\begin{aligned} & 15 \\ & 1.5 \end{aligned}$ | $\begin{gathered} 1.5 \\ .3 \end{gathered}$ | $\begin{aligned} & 15 \\ & 1.5 \end{aligned}$ | $\begin{gathered} 1.5 \\ .3 \end{gathered}$ | $\begin{aligned} & 15 \\ & 1.5 \end{aligned}$ | $\begin{array}{\|c\|} \hline 1.5 \\ .3 \\ \hline \end{array}$ | $\begin{aligned} & 15 \\ & 1.5 \end{aligned}$ |  |

NOTES:

1. " $x$ " in part number indicates power rating ( S or L ).
2. $\mathrm{Vcc}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ for Typ.
3. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
4. $f=0$ means no address or control lines change.
5. At $\mathrm{f}=\mathrm{fmax}$, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 / t \mathrm{tc}$, and using "AC Test Conditions" of input levels of GND to 3 V .
6. For the case of one port, divide the appropriate current by four.

## DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES ${ }^{(1)}$

(L Version Only) VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{VCC}-0.2 \mathrm{~V}$

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & \overline{\mathrm{CE}} \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \leq \mathrm{VLC} \end{aligned}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | 25 | 1800 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | 25 | 600 |  |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $t \mathrm{R}^{(3)}$ | Operation Recovery Time |  |  | tRC ${ }^{(2)}$ | - | - | ns |

NOTES:

1. $\mathrm{VCC}=2 \mathrm{~V}, \mathrm{~T} A=+25^{\circ} \mathrm{C}$
2. thC $=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## LOW Vcc DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |

2698 tol 09


Figure 1. Output Load


Figure 2. Output Load (for tiz, thz, twz, tow)

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE| Symbol | Parameter | $\begin{array}{\|l} \text { IDT7050S25 } \\ \text { IDT7050L25 } \\ \hline 1,3) \\ \hline \end{array}$ |  | $\begin{aligned} & \text { IDT7050S30 } \\ & \text { IDT7050L30 } \end{aligned}$ |  | IDT7050S35 IDT7050L35 |  | $\begin{aligned} & \text { IDT7050S45 } \\ & \text { IDT7050L45 } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| tAA | Address Access Time | - | 25 | - | 30 | - | 35 | - | 45 | ns |
| tace | Chip Enable Access Time | - | 25 | - | 30 | - | 35 | - | 45 | ns |
| taie | Output Enable Access Time | - | 15 | - | 20 | - | 25 | - | 30 | ns . |
| tor | Output Hold from Address Change | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLz | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | 3 | - | 3 | - | 5 | - | 5 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | - | 20 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 20 | - | 30 | - | 50 | - | 50 | ns |

## NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.

TIMING WAVEFORM OF READ CYCLE NO. 1 , ANY PORT ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, ANY PORT ${ }^{(1,3)}$


## NOTES:

1. $R / \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{C E}=$ VIL.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{O E}=V \mathrm{IL}$.

## AC ELECTRICAL CHARACTERISTICS OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Symbol | Parameter | $\begin{array}{\|l} \hline \text { IDT7050S25 } \\ \text { IDT7050L25 } \\ \hline \end{array}$ |  | $\begin{aligned} & \text { IDT7050S30 } \\ & \text { IDT7050L30 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7050S35 } \\ & \text { IDT7050L35 } \\ & \hline \end{aligned}$ |  | IDT7050S45 IDT7050L45 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| tew | Chip Enable to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width ${ }^{(3)}$ | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| twR | Write Recovery Time | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tDW | Data Valid to End of Write | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | - | 20 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twZ | Write Enabled to Output in High $\mathrm{Z}^{(1,2)}$ | - | 15 | - | 15 | - | 15 | - | 20 | ns |
| tow | Output Active from End of Write ${ }^{(1,2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twDD | Write Pulse to Data Delay ${ }^{(4)}$ | - | 45 | - | 50 | - | 55 | - | 65 | ns |
| tDD | Write Data Valid to Read Data Delay ${ }^{(4)}$ | - | 35 | - | 40 | - | 45 | - | 55 | ns |
| BUSY INPUT TIMING |  |  |  |  |  |  |  |  |  |  |
| twB | Write to $\overline{B U S Y}^{(5)}$ | 0 | - | 0 | - | 0 | 一 | 0 | - | ns |
| tWH | Write Hold After $\overline{\mathrm{BUSY}}^{(6)}$ | 15 | - | 20 | - | 20 | - | 20 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2 ).
2. This parameter is guaranteed but not tested.
3. Specified for $\overline{\mathrm{OE}}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).
4. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read with Port-to-Port Delay".
5. To ensure that the write cycle is inhibited during contention.
6. To ensure that a write cycle is completed after contention.
7. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.

TIMING WAVEFORM OF WRITE CYCLE NO. 1, R/ $\bar{W}$ CONTROLLED TIMING ${ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2, $\overline{\operatorname{CE}} \operatorname{CONTROLLED~} \operatorname{TIMING}{ }^{(1,2,3,5)}$


NOTES:

1. $\mathrm{R} / \bar{W}$ or $\overline{\mathrm{CE}}$ must be high during all address transitions.
2. A write occurs during the overlap (tew or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. TWR is measured from the earlier of $\overline{C E}$ or R/W going high to the end of write cycle.
4. During this period, the l/O pins are in the output state, and input signals must not be applied.
5. If the $\bar{C} \bar{E}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. 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.
7. If $\overline{O E}$ is low during a $\mathrm{R} \bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or (twZ + tow) to allow the I/O drivers to turn off data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$

NOTES:


1. Assume $\overline{B U S Y}$ input at HI and $\overline{\mathrm{CE}}$ at LO for the writing port
2. Write cycle parameters should be adhered to in order to ensure proper writing.
3. Device is continuously enabled for any of the reading ports which has its $\overline{\mathrm{OE}}$ at LO .

TIMING WAVEFORM OF WRITE WITH $\overline{B U S Y}$ INPUT


## FUNCTIONAL DESCRIPTION

The IDT7050 provides four ports with separate control, address and l/O pins that permit independent access for reads or writes to any location in memory. These devices have an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into standby mode when not selected (CE high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{O E}$ ). In the read mode, the port's $\overline{O E}$ turns on the output drivers when set LOW. READ/WRITE conditions are illustrated in the table below.

TABLE I - READ/WRITE CONTROL

| Any Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :--- |

NOTES:
2698 tbl 12

1. $\mathrm{H}=\mathrm{HIGH}, \mathrm{L}=$ LOW, $\mathrm{X}=$ Don't Care, $\mathrm{Z}=$ High Impedance
2. If $\overline{B U S Y}=$ LOW, data is not written.
3. For valid write operation, no more than one port can write to the same address location at the same time.

## ORDERING INFORMATION



Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Compliant to MIL-STD-883, Class B
108-Pin Pin Grid Array
132-Pin Plastic Quad Flatpack
132-Pin Cerquad
Commercial Only


Low Power
Standard Power
$8 \mathrm{~K}(1 \mathrm{~K} \times 8)$ FourPort RAM

Integrated Device Technology, Inc.

## HIGH-SPEED

$2 \mathrm{~K} x 8$ FourPort $^{\mathrm{TM}}$ STATIC RAM

PRELIMINARY IDT7052S IDT7052L

## FEATURES:

- High-speed access
- Military: $30 / 35 / 45 n s$ (max.)
- Commercial: 25/30/35/45ns (max.)
- Low-power operation
- IDT7052S Active: 750 mW (typ.) Standby: 10 mW (typ.)
- IDT7052L Active: 750 mW (typ.) Standby: 1.5 mW (typ.)
- Fully asynchronous operation from each of the four ports: P1, P2, P3, P4
- Versatile control for write-inhibit: separate $\overline{B U S Y}$ input to control write-inhibit for each of the four ports
- Battery backup operation- 2 V data retention
- TTL-compatible; single 5 V ( $\pm 10 \%$ ) power supply
- Available in several popular hermetic and plastic packages for both through-hole and surface mount
- Military product compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7052 is a high-speed $2 \mathrm{~K} \times 8$ FourPort static RAM designed to be used in systems where multiple access in a common RAM is required. This FourPort static RAM offers increased system performance in multiprocessed systems that have a need to communicate in real time and also offers
added benefit for high-speed systems in which multiple access is required in the same cycle.
The IDT7052 is also an extremely high-speed $2 \mathrm{~K} \times 8$ FourPort static RAM designed to be used in systems where on-chip hardware port arbitration is not needed. This part lends itself to those systems which cannot tolerate wait states or are designed to be able to externally arbitrate or withstand contention when all ports simultaneously access the same FourPort RAM location.
The IDT7052 provides four independent ports with separate control, address and $1 / O$ pins that permit independent, asynchronous access for reads or writes to any location in memory. It is the user's responsibility to ensure data integrity when simultaneously accessing the same memory location from all ports. An automatic power down feature, controlled by $\overline{C E}$, permits the on-chip circuitry of each port to enter a very low power standby power mode.
Fabricated using IDT's CEMOS ${ }^{\text {TM }}$ high-performance technology, this four port RAM typically operates on only 750 mW of power at maximum access times as fast as 25 ns . Low-power (L) versions offer battery backup data retention capability, with each port typically consuming $50 \mu \mathrm{~W}$ froma 2 V battery.
The IDT7052 is packaged in either a ceramic or plastic 108-pin PGA and 132-pin quad flatpack. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B.

## FUNCTIONAL BLOCK DIAGRAM



| $\begin{array}{\|c} 81 \\ \mathrm{R} \bar{W} \\ \mathrm{P} 2 \end{array}$ | ${ }^{80} \mathrm{NC}$ | $\begin{array}{\|r\|} \hline 77 \\ \text { A7 } \\ \text { P2 } \end{array}$ | $\begin{array}{\|c\|} \hline 74 \\ \text { A5 } \\ \text { P2 } \end{array}$ | $\begin{array}{r} 72 \\ A_{3} \\ P_{2} \end{array}$ | $\begin{gathered} 69 \\ \text { A0 } \\ \mathrm{P} 2 \end{gathered}$ | 68 <br> A0 P3 | $\begin{aligned} & 65 \\ & \mathrm{~A}_{3} \\ & \mathrm{P} 3 \end{aligned}$ | 63 <br> ${ }^{A} 5$ P3 | 60 <br> A7 P3 | ${ }^{57} \mathrm{NC}$ | $\begin{gathered} 54 \\ \mathrm{R} \bar{W} \\ \mathrm{P3} \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{\|l} \hline 84 \\ \overline{B U S Y} \\ P 2 \end{array}$ | 83 $\overline{\mathrm{OE}}$ P 2 | $\begin{array}{\|r\|} \hline 78 \\ \mathrm{As} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c\|} \hline 76 \\ \text { A10 } \\ \text { P2 } \end{array}$ | $\begin{array}{\|r\|} \hline 73 \\ \mathrm{~A}_{4} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|l\|} \hline 70 \\ \mathrm{~A}_{1} \\ \mathrm{P} 2 \end{array}$ | 67 <br> $\mathrm{A}_{1}$ P 3 | 64 ${ }^{6} 4$ $\mathrm{P}_{3}$ | 61 <br> A 10 P3 | $\begin{array}{\|l\|} \hline 59 \\ A_{8} \\ P 3 \end{array}$ | $\begin{gathered} 56 \\ \overline{\mathrm{OE}} \\ \mathrm{P} 3 \end{gathered}$ | $\begin{gathered} 53 \\ \overline{\mathrm{BUSY}} \mathrm{P3} \end{gathered}$ |
| $\begin{array}{\|r\|} \hline 87 \\ \mathrm{~A}_{2} \\ \mathrm{P}_{1} \end{array}$ | $\begin{array}{\|c} 86 \\ A_{1} \\ P_{1} \end{array}$ | $\begin{array}{\|c\|} \hline 82 \\ \overline{\mathrm{CE}} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|r\|} \hline 79 \\ \text { A9 } \\ \text { P2 } \end{array}$ | $\begin{array}{\|r} \hline 75 \\ \text { A6 } \\ \text { P2 } \end{array}$ | $\begin{array}{\|r\|} \hline 71 \\ \mathrm{~A}_{2} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c} \hline 66 \\ A_{2} \\ \mathrm{P}_{3} \end{array}$ | $\begin{array}{\|r\|} \hline 62 \\ \text { A6 } \\ \text { P3 } \end{array}$ | $\begin{array}{\|l\|} \hline 58 \\ \mathrm{~A}_{9} \\ \mathrm{P} 3 \end{array}$ | $\begin{array}{\|c} 55 \\ \overline{\mathrm{CE}} \\ \mathrm{P} 3 \end{array}$ | $\begin{array}{r} \hline 51 \\ A_{1} \\ P_{4} \end{array}$ | $\begin{array}{r} 50 \\ \mathrm{~A}_{2} \\ \mathrm{P}_{4} \end{array}$ |
| $\begin{aligned} & 90 \\ & \mathrm{~A}_{5} \\ & \mathrm{P} 1 \end{aligned}$ | $\begin{array}{\|c\|} \hline 88 \\ \mathrm{~A}_{3} \\ \mathrm{P} 1 \end{array}$ | 85 <br> Ao P1 | $\begin{aligned} & \text { IDT7052 } \\ & \text { 108-Pin PGA } \\ & \text { TOP VIEW } \end{aligned}$ |  |  |  |  |  | $\begin{array}{\|r\|} \hline 52 \\ A_{0} \\ P_{4} \end{array}$ | $\begin{array}{r} 49 \\ \mathrm{~A}_{3} \\ \mathrm{P}_{4} \end{array}$ | $\begin{array}{r} 47 \\ \mathrm{~A}_{5} \\ \mathrm{P} 4 \end{array}$ |
| 92 <br> A 10 P1 | $\begin{array}{\|ll\|} \hline 91 & \\ & \text { A6 } \\ & \text { P1 } \end{array}$ | $\begin{array}{\|l\|} \hline 89 \\ \mathrm{~A}_{4} \\ \mathrm{P}_{1} \end{array}$ |  |  |  |  |  |  | $\begin{array}{\|r} \hline 48 \\ \mathrm{~A}_{4} \\ \mathrm{P} 4 \end{array}$ | $\begin{array}{r} 46 \\ \mathrm{~A}_{6} \\ \mathrm{P} 4 \end{array}$ | $\begin{gathered} 45 \\ \mathrm{~A}_{10} \\ \mathrm{P}_{4} \end{gathered}$ |
| $\begin{array}{\|c} 95 \\ \mathrm{AB}_{\mathrm{P}} \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|c\|} \hline 94 \\ A_{7} \\ P_{1} \end{array}$ | $\begin{array}{\|cc} 93 \\ \mathrm{Vcc} \end{array}$ |  |  |  |  |  |  | ${ }^{44} \text { GND }$ | $\begin{array}{r} 43 \\ \mathrm{~A}_{7} \\ \mathrm{P} 4 \end{array}$ | $\begin{array}{r} 42 \\ \mathrm{~A}_{8} \\ \mathrm{P}_{4} \end{array}$ |
| 96 <br> A9 <br> P1 | ${ }^{97}$ NC | ${ }^{98} \overline{\mathrm{CE}}$ |  |  |  |  |  |  | $\begin{array}{\|c} { }^{39} \overline{\mathrm{CE}} \\ \mathrm{P} 4 \end{array}$ | ${ }^{40} \mathrm{NC}$ | $\begin{array}{\|c} 41 \\ \mathrm{Ag} \\ \mathrm{P} 4 \end{array}$ |
| $\begin{array}{\|c} 99 \\ \mathrm{R} \overline{\mathcal{W}} \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|c} 100 \\ \overline{\mathrm{OE}} \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|c\|} \hline 102 \\ \text { I/Oo } \\ P_{1} \end{array}$ |  |  |  |  |  |  |  | $\begin{gathered} { }^{37} \\ \overline{\mathrm{OE}} \\ \mathrm{P} 4 \end{gathered}$ | $\begin{gathered} 38 \\ \begin{array}{c} \text { R } \bar{W} \\ \mathrm{P}_{4} \end{array} \\ \hline \end{gathered}$ |
| $\frac{101}{\overline{B U S Y}}$ P1 | $\begin{array}{\|c\|} \hline 103 \\ 1 / \mathrm{O}_{1} \\ \mathrm{P}_{1} \end{array}$ | 106 GND |  |  |  |  |  |  | ${ }^{31} \text { GND }$ | I/O7 <br> P4 | $\begin{array}{\|c} \hline 36 \\ \hline \mathrm{BUSY} \\ \mathrm{P}_{4} \end{array}$ |
|  | $\begin{array}{\|c\|} \hline 105 \\ 1 / \mathrm{O}_{3} \\ \mathrm{P} 1 \end{array}$ | I/O6 P1 | Vcc | $8^{8} \text { GND }$ | $12$ | ${ }^{17} \mathrm{Vcc}$ | $\begin{array}{\|l\|} \hline 21 \\ \text { GND } \end{array}$ | ${ }^{25} \mathrm{Vcc}$ | $\left\lvert\, \begin{gathered} 28 \\ \mathrm{I} / \mathrm{O}_{2} \\ \mathrm{P} 4 \end{gathered}\right.$ | 32 <br> I/O5 P4 | $\begin{gathered} 33 \\ \mathrm{I}_{1} \mathrm{O}_{6} \\ \mathrm{P} 4 \end{gathered}$ |
| $\begin{gathered} 107 \\ 1 / \mathrm{O}_{4} \\ \mathrm{P} 1 \end{gathered}$ | $\begin{array}{\|c} 2 \\ \mathrm{I}_{1} \mathrm{O}_{7} \\ \mathrm{P} 1 \end{array}$ | $\begin{array}{\|c\|} \hline 5 \\ \text { I/OO } \\ \text { P2 } \end{array}$ | $\mathrm{I} / \mathrm{O}_{2}$ P2 | $\begin{array}{\|c\|} \hline 10 \\ 1 / \mathrm{O}_{4} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c\|} \hline 13 \\ \mathrm{I} / \mathrm{O}_{6} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c\|} \hline 16 \\ 1 / \mathrm{O}_{1} \\ \mathrm{P} 3 \end{array}$ | 19 <br> I/O3 P3 | $\begin{gathered} \hline 22 \\ 1 / \mathrm{O}_{5} \\ \mathrm{P} 3 \end{gathered}$ | $\begin{array}{\|c} 24 \\ 1 / \mathrm{O}_{7} \\ \mathrm{P} 3 \end{array}$ | $\begin{gathered} 29 \\ 1 / \mathrm{O}_{3} \\ \mathrm{P} 4 \end{gathered}$ | $\begin{gathered} \hline 30 \\ 1 / O_{4} \\ \mathrm{P}_{4} \end{gathered}$ |
| $\begin{gathered} 108 \\ \mathrm{I} / \mathrm{O}_{5} \\ \mathrm{P} 1 \end{gathered}$ | ${ }^{3} \mathrm{NC}$ | $\begin{aligned} & \hline 6 \\ & \text { I/O1 } 1 \\ & \text { P2 } \end{aligned}$ | $\begin{array}{\|c} \hline 9 \\ { }^{1 / \mathrm{O}_{3}} \\ \mathrm{P} 2 \end{array}$ | $\begin{array}{\|c} \hline 11 \\ \text { 1/O5 } \\ \text { P2 } \end{array}$ | $\begin{gathered} 14 \\ 1 / \mathrm{O}_{7} \\ \mathrm{P} 2 \end{gathered}$ | $\begin{array}{\|c\|} \hline 15 \\ \text { I/OO } \\ \text { P3 } \end{array}$ | 18 <br> I/O2 P3 | $\begin{gathered} \hline 20 \\ 1 / \mathrm{O}_{4} \\ \mathrm{P} 3 \end{gathered}$ | $\begin{array}{\|c\|} \hline 23 \\ 1 / \mathrm{O}_{6} \\ \mathrm{P} 3 \end{array}$ | $\begin{gathered} 26 \\ 1 / \mathrm{O}_{0} \\ \mathrm{P} 4 \end{gathered}$ | $\begin{array}{\|c} \hline 27 \\ 1 / O_{1} \\ P 4 \end{array}$ |
| A | B | C | D | E | F | G | H | $J$ | K | L | M <br> 2674 drw 02 |

NOTES:
2674 drw 02

1. All VCC pins must be connected to the power supply.
2. All GND pins must be connected to the ground supply.
3. NC denotes no-connect pin.


NOTES:

1. All Vcc pins must be connected to the power supply.
2. All GND pins must be connected to the ground supply.
3. NC denotes no-connect pin.

## PIN CONFIGURATIONS

| Symbol | Pin Name |
| :---: | :---: |
| $\mathrm{A}_{0} \mathrm{P} 1$ - $\mathrm{A}_{10} \mathrm{P} 1$ | Address Lines - Port 1 |
| $\mathrm{A}_{0} \mathrm{P} 2$ - $\mathrm{A}_{10} \mathrm{P} 2$ | Address Lines - Port 2 |
| A0 P3-A10 P3 | Address Lines - Port 3 |
| A0 P4-A10 P4 | Address Lines - Port 4 |
| $1 / O_{0} \mathrm{P} 1-1 / \mathrm{O}_{7} \mathrm{P} 1$ | Data I/O - Port 1 |
| $1 / O_{0} \mathrm{P} 2-\mathrm{l} / \mathrm{O}_{7} \mathrm{P} 2$ | Data I/O - Port 2 |
| $1 / \mathrm{O} 0 \mathrm{P} 3-1 / \mathrm{O}_{7} \mathrm{P} 3$ | Data l/O-Port 3 |
| $1 / \mathrm{O} 0 \mathrm{P} 4-1 / \mathrm{O}_{7} \mathrm{P} 4$ | Data I/O-Port 4 |
| $\mathrm{R} \bar{W} \mathrm{P} 1$ | Read/Write - Port 1 |
| $\mathrm{R} \bar{W}$ P2 | Read/Write - Port 2 |
| $\mathrm{R} \overline{\mathcal{W}} \mathrm{P} 3$ | Read/Write - Port 3 |
| $\mathrm{R} \overline{\mathrm{W}}$ P4 | Read/Write - Port 4 |
| GND | Ground |
| $\overline{\mathrm{CE}}$ P1 | Chip Enable - Port 1 |
| $\overline{\mathrm{CE}}$ P2 | Chip Enable - Port 2 |
| $\overline{\mathrm{CE}}$ P3 | Chip Enable - Port 3 |
| $\overline{\mathrm{CE}} \mathrm{P} 4$ | Chip Enable - Port 4 |
| $\overline{\mathrm{OE}} \mathrm{P} 1$ | Output Enable - Port 1 |
| $\overline{\mathrm{OE}} \mathrm{P} 2$ | Output Enable - Port 2 |
| OE P3 | Output Enable - Port 3 |
| OEP4 | Output Enable - Port 4 |
| BUSY P1 | Write Disable - Port 1 |
| BUSY P2 | Write Disable - Port 2 |
| BUSY P3 | Write Disable - Port 3 |
| BUSY P4 | Write Disable - Port 4 |
| Vcc | Power |
| GND | Ground |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2074 tb 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | Vin $=\mathrm{OV}$ | 11 | pF |
| Cout | Output Capacitance | VouT $=0 \mathrm{~V}$ | 11 | pF |

NOTE:
2674 tit 03

1. This parameter is determined by device characterization but is not production tested.

## RECOMMENDED OPERATING <br> TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

2674 tol 04

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2674 tbl 05

1. $\mathrm{V}_{\mathrm{KL}}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS OVER THE

OPERATING TEMPERATURE AND SUPPLY VOLTAGE (Vcc $=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Test Conditions | IDT7052S |  | IDT7052L |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|lıI| | Input Leakage Current | $\mathrm{Vcc}=5.5 \mathrm{~V}, \mathrm{~V}$ IN $=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage Current | $\overline{\mathrm{CE}}=\mathrm{VIH}$, Vout $=0 \mathrm{~V}$ to Vcc | - | 10 | - | 5 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | $V$ |

DC ELECTRICAL CHARACTERISTICS OVER THE
OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE ${ }^{(1,2,6)}(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%)$

| Symbol | Parameter | Test Condition | Version |  | IDT7052x25 ${ }^{(3)}$ |  | IDT7052x30 |  | IDT7052x35 |  | IDT7052x45 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Typ. | Max. | Typ. | Max. | Typ. | Max. | Typ. | Max. |  |
| lcc1 | Operating Power Supply Current <br> (All Ports Active) | $\overline{\mathrm{CE}} \leq$ VIL Outputs Open$f=0^{(4)}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | - | $\begin{aligned} & 150 \\ & 150 \end{aligned}$ | $\begin{aligned} & 360 \\ & 300 \end{aligned}$ | $\begin{aligned} & 150 \\ & 150 \end{aligned}$ | $\begin{aligned} & 360 \\ & 300 \end{aligned}$ | $\begin{aligned} & 150 \\ & 150 \end{aligned}$ | $\begin{aligned} & 360 \\ & 300 \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 150 \\ & 150 \end{aligned}$ | $\begin{array}{r} 300 \\ 250 \\ \hline \end{array}$ | $\begin{array}{r} 150 \\ 150 \\ \hline \end{array}$ | $\begin{array}{r} 300 \\ 250 \\ \hline \end{array}$ | $\begin{aligned} & 150 \\ & 150 \\ & \hline \end{aligned}$ | $\begin{array}{r} 300 \\ 250 \\ \hline \end{array}$ | $\begin{aligned} & 150 \\ & 150 \\ & \hline \end{aligned}$ | $\begin{array}{r} 300 \\ 250 \end{array}$ |  |
| IcC2 | Dynamic Operating Current <br> (All Ports Active) | $\overline{\overline{C E}} \leq \mathrm{VIL}$ <br> Outputs Open $f=f \text { max } x^{(5)}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | 二 | - | $\begin{aligned} & 220 \\ & 190 \\ & \hline \end{aligned}$ | $\begin{aligned} & 400 \\ & 335 \end{aligned}$ | $\begin{aligned} & 210 \\ & 180 \\ & \hline \end{aligned}$ | $\begin{aligned} & 395 \\ & 330 \\ & \hline \end{aligned}$ | $\begin{aligned} & 195 \\ & 170 \end{aligned}$ | $\begin{aligned} & 390 \\ & 325 \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & 225 \\ & 195 \\ & \hline \end{aligned}$ | $\begin{array}{r} 350 \\ 305 \\ \hline \end{array}$ | $\begin{array}{r} 220 \\ 190 \\ \hline \end{array}$ | $\begin{array}{r} 340 \\ 295 \\ \hline \end{array}$ | $\begin{array}{r} 210 \\ 180 \\ \hline \end{array}$ | $\begin{array}{r} 335 \\ 290 \\ \hline \end{array}$ | $\begin{array}{\|l} \hline 195 \\ 170 \\ \hline \end{array}$ | $\begin{array}{r} 330 \\ 285 \\ \hline \end{array}$ |  |
| IsB | Standby Current <br> (All Ports — TTL <br> Level Inputs) | $\begin{aligned} & \overline{C E} \geq V_{I H} \\ & f=f M A X^{(5)} \end{aligned}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | 二 | $\begin{aligned} & 45 \\ & 40 \end{aligned}$ | $\begin{gathered} 115 \\ 85 \end{gathered}$ | $\begin{aligned} & 40 \\ & 35 \end{aligned}$ | $\begin{gathered} 110 \\ 80 \\ \hline \end{gathered}$ | $\begin{aligned} & 35 \\ & 30 \\ & \hline \end{aligned}$ | $\begin{gathered} 105 \\ 75 \end{gathered}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{array}{r} 60 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & 85 \\ & 70 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 40 \end{aligned}$ | $\begin{aligned} & 80 \\ & 65 \\ & \hline \end{aligned}$ | $\begin{aligned} & 40 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{aligned} & 75 \\ & 60 \\ & \hline \end{aligned}$ | $\begin{aligned} & 35 \\ & 30 \end{aligned}$ | $\begin{aligned} & 70 \\ & 55 \\ & \hline \end{aligned}$ |  |
| ISB1 | Full Standby Current (All Ports - All CMOS Level Inputs) | All Ports$\begin{aligned} & \overline{C E} \geq V c c-0.2 V \\ & V I N \geq V c c-0.2 V \text { or } \\ & V \mathbb{I} \leq 0.2 V, f=0^{(4)} \end{aligned}$ | MIL. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | - | - | $\begin{gathered} 1.5 \\ .3 \end{gathered}$ | $\begin{aligned} & 30 \\ & 4.5 \end{aligned}$ | $\begin{gathered} 1.5 \\ .3 \end{gathered}$ | $\begin{aligned} & 30 \\ & 4.5 \end{aligned}$ | $\begin{aligned} & 1.5 \\ & \hline .3 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 4.5 \end{aligned}$ | mA |
|  |  |  | COM'L. | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{gathered} 1.5 \\ .3 \end{gathered}$ | $\begin{aligned} & 15 \\ & 1.5 \end{aligned}$ | $\begin{gathered} 1.5 \\ .3 \end{gathered}$ | $\begin{gathered} 15 \\ 1.5 \end{gathered}$ | $\begin{gathered} 1.5 \\ .3 \end{gathered}$ | $\begin{aligned} & 15 \\ & 1.5 \end{aligned}$ | $\begin{gathered} 1.5 \\ \hline .3 \end{gathered}$ | $\begin{aligned} & 15 \\ & 1.5 \end{aligned}$ |  |

NOTES:

1. " $x$ " in part number indicates power rating ( S or L ).
2. $\mathrm{Vcc}=5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$ for Typ.
3. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
4. $f=0$ means no address or control lines change.
5. At $f=$ fmax, address and data inputs (except Output Enable) are cycling at the maximum frequency of read cycle of $1 / t \mathrm{tc}$, and using "AC Test Conditions" of input levels of GND to 3 V .
6. For the case of one port, divide the above appropriate current by four.

DATA RETENTION CHARACTERISTICS OVER ALL TEMPERATURE RANGES ${ }^{(1)}$
(L Version Only) VLC $=0.2 \mathrm{~V}, \mathrm{VHC}=\mathrm{VCC}-0.2 \mathrm{~V}$

| Symbol | Parameter | Test Condition |  | Min. | Typ. ${ }^{(1)}$ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | $\begin{aligned} & \mathrm{VCC}=2 \mathrm{~V} \\ & \overline{\mathrm{CE}} \geq \mathrm{VHC} \\ & \mathrm{VIN} \geq \mathrm{VHC} \text { or } \leq \mathrm{VLC} \end{aligned}$ |  | 2.0 | - | - | V |
| ICCDR | Data Retention Current |  | MIL. | - | 25 | 1800 | $\mu \mathrm{A}$ |
|  |  |  | COM'L. | - | 25 | 600 |  |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  |  | 0 | - | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  |  | $\mathrm{trc}^{(2)}$ | - | - | ns |

## NOTES:

1. $V C C=2 V, T_{A}=+25^{\circ} \mathrm{C}$
2. $t R C=$ Read Cycle Time
3. This parameter is guaranteed but not tested.

## LOW Vcc DATA RETENTION WAVEFORM



## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing. Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |
| 2674 mlog |  |



Figure 1. Output Load


Figure 2. Output Load (for tiz, thz, twz, tow)

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE| Symbol | Parameter | $\begin{aligned} & \text { IDT7052S25 }{ }^{(1)} \\ & \text { IDT7052L25 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7052S30 } \\ & \text { IDT7052L30 } \\ & \hline \end{aligned}$ |  | IDT7052S35 <br> IDT7052L35 |  | IDT7052S45 IDT7052L45 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| tAA | Address Access Time | - | 25 | - | 30 | - | 35 | - | 45 | ns |
| tace | Chip Enable Access Time | - | 25 | - | 30 | - | 35 | - | 45 | ns |
| taioe | Output Enable Access Time | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| tOH | Output Hold from Address Change | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLZ | Output Low $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | 3 | - | 3 | - | 5 | - | 5 | - | ns |
| thz | Output High $\mathrm{Z} \mathrm{Time}{ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | - | 20 | ns |
| tPU | Chip Enable to Power Up Time ${ }^{(2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD | Chip Disable to Power Down Time ${ }^{(2)}$ | - | 20 | - | 30 | - | 50 | - | 50 | ns . |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.

TIMING WAVEFORM OF READ CYCLE NO. 1, ANY PORT ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, ANY PORT ${ }^{(1,3)}$


NOTES:
2674 drw 07

1. $R \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CE}}$ transition low.
4. $\overline{O E}=V I L$.

## AC ELECTRICAL CHARACTERISTICS OVER THE

 OPERATING TEMPERATURE AND SUPPLY VOLTAGE| Symbol | Parameter | $\begin{aligned} & \text { IDT7052S25 } \\ & \text { IDT7 } \\ & \text { IDT052L25 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7052S30 } \\ & \text { IDT7052L30 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT7052S35 } \\ & \text { IDT7052L35 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { IDT7052S45 } \\ & \text { IDT7052L45 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |

## WRITE CYCLE

| twC | Write Cycle Time | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tEW | Chip Enable to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| taW | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twP | Write Pulse Width |  |  |  |  |  |  |  |  |  |
| (3) | 20 | - | 25 | - | 30 | - | 35 | - | ns |  |
| tWR | Write Recovery Time | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tDW | Data Valid to End of Write | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tHZ | Output High Z Time ${ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | - | 20 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twZ | Write Enabled to Output in High Z ${ }^{(1,2)}$ | - | 15 | - | 15 | - | 15 | - | 20 | ns |
| tow | Output Active from End of Write ${ }^{(1,2)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twDD | Write Pulse to Data Delay ${ }^{(4)}$ | - | 45 | - | 50 | - | 55 | - | 65 | ns |
| tDOD | Write Data Valid to Read Data Delay ${ }^{(4)}$ | - | 35 | - | 40 | - | 45 | - | 55 | ns |


| BUSY INPUT TIMING |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twb | Write to $\overline{\mathrm{BUSY}}^{(5)}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tWH | Write Hold After $\overline{\mathrm{BUSY}}{ }^{(6)}$ | 15 | - | 20 | - | 20 | - | 20 | - | ns |

NOTES:

1. Transition is measured $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is guaranteed but not tested.
3. Specified for $\overline{O E}$ at high (refer to "Timing Waveform of Write Cycle", Note 7).
4. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read with Port-to-Port Delay".
5. To ensure that the write cycle is inhibited during contention.
6. To ensure that a write cycle is completed after contention.
7. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.

## timing waveform of write cycle no. 1, r/W CONTROLLED Timing ${ }^{(1,2,3,7)}$



## TIMING WAVEFORM OF WRITE CYCLE NO. 2, $\overline{\text { CE }}$ CONTROLLED $\operatorname{TIMING}{ }^{(1,2,3,5)}$



NOTES:

1. $R \bar{W}$ or $\overline{C E}$ must be high during all address transitions.
2. A write occurs during the overlap (tew or twP) of a low $\overline{C E}$ and a low $R / \bar{W}$.
3. twR is measured from the earlier of $\overline{C E}$ or RNW going high to the end of write cycle.
4. During this period, the I/O pins are in the output state, and input signals must not be applied.
5. If the $\overline{C E}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the outputs remain in the high impedance state.
6. 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:
7. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or (twZ + tow) to allow the I/O drivers to turn off data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$


TIMING WAVEFORM OF WRITE WITH BUSY INPUT


## FUNCTIONAL DESCRIPTION

The IDT7052 provides four ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. These devices have an automatic power down feature controlled by $\overline{\mathrm{CE}}$. The $\overline{\mathrm{CE}}$ controls on-chip power down circuitry that permits the respective port to go into standby mode when not selected ( $\overline{\mathrm{CE}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{O E}$ ). In the read mode, the port's $\overline{O E}$ turns on the output drivers when set LOW. READ/WRITE conditions are illustrated in the table below.

TABLE I - READ/WRITE CONTROL

| Any Port ${ }^{(1)}$ |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
| R/W | $\overline{C E}$ | $\overline{\mathbf{O E}}$ | D0.7 |  |
| X | H | X | Z | Port Disabled and in Power Down Mode |
| X | H | X | Z | $\overline{\mathrm{CEP}}_{1}=\overline{\mathrm{CEP}}_{2}=\overline{\mathrm{CEP}}_{3}=\overline{\mathrm{CEP}}_{4}=$ H Power Down Mode, IsB or ISB1 |
| $L$ | L | X | DATAIN | Data on port written into memory ${ }^{(2,3)}$ |
| H | L | L | DATAOUT | Data in memory output on port |
| X | X | H | Z | High impedance outputs |

NOTES:
2698 か 12

1. $H=H I G H, L=L O W, X=$ Don't Care, $Z=$ High Impedance
2. If $\overline{B U S Y}=$ LOW, data is not written.
3. For valid write operation, no more than one port can write to the same address location at the same time.

## ORDERING INFORMATION



## FEATURES:

- $4 \mathrm{~K} \times 16 \mathrm{RAM}$ with registered outputs, serial or parallel load and readback capability in only 48 pins
- Serial Protocol Channel allows serial load and readback of RAM over a 4-wire channel
- RAM address counter speeds RAM load and readback
- Outputs may be programmed to be registered or non-registered in groups of 8 bits
- Initialize register allows initial microword selection
- Synchronous and asynchronous output enables allow for depth expansion and bus driving
- Programmable chip selects enable depth \& width expansion without any external decode logic
- Breakpoint comparator supports system diagnostics
- Parity check on outputs for high reliability designs
- High-speed (address set-up before clock)
- Military: 35/45/55ns (max.)
- Commercial: 25/35/45ns (max.)
- Low-power consumption
- IDT71502S - Active: 750 mW (typ.)
- IDT71502L - Active: 600 mW (typ.)
- Input and output directly TTL-compatible
- Standard 48-pin DIP, 48-pin LCC and 52-pin PLCC.
- Military product $100 \%$ compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT71502 Registered RAM is a 65,536 bits high speed static RAM organized as $4 \mathrm{~K} \times 16$, with a high speed register at the RAM outputs and serial load and readback capability using the IDT Serial Protocol Channel, SPC ${ }^{\text {M }}$.

This device is the first in a family of multifeatured RAM's with a built-in Serial Protocol Channel SPC ${ }^{\text {TM }}$ letting the user set the best configuration for his system:

- SELF-ADDRESSING RAM
- writable control store
- LOGIC ANALYZER/RECORDER

The 71502 is fabricated using IDT's high-performance, highreliability technology-CEMOS ${ }^{\text {™ }}$. This technology gives the 71502 the combination of low power, high speed, and high density that makes it a cost effective solution.

The IDT71502 is available with address set up before clock times as fast as $25 n \mathrm{n}$. These times are available with a maximum power consumption of only 1.6 W .

All inputs and outputs of the IDT71502 are TTL-compatible, and the device operates from a single 5 V supply. Fully static, asynchronous circuitry is used, requiring no clocks (with the exception of the register clock) or refreshing for operation.

The IDT71502 is packaged in plastic and ceramic versions of either a 48 -pin, 600 mil DIP; a 48 -pin leadless chip carrier, or a 52-pin plastic leadless chip carrier providing high board level packing densities.

The IDT71502 is $100 \%$ processed in compliance to the test methods of MIL-STD-883, Method 5004.

## FUNCTIONAL BLOCK DIAGRAM



CEMOS is a trademark of Integrated Device Technology, Inc.

PIN CONFIGURATION


## LOGIC SYMBOL



## PIN NAMES

| NAME | FUNCTION |
| :--- | :--- |
| $A_{0-11}$ | Address |
| $I / O_{0-15}$ | Data Input/Output |
| $\overline{C S} 0-2$ | Chip Select |
| $\overline{W E}$ | Write Enable |
| $\overline{O E}$ | Output Enable |
| SOE | Synchronous Output Enable |
| CLK | Clock (to register) |
| $\overline{\text { NIT }}$ | Initialize |
| BKPT | Breakpoint Detect |
| PAR | Parity |
| SI | SPC Serial DATA ${ }_{\text {IN }}{ }^{(1)}$ |
| SO | SPC Serial DATA ${ }^{(1)}$ |
| SCLK | SPC Clock ${ }^{(1)}$ |
| C/D | SPC Command/Data ${ }^{(1)}$ |
| GND | Ground |
| $V_{\text {CC }}$ | Power |

NOTE:

1. The Serial Protocol Channel (SPC) is discussed at length in IDT Application Note 16.


7

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| SYMBOL | RATING | COMMERCIAL | MILITARY | UNIT |
| :--- | :--- | :---: | :---: | :---: |
| $V_{\text {TEAM }}$ | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| $T_{A}$ | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {BIAS }}$ | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {STG }}$ | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ${ }^{(1)}\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| SYMBOL | PARAMETER | CONDITIONS | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ | 12 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ | 12 | pF |

## NOTE:

1. This parameter is determined by device characterization but is not production tested.

TRUTH TABLE - READ/WRITE OPERATIONS STANDARD PIPELINED MODE

| MODE | $\overline{\mathrm{CS}}$ | $\overline{\text { WE }}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { SOE }}$ | CLK | I/O OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Deselected | H | X | L | X | - | High Z |
| Read | L | H | H | X | X | High Z |
| Read | L | H | L | H | - | High Z |
| Read | L | H | L | L | - | DATA $_{\text {Out }}$ @ Address |
| Write | L | L | X | X | X | DATA $_{\text {IN }}$ @ Address |

TRUTH TABLE - SPC OPERATIONS

| MODE | C/D | SCLK | FUNCTION |
| :---: | :---: | :---: | :--- |
| Command | H | - | Shift bit into command register |
| Data | L | - | Shift bit into data register |
| Execute | L | - | Execute command during time <br> between C/D and SCLK |

RECOMMENDED DC OPERATING CONDITIONS

| SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNIT |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.2 | - | 6.0 | V |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{V}_{\mathrm{IL}}$ (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| GRADE | AMBIENT <br> TEMPERATURE | GND | $V_{c c}$ |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm \cdot 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$

| SYMBOL | PARAMETER | TEST CONDITIONS |  |  | T71502 |  |  | T71502 |  | NIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER |  |  | MIN. | TYP. ${ }^{(1)}$ | MAX. | MIN. | TYP. ${ }^{(1)}$ | MAX. | UNIT |
| 111 | Input Leakage Current | $V_{C C}=M a x ., V_{I N}=G N D$ to $V_{C C}$ | MIL. | - | - | 10 | - | - | 5 | $\mu A$ |
|  |  |  | COM'L. | - | - | 5 | - | - | 2 |  |
| $\mathrm{ILO}_{\mathrm{LO}}$ | Output Leakage Current | $\begin{aligned} & V_{C C}=\text { Max. } \\ & \mathrm{CS}=V_{I H}, V_{O U T}=G N D \text { to } V_{C C} \end{aligned}$ | MIL. | - | - | 10 | - | - | 5 | $\mu A$ |
|  |  |  | COM'L. | - | - | 5 | - | - | 2 |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage ${ }^{(2)}$ | $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}, \mathrm{~V}_{C C}=$ Min. |  | - | - | 0.5 | - | - | 0.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ${ }^{(2)}$ | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$. |  | 2.4 | - | - | 2.4 | - | - | $V$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage, BKPT | $I_{O L}=24 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$. |  | - | - | 0.5 | - | - | 0.5 | V |

## NOTES:

1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V},+25^{\circ} \mathrm{C}$ ambient.
2. All outputs except BKPT, which is open drain.

## DC ELECTRICAL CHARACTERISTICS ${ }^{(1)}$

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%$

| SYMBOL | PARAMETER | POWER | $\begin{array}{\|l\|} \hline \text { IDT71502S25 } \\ \text { IDT7 4) } \\ \text { IDT1502L25(2, 4) } \end{array}$ | $\begin{aligned} & \text { IDT71502S35 }{ }^{(4)} \\ & \text { IDT71502L35 } \end{aligned}$ |  | IDT71502S45 ${ }^{(4)}$ IDT71502L45 (4) |  | $\begin{aligned} & \text { IDT71502S555 } \\ & \text { IDT71502L55 }{ }^{(3,4)} \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | COM'L. | COM'L. | MIL. | COM'L. | MIL. | СОM'L. | MIL. |  |
| $\mathrm{I}_{\mathrm{cc}}$ | Operating Power Supply Current <br> $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{LL}}$, Outputs Open, $V_{C C}=\text { Max., } f=0$ | $s$ | 155 \% | 155 | 170 | 155 | 170 | 155 | 170 | mA |
|  |  | L | 135 | 135 | 150 | 135 | 150 | 135 | 150 |  |
| $\mathrm{I}_{\text {cce }}$ | Dynamic Operating Current $\overline{C S}=V_{L L}$, Outputs Open, $V_{C C}=M_{\text {Mx. }}, f=f_{\text {MAX }}=1 / \mathrm{TRC}$ | S | 280 | 255 | 270 | 230 | 245 | 220 | 235 | mA |
|  |  | L | . 250 | 225 | 240 | 200 | 215 | 190 | 205 |  |

## NOTES:

1. All values are guaranteed maximums.
2. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
3. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
4. Pipelined address access set-up time.

AC ELECTRICAL CHARACTERISTICS
( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$, All Temperature Ranges)

| SYMBOL | PARAMETER | $\begin{aligned} & \text { IDT71502S25(1,4) } \\ & \text { IDT71502L25(1,4) } \end{aligned}$ | $\begin{aligned} & \text { IDT71502S355 } \\ & \text { IDT71502L35 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT71502S45 } \\ & \text { IDT71502L45 } \end{aligned}$ |  | $\begin{aligned} & \text { IDT71502S55 (2, 4) } \\ & \text { IDT71502L55 }(2,4) \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. MAX. | MIN. | MAX. | MIN. | MAX. | MIN. |  |  |
| READ CYCLE - PIPELINED |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {RC }}$ | Read Cycle Time | 40 - - | 50 | - | 65 | - | 80 | - | ns |
| $t_{\text {AS }}$ | Address Set-up Time | 25 , | 35 | - | 45 | - | 55 | - | ns |
| $\mathrm{t}_{\mathrm{cs}}$ | Chip Select Set-up Time | 10 | 12 | - | 15 | - | 20 | - | ns |
| $\mathrm{t}_{\text {s }}$ | Set-up Time: SOE | 10 | 12 | - | 15 | - | 20 | - | ns |
| $\mathrm{t}_{\mathrm{AH}}$ | Address Hold Time | 0 . | 0 | - | 0 | - | 0 | - | ns |
| $t_{\text {ch }}$ | Chip Select Hold Time | 2. | 2 | - | 2 | - | 2 | - | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Hold Time: SOE | $2 \rightarrow-$ | 2 | - | 2 | - | 2 | - | ns |
| $t_{\text {co }}$ | Clock to Output Delay | - ......12 | - | 15 | - | 20 | - | 25 | ns |
| ${ }_{\text {t }}{ }_{\text {cWH }}$ | Clock Width, High | 15. | 15 | - | 20 | - | 20 | - | ns |
| $\mathrm{t}_{\text {cWL }}$ | Clock Width, Low | 15 - | 15 | - | 20. | - | 20 | - | ns |
| $t_{\text {tee }}$ | Asynchronous Output Enable To Data Valid Time |  | - | 15 | - | 20 | - | 25 | ns |
| ${ }^{\text {toz }}$ | Asynchronous Output Disable Time ${ }^{(3)(5)}$ | - . 1 \% 11 | - | 14 | - | 19 | - | 24 | ns |
| ${ }^{\text {t SOE }}$ | Synchronous Output Enable To Data Valid Time | - 12 | - | 15 | - | 20 | - | 25 | ns |
| ${ }^{\text {t }}$ SOz | Synchronous Output Disable Time ${ }^{(3)(5)}$ | $\checkmark \times 11$ | - | 14 | - | 19 | - | 24 | ns |
| $\mathrm{t}_{\text {INIT }}$ | Initialize to Output Delay | $\square{ }^{-}$ | - | 50 | - | 65 | - | 80 | ns |
| $\mathrm{t}_{\text {IR }}$ | Initialize Recovery Time | $30 \sim \sim$ | 35 | - | 45 | - | 55 | - | ns |
| $\mathrm{t}_{\text {w }}$ | Initialize Pulse Width | 30 - | 35 | - | 45 | - | 55 | - | ns |
| $\mathrm{t}_{\text {PAR }}$ | Parity Generation Time | , \% 30 | - | 35 | - | 45 | - | 55 | ns |
| $t_{\text {BPR }}$ | Breakpoint Delay From Register | 35 | - | 35 | - | 45 | - | 55 | ns |
| $\mathrm{t}_{\text {BPA }}$ | Breakpoint Delay From Address |  | - | 35 | - | 45 | - | 55 | ns |
| ${ }^{\text {ABFS }}$ | Address to BKPT FF Set-up | 30 | 35 | - | 40 | - | 50 | - | ns |
| $\mathrm{t}_{\text {ABFH }}$ | Address to BKPT FF Hold | 0 『 | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\text {BFCD }}$ | BKPT FF Clock to Data | आ..... 16 | - | 20 | - | 25 | - | 30 | ns |
| READ CYCLE - NON-PIPELINED |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {AAN }}$ | Address Access Time | $\cdots$, 30 | - | 35 | - | 65 | - | 80 | ns |
| $\mathrm{t}_{\mathrm{OLZ}}$ | Asynchronous Output Enable Time ${ }^{(3)(5)}$ | 2.......). | 2 | - | 2 | - | 2 | - | ns |
| $\mathrm{t}_{\text {Soen }}$ | Synchronous Output Enable To Data Valid Time | 12 | - | 15 | - | 20 | - | 25 | ns |
| $\mathrm{t}_{\text {CAN }}$ | Chip Select Access Time | ~~. | - | 20 | - | 30 | - | 35 | ns |
| $t_{\text {ASPN }}$ | Address Set-up Parity Time | 40 | 50 | - | 65 | - | 80 | - | ns |
| $t_{\text {AABN }}$ | Address Access to Breakpoint | $\rightarrow$, | - | 65 | - | 80 | - | 95 | ns |
| $t_{\text {AABFS }}$ | Address Access to BKPT FF Set-up | 40.../. | 50 | - | 65 | - | 80 | - | ns |
| $t_{\text {AABFH }}$ | Address Access to BKPT FF Hold | 0 - | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\text {PFCD }}$ | Parity Flip-Flop Clock to data | - 12 | - | 15 | - | 20 | - | 25 | ns |

## NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. This parameter guaranteed but not tested.
4. Pipelined address access set-up time.
5. Transition is measured $\pm 500 \mathrm{~mW}$ from steady state with 5 pF load (including scope and jig).

TIMING WAVEFORM OF READ CYCLE NO. 1


NOTE:

1. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with 5 pF load (including scope and jig).

TIMING WAVEFORM OF READ CYCLE NO. 2-NON-PIPELINED


NOTE:

1. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with 5 pF load (including scope and jig).

AC ELECTRICAL CHARACTERISTICS $\mathrm{N}_{C C}=5 \mathrm{~V} \pm 10 \%$, All Temperature Ranges)

| SYMBOL | PARAMETER | $\begin{aligned} & \text { IDT71502S25 }(1,4) \\ & \text { IDT71502L25 }(1,4) \\ & \text { MIN. } \quad \text { MAX. } \end{aligned}$ | $\begin{aligned} & \text { IDT71502S35 }{ }^{(4)} \\ & \text { IDT71502L35 (4) } \\ & \text { MIN. } \quad \text { MAX. } \end{aligned}$ | $\begin{aligned} & \text { IDT71502S45 }{ }^{(4)} \\ & \text { IDT71502L45 (4) } \\ & \text { MIN. } \end{aligned}$ | $\begin{aligned} & \text { IDT71502S55 }{ }^{(2,4)} \\ & \text { IDT71502L55 }(2,4) \\ & \text { MIN. } \\ & \hline \end{aligned}$ | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RAM WRITE CYCLE |  |  |  |  |  |  |
| $t_{\text {wc }}$ | RAM Write Cycle Time | $40 \quad \rightarrow$ | 50 - | 65 - | 80 - | ns |
| $t_{\text {WAS }}$ | RAM Write Address Set-up Time | 0 - | 0 - | 0 | 0 | ns |
| $t_{\text {WP }}$ | RAM Write Pulse Width ${ }^{(5)}$ | 20 - - | 25 - | 35 - | 45 - | ns |
| ${ }^{\text {DW }}$ | RAM Write Data Set-up Before End Of Write | 15 \% $\quad \begin{gathered}\text { \%- } \\ \text { \% }\end{gathered}$ | 17 - | 25 - | 30 - | ns |
| $t_{\text {AW }}$ | Address Valid to End of Write | $25 \%$ - | $30 \quad-$ | 50 - | 60 - | ns |
| $t_{\text {WCW }}$ | Chip Select To End Of Write | 25 - | $30 \quad-$ | 50 | 60 | ns |
| ${ }^{\text {WWOH }}$ | RAM Write Data Hold Time | $0 \times-$ | 0 - | 0 - | 0 | ns |
| $t_{\text {WR }}$ | Write Recovery Time | 5. 良 - | 5 - | 5 - | 5 - | ns |
| $t_{\text {WZ }}$ | Write Enable to Output $\mathrm{Hi}-Z^{(3,6)}$ | $\cdots$ - 15 | 15 | - 20 | - 20 | ns |
| tow | Output Active from End of Write ${ }^{(3,6)}$ | 5. - | 5 - | 5 - | 5 - | ns |

## NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. This parameter is guaranteed but not tested.
4. Pipelined address access set-up time.
5. $\overline{O E}=V_{I H}$.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with 5 pF load (including scope and jig).

TIMING WAVEFORM OF WRITE CYCLE ${ }^{(1)}$


NOTE:

1. A write occurs during the overlap of both $\overline{\mathrm{CS}}$ and $\overline{\mathrm{WE}}$ low.
2. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with 5 pF load (including scope and jig).

AC ELECTRICAL CHARACTERISTICS ( $\mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$, All Temperature Ranges)

| SYMBOL | PARAMETER | IDT71502S25 IDT71502L25 ${ }^{(1,4)}$ (1, 4) MIN. MAX. | IDT71502S35 ${ }^{(4)}$ IDT71502L35 ${ }^{(4)}$ MIN. MAX. | $\begin{aligned} & \text { IDT71502S45 }{ }^{(4)} \\ & \text { IDT71502L45 } \\ & \text { MIN. MAX. } \end{aligned}$ | IDT71502S55 IDT71502L55 ${ }^{(2,4)}$ <br> MIN. MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| trace write cycle |  |  |  |  |  |  |
| $t_{\text {TwC }}$ | Trace Write Cycle Time | 40 * | 50 | 65 | 80 | ns |
| $t_{\text {TwDS }}$ | Trace Write Data Set-up Time | 8 - | 10 | 12 | 15 | ns |
| ${ }^{\text {t }}$ WOH | Trace Write Data Hold Time | 2 . ${ }^{\text {a }}$ | 2 | 2 | 2 | ns |
| $t_{\text {tws }}$ | Trace Write Enable Set-up Time | 8 . | 10 | 12 | 15 | ns |
| ${ }_{\text {t }}^{\text {TCS }}$ | Trace Write Chip Select Set-up Time | 8 | 10 | 12 | 15 | ns |
| $\mathrm{t}_{\text {TWH }}$ | Trace Write Enable Hold Time | 2 , - | 2 | 2 | 2 | ns |
| $\mathrm{t}_{\text {TCH }}$ | Trace Write Chip Select Hold Time | 2. | 2 | 2 | 2 | ns |

## NOTES:

1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
3. This parameter is guaranteed but not tested.
4. Pipelined address access set-up time.

## TIMING WAVEFORM OF TRACE WRITE CYCLE ${ }^{(1)}$



NOTE:

1. A write occurs if both $\overline{\mathrm{CS}}$ and WE are low at the clock low-to-high transition

AC TEST CONDITIONS (Read and Write Cycles)

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load, Parity Output
Figure 2. Output Load (for BKPT pin)

SPC AC ELECTRICAL CHARACTERISTICS ${ }^{(1)} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$, All Temperature Ranges

| SYMBOL | PARAMETER | IDT71502S/L ${ }^{(1)}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. |  |
| $t_{\text {sCLK }}$ | SCLK Period | 100 | - | ns |
| $\mathrm{t}_{\text {scw }}$ | SCLK Pulse Width | 40 | - | ns |
| $\mathrm{t}_{\text {sDs }}$ | Serial Data Set-up Time | 20 | - | ns |
| $\mathrm{t}_{\text {SDH }}$ | Serial Data Hold Time | 2 | - | ns |
| $\mathrm{t}_{\text {SCD }}$ | Clock to serial Data Output Delay | - | 30 | ns |
| ${ }_{\text {t }}^{\text {SPD }}$ | Serial Data-In-to-Out Delay, Stub Mode | - | 20 | ns |
| $\mathrm{t}_{\text {CMLH }}$ | Command/Data Set-up Time, Low-to-High ${ }^{(2)}$ | 20 | - | ns |
| $\mathrm{t}_{\text {CMHL }}$ | Command Set-up Time, High-to-Low (Execution Time) ${ }^{(2)}$ | 35 | - | ns |
| $\mathrm{t}_{\text {cM }}$ | Command/Data Hold Time ${ }^{(2)}$ | 5 | - | ns |
| $\mathrm{t}_{\text {cscD }}$ | Command/Data to Serial Data Output Delay (1st Bit Only) | - | 45 | ns |

## NOTES:

1. These specifications apply to all speed grades of the product.
2. $C / \bar{D}$ cannot change while SCLK is high.

TIMING WAVEFORM OF SPC CHANNEL


## AC TEST CONDITIONS (SPC)

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 3 |



Figure 3. Output Load for Serlal Output
*Includes scope and jig.

## SPC FUNCTIONAL BLOCK DIAGRAM



## SPC COMMAND FORMAT

| 7 | 4 |
| :---: | :---: |

## SPC COMMAND CODES

| COMMAND <br> CODE | READ/WRITE <br> FUNCTION | ACTION | NOTES |
| :---: | :---: | :--- | :--- |
| 0 | Read | Read Register | Uses Register Select Field |
| 1 | Write | Write Register | Uses Register Select Field |
| 2 | Read | Read Register and Increment Initialize Counter | Serial RAM Read |
| 3 | Write | Write Register and Increment Initialize Counter | Serial RAM Write |
| $4-$ C | - | Reserved (No-Op) |  |
| D | Write | Stub Diagnostic | Broadcast Commands |
| E | Write | Serial Diagnostic | Serial Commands |
| F | - | No-Op | Guaranteed No-Op |

## SPC REGISTER CODES

| REGISTER <br> CODE | READ/WRITE <br> FUNCTION | REGISTER | NOTES |
| :---: | :---: | :--- | :---: |
| 0 | R/N | Initialize Counter | - |
| 1 | R/W | RAM Output (or Input if reading) | - |
| 2 | R/W | Pipeline Register | - |
| 3 | RNW | Break Mask Register | - |
| 4 | RNW | Break Data Register | - |
| 5 | R/W | Set-up + Status Register |  |
| 6 | Rd Only | $1 / O_{15}-1 / O_{0}$ (Data Pins) | Break Multiplexer, Trace Mode, etc. |
| 7 | Rd Only | RAM Address | Data Pins of Chip |
| $8-F$ | - | Reserved (unused) | Address Going into RAM |

## REGISTERED RAM DATA FLOW BLOCK DIAGRAM


note:

1. SPC and RAM accesses are mutually exclusive. Hence, these two operations must not occur simultaneously. During SPC accesses, the content of the pipeline register will change if the parallel clock is active.

## SET-UP REGISTER FORMAT

| BIT | NAME | TYPE ${ }^{(1)}$ | FUNCTION | POWER-UP VALUE |
| :---: | :---: | :---: | :---: | :---: |
| 15 | CE | RO | Chip Enable State: NOR of All Chip Enable Pins | 0 |
| 14 | $\overline{\text { SOE FF }}$ | RO |  | 0 |
| 13 | $\overline{\text { SOE Pin }}$ | RO |  | 0 |
| 12 | $\overline{\mathrm{OE}} \mathrm{Pin}$ | RO | $\overline{\mathrm{OE}}$ Pin State: $1=$ High, $0=$ Low | 0 |
| 11 | $\overline{W E}$ Pin | RO |  | 0 |
| 10 | $\overline{\text { INIT Pin }}$ | RO | INIT Pin State: $1=$ High, $0=$ Low | 0 |
| 9 | BP Compare | RO | Breakpoint Comparator Output: $1=$ Compare Valid | 0 |
| 8 | BP Pin | RO | BP Pin State: $1=$ High, $0=$ Low | 0 |
| 7 | $\overline{\mathrm{CS}}_{1}$ Level | R/W | $0=\overrightarrow{\mathrm{CS}}_{1}$ is Low Active; $1=\mathrm{CS}_{1}$ is High Active | 0 |
| 6 | $\overline{\mathrm{CS}}_{0}$ Level | R/W | $0=\overline{\mathrm{CS}}_{0}$ is Low Active; $1=\mathrm{CS}_{0}$ is High Active | 0 |
| 5 | Non-Reg High | R/W | Set Pipeline Register Bits 15-8 to Flow-Through Mode | 0 |
| 4 | Non-Reg Low | R/W | Set Pipeline Register Bits 7-0 to Flow-Through Mode | 0 |
| 3 | - | - | (Unused) | 0 |
| 2 | BC Address | R/W | $0=$ Breakpoint on Pipeline Register Output, $1=$ Breakpoint on RAM Address Inputs | 0 |
| 1 | BC Pipelined | R/W | Set Breakpoint Output MUX for Pipeline FF Output | 0 |
| 0 | Trace Mode | R/W | Set for Trace Mode: 1/O $\mathrm{O}_{15-0}$ to Pipeline Register. Pipeline Register to RAM. Initialize Counter as Address, Write with Clock Pulse | 0 |

## NOTE:

1. RO means Read Only. RN means Read/Write.

## GENERAL DESCRIPTION

The IDT71502 Registered RAM consists of a $4 \mathrm{~K} \times 16$-bit RAM plus a 16-bit pipeline register and is designed for microcode writable control store use. A serial shift register system, the Serial Protocol Channel (SPC), is included on-chip for serial load and read-back of the RAM data. A RAM address counter is also provided to speed up RAM load and read-back. The SPC serial shift register is also configured to be used as a diagnostic register. The shift register can read all status conditions on the chip such as the RAM output, pipeline register output, data output pin state and RAM load/read counter value. A breakpoint comparator is included to support the diagnostic function. This breakpoint comparator can be used to detect a particular bit pattern in the RAM address or pipeline register outputs.

The IDT71502 Registered RAM includes features to support control store applications. These include synchronous output enable and an initialize register for selecting the initial value of the pipeline register. A parity output is provided which indicates the parity of the contents of the pipeline register. The parity output can be used to provide parity check control for high-reliability systems.

The IDT71502 Registered RAM can also be used as a trace RAM for recording external data. In this mode, the data I/O pins are inputs and data is clocked into the RAM using the Initialize register as the address counter. The Trace mode, in combination with the breakpoint comparator, allows the IDT71502 Registered RAM to be used as a one-chip logic analyzer.

## RAM Operation

After power up, and in its typical operating mode, the IDT71502 Registered RAM is set for pipelined read and direct (non-pipelined) write. Data may be directly written into the RAM by driving the address and data inputs and strobing the Write Enable input. Data is read from the RAM by driving the address lines and clocking the pipeline register.

The RAM may also be read and written by the Serial Protocol Channel (SPC). This is the typical path for loading the RAM after power up. SPC and RAM accesses are mutually exclusive. Hence, these two operations must not occur simultaneously. During SPC accesses, the content of the pipeline register will change if the parallel clock is active.

## Serial Protocol Channel

The Serial Protocol Channel (SPC) logic consists of a 16-bit data shift register, an 8-bit command register and clock logic consisting of gates and a flip-flop. A block diagram of the command decode logic is shown for reference. The command decode logic decodes and executes the command in the command shift register using the clock from the clock logic. The command is divided into two four-bit fields. The most significant four bits of the command register define the command to be executed: read, write, etc. The least significant four bits define the register to be read or written. (NOTE: The data to the SPC is shifted in LSB first.)

The SPC is connected to the outside world through four wires. These wires consist of serial data in and out, a shitt clock and a command/data line. When the command/data line is high, commands are shifted from the serial data in to the command register by the clock. When the command/data line is low, data is shifted into the data shift register by the clock. When the command/data line transitions from high (command) to low (data), a clock pulse is generated internally to the command decode logic. This pulse lasts from the beginning of the high-to-low transition to the next serial clock pulse and is used to execute the command in the command register.

Two of the defined commands are Serial and Stub. These commands control a latch which determines the source of the serial
data out in the command mode. The Serial command causes the data output to be taken from the last stage of the command shift register. This is the normal operating mode, where all the shift registers in a system are connected into one long shift register. The SPC logic in the IDT71502 is automatically set to the Serial mode by power up. The Stub command sets the latch and causes the serial output data to be taken from the serial input. In this mode, the serial data is passed directly from one chip to the next so that all command registers have the same data at their serial inputs. This allows a broadcast mode where all command registers in a system can be loaded with the same command at the same time.

## RAM Load/Readback Logic

The RAM write pulse is generated by an internal one-shot triggered by the clock. Data is written into the RAM immediately following pipeline register load and the Initialize Counter is incremented by the trailing edge of the write pulse. Using an internally generated write pulse makes RAM writing independent of clock high and low times. A timing diagram of the RAM clocking is shown in the Trace Mode Clock Timing Diagram (Figure 5).

A detailed block diagram of the IDT71502 Registered RAM, showing the various internal registers and the load and readback paths, is shown in the Registered RAM Data Flow Block Diagram. In addition to the logic shown in the Functional Block Diagram on the first page of the data sheet, there is an Initialize Counter for loading and initializing the RAM, Break Data and Mask registers for the Breakpoint Comparator and multiplexers at the input to the Pipeline register for allowing data from the data $1 / O$ pins to be clocked into the Pipeline register in the Trace mode before being written into the RAM. The data flow block diagram also shows the various multiplexers for routing data for breakpoint and readback use.

## Initialize Counter

The Initialize Counter provides the initial address to the RAM after reset of the part. A pulse applied to the Initialize pin causes the Initialize Counter to be gated to the RAM address and the RAM data to be preset into the pipeline register. This provides an initial value in the pipeline register before the first clock pulse arrives. The initialize Counter can be reset to zero at power up of the chip and can be loaded with a value other than zero by the SPC. Once loaded with a value by the SPC, this value is used in further chip reset operations.

## Set-up Register

The Set-up Register is a 16-bit register used to set the chip operating mode and to read back chip operating status conditions. A command word written into the Set-up Register sets 7 latches which control the chip operating conditions. Reading the Set-up Register provides the current status of these 7 latches and various other signals on the chip. At power up, the 7 latches are cleared to zero and the Initialize counter is cleared to zero. The format of the Set-up Register is shown in the Set-up Register Format table.

The Set-up Register has 7 latches which determine the operating mode of the chip. These are $\overline{\mathrm{CS}}_{1}, \overline{\mathrm{CS}}_{0}$, Non-Reg High, NonReg Low, BC RAM, Break Pipe and Trace. The $\overline{\mathrm{CS}}_{1}$ and $\mathrm{CS}_{0}$ bits determine the polarity of the $\mathrm{CS}_{1}$ and $\overline{\mathrm{CS}}_{0}$ chip enables. The NonReg High and Low bits set the upper and lower bytes of the Pipeline Register to a flow-through mode, respectively. The BC RAM bit determines the source of the data for breakpoint comparison, either the Pipeline Register or the RAM address. The Break Pipe latch switches the breakpoint pin multiplexer from the comparator to the buffer flip-flop. The trace latch sets the chip into the Trace mode.

## Power Up State

Power up is defined as taking $V_{c c}$ from below 1.0 volts to 5.0 volts nominal. This generates power up reset, an internal signal which resets several registers on the chip. After power up, the IDT71502 is in the following state:

- Set-up Register cleared to zero
- Initialize Counter cleared to zero
- Breakpoint Mask Register cleared to equal (Breakpoint output high)
- $\overline{\text { SOE Flip-Flop cleared to outputs off }}$

Note that taking $V_{c c}$ from 5.0 volts to 2.0 volts and back to 5.0 volts will not cause power up reset.

## Set-up Register: Programmable Chip Enable

The chip enable function is programmable by bits in the Set-up Register. The logic for this is shown in Figure 1. The bits in the Setup Register define the active state of each chip enable: high or low. This allows up to four RAMs to be cascaded in depth with no external decoders required ( $16 \mathrm{~K} \times 16$ bits of RAM).


Figure 1. Chip Enable Logic Block Diagram

## Set-up Register: Non-Registered Outputs

Two bits of the Set-up Register, Non-Reg Hi and Non-Reg Lo, can be set to cause the Pipeline Register bits 15-9 and 7-0, respectively, to be set to the flow-through mode. In the flow-through mode, both latches of the register are open and the register acts like a simple buffer with its output following its input. This allows the user to have some non-registered bits in microcode applications. The output circuit consisting of the Pipeline Register, the Synchronous Output Enable (SOE), and the Output Enable (OE), has some special logic to support this mode, as shown in Figure 2.

Also, activating the Initialize pin causes the Pipeline Register to be put in the flow-through mode. Figure 2 shows the Pipeline Register as two latches operated in the MASTER/SLAVE configuration. The clock input will cause the latch pair to work as a register. If the Initialize pin is activated, both registers will be placed in the flowthrough mode by the OR gates. Also, if either Non-Reg bit is set, its corresponding 8 -bit portion of the register will be placed in the flow-through mode.


Figure 2. Output Logic Block Dlagram

When in the flow-through mode, the output enable flip-flop for that half must also be in the flow-through mode for external chip expansion to work properly. A non-registered RAM bit must be enabled by a non-registered output enable, while a registered bit
must be enabled by a synchronous output enable. This is done by using the non-registered bit to control a multiplexer which selects between the SOE flip-fiop input and output as the source of the output enable.

## Set-up Register: Breakpoint Comparator Control

The Breakpoint Comparator (BC) provides a masked 16 -bit comparison of the various data paths that can be read by the SPC. It consists of an equal-comparator and the Break Data and Mask registers, as shown in Breakpoint Comparator Logic Block Diagram (Figure 3). The BC compares the data from the chip against the data in the Break Data Register and activates the Breakpoint Compare output if the two are equal. The Mask Register enables comparison: if a bit in the Mask Register is a one, comparison is enabled on the corresponding bit in the Break Data Register. If it is zero, the comparison on the that bit is disabled: i.e., forced to equal.

The Breakpoint output is an open drain type to allow width expansion of the Breakpoint Comparison. For example, if two IDT71502 chips have their breakpoint pins tied together to the same load resistor, both breakpoint comparators must be valid before the output can rise. The result is a 32-bit comparison.

A selectable flip-flop is provided for the Breakpoint Output. This allows pipeline registered bits, non-registered bits and address bits to be used in comparison with the same timing. Breakpoint comparison is commonly performed on the pipeline register outputs. These outputs are valid after the clock; i.e. for the current cycle. Address inputs and non-pipelined outputs are valid before the clock, representing address and data for the next cycle, respectively. If address or non-pipelined outputs are to be used in breakpoint comparison, a flip-flop delay must be added so that they will be valid after the clock in the same manner as pipelined bits. The selectable flip-flop provides this delay so that all breakpoint comparison outputs are valid in the current cycle.

The Breakpoint output driver is enabled by the $\overline{S O E}$ Flip-Flop to allow depth expansion of the comparison. SOE must be low prior to clock going high whether in pipelined mode or not.


Figure 3. Breakpoint Comparator Logic Block Diagram

## Set-up Register: Trace Mode Operation

When the trace bit in the Set-up Register is set, the chip is in the Trace mode. In this mode, data from the chip data pins, $1 / \mathrm{O}_{15}-1 / \mathrm{O}_{0}$, is written into sequential locations in the RAM. The address for the RAM comes from the Initialize Counter, which is incremented after each RAM write. The Trace mode is used to record external data events in the same manner as a logic analyzer. The Trace mode recording sequence is as follows:

1. Data from the $1 / O$ pins is written into the Pipeline Register by the clock.
2. Data in the Pipeline Register is written into the RAM by a oneshot driven by the trailing edge of the clock. The RAM address comes from the Initialize Counter.
3. The Initialize Counter is incremented by the trailing edge of the RAM write pulse.

Trace operation requires both $\overline{W E}$ and $\overline{\mathrm{CS}}$ to be active. If either is inactive (high), the Initialize Register will not be incremented and data will not be written into the RAM. The Pipeline Register will be loaded, however. This allows the write enable to be used for skipping words. A timing diagram of this logic is shown in the Trace Mode Sequence Timing Diagram (Figure 4).

The RAM write pulse is generated by an internal one-shot triggered by the clock. Data is written into the RAM immediately following pipeline register load and the Initialize Counter is incremented by the trailing edge of the write pulse. Using an internally generated write pulse makes RAM writing independent of clock high and low times. A timing diagram of the RAM clocking is shown in the Trace Mode Clock Timing Diagram (Figure 5).


Figure 4. Trace Mode Sequence TIming Diagram


Figure 5. Trace Mode Clock Timing Diagram

## Parity Output

The Parity Output pin is generated from a 16-bit parity tree, as shown in the Parity Tree Logic Block Diagram (Figure 6). Even parity is used. Parity is generated on the contents of the Pipeline Register. The parity output driver is three-state and is enabled by the SOE Flip-Flop to allow depth expansion of the parity output.

The Parity Output always reflects the parity of the registered value. Additional flip-flops and multiplexers are included in the parity tree to cover the case of non-registered outputs. If one or both
bytes of the Pipeline Register are set to the Non-Registered mode, a flip-flop pipeline delay is added to the corresponding byte parity chain to make the result of that byte parity calculation the same as if the Pipeline Register was not in the Non-Pipelined mode. $\overline{\text { SOE }}$ must be low prior to the clock going high in pipelined or nonpipelined mode.


Figure 6. Parity Tree Logic Block Diagram

## REGISTERED RAM APPLICATIONS

## Using the Registered RAM in Writable Control Stores

The IDT71502 Registered RAM is designed expressly for efficient use in writable control stores. A simplified block diagram of a

16 -bit microprogram-controlled system using the IDT71502 is shown in Writable Control Store Using Registered RAM (Figure 7). The system shown uses four IDT71502 Registered RAM chips to provide $4 \mathrm{~K} \times 64$ bits of microcode writable control store.


Figure 7. Writable Control Store Using Registered RAM

## Using the Parity Output

The parity output can be used in conjunction with an additional IDT71502 Registered RAM to provide parity checking for control stores. This is shown in the Parity Check in a Writable Control Store System (Figure 8) block diagram. The parity output driver is gated
by the $\overline{\text { SOE Flip-Flop. This allows simple depth expansion of the }}$ parity function by paralleling the parity outputs in the same manner as the data outputs, as shown in the Parity Check in a Depth Expanded Writable Control Store System (Figure 9) block diagram.


Figure 8. Parity Check in a Writable Control Store System


Figure 9. Parity Check in a Depth Expanded Writable Control Store System

## Using Trace Mode as a Logic Analyzer

The Trace mode allows the IDT7 1502 to be used as an on-board logic analyzer for system diagnostics. It is particularly powerful when used in conjunction with the Breakpoint function. In the Trace mode, data is recorded in sequential locations in the RAM as controlled by the Trace Counter. Since the incoming data is clocked into the pipeline register, the set-up and hold times are short and compatible with capturing changing bus data, for example. A block diagram of a system with an IDT7 1502 used in the Trace mode is shown in Diagnostic Bus Monitoring Using Trace Mode (Figure 10).

The Breakpoint outputs from the IDT7 1502 devices in a system can be used to control the Trace mode writing. The Breakpoint out-
puts are open drain types which provide a wire-AND function when connected together to a single pull-up resistor. By tying the Breakpoint outputs for the writable control store RAMs and the trace RAM, a breakpoint comparison can be made over the full microcode word plus the data bus contents. This comparison can be used to enable the trace write so that only data which occurred at the Breakpoint times is recorded. This allows recording the data that was on the bus during each instance of an I/O write, for example.


Figure 10. Diagnostic Bus Monitoring Using Trace Mode

## Serial Loading of the IDT71502 Using the SPC

In order to use the IDT71502 in writable control store applications, it must be loaded with the microprogram before use. This is done using the Serial Protocol Channel (SPC). Loading the RAM over the SPC can be done in several ways. The microcode can be loaded from a central microprocessor, which can perform both microcode load and system diagnostics at power up, or it can be loaded using dedicated load logic.

An example of a design of this dedicated load logic is shown in the Microcode Load Logic Example (Figure 11). The purpose of this example is to show how one goes about designing this logic. This example shows an approach which loads the RAMs with data from a sing!e EPROM. The load logic gets the SPC command and
data information from the EPROM. It is controlled by single byte instructions from the same EPROM. The format of these instructions is shown in Microcode Load Logic Instruction Formats (Figure 12), and a map of the typical contents of the EPROM is shown in Microcode Load EPROM Memory Map (Figure 13).

The load logic consists of a 16-bit address counter, an 8-bit shift register, a 4 -bit byte counter and a PAL containing a 2 -bit instruction register. The logic in the PAL interprets the 2-bit load instructions to cause bytes of command or data information to be loaded into the IDT74FCT299 shift register and shifted to the SPC. The two IDT74FCT161 counters are used to count the bytes being sent and the 8 bits in each byte.


Figure 11. Microcode Load Logic Example


Figure 12. Microcode Load Logic Instruction Formats


Figure 13. Microcode Load EPROM Memory Map

## ORDERING INFORMATION



| Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) |  |
| :---: | :---: |
| Military ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ) Compliant to MIL-STD-883, Class B |  |
|  |  |
| Sidebraze DIP |  |
| Plastic DIP |  |
| 48-Lead LCC |  |
| 52-Lead PLCC |  |
| Commercial only |  |
|  | Speed in Nanoseconds |
| Military Only |  |
| Low Power |  |
| Standard Power |  |
| 64 K (4K $\times 16$-Bit) | gistered RAM |

# GEMERAL INBORTATION 

## TECTMOLOGY AND CAPAELITIES



PACRAGEDAGRAMOUTLINES

ECl phovucts

PHOPRODUCTS

SPECIALTY MEMORY PRODUCTS

## SUBSYSTEMS PRODUCTS

## SUBSYSTEM PRODUCTS

IDT Subsystems Division has the resources and experience to deliver the highest quality RAM module products. IDT's combination of advanced design, assembly, and test capabilities give customers the highest levels of quality, service and performance. Product offerings include a number JEDEC standards as well as specialized and application specific RAM modules, including the world's highest performance and densest SRAMs, Dual-Port RAMs, and FIFOs. Custom capabilities allow our customers to enjoy the benefits of parametically tested complete memory-based subsystems including extremely high performance caches for a wide range of processors and complete memory subsystems including multi-megabyte microprocessor main memories.

DT modules products provide a number of benefits to the high performance system designer:

For system designers of high performance systems, modules solve a number of major problems through the benefits they provide. The biggest benefit of modules is that they save significant amounts of space for designers packing ever more performance in less space by utilizing double sided surface mount technology (SMT). Modules allow designers to take advantage of SMT for performance critical memory paths without the investments or the volume necessary to justify employing SMT for an entire system. Since systems at the high performance end of the spectrum tend to be lower volume, it makes sense to take advantage of module technology to enjoy the space savings and performance advantages of SMT without the cost. In addition, decoupling capacitors are mounted next to or underneath the active memory components on the module, thus eliminating the need to consider them or the real estate they consume.

Numerous module packaging options are available which allow designers to tradeoff board area, height and mechanical stability. Vertical mount module options (modules in which mounted components are oriented in a vertical fashion) such as single in-line packages (SIPs), dual-row SIPs (DSIPs), zigzag in-line packages (ZIPs) and single-in-line memory modules (SIMMs) are ideal packages for applications requiring the highest density. Many of these vertical mount modules are maximum 0.5 inch tall, which is well within the board space requirements for card rack type systems. Horizontal mount module options include dual in-line packages (DIPs), quad inline packages (QIPs), and hex in-line packages (HIPs). These modules are ideal for those applications requiring the most in
mechanical stability and those with many I/O pins.
Design, manufacturing, and marketing often disagree on the size of memory that their high performance system will offer. By allowing the decision to made at manufacturing time by having module solutions with different memory sizes and common pinouts, the module user lets the market dictate memory requirements. JEDEC has defined standards for memory pinouts including $128 \mathrm{~K} \times 8$ and $512 \mathrm{~K} \times 8$ SRAM in the same 600 mil wide 32 lead DIP and $16 \mathrm{~K} \times 32,64 \mathrm{~K} \times 32$ and $256 \mathrm{~K} \times 32$ SRAM in the same 64 lead SIMM/ZIP which are among the most common industry standard SRAM modules.

Testing is both a design and manufacturing problem that is often an afterthought. By providing a pretested higher level block, modules simplify the test issue for both design and manufacturing. Since the module is tested using full parametric AC/DC guardbanded test patterns over the specified operating temperature range, designers are guaranteed a level of performance for a larger block of their system versus a spec for an individual component. System board test is simplified because a major block of memory has been fully tested at the module level, thus simplifying the test method and debug cycle at the board level.

Time to market is always a very important issue. Studies have shown that a major portion of profits are made in the early part of the product life cycle before competition drives down prices to a level based on manufacturing costs rather than a unique level of value. Integrating the high performance memory into an module shortens the design cycle by simplifying board design by leveraging off the module manufacturer's design expertise. System board layout and the design cycle are simplified because the number of input/outputs (I/ Os) are reduced by combining common component address, data, control, and power pins.
Module solutions help reduce hidden costs that are not often taken into account. Since active and passive components necessary to realize an module solution are combined onto a single substrate, the module user reduces inventory and handling costs by combining a number of diverse components into one single component. IDT Subsystems products provide an ideal solution for system designers to integrate high performance RAM in order to maximize density, performance and cost-effectiveness for both commercial and military applications.

## TABLE OF CONTENTS

PAGE
SUBSYSTEMS PRODUCTS
MULTI-PORT MODULES
IDT7M134 $8 \mathrm{~K} \times 8$ Master Dual-Port SRAM Module ..... 8.1
IDT7M144 $8 \mathrm{~K} \times 8$ Slave Dual-Port SRAM Module ..... 8.2
IDT7M135 16K x 8 Master Dual-Port SRAM Module ..... 8.1
16K x 8 Slave Dual-Port SRAM Module ..... 8.2
$32 \mathrm{~K} \times 8$ Master Dual-Port SRAM Module ..... 8.3
$64 \mathrm{~K} \times 8$ Dual-Port SRAM Module ..... 8.4
$128 \mathrm{~K} \times 8$ Dual-Port SRAM Module ..... 8.4
$8 \mathrm{~K} \times 9$ Dual-Port SRAM Module ..... 8.5
$16 \mathrm{~K} \times 9$ Dual-Port SRAM Module ..... 8.5
32K x 16 Dual-Port (Shared Memory) SRAM Module ..... 8.6
32K x 16 Dual-Port SRAM Module ..... 8.7
$64 \mathrm{~K} \times 16$ Dual-Port SRAM Module ..... 8.7
$64 \mathrm{~K} \times 16$ Dual-Port (Shared Memory) SRAM Module ..... 8.6
$128 \mathrm{~K} \times 16$ Dual-Port (Shared Memory) SRAM Module ..... 8.6
$32 \mathrm{~K} \times 18$ Dual-Port (Shared Memory) SRAM Module ..... 8.8
64K x 18 Dual-Port (Shared Memory) SRAM Module ..... 8.8
128K x 18 Dual-Port (Shared Memory) SRAM Module ..... 8.8
$16 \mathrm{~K} \times 32$ Dual-Port SRAM Module ..... 8.9
$8 \mathrm{~K} \times 8$ FourPort ${ }^{\text {™ }}$ SRAM Module ..... 8.10
$4 \mathrm{~K} \times 8$ FourPort ${ }^{\text {M }}$ SRAM Module ..... 8.10
$4 \mathrm{~K} \times 16$ FourPort ${ }^{\text {M }}$ SRAM Module ..... 8.11
$2 \mathrm{~K} \times 16$ FourPort $^{\text {M }}$ SRAM Module ..... 8.11
FIFO MODULES
IDT7M205
$8 \mathrm{~K} \times 9$-Bit CMOS FIFO Module ..... 8.12
IDT7MP2005
IDT7M206
IDT7MP2011
IDT7M207
IDT7MP2010
IDT7MP2009
8K x 9-Bit FIFO Module ..... 8.13
16K x 9-Bit CMOS FIFO Module ..... 8.12
16K x 9 Bit FIFO Module ..... 8.13
$32 \mathrm{~K} \times 9$-Bit CMOS FIFO Module ..... 8.14
16K x 18-Bit FIFO Module ..... 8.15
32K x 18-Bit FIFO Module ..... 8.15
SRAM MODULES
IDT7MC4001
IDT7M4042
1M $\times 1$ CMOS Static RAM Module ..... 8.16
256K x 4 CMOS Static RAM Module ..... 8.17
$64 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.18
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.19
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.20
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.21
$256 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.22
512K $\times 8$ CMOS Static RAM Module ..... 8.23
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.23
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.24
$512 \mathrm{~K} \times 8$ CMOS Static RAM Module ..... 8.25
$64 \mathrm{~K} \times 9$ CMOS Static RAM Module ..... 8.18
$256 \mathrm{~K} \times 9$ CMOS Static RAM Module ..... 8.26
$16 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.27
2(16K x 16) CMOS Static RAM Module ..... 8.28
$32 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.29
1990-91 SPECIALIZED MEMORIES DATA BOOK (CONTINUED) ..... PAGE
SRAM MODULES (CONTINUED)
IDT8MP612S $32 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.30
IDT8MP612L $32 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.31
IDT7M624 $64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.32
IDT8M624 $64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.29
IDT8MP624S $64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.30
IDT8MP624L $64 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.31
IDT7M4016 $256 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.33
IDT7MP4047 $512 \mathrm{~K} \times 16$ CMOS Static RAM Module ..... 8.34
IDT7MC4032 16K $\times 32$ CMOS Static RAM Module w/Separate Data I/O ..... 8.35
IDT7MP4031 $16 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.36
IDT7M4003 32K x 32 CMOS Static RAM Module ..... 8.37
IDT7M4017 $64 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.38
IDT7MP4036 $64 \mathrm{~K} \times 32 \mathrm{CMOS}$ Static RAM Module ..... 8.39
IDT7M4013 $128 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.37
IDT7MP4045 $256 \mathrm{~K} \times 32$ CMOS Static RAM Module ..... 8.40
CACHE MODULES
IDT7MB6064 ( $2 \times 4 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.41
IDT7MB6044 ( $2 \times 4 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU ..... 8.42
IDT7MB6043 ( $2 \times 8 \mathrm{~K} \times 64$ ) Datalnstruction Cache Module for IDT79R3000 CPU ..... 8.43IDT7MB6051 ( $2 \times 8 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for IDT79R3000 CPU(Multiprocessor)8.44
IDT7MB6039  ..... 8.45
IDT7MB6049 ( $2 \times 16 \mathrm{~K} \times 60$ ) Data/Instruction Cache Module for IDT79R3000 CPU (Multiprocessor) ..... 8.46
IDT7MB6040 ( $2 \times 16 \mathrm{~K} \times 64$ ) Data/Instruction Cache Module for General Purpose CPUs ..... 8.47
IDT7MB6061 ( $2 \times 16 \mathrm{~K} \times 60$ ) Data/Instruction w/Resettable Instruction Tag ..... 8.48
WRITABLE CONTROL STORE MODULES
IDT7M6032 $16 \mathrm{~K} \times 32$ Writable Control Store Static RAM Module ..... 8.49
IDT7MB6042 $8 \mathrm{~K} \times 112$ Writable Control Store Static RAM Module ..... 8.50
OTHER MODULES
Flexi-Pak Family Modules with Various Combinations of SRAMs, EPROMs and EEPROMs ..... 8.51
CUSTOM MODULES
Subsystem Custom Module Capabilities ..... 8.52


## FEATURES：

－High－density $64 \mathrm{~K} / 128 \mathrm{~K}$ CMOS Dual－Port RAM modules
－ $16 \mathrm{~K} \times 8$（IDT7M135）or $8 \mathrm{~K} \times 8$（IDT7M134）option
－Fully asynchronous read／write operation from either port
－Fast access time
－commercial：30ns（max．）
－military：40ns（max．）
－Low power consumption
－On－chip port arbitration logic
－BUSY flags
－Single 5 V （ $\pm 10 \%$ ）power supply
－Dual Vcc and GND pins for maximum noise immunity
－On－chip pull up resistors for open－drain BUSY flag option
－Inputs and outputs directly TTL－compatible

## DESCRIPTION：

The IDT7M134／IDT7M135 are 64K／128K high－speed CMOS Dual－Port static RAM modules constructed on a multi－ layered ceramic substrate using four IDT7132 $2 \mathrm{~K} \times 8$ dual－ port static RAMs（IDT7M134）or eight IDT7132 dual－port static RAMs（IDT7M135）in leadless chip carriers．Dual－ port function is achieved by utilization of the two on－board IDT54／IDT74FCT138 decoder circuits that interpret the higher order addresses AL11－13 and AR11－13 to select one of the eight $2 \mathrm{~K} \times 8$ dual－port static RAMs．（On IDT7M134 8K $\times 8$
option，AL13 and AR13 need to be externally grounded and the selection becomes one of the four $2 \mathrm{~K} \times 8$ dual－port static RAMs）．Extremely high speeds are achieved in this fashion due to the use of the IDT7132 dual－port static RAM， fabricated in IDT＇s high－performance CEMOS ${ }^{\text {TM }}$ technology．

The IDT7M134／IDT7M135 provide two ports with sepa－ rate control，address and I／O pins that permit independent access for reads or writes to any location in the memory． The BUSY flags are provided for the situation when both ports simultaneously access the same memory location． The on－chip arbitration logic will determine which port has access and sets the BUSY flag of the delayed port．BUSY is set at speeds that permit the processor to hold the opera－ tion and its respective address and data．The delayed port will have access when BUSY goes high（inactive）．

The IDT7M134／IDT7M135 are available with access times as fast as 30ns commercial and 40ns military temperature range，with operating power consumption of only $2.1 \mathrm{~W} / 3.5 \mathrm{~W}$ （max．）．The module also offers a standby power mode of $1.4 \mathrm{~W} / 2.8 \mathrm{~W}$（max．）and a full standby mode of $660 \mathrm{~mW} / 1.3 \mathrm{~W}$ （max．）．

All IDT miliitary module semiconductor components are manufactured in compliance with the latest revision of MIL－ STD－883，Class B，making them ideally suited to applica－ tions demanding the highest level of performance and relia－ bility．

## PIN CONFIGURATION ${ }^{(2)}$

| GND -1 | 58 －Vcc |
| :---: | :---: |
| CSLC2 | 57 －${ }^{\text {CSR }}$ |
| R／WLC3 | 56 R／WR |
| R27a ${ }^{2}$ | 55 R 270 O |
| BUSYL 5 | 54 万BUSYR |
| OEL 6 | 53 万OER |
| AoL ${ }^{\text {a }}$ | 52 A ${ }^{\text {a }}$ R |
| A1L ${ }^{\text {c }}$ | $51 . \mathrm{A}_{12}$ |
| AzL ${ }^{\text {a }}$ | $50{ }^{\text {a }}$ AR |
| Аз 10 |  |
| $\mathrm{A}_{4} \mathrm{~L}$－11 | $48 . \mathrm{A}_{4} \mathrm{R}$ |
| A5L－12 | 47 同AsR |
| A6L 13 | 46 成 $\mathrm{A}_{6}$ |
| A7L 14 | 45 万A＞R |
| A8L ${ }^{\text {c }} 15$ | 44 คA8R |
| Agl 16 | 43 A ${ }^{\text {ar }}$ |
| A 102 C 17 | $42{ }^{-1} A_{10}$ |
| A 112 －18 | 41 月 $\mathrm{A}_{11} \mathrm{R}$ |
| A12L 19 | 40 － $\mathrm{A}_{12 \mathrm{R}}$ |
| A13L ${ }^{(1)}$－20 | 39 ค $\mathrm{A}_{13 \mathrm{R}}{ }^{(1)}$ |
| ／O ol $\mathrm{C}^{21}$ | $38.1 / O_{0 R}$ |
| $1 / 011.22$ | 37 1／ $\mathrm{O}_{1 \mathrm{R}}$ |
| $1 / \mathrm{O} 2 \mathrm{~L}$－23 | $36 \square^{1 / O}$ |
| I／O 3L． 24 | 35 － $1 /$ О3п |
| ／／O 4L ${ }^{\text {L }} 25$ | $34{ }^{1} / \mathrm{O}_{4 \mathrm{R}}$ |
| ／／O 5L－26 | $331 /{ }^{\text {¢ }}$ 5R |
| 1／O 6L－27 | 32 砛 ${ }_{6}$ |
| 1／O 7L－28 |  |
| GND $\mathrm{C}_{29}$ | $30 . \mathrm{Vcc}$ |

## PIN NAMES

| Left Port | Right Port | Names |
| :---: | :---: | :---: |
| AoL－AisL | AOR－A13R | Address |
| l／Ool－IO7L | I／OOR－I／O7R | Data Input／Output |
| $\overline{\mathrm{CS}}$ | $\overline{\mathrm{CS}}$ R | Chip Select |
| $\mathrm{R} \bar{W} \mathrm{~L}$ | $\mathrm{R} / \bar{W}_{\mathrm{R}}$ | Read／Write Enable |
| $\overline{\text { OEL }}$ | $\overline{\mathrm{OE}} \mathrm{R}$ | Output Enable |
| $\overline{\text { BUSYL }}$ | $\overline{\text { BUSYR }}$ | BUSY Flag（Open Drain） |
| R270L | R270R | PULL－UP Resistors for Open－drain BUSY Flag option |
| Vcc | Vcc | Power |
| GND | GND | Ground |

## NOTES：

1．On $8 \mathrm{~K} \times 8$ IDT7M134 option A13L and A13R need to be externally connected to ground for proper operation．
2．For module dimensions，please refer to module drawing M12 in the packaging section．

## FUNCTIONAL BLOCK DIAGRAMS

IDT7M135 (16K x 8)



ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED DC <br> OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

DC ELECTRICAL CHARACTERISTICS ${ }^{(4)}$
$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | IDT7M134S Typ. ${ }^{(1)}$ Max. | $\begin{array}{r} \text { ID } \\ \text { Min. } \end{array}$ | $\begin{aligned} & \text { T7M135S } \\ & \text { Typ. }{ }^{11} \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \|lii] | Input Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to Vcc | - | 15 | - | - 20 | $\mu \mathrm{A}$ |
| \|lol | Output Leakage Current | $\overline{\mathrm{CS}}=\mathrm{VIH}_{1}$, Vout $=0 \mathrm{~V}$ to Vcc | - | 15 | - | 20 | $\mu \mathrm{A}$ |
| VIH | Input High Voltage | - | 2.2 | 6.0 | 2.2 | - 6.0 | V |
| VIL | Input Low Voltage | - | $-1.0^{(2)}$ | 0.8 | $-1.0^{(2)}$ | - 0.8 | V |
| ICC | Dynamic Operating Current (Both Ports Active) | $\overline{\overline{\mathrm{CS}}}=\mathrm{V} \text { IL, Outputs Open, }$ $f=f M A X$ | - | $190 \quad 380$ | - | 320640 | mA |
| ISB | Standby Current (Both Ports Standby) | $\overline{\mathrm{CS}} \mathrm{L}$ and $\overline{\mathrm{CS}} \mathrm{R} \geq \mathrm{V}_{\mathrm{IH}}, \mathrm{VCC}=$ Max., <br> Both Ports Output Open | - | 130260 | - | 260520 | mA |
| ISB1 | Standby Current (One Port Standby) | $\overline{\mathrm{CS}} \mathrm{~L} \text { or } \overline{\mathrm{CS}}_{R} \geq \mathrm{V}_{\mathrm{I}}, \mathrm{VCC}=\text { Max. }$ <br> Active Port Outputs Open | - | 160320 | - | 290580 | mA |
| ISB2 | Full Standby Current (Both Ports Full Standby) | Both Ports $\overline{\mathrm{CSL}}$ and $\overline{\mathrm{CE}} \mathrm{R} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ VIN $\geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ | - | $4120^{(3)}$ | - | $10240^{(3)}$ | mA |
| Vol | Output Low Voltage (//O0-1/O7) | $\begin{aligned} & \mathrm{IOL}=4 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V} \\ & \mathrm{IOL}=8 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V} \end{aligned}$ | - | $\begin{array}{ll} - & 0.4 \\ - & 0.5 \end{array}$ | - | $\begin{array}{ll} - & 0.4 \\ -\quad 0.5 \end{array}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Vol | Open Drain Output Low Voltage (BUSY) | $\mathrm{lOL}=16 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ | - | - 0.5 | - | - 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ | 2.4 | - | 2.4 | - - | V |

## NOTES:

1. $V C C=5 V, T A=+25^{\circ} \mathrm{C}$.
2. $V_{H L} \min .=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .
3. Is82 max. of IDT7M134/IDT7M135 at commercial temperature $=80 \mathrm{~mA} / 150 \mathrm{~mA}$.
4. For $\mathrm{t} A \mathrm{~A}=30,35,40 \mathrm{~ns}$ versions all D.C. parameters are preliminary only.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1,2 and 3 |



Figure 1. Output Load


Figure 2. Output Load (for tchz, ICLZ, tohz, tolz, twhz, tow)


Figure 3. $\overline{B U S Y}$ Output Load

* Including scope and jig. 30pF for fast speed versions. Consult factory for further details.


## AC ELECTRICAL CHARACTERISTICS

$\left(V C C=5.0 \mathrm{~V} \pm 10 \%, T A=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter |  <br> 7M13 <br> 7M13 <br> (Com'l <br> Min. | $\begin{aligned} & 4 \mathrm{~S} 30 \\ & 5 \mathrm{~S} 30 \\ & \text { Only) } \\ & \text { Max. } \end{aligned}$ |   <br>  7M1313 <br> 7M13'  <br> (Com  <br> Min.  | $\begin{aligned} & \hline 34 \mathrm{~S} 35 \\ & 35 \mathrm{~S} 35 \\ & \text { I. Only) } \\ & \text { Max. } \end{aligned}$ | 7M13 7M1 Min. | $\begin{gathered} 34 \mathrm{~S} 40 \\ 35 \mathrm{~S} 40 \\ \text { Max. } \end{gathered}$ | 7M13 7M1 Min. | 4S45 <br> 5S45 <br> Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |
| tRc | Read Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| taA | Address Access Time | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tacs | Chip Select Access Time | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| toe | Output Enable Access Time | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| toh | Output Hold From Address Change | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tclz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 10 | - | ns |
| tchz ${ }^{(1)}$ | Chip Select to Output in High Z | - | 10 | - | 15 | - | 15 | - | 20 | ns |
| tohz ${ }^{(1)}$ | Output Enable to Output in High Z | - | 10 | - | 15 | - | 15 | - | 30 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 50 | - | 50 | - | 50 | - | 50 | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tcw | Chip Select to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| taw | Address Valid to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| twn | Write Recovery Time | 0 | - | 0 | - | 0 | - | 5 | - | ns |
| tDw | Data Valid to End of Write | 20 | - | 20 | - | 22 | - | 25 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 5 | - | ns |
| tohz ${ }^{(1)}$ | Output Enable to Output in High Z | - | 10 | - | 15 | - | 15 | - | 20 | ns |
| tWHz ${ }^{(1)}$ | Write Enabled to Output in High Z | - | 10 | - | 15 | - | 15 | - | 20 | ns |
| tow ${ }^{(1)}$ | Output Active From End of Write | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| BUSY TIMING |  |  |  |  |  |  |  |  |  |  |
| tBAA | $\overline{\text { BUSY }}$ Access Time to Address | - | 35 | - | 35 | - | 40 | - | 40 | ns |
| tBDA | BUSY Disable Time to Address | - | 30 | - | 35 | - | 35 | - | 35 | ns |
| tBAC | BUSY Access Time to Chip Select | - | 30 | - | 35 | - | 35 | - | 40 | ns |
| tBDC | BUSY Disable Time to Chip Select | - | 30 | - | 30 | - | 30 | - | 35 | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data | - | 20 | - | 25 | - | 30 | - | 30 | ns |
| twD | Write Pulse to Data Delay | - | 50 | - | 55 | - | 60 | - | 65 | ns |
| toDD | Write Data Valid to Read Data | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tAPS | Arbitration Priority Set-up Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |

## NOTE:

1. This parameter is guaranteed by design, but not tested.

AC ELECTRICAL CHARACTERISTICS (Continued)
(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{array}{\|l\|} \hline \text { IDTM134S50 } \\ \text { IDTM135S50 } \end{array}$ |  | $\begin{aligned} & \text { IDTM134S60 } \\ & \text { IDTM135S60 } \end{aligned}$ |  | $\begin{gathered} \text { IDTM134S70 } \\ \text { IDTM135S70 } \\ \text { (Mil. Only) } \end{gathered}$ |  | IDTM134S90 <br> IDTM135S90 <br> (Mil. Only) |  | $\begin{aligned} & \text { IDTM134S100 } \\ & \text { IDTM135S100 } \\ & \text { (Mil. Only) } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min: | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 50 | - | 60 | - | 70 | - | 90 | - | 100 | - | ns |
| taA | Address Access Time | - | 50 | - | 60 | - | 70 | - | 90 | - | 100 | ns |
| tacs | Chip Select Access Time | - | 50 | - | 60 | - | 70 | - | 90 | - | 100 | ns |
| toe | Output Enable Access Time | - | 35 | - | 40 | - | 40 | - | 45 | - | 50 | ns |
| toh | Output Hold From Address Change | 0 | - | 0 | - | 5 | - | 10 | - | 10 | - | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 10 | - | 10 | - | 10 | - | 15 | - | 15 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Select to Output in High Z | - | 25 | - | 35 | - | 35 | - | 45 | - | 50 | ns |
| tohz ${ }^{(1)}$ | Output Enable to Output in High Z | - | 40 | - | 40 | - | 30 | - | 40 | - | 40 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low $\mathbf{Z}$ | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tpu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 50 | - | 60 | - | 70 | - | 90 | - | 100 | - | ns |
| tcw | Chip Select to End of Write | 45 | - | 50 | - | 60 | - | 80 | - | 95 | - | ns |
| taw | Address Valid to End of Write | 45 | - | 50 | - | 60 | - | 80 | - | 95 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 40 | - | 45 | - | 45 | - | 50 | - | 55 | - | ns |
| twR | Write Recovery Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tow | Data Valid to End of Write | 25 | - | 25 | - | 30 | - | 40 | - | 40 | - | ns |
| tD | Data Hold Time | 5 | - | 5 | 一 | 10 | - | 10 | - | 10 | - | ns |
| tohz ${ }^{(1)}$ | Output Enable to Output in High Z | - | 25 | - | 35 | - | 35 | - | 40 | - | 40 | ns |
| twhz ${ }^{(1)}$ | Write Enabled to Output in High Z | - | 25 | - | 35 | - | 35 | - | 40 | - | 40 | ns |
| tow ${ }^{(1)}$ | Output Active From End of Write | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| BUSY TIMING |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | $\overline{\text { BUSY }}$ Access Time to Address | - | 40 | - | 45 | - | 45 | - | 45 | - | 50 | ns |
| tBDA | $\overline{B U S Y}$ Disable Time to Address | - | 40 | - | 45 | - | 45 | - | 45 | - | 50 | ns |
| tBAC | BUSY Access Time to Chip Select | - | 40 | - | 40 | - | 40 | - | 40 | - | 50 | ns |
| tBDC | BUSY Disable Time to Chip Select | - | 35 | - | 35 | - | 35 | - | 35 | - | 50 | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Data | - | 35 | - | 40 | - | 50 | - | 50 | - | 60 | ns |
| twod | Write Pulse to Data Delay | - | 75 | - | 85 | - | 90 | - | 100 | - | 120 | ns |
| tDD | Write Data Valid to Read Data | - | 50 | - | 60 | - | 70 | - | 80 | - | 100 | ns |
| taps | Arbitration Priority Set-up Time | 10 | - | 10 | - | 10 | - | 10 | 二 | 10 | - | ns |

## NOTE:

1. This parameter is guaranteed by design, but not tested.

CAPACITANCE ${ }^{(1,2)}\left(\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | IDT7M134S | IDT7M135S | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CIN(D) | Input Capacitance (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 50 | 95 | pF |
| CIn(A) | Input Capacitance (Address) | $\mathrm{VIN}=0 \mathrm{~V}$ | 50 | 100 | pF |
| CIn(C) | Input Capacitance ( $\overline{\mathrm{CS}}$ ) | $V 1 N=O V$ | 14 | 14 | pF |
| Cin(C) | Input Capacitance ( $\overline{\mathrm{BUSY}}$, $\overline{\mathrm{OE}}$ ) | V IN $=0 \mathrm{~V}$ | 50 | 95 | pF |
| CIn(C) | Input Capacitance ( $\mathrm{R} / \overline{\mathrm{W}}$ ) | $\mathrm{VIN}=0 \mathrm{~V}$ | 50 | 95 | pF |
| Cout | Output Capacitance | VOUT $=0 \mathrm{~V}$ | 50 | 95 | pF |

## NOTES:

1. This parameter is guaranteed by design but not tested.
2. Typical values.

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,6)}$


## TIMING WAVEFORM OF READ CYCLE NO. 2 EITHER SIDE ${ }^{(1,3)}$



## NOTES:

1. RWW is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CS}}=\mathrm{VIL}$.
. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
3. If $\overline{\mathrm{CS}}$ goes high simultaneously with $\mathrm{R} / \overline{\mathrm{W}}$ high, the outputs remain in the high impedance state.
. $\overline{\mathrm{CS}} \mathrm{L}=\overline{\mathrm{CS}} \mathrm{F} \leq \mathrm{V}_{\mathrm{IL}}$
4. $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$
5. $\mathrm{R} \overline{\mathrm{W}}=\mathrm{V}_{I H}$ during address transition.
6. Transition is measured at +500 mV from low or high impedance voltage with load (Figures 1,2 and 3).
7. For SLAVE port (IDT7M144/IDT7M145) only.
8. Port-to-port delay through RAM cells from writing port to reading port.
9. This parameter guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 (R/W CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\mathrm{CS}}$ CONTROLLED TIMING) ${ }^{(1,2,3,5)}$


2686 drw 08
NOTES:

1. $\mathrm{R} \overline{\mathrm{W}}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low R/W.
3. twR is measured from the earlier of $\overline{C S}$ or $R / \bar{W}$ going high to the end of write cycle.
4. During this period, $1 / O$ pins are in the output state, and input signals must not be applied.
5. If the CS low transition occurs simultaneously with or after the R/W low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design, but not tested.
7. During a R $/ \bar{W}$ controlled write cycle, write pulse (twp $>t w z+t o w$ ) to allow the $I / O$ drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during a $\mathrm{R} \overline{\mathrm{W}}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

TIMING WAVEFORM OF CONTENTION CYCLE NO. 1, $\overline{\mathrm{CS}}$ ARBITRATION
$\overline{\text { CSL VALID FIRST: }}$


TIMING WAVEFORM OF CONTENTION CYCLE NO. 2, ADDRESS VALID ARBITRATION ${ }^{(5)}$
LEFT ADDRESS VALID FIRST:


2686 drw 11
RIGHT ADDRESS VALID FIRST:


NOTES:

1. RWW is high for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CS}}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. If $\overline{\mathrm{CS}}$ goes high simultaneously with $\mathrm{R} / \overline{\mathrm{W}}$ high, the outputs remain in the high impedance state.
5. $\overline{\mathrm{CS}}_{\mathrm{L}}=\overline{\mathrm{CS}} \mathrm{B} \leq \mathrm{V}_{\mathrm{IL}}$
6. $\overline{O E}=V I L$
7. $R / \bar{W}=V_{I H}$ during address transition.
8. Transition is measured at +500 mV from low or high impedance voltage with load (Figures 1, 2 and 3).
9. For SLAVE port (IDT7M144/IDT7M145) only.
10. Port-to-port delay through RAM celis from writing port to reading port.
11. This parameter guaranteed by design, but not tested.

TIMING WAVEFORM OF READ WITH BUSY ${ }^{(5)}$


## TIMING WAVEFORM OF WRITE WITH BUSY ${ }^{(5)}$



## NOTES:

1. $\mathrm{R} \overline{\mathrm{W}}$ is high for Read Cycles.
2. Device is continuously enabled, $\mathrm{CS}=\mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. If $\overline{C S}$ goes high simultaneously with $R / \bar{W}$ high, the outputs remain in the high impedance state.
5. $\overline{\mathrm{CSL}}=\overline{\mathrm{CS}} \mathrm{R} \leq \mathrm{V}_{\mathrm{L}}$
6. $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{I}}$
7. $R \bar{W}=V_{I H}$ during address transition
8. Transition is measured at +500 mV from low or high impedance volage with load (Figures 1,2 and 3 ).
9. For SLAVE port (IDT7M144/IDT7M145) only.
10. Port-to-port delay through RAM cells from writing port to reading port.
11. This parameter guaranteed by design, but not tested.

## FUNCTIONAL DESCRIPTION

The IDT7M134/IDT7M135 provide two ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. The IDT7M134/IDT7M135 have an automatic power down feature controlled by $\overline{\mathrm{CS}}$. The $\overline{\mathrm{CS}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{\mathrm{CS}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}}$ ). In the read mode, the port's $\overline{O E}$ turns on the output drivers when set LOW. Non-contention READ/WRITE conditions are illustrated in Table I.

## ARBITRATION LOGIC, FUNCTIONAL DESCRIPTION

The arbitration logic will resolve an address match or a chip select match down to 10 ns minimum and determine which port has access. In all cases, an active $\overline{B U S Y}$ flag will be set for the delayed port.

The $\overline{B U S Y}$ flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and set the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address and data. It is important to note that the operation is invalid for the port that has $\overline{\mathrm{BUSY}}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two medes of arbitration are provided: (1) if the addresses match and are valid before $\overline{\mathrm{CS}}$, on-chip control logic arbitrates between $\overline{\mathrm{CS}} \mathrm{L}$ and $\overline{\mathrm{CS}} \mathrm{R}$ for access; or (2) if the $\overline{\mathrm{CS}}$ s are low before
an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table III, Address Arbitration). In either mode of arbitration, the delayed port's $\overline{B U S Y}$ flag is set and will reset when the port granted access complete its operation.

## DATA BUS WIDTH EXPANSION, MASTER/SLAVE DESCRIPTION

Expanding the data bus width to sixteen-or-more-bits in a dual-port static RAM system implies that several modules will be active at the same time. If each module includes a hardware arbitrator, and the addresses for each chip arrive at the same time, it is possible that one will activate its $\overline{B U S Y L}$ while another activates its BUSYR signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid this "busy lock-out" problem, IDT has developed a MASTER/SLAVE approach where only one hardware arbitrator, in the MASTER, is used. The SLAVE has $\overline{B U S Y}$ inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port static RAMs in width, the writing of the SLAVE modules must be delayed until after the $\overline{B U S Y}$ input has settled. Otherwise, the SLAVE module may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{B U S Y}$ to ensure that a write cycle takes place after the contention is resolved. This timing is inherent in all dual-port memory systems when more than one module is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

## TRUTH TABLES

TABLE I - NON-CONTENTION
READ/WRITE CONTROL,
LEFT OR RIGHT PORT ${ }^{(1)}$

| R/ $\bar{W}$ | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{OE}}$ | $1 / \mathrm{O} 0 \cdot 7$ | FUNCTION |
| :---: | :---: | :---: | :---: | :--- |
| X | H | X | Z | Port Disabled and in <br> Power Down Mode, ISB |
| X | H | X | Z | $\overline{\mathrm{CS}}=\overline{\mathrm{CS}} \mathrm{L}=\mathrm{H}$, <br> Power Down Mode, ISB or ISB2 |
| L | L | X | DATAIN | Data on Port Written into <br> Memory |
| H | L | L | DATAOUT | Data in Memory Output <br> on Port ${ }^{(3)}$ |
| H | L | H | Z | High Impedance Outputs |

NOTES:

1. AOL-A13L $\neq A 0 R-A_{13 R}$
2. If $B U S Y=L$, data is not written.
3. If BUSY $=L$, data may not be valid, see twDD and ToDD timing.
4. $H=H I G H, L=L O W, X=D O N ' T$ CARE, $Z=H I G H$ IMPEDANCE

TABLE III - ARBITRATION

| LEFT PORT |  | RIGHT PORT |  | FLAGS ${ }^{(1)}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CS}}$ | A0L-A13L | $\overline{\mathrm{CS}}$ R | A0L-A13R | BUSYL | BUSYR | FUNCTION |
| H | X | H | X | H | H | No Contention |
| L | Any | H | X | H | H | No Contention |
| H | $X$ | L | Any | H | H | No Contention |
| L | $\neq$ A0R-A13R | L | \#A0L-A13L | H | H | No Contention |
| ADDRESS ARBITRATION WITH CS LOW BEFORE ADDRESS MATCH |  |  |  |  |  |  |
| L | LV10R | L | LV10R | H | L | Left-Port Wins |
| L | RV10L | L | LV10L | L | H | Right-Port Wins |
| L | Same | L | Same | H | L | Arbitration Resolved |
| L | Same | L | Same | L | H | Arbitration Resolved |
| $\overline{\text { CS }}$ ARBITRATION WITH ADDRESS MATCH BEFORE $\overline{\text { CS }}$ |  |  |  |  |  |  |
| LLI0R | = A0R-A13R | LL10R | $=A 0 L-A_{13 L}$ | H | L | Lett-Port Wins |
| RLIOL | $=A 0 R-A_{13 R}$ | RL10R | = AOL-A13L | L | H | Right-Port Wins |
| LW10R | $=A 0 R-A_{13 R}$ | LW10R | $=A 0 L-A_{13 L}$ | H | L | Arbitration Resolved |
| LW10R | $=$ A0R-A13R | LW10R | $=A 0 L-A_{13 L}$ | L | H | Arbitration Resolved |

## NOTE:

1. $X=$ DON'T CARE, $L=L O W, H=H I G H$, Same $=$ Loft and Right Addresses match within 10 ns of each other.

LV10R = Left Address Valid $\geq 10$ ns before Right Address.
RV10L = Right Address Valid $\geq 10$ ns before Left Address.
LL10R $=$ Left $\overline{\mathrm{CS}}=\mathrm{LOW} \geq 10 \mathrm{n}$ s before Right $\overline{\mathrm{CS}}$.
RL10L $=$ Right $C S=L O W \geq 10$ ns before left $C S$.
LW10R $=$ Left and Right $\overline{C S}=$ LOW within 10 ns of each other.

## ORDERING INFORMATION



| Integrated Device Technology，Inc． | $\begin{array}{\|l\|} \hline 8 \mathrm{~K} \times 8 \\ 16 \mathrm{~K} \times 8 \\ \text { CMOS DUAL-PORT STATIC } \\ \text { RAM MODULE (SLAVE) } \\ \hline \end{array}$ | IDT7M144S IDT7M145S |
| :---: | :---: | :---: |

## FEATURES：

－High－density 64K／128K CMOS SLAVE Dual－Port static RAM modules
－ $16 \mathrm{~K} \times 8$（IDT7M145）or $8 \mathrm{~K} \times 8$（IDT7M144）option
－Easily expands data bus width to 16－or－more－bits when used with MASTER IDT7M134 or IDT7M135 modules
－Fully asynchronous read／write operation from either port
－Fast access time
－commercial：30ns（max．）
－military：40ns（max．）
－Low－power consumption
－$\overline{B U S Y}$ output flags
－Dual Vcc and GND pins for maximum noise immunity
－Inputs and outputs directly TTL－compatible
－Single 5 V （ $\pm 10 \%$ ）power supply

## DESCRIPTION：

The IDT7M144／IDT7M145 are $64 \mathrm{~K} / 128 \mathrm{~K}$ high－speed CEMOSTM SLAVE Dual－Port static RAM modules con－ structed on a multi－layered，co－fired，ceramic substrate us－ ing four IDT7142 $2 \mathrm{~K} \times 8$ SLAVE dual－port static RAMs （IDT7M144）or eight IDT7142 SLAVE dual－port static RAMs （IDT7M145）in leadless chip carriers．Dual－port function is achieved by utilization of the two on－board IDT54／ IDT74FCT138 decoder circuits that interpret the higher or－ der addresses AL11－13 and AR11－13 to select one of the

## PIN CONFIGURATION ${ }^{(3)}$

| GND -1 | 58 V Vcc |
| :---: | :---: |
| CSL－2 | 57 DCSR |
| R／WL－${ }^{\text {d }}$ | $56.7 \mathrm{R} / W_{R}$ |
| NC－4 | 55 JNC |
| $\overline{\mathrm{BUSY}} \mathrm{L}^{(2)} \square^{\text {l }} 5$ | $54 \mathrm{BESSS}^{(2)}$ |
| OEL 6 | 53 OOER |
| AOL 7 | $52 \bigcirc \mathrm{~A} 0 \mathrm{R}$ |
| $A_{11} \square^{-1}$ | 51 ค $A_{1 R}$ |
| A2L 99 | $50 \bigcirc \mathrm{~A}_{2}$ |
| $\mathrm{A}_{3 L} \square_{10}$ |  |
| A4L 11 | 48 ПA4R |
| A5L 12 | $47 \square^{\square} \mathrm{A}_{5 R}$ |
| A6L 13 | 46 ¢A6R |
| A7L 14 | 45 คA7R |
| A8L 15 | 44 คA8R |
| Agl 516 | 43 คA9R |
| Alol -17 | $42 \bigcirc A_{10 R}$ |
| $A_{112}^{\square} 18$ | $41.7 A_{11 R}$ |
| $\mathrm{A}_{12 \mathrm{~L}} \mathrm{C}_{19}$ | $40 \square \mathrm{~A}_{12 \mathrm{R}}$ |
| $\mathrm{A}_{136}{ }^{(1)} \square_{2} 20$ | $39.1 A_{13 R^{(1)}}$ |
| 1／O OL C 21 | $38.1 / \mathrm{O}$ |
| 1／O 14 प－22 | 37 ¢ $1 / O_{18}$ |
| 1／O 2L $\square^{-13}$ | $36 \mathrm{l} / \mathrm{O}_{2 \mathrm{R}}$ |
| 1／O 3－ 24 | 35 万1／O3R |
| ／／O 4L－ 25 | $34 \mathrm{nl} \mathrm{O}_{4 \mathrm{R}}$ |
| 1／O 5L $\square 26$ | 33 口1／O5R |
| 1／O6L－ 27 | 32 ص1／O6R |
| 1／O 7L $\mathrm{C}^{28}$ | 31 1／O7R |
| GND－29 | 30 万Vcc |

2687 dwg 01
eight $2 \mathrm{~K} \times 8$ dual－port static RAMs．（On IDT7M144 $8 \mathrm{~K} \times 8$ option，the AL13 and AR13 need to be externally grounded and the selection becomes one of the four $2 \mathrm{~K} \times 8$ dual－port static RAMs）．

The IDT7M144／IDT7M145 are designed as＂SLAVE＂dual－ port static RAM modules to be used together with the IDT7M135／IDT7M135＂MASTER＂dual－port RAM modules in 16－or－more－bit systems，whereas the IDT7M134／ IDT7M135 are designed to be used as stand－alone 8－bit dual－port static RAM modules．Using the IDT MASTER／ SLAVE dual－port static RAM module approach in 16 －or－ more－bit memory system applications results in full speed operation without the need for additional discrete logic．

Both SLAVE IDT7M144／IDT7M145 and MASTER IDT7M134／IDT7M135 modules provide two ports with sepa－ rate control，address and I／O pins that permit independent asynchronous access for reads or writes to any location in the memory．The $\overline{B U S Y}$ flags are provided for the situation when both ports simultaneously access the same memory location．BUSY is set at speeds that permit the processor to hold the operation and its respective address and data． The delayed port will have access when BUSY goes high （inactive）．The BUSY pins are outputs on the MASTER and inputs on the SLAVE．

All military module semiconductor components are manu－ factured in compliance with the latest revision of MIL－STD－ 883 Class B，making them ideally suited for applications demanding the highest level of performance and reliability．

## PIN NAMES

| Left Port | Right Port | Names |
| :--- | :--- | :--- |
| AoL－A13L | AOR－At3R | Address Input |
| I／OoL－IO7L | I／OoR－I／O7R | Data Input／Output |
| $\overline{\mathrm{CSL}}$ | $\overline{\mathrm{CS}} \mathrm{R}$ | Chip Select |
| $\mathrm{R} \bar{W} \mathrm{~L}$ | $\mathrm{R} \overline{W_{\mathrm{W}}}$ | Read／Write Enable |
| $\overline{\mathrm{OEL}}$ | $\overline{\mathrm{OE}} \mathrm{R}$ | Output Enable |
| $\overline{\mathrm{BUSY}} \mathrm{L}$ | $\overline{\mathrm{BUSY}} \mathrm{R}$ | $\overline{\mathrm{BUSY}}$ Input |
| VCC | VCC | Power |
| GND | GND | Ground |

## NOTES：

1．On $8 \mathrm{~K} \times 8$ IDT7M144 option，A13L and A13R need to be externally con－ nected to ground for proper operation．
2．IDT7M134／IDT7M135（MASTER）：$\overline{\text { BUSY }}$ is open drain output and re－ quires pull up resistor．IDT7M144／IDT7M145（SLAVE）：$\overline{B U S Y}$ is input．
3．For module dimensions，please refer to module drawing M12 in the packaging section．

## FUNCTIONAL BLOCK DIAGRAMS

## IDT7M145 (16K x 8)



IDT7M144 (8K x 8)

(GROUND A13L AND A13R EXTERNALLY)

## DC ELECTRICAL CHARACTERISTICS

## OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE

(DC electricals for the IDT7M144/IDT7M145 SLAVE module are identical to the IDT7M134/IDT7M135 MASTER module. Reference the IDT7M134/IDT7M135 CMOS Dual-Port static RAM data sheet.)

## AC ELECTRICAL CHARACTERISTICS

## OVER THE OPERATING TEMPERATURE AND SUPPLY VOLTAGE RANGE

(AC electricals for the IDT7M144/IDT7M145 SLAVE module are identical to the IDT7M134/IDT7M135 MASTER module except where noted below.)

| Symbol | Parameter | IDTM144S30 <br> IDTM145S30 <br> (Com'I. Only) <br> Min. Max. | IDTM144S35 <br> IDTM145S35 <br> (Com'l. Only) <br> Min. Max. | IDTM IDTM Min. | $\begin{gathered} 44 \mathrm{~S} 40 \\ 45 \mathrm{~S} 40 \\ \text { Max. } \end{gathered}$ | IDTM IDTM Min. | $\begin{aligned} & \text { 44S45 } \\ & \text { 45S45 } \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twb | Write to BUSY | 0 | 0 | 0 | - | 0 | - | ns |
| tWH | Write Hold After $\overline{\text { BUSY }}$ | 20 | 20 | 20 | - | 20 | - | ns |


| Symbol | Parameter | IDTM144S50 IDTM145S50 |  | IDTM144S60IDTM145S60 |  | IDTM144S70 IDTM145S70 (MII. Only) |  | IDTM144S90 IDTM145S90 (MII. Only) |  | IDTM144S100 IDTM145S100 (Mil. Only) |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| twb | Write to BUSY | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twh | Write Hold After BUSY | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | ns |

## 16-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEM



NOTE:

[^12]
## ORDERING INFORMATION




## FEATURES:

- High-density 256K CMOS Dual-Port static RAM module
- $32 \mathrm{~K} \times 8$ organization
- Fully asynchronous read/write operation from either port
- Fast access time
- commercial: 30ns (max.)
- military: 40ns (max.)
- Low power consumption
- Dual Vcc and GND pins for maximum noise immunity
- Inputs and outputs directly TTL-compatible
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## DESCRIPTION:

The IDT7M137 is a 256 K high-speed CMOS Dual-Port static RAM module constructed on a multi-layered ceramic substrate using eight IDT7134 dual-port static RAMs in leadless chip carriers. The full 32 K bytes of dual-port static RAM are directly addressable by utilization of the two onboard IDT54/IDT74FCT138 decoder circuits that interpret
the higher order addresses AL12-14 and AR12-14 to select one of the eight $4 \mathrm{~K} \times 8$ dual-port static RAMs. Extremely high speeds are achieved in this fashion due to the use of the IDT7134 dual-port static RAM, fabricated in IDT's highperformance CEMOS™ technology.

The IDT7M137 provides two ports with separate control, address and I/O pins that permit independent, asynchronous access for reads or writes to any location in the memory. The IDT7M137 is designed to be used in systems where on-chip hardware port arbitration is not needed. It is the user's responsibility to ensure data integrity when simultaneously accessing the same memory location from both ports.

The IDT7M137 is available with access times as fast as 30 ns commercial and 40 ns military temperature range. The module fits into a 58-pin sidebrazed DIP (Dual In-line Package).

All IDT7M137 military module semiconductor components are manufactured in compliance to the latest revision of MIL-STD-883, Class B, making them ideally suited to applications demanding the highest level of performance and reliability.


NOTE:

1. For module dimensions, please refer to module drawing M12 in the packaging section.

## PIN NAMES

| LEFT PORT | RIGHT PORT | NAMES |
| :---: | :---: | :---: |
| Vcc | Vcc | Power |
| GND | GND | Ground |
| $\overline{\mathrm{CS}} \mathrm{L}$ | $\overline{\mathrm{CS}}$ R | Chip Select |
| $\mathrm{R} \bar{W} \mathrm{~L}$ | $\mathrm{R} \bar{W} \mathrm{R}$ | Read/Write Enable |
| $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}} \mathrm{R}$ | Output Enable |
| A0L-14L | A0R-14R | Address |
| I/OOL-7L | I/OOR-7R | Data input/Output |
| NC | NC | No Connect |

2685 tbl 01


## FUNCTIONAL DESCRIPTION:

The IDT7M137 provides two ports with separate controls, address and I/O that permit independent access for reads or writes to any location in memory. The IDT7M137 has an automatic power down feature controlled by $\overline{\mathrm{CS}}$. The $\overline{\mathrm{CS}}$ controls on-chip power down circuitry that permits
the respective port to go into a standby mode when not selected ( $\overline{C S}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}}$ ). In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW.

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED OPERATING

 TEMPERATURE AND SUPPLY VOLTAGE| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ | 2685 히 03

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{V}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}^{2}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| COUT | Output Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 120 | pF |
| CIN | Input Capacitance | Vout $=0 \mathrm{~V}$ | 50 | pF |

NOTE:

1. This parameter is guaranteed by design, but not tested.

## DC ELECTRICAL CHARACTERISTICS ${ }^{(4)}$

(VCC $=5.0 \mathrm{~V} \pm 10 \%, T A=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7M137 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |  |
| \||LI| | Input Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=0 \mathrm{~V}$ to VCC | - | - | 20 | $\mu \mathrm{A}$ |
| \|liol | Output Leakage Current | $\overline{\mathrm{CS}}=\mathrm{VIH}$, VOUT $=0 \mathrm{~V}$ to VCC | - | - | 20 | $\mu \mathrm{A}$ |
| VIH | Input High Voltage |  | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage |  | -1.0(2) | - | 0.8 | V |
| ICC | Dynamic Operating Current (Both Ports Active) | CS $=$ VIL, Outputs Open | - | 275 | 730 | mA |
| ISB | Standby Current (Both Ports Standby) | CSL and $\mathrm{CSR} \geq \mathrm{VIH}, \mathrm{VCC}=\mathrm{Max}$., Both Ports Outputs Open | - | 200 | 560 | mA |
| ISB1 | Standby Current (One Port Standby) | CSL or CSR $\geq \mathrm{VIH}, \mathrm{VCC}=\mathrm{Max}$., Active Port Outputs Open | - | 225 | 650 | mA |
| ISB2 | Full Standby Current (Both Ports Full Standby) | Both Ports $\overline{\mathrm{CS}} \mathrm{L}$ and $\overline{\mathrm{CS}} \mathrm{R} \geq \mathrm{VCC}-0.2 \mathrm{~V}$ <br> VIN $\geq \mathrm{VCC}-0.2 \mathrm{~V}$ or $\mathrm{VIN} \leq 0.2 \mathrm{~V}$ | - | 8 | 240(3) | mA |
| Vol | Output Low Voltage | $\begin{aligned} & \mathrm{OOL}=8 \mathrm{~mA} \\ & \mathrm{OL}=10 \mathrm{~mA} \end{aligned}$ | - | $-$ | $\begin{aligned} & 0.4 \\ & 0.5 \end{aligned}$ | $\begin{aligned} & V \\ & V \end{aligned}$ |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | - | V |

## NOTES:

1. $V C C=5 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$
2. VII min. $=-3.0 \mathrm{~V}$ for pulse width less than 30 ns .
3. ISB2 max. of IDTM137 at commercial temperature $=150 \mathrm{~mA} .4$. For $\mathrm{IAA}=30,35,40,45 \mathrm{~ns}$ versions all $D C$ parameters are preliminary only.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 10 s |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1,2 and 3 |

2685 tol 108


Figure 1. Output Load


2685 drw 07
Figure 2.
Outpui Load
(for thz, tLz, twz, and tow)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter |  | $\begin{aligned} & 7 \mathrm{~S} 30 \\ & \text { Only) } \\ & \text { Max. } \end{aligned}$ |  | $\begin{aligned} & 7 \mathrm{~S} 35 \\ & \text { Only) } \\ & \text { Max. } \end{aligned}$ |  | $\begin{aligned} & 7 \mathrm{~S} 40 \\ & \text { Max. } \end{aligned}$ |  | $\begin{aligned} & 7 \mathrm{~S} 45 \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tAA | Address Access Time | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tacs | Chip Select Access Time | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| toe | Output Enable Access Time | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| tor | Output Hold From Address Change | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tchz (1) | Chip Select to Output in High Z | - | 10 | - | 15 | - | 15 | - | 25 | ns |
| tohz(1) | Output Enable to Output in High Z | - | 10 | - | 15 | - | 15 | - | 25 | ns |
| tolz (1) | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tPu(1) | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD(1) | Chip Deselect to Power Down Time | - | 50 | - | 50 | - | 50 | - | 60 | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tcw | Chip Select to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| taw | Address Valid to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 20 | - | 25 | - | 30 | - | 40 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tDw | Data Valid to End of Write | 20 | - | 20 | - | 22 | - | 22 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tohz (1) | Output Enable to Output in High Z | - | 10 | - | 15 | - | 15 | - | 20 | ns |
| tWHZ 1 (1) | Write Enabled to Output in High Z | - | 10 | - | 15 | - | 15 | - | 20 | ns |
| tow(1) | Output Active From End of Write | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| NOTES: 2685 ه106 |  |  |  |  |  |  |  |  |  |  |

1. This parameter is guaranteed by design, but not tested.

## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $\left.+70^{\circ} \mathrm{C}\right)$ (Continued)

| Symbol | Parameter | IDTM137S55 |  | IDTM137S60 |  | $\begin{aligned} & \text { IDTM137S70 } \\ & \text { (MiI. Only) } \end{aligned}$ |  | $\left\|\begin{array}{c}\text { IDTM137S90 } \\ \text { (Mil. Only) }\end{array}\right\|$ |  | IDTM137S100 (Mil. Only) |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. |  |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 55 | - | 60 | - | 70 | - | 90 | - | 100 | - | ns |
| tAA | Address Access Time | - | 55 | - | 60 | - | 70 | - | 90 | - | 100 | ns |
| tacs | Chip Select Access Time | - | 55 | - | 60 | - | 70 | - | 90 | - | 100 | ns |
| toe | Output Enable Access Time | - | 35 | - | 35 | - | 40 | - | 40 | - | 40 | ns |
| toh | Output Hold From Address Change | 0 | - | 0 | - | 0 | - | 10 | - | 10 | - | ns |
| tCLZ (1) | Chip Select to Output in Low Z | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| tCHZ (1) | Chip Select to Output in High Z | - | 35 | - | 40 | - | 40 | - | 40 | - | 40 | ns |
| tolz (1) | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tohz (1) | Output Enable to Output in High Z | - | 30 | - | 35 | - | 40 | - | 40 | - | 40 | ns |
| tPU (1) | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD (1) | Chip Deselect to Power Down Time | - | 60 | - | 60 | - | 60 | - | 60 | - | 60 | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 55 | - | 60 | - | 70 | - | 90 | - | 100 | - | ns |
| tcw | Chip Select to End of Write | 50 | - | 55 | - | 60 | - | 80 | - | 90 | - | ns |
| taw | Address Valid to End of Write | 50 | - | 55 | - | 60 | - | 80 | - | 90 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 45 | - | 50 | - | 55 | - | 70 | - | 80 | - | ns |
| twR | Write Recovery Time | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tDW | Data Valid to End of Write | 25 | - | 30 | - | 35 | - | 45 | - | 50 | - | ns |
| tDH | Data Hold Time | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tohz (1) | Output Enable to Output in High Z | - | 35 | - | 40 | - | 40 | - | 40 | - | 50 | ns |
| tWHZ (1) | Write Enabled to Output in High Z | 0 | 35 | 0 | 40 | 0 | 40 | 0 | 40 | 0 | 50 | ns |
| tow (1) | Output Active From End of Write | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. This parameter is guaranteed by design, but not tested.
timing waveform of read cycle no. 1, EIther Side ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3)}$


NOTES:

1. $R / \bar{W}$ is High for Read Cycles.
2. Device is continuously enabled, $\overline{\mathrm{CS}}=\mathrm{V} / \mathrm{L}$
3. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low
4. $O E=V I L$.
5. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 (R/W CONTROLLED TIMING) ${ }^{1,2,3,7 \text { ) }}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\mathrm{CS}}$ CONTROLLED TIMING) ${ }^{(1,2,3,5)}$


## NOTES:

1. $\mathrm{R} \overline{\mathrm{W}}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low R/W.
3. twr is measured from the earlier of $\overline{C S}$ or $R / \bar{W}$ going high to the end of write cycle.
4. During this period, $t / O$ pins are in the output state, and input signals must not be applied
5. If the CS low transition occurs simultaneously with or after the $\mathrm{R} / \overline{\mathrm{W}}$ low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design, but not tested
7. During a R $/ \bar{W}$ controlled write cycle, write pulse ( $\mathrm{t} P$ ) $>(\mathrm{t} W \mathrm{~L}+\mathrm{tDW}$ ) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during a $\mathrm{R} \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.


128K x 8
64K x 8
CMOS DUAL-PORT
RAM MODULE

## ADVANCE INFORMATION IDT7M1001 IDT7M1003

## FEATURES:

- High density 1 megabit/512K CMOS Dual-Port static RAM modules
- Fast access times
- commercial: $40,45,55,65,80 \mathrm{~ns}$
- military: 45, 55, 65, 80, 100ns
- Fully asynchronous read/write operation from either port
- Easy to expand data bus width to 16 -bits or more using the Master/Slave function
- On-chip port arbitration logic and BUSY output flag
- INT flag for port-to-port communication
- Full on-chip hardware support of semaphore signaling between ports
- Surface mounted fine pitch ( 25 mil) LCC packages allow a through-hole module to fit onto 2.5 sq . inches of board space
- Single 5V ( $\pm 10 \%$ ) power supply
- Inputs/outputs directly TTL compatible

PIN CONFIGURATION ${ }^{(1)}$


## NOTE:

1. For module dimensions, please refer to drawing M18 (7M1001) and M19 (7M1003) in the packaging section.

## DESCRIPTION:

The IDT7M1001/1003 are 1 megabit/512K high-speed CMOS Dual-Port RAM modules constructed on a co-fired ceramic substrate using 8 IDT7006 (16K X 8) Dual-Port RAMs or depopulated with only 4 IDT7006 Dual-Port RAMs. The IDT7M1001/1003 modules are designed to be used as stand-alone 1 megabit/512K dual-port RAM or as a combination master/slave dual-port RAM for 16-bit or more word width systems. Using the IDT Master/Slave in that system application results in full-speed, error-free operation without the need for additional discrete logic.

Both devices provide independent ports with separate control, address, and I/O pins that permit independent and asynchronous access for reads or writes to any location in memory. System performance is enhanced by facilitating port-to-port communication via additional control signals $\overline{\text { SEM }}$ \& INT.

The IDT7M1001/1003 modules are packaged in an 80 pin ceramic QIP (Quad In-line Package) only 1.0 inches wide. Maximum access times as fast as 40 ns are available over the commercial temperature range and 45 ns over the military temperature range.

All IDT military modules are constructed with semiconductor components manufactured in compliance with the latest revision of MIL-STD-883 Class B, making them ideally suited to applications demanding the highest level of performance and reliability.

## PIN NAMES

| L_Ao-16 | Left Port Address Lines |
| :---: | :---: |
| R_A0-16 | Right Port Address Lines |
| $\mathrm{L} \mathrm{L} / \mathrm{OO}-7$ | Left Port Data Input/Output |
| R_I/O0-7 | Right Port Data Input/Output |
| L R $\bar{W}$ | Left Port Read/Write Select |
| R R $\bar{W}$ | Right Port Read/Write Select |
| L_ $\overline{\mathrm{CS}}_{1-3}$ | Left Port Chip Selects |
| R $\overline{C S}_{1-3}$ | Right Port Chip Selects |
| L $\overline{O E}$ | Left Port Output Enable |
| $\mathrm{R} \overline{\mathrm{OE}}$ | Right Port Output Enable |
| $L$ BUSY | Left Port Busy Flag |
| R_BUSY | Right Port Busy Flag |
| L INT | Left Port Interrupt Line |
| R INT | Right Port Interrupt Line |
| L SEM 1 - 3 | Left Port Semaphore Control |
| R_SEM 1 -3 | Right Port Semaphore Control |
| M/S | Master/Slave Control |
| VCC | Power |
| GND | Ground |

## PACKAGE DIMENSIONS



2804 drw 02

## ORDERING INFORMATION




Integrated Device Technology, Inc.
$8 \mathrm{~K} \times 9$
16K x 9
CMOS DUAL-PORT STATIC RAM MODULES

## PRELIMINARY

IDT7M1004
IDT7M1005

## FEATURES:

- High density $8 \mathrm{~K} / 16 \mathrm{~K} \times 9$ CMOS Dual-Port Static RAM modules
- Fast access times
-commercial: $30,35,45,55,65 \mathrm{~ns}$
—military: $40,45,55,65,80,100 \mathrm{~ns}$
- Fully asynchronous read/write operation from either port
- Slave configuration only
- Expand data bus width to 18 bits or more using external arbitration
- Surface mounted LCC packages allow through-hole module to fit on a 60-pin sidebrazed DIP
- Single 5 V ( $\pm 10 \%$ ) power supply
- Inputs/outputs directly TTL compatible


## DESCRIPTION:

The IDT7M1004/1005 are 8K/16K $\times 9$ high speed CMOS Dual-Port static RAM modules constructed on a co-fired ceramic substrate using 8 IDT7012 ( $2 \mathrm{~K} \times 9$ ) Dual-Port RAMs or depopulated using only 4 IDT7012 Dual-Port RAMs. The IDT7M1004/1005 modules are designed to be used as stand alone dual-port RAM Slaves or as dual-port RAM slaves for 18-bit or more word width systems.

This module provides two independent ports with separate control, address, and I/O pins that permit independent and asynchronous access for reads or writes to any location in memory. The IDT7M1004/1005 modules are configured only as Slaves. If contention(simultaneous access fromboth ports to the same exact address) is a possible occurance in this application, and data integrity is required, external logic must be used to compare address and control signals between the two sides to prevent a data conflict. Most often, users are able to assure by other means (such as software handshaking or interrupts) that such a contention between sides does not occur.

The IDT7M1004/1005 modules are packaged in a 60 -pin ceramic sidebrazed DIP (Dual In-line Package). Maximum access times as fast as 30 ns are available over the commercial temperature range and 40 ns over the military temperature range.

All IDT military modules are constructed with semiconductor components manufactured in compliance with the latest revision of MIL-STD-883, Class B making them ideally suited to applications demanding the highest level of performance and reliability.

## PIN CONFIGURATION

| cc | , |  | GND |
| :---: | :---: | :---: | :---: |
| L_R/W | -2 | 59 | R_R/W |
| L-A(0) | 1 |  | R-A 0 ) |
| L_A (1) | 4 | 57 | $\mathrm{R}^{-} \mathrm{A}(1)$ |
| L-A(2) | 5 | 56 | R_A (2) |
| L-A 3 ) | 56 | 55 | R_A (3) |
| L-A 4 ) | 7 | 54 | R-A(4) |
| GND | 8 | 53 | R_A(5) |
| L A $(5)$ | 49 | 52 | R_A(6) |
| L-A(6) | 10 | 51 | R-A(7) |
| L_A 7 ) | 11 | 50 | R-A (8) |
| L_A ${ }^{-}$(8) | 12 | 49 | R_A ${ }^{\text {a }}$ |
| LA(9) | 13 | 48 | R_A(10) |
| LA ${ }^{\text {(10) }}$ | 14 | 47 | R-A(11) |
| L-A(11) | 515 | 46 | R-A (12) |
| Vcc | 16 | 45 | $\square \mathrm{GND}$ |
| L_A(12) | $0^{17}$ |  | R A (13) |
| L_A(13) |  | 43 | R OE |
| LOE | 19 | 42 | R_CS |
| L-CS | $\square 20$ |  | $\mathrm{R}_{-1 / \mathrm{O}}(0)$ |
| -1/O(0) | C21 |  | $\mathrm{R}^{-} / \mathrm{O}(1)$ |
| -1/O(1) | - 22 |  | $R \mathrm{R} / 1 / \mathrm{O}(2)$ |
| -1/O(2) | $\square 23$ | 38 | $\square \mathrm{GND}$ |
| -1/0(3) | 24 | 37 | R $1 / \mathrm{O}(3)$ |
| -1/0(4) | -25 | 36 | R-1/0(4) |
| -1/0(5) | -26 |  | $\mathrm{R}_{1}^{-1 / O}(5)$ |
| -1/O(6) | -27 |  | R-1/O(6) |
| -1/O(7) | -28 | 33 | R-1/O(7) |
| -1/O(8) | -29 | 32 | R-1/O(8) |
| GND | - 30 | 31 | V cc |
|  |  |  | 2797 drw 14 |

## PIN NAMES

| Left Port | Right Port | Names |
| :---: | :---: | :---: |
| L_CS | R_CS | Chip Selects |
| L_R $\bar{W}$ | R_R $\bar{W}$ | Read/Write Enables |
| L_ $\overline{O E}$ | R_DE | Output Enables |
| L_A (0-13) | R_A (0-13) | Address Inputs |
| L_I/O (0-8) | R_l/O (0-8) | Data Input/Outputs |
| Vcc |  | Power |
| GND |  | Ground |

NOTE:
2797 tb 01

1. On the IDT7M1004 option ( $8 \mathrm{~K} \times 9$ ) L_A13 and R_A 13 need to be connected to GND for proper operation of the module.

NOTE:

1. For module dimensions, please refer to drawing M14 in the packaging section.

CEMOS is a trademark of Integrated Device Technology, inc.

## FUNCTIONAL BLOCK DIAGRAMS

IDT7M1005 (16K x 9)


IDT7M1004 (8K x 9)


ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

## RECOMMENDED DC

 OPERATING CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2797 tbl 03

1. $V I L \geq-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING

 TEMPERATURE AND SUPPLY VOLTAGE| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

CAPACITANCE TABLE $\left(T A=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | IDT7M1004 Max. | IDT7M1005 Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| C_IN(1) | Input Capacitance ( $A(0-10), \overline{B U S Y}, \overline{O E}, R / \bar{W})$ | V _ $\mathbb{N}=0 \mathrm{~V}$ | 80 | 40 | pF |
| C_IN(2) | Input Capacitance (Data) | V _ $\mathrm{N}=0 \mathrm{~V}$ | 90 | 45 | pF |
| C_IN(3) | Input Capacitance (A(11-13), $\overline{C S}, \overline{N T})$ | $V_{-} 1 N=0 V$ | 12 | 12 | pF |
| Cout | Output Capacitance (Data) | V_OUT $=0 \mathrm{~V}$ | 90 | 45 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7M1004 |  | IDT7M1005 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|l| | Input Leakage | $\begin{aligned} & V C C=M a x . \\ & V I N=G N D \text { to } V C C \end{aligned}$ | - | 40 | - | 80 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage | $\begin{aligned} & V C C=M a x . \\ & \overline{C S} \geq V I H, V O U T=G N D \text { to } V C C \end{aligned}$ | - | 40 | - | 80 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} . \mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min}, \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |

2797 tbl 06

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7M1004/5 (Com'l.) |  |  | IDT7M1004/5 (Mil.) |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. ${ }^{(1)}$ | Max. ${ }^{(2)}$ | Min. | Max. ${ }^{(1)}$ | Max. ${ }^{(2)}$ |  |
| Icc2 | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \text { VCC = Max., } \overline{\mathrm{CS}} \leq \text { VII, } \overline{\mathrm{SEM}}=\text { Don't Care } \\ & \text { Outputs Open, } \mathrm{f}=\mathrm{fmAX} \end{aligned}$ | - | 500 | 870 | - | 560 | 860 | mA |
| ISB | Standby Supply <br> Current (Both Ports Inactive) | $V C C=M a x ., \overline{\mathrm{CS}} \mathrm{L}$ and $\overline{\mathrm{CS}} \mathrm{R} \geq \mathrm{VIH}$ Outputs Open, $f=f$ max | - | 280 | 560 | - | 280 | 560 | mA |
| IsB1 | Standby Supply <br> Current (One Port Inactive) | $\begin{aligned} & \text { Vcc = Max., } \overline{\mathrm{CS}} \mathrm{~L} \text { or } \overline{\mathrm{CS}} \geq \mathrm{VIH} \\ & \text { Outputs Open, } \bar{f}=\mathrm{fmAX} \end{aligned}$ | - | 370 | 650 | - | 430 | 750 | mA |
| IsB2 | Full Standby Supply Current (Both Ports Inactive) | $\overline{C S} L$ and $\overline{C S} R \geq V C C-0.2 \mathrm{~V}$ <br> $\mathrm{VIN}>\mathrm{Vcc} 0.2 \mathrm{~V}$ or $<0.2 \mathrm{~V}$ <br> SEM_L and SEM_R $\geq$ Vcc -0.2 V | - | 60 | 120 | - | 120 | 240 | mA |

## NOTES:

2797 tbl 07

1. For IDT7M1004 ( $8 \mathrm{~K} \times 9$ ) version only.
2. For IDT7M1005 $(16 \mathrm{~K} \times 9)$ version only

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |
| 2797 tol 08 |  |



Figure 1. Output Load
Figure 2. Output Load (For tchz, tclz, tohz, tolz, twhz, tow)

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7M1004S30 7M1005S30 (Com'I. Only) |  | $\left(\begin{array}{l} 7 \mathrm{M} 1004 \mathrm{~S} 35 \\ 7 \mathrm{M} 1005 \mathrm{~S} 35 \\ \text { (Com'l. Only) } \end{array}\right.$ |  | $\begin{array}{\|l\|} \hline 7 \mathrm{M} 1004 \mathrm{~S} 40 \\ 7 \mathrm{M} 1005 \mathrm{~S} 40 \end{array}$ |  | $\left\lvert\, \begin{aligned} & \text { 7M1004S45 } \\ & \text { 7M1005S45 } \end{aligned}\right.$ |  | $\left\|\begin{array}{l} \text { 7M1004S55 } \\ 7 \mathrm{M} 1005 \mathrm{~S} 55 \end{array}\right\|$ |  | $\left\|\begin{array}{l} \text { 7M1004S65 } \\ 7 \mathrm{M} 1005 \mathrm{~S} 65 \end{array}\right\|$ |  | $\begin{array}{\|c\|} \hline 7 \mathrm{M1004S} 80 \\ 7 \mathrm{M1005S} 80 \\ \text { (Mil. Only) } \\ \hline \end{array}$ |  | 7M1004S100 7M1005S100 (Mil. Only) |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| thc | Read Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | - | ns |
| tas | Address Access Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |
| tAcs ${ }^{(2)}$ | Chip Select Access Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |
| toe | Output Enable Access Time | - | 15 | - | 20 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| OH | Output Hold from Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tcız ${ }^{(1)}$ | Chip Select to Output in Low $Z$ | 3 | - | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 15 | - | 15 | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tocz ${ }^{(1)}$ | Output Enable to Output in Low Z | 3 | - | 3 | - | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 15 | - | 15 | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tpu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{PDD}^{(1)}$ | Chip Deselect to Power Up Time | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |

Write Cycle

| twc | Write Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tcw ${ }^{(2)}$ | Chip Select to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | 50 | - | 55 | - | 60 | - | ns |
| taw | Address Valid to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | 50 | - | 55 | - | 60 | - | ns |
| tAS | Address Set-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 25 | - | 30 | - | 35 | - | 35 | - | 40 | - | 50 | - | 55 | - | 60 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 20 | - | 25 | - | 25 | - | 25 | - | 30 | - | 40 | - | 45 | - | 50 | - | ns |
| tor | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tOHZ ${ }^{(1)}$ | Output Disable to Output in High Z | - | 15 | - | 15 | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| twhz ${ }^{(1)}$ | Write Enable to Output in High Z | - | 15 | - | 15 | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:
2797 tbl OS

1. This parameter is guaranteed by design but not tested
2. To access RAM array, $\overline{\mathrm{CS}} \leq \mathrm{V}$ IL.
3. Master mode is not available on this module.
4. The module is always in the Slave Mode.
5. Port-to-Port delay through the RAM cells from the writing port to the reading port.
6. To ensure that the earlier of the two ports wins.
7. To ensure that the write cycle is inhibited during contention.
8. To ensure that a write cycle is completed after contention.

TIMING WAVEFORM OF READ CYCLE NO. 1 (EITHER SIDE) ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2 (EITHER SIDE) ${ }^{(1,3,5)}$


NOTES:

1. R/W is high for Read Cycles
2. Device is continuously enabled, $\overline{C S}=L$. This waveform cannot be used for semaphore reads.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low
4. $\overline{O E}=L$
5. To access RAM, $\overline{C S}=L$. To access semaphore, $\overline{C S}=H$.
6. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 (R/W CONTROLLED TIMING) ${ }^{(1,3,5,8)}$


TIMING WAVEFORM OF WRITE CYCLE NO. $2\left(\overline{\operatorname{CS}}\right.$ CONTROLLED TIMING) ${ }^{(1,3,5,8)}$


## ORDERING INFORMATION



$$
\begin{array}{ll}
\text { 128K X 16, 64K X 16, 32K X } 16 & \text { IDT7MB6036 } \\
\text { CMOS DUAL-PORT RAM } & \text { IDT7MB6046 } \\
\text { (SHARED MEMORY MODULE) } & \text { IDT7MB6056 }
\end{array}
$$

## FEATURES:

- High density 2 megabit/1 megabit/512K-bit CMOS DualPort static RAM (shared memory modules)
- Fully asynchronous read/write operation from either port
- Port arbitration/multiplexing logic by custom FCT chip set
- Memory array comprised of industry standard static RAM component
- Fast access time
- 50ns (max.)
- Versatile controls: $\overline{\text { BUSY }}$ output flag and separate controls for lower and upper byte writes on each port
- Master/Slave control on-board for expanding word width
- Multiple GND and Vcc pins for maximum noise immunity
- Inputs and outputs directly TTL-compatible
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## DESCRIPTION:

The Shared Memory Module provides two ports with separate control, address and Data l/O pins that permit independent access for read or writes to any location in the memory array. Using the on-board Master/Slave input allows these modules to be used as building blocks in 32-bit or more-bit systems requiring full speed operation without additional discrete logic.

In the Master Mode, the Shared Memory Module arbitrates asynchronously between the left and right ports $\overline{\mathrm{CS}}$ inputs. The first to arrive is granted exclusive access to the entire RAM array for as long as its $\overline{\mathrm{CS}}$ is asserted. If both ports attempt simultaneous access, the losing port will have its $\overline{B U S Y}$ asserted until the winning port completes it access, at which time the second port will be granted its own exclusive access to the entire RAM array. See application note AN-74 for more details regarding proper module operating modes.

FUNCTIONAL BLOCK DIAGRAM


PIN CONFIGURATION ${ }^{(1,2,3,4,5)}$


NOTES:

1. For module dimensions (7MB6036), please refer to drawing M20 in the packaging section.
2. For module dimensions (7MB6046), please refer to drawing M21 in the packaging section.
3. For module dimensions (7MB6056), please refer to drawing M22 in the packaging section.
4. Pins 7 and 57 must be grounded for proper operation of the 7 MB6046 module.
5. Pins $6,7,56$ and 57 must be grounded for proper operation of the 7 MB6056 module.

PIN DESCRIPTION

| Symbol | Description |
| :---: | :---: |
| Vcc | Power |
| GND | Ground |
| A0.16L | Left Port Address |
| D0.15L | Left Port Data |
| A0.16R | Right Port Address |
| Do.15L | Right Port Data |
| R $\bar{W}$ | Read/Write Control |
| $\overline{\mathrm{CS}}$ | Active Low Chip Select |
| $\overline{\text { DSL }}$ | Data Strobe for Lower Byte |
| $\overline{\text { DSU }}$ | Data Strobe for Upper Byte |
| $\overline{\mathrm{OEL}}$ | Output Enable for Lower Byte |
| $\overline{\text { OEU }}$ | Output Enable for Upper Byte |
| $\overline{\text { BSYL or LTAIN }}$ | Left Busy Output for Stand Alone or Master Mode. Left or Right Port Select Input for Slave Mode. |
| BSYR or SELIN | Right Busy Output for Stand Alone or Master Mode. RAM Array Select Input for Slave Mode. |
| L/̄̆OUT | Left or Right Port Select Output on Master to be Connected to L/ $\overline{\mathrm{R}}$ _IN Input on One or More Slaves when Width Expansion is Required. |
| SELOUT | RAM Array Select Output on Master to be Connected to SEL_IN Input on One or More Slaves when Width Expansion is Required. |
| M/ $\overline{\text { S }}$ | Master/Slave signal for cascading master w/one or more slaves. |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Military | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## CAPACITANCE

| Symbol | Parameter | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CiN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 100 | pF |
| CouT | Output Capacitance | VoUT $=0 \mathrm{~V}$ | 40 | pF |

## RECOMMENDED

DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.0 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $V_{\text {IL }}=-3.5 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
( $\mathrm{Vcc}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \|lu| | Input Leakage Current | $\begin{aligned} & V c \mathrm{C}=\mathrm{Max} . \\ & \mathrm{ViN}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 15 | $\mu \mathrm{A}$ |
| \|ILO] | Output Leakage Current | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{CS}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 15 | $\mu \mathrm{A}$ |
| Icc | Dynamic Operating Current | $\begin{aligned} & \text { VCG = Max., } \overline{\mathrm{CS}} \leq \text { VIL, } \\ & \mathrm{f}=\mathrm{fMAX} \text {, Output Open } \end{aligned}$ | - | 520 | mA |
| IsB | Standby Power Supply Current | $\overline{\mathrm{CS}} \geq \mathrm{V}_{\mathrm{IH}}, \mathrm{VCC}=\mathrm{MAX} .$ <br> Outputs Open, $f=f$ max. | - | 200 | mA |
| VOH | Output Low Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{IOH}=-8 \mathrm{~mA} \end{aligned}$ | 2.4 | - | V |
| VoL | Output High Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{lOL}=16 \mathrm{~mA} \end{aligned}$ |  | 0.4 | V |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 2. Output Load (for torz and tolz)

Figure 1. Output Load
*Including scope and jig.

## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V}+10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\left\|\begin{array}{\|c\|}7 M B 6036 S 50 \\ \text { 7MB6046S50 } \\ \text { 7MB6056S50 }\end{array}\right\|$ |  | $7 M B 6036 S 60$ <br> $7 M B 6046 S 60$ <br> $7 M B 6056 S 60$ |  | 7MB6036S70 <br> 7MB6046S70 <br> 7MB6056S70 |  | $\begin{aligned} & \text { 7MB6036S85 } \\ & \text { 7MB6046S85 } \\ & \text { 7MB6056S85 } \\ & \hline \end{aligned}$ |  | 7MB6036S100 7MB6036S1207MB6046S100 7MB6046S1207MB6056S1007MB6056S120 |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| No Contention Read |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 50 | - | 60 | - | 70 | - | 85 | - | 100 | - | 120 | - | ns |
| tAA | Address Access Time | - | 50 | - | 60 | - | 70 | - | 85 | - | 100 | - | 120 | ns |
| tacs | Chip Select Access Time | - | 50 | - | 60 | - | 70 | - | 85 | - | 100 | - | 120 | ns |
| toe | Output Enable to Data Valid | - | 27 | - | 32 | - | 37 | - | 42 | - | 47 | - | 52 | ns |
| tor | O/P Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tolz ${ }^{(1)}$ | $\overline{O E}$ to Output in Low-Z | 8 | - | 8 | - | 8 | - | 8 | - | 8 | - | 8 | - | ns |
| torz ${ }^{(1)}$ | $\overline{\text { OE }}$ to Output in High-Z | - | 7.5 | - | 7.5 | - | 7.5 | - | 7.5 | - | 7.5 | - | 7.5 | ns |
| No Contention Write |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 50 | - | 60 | - | 70 | - | 85 | - | 100 | - | 120 | - | ns |
| taw | Address Valid to End of Write | 45 | - | 50 | - | 60 | - | 75 | - | 90 | - | 110 | - | ns |
| tcw | $\overline{\mathrm{CS}}$ to End of Write | 45 | - | 50 | - | 60 | - | 75 | - | 90 | - | 110 | - | ns |
| tAS | Address Set-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tcos | $\overline{C S}$ to Data Strobe | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| tDS | Data Strobe Width | 25 | - | 30 | - | 35 | - | 50 | - | 60 | - | 70 | - | ns |
| twR | Write Recovery Time | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tow | Data Valid to End of Write | 22 | - | 25 | - | 30 | - | 45 | - | 50 | - | 55 | - | ns |
| tDH | Data Hold from End of Write | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | 10 | - | ns |

## Contention Read

| tCB | $\overline{\mathrm{CS}}$ to BUSY | - | 12 | - | 12 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tBD | Busy Negate to Data Valid | - | 50 | - | 60 | - | 70 | - | 85 | - | 100 | - | 120 | ns |

## Contention Write

| tCB | CS to BUSY | - | 12 | - | 2 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tBDS | Busy Negate to Data Strobe | 7 | - | 7 | - | 10 | - | 15 | - | 15 | - | 15 | - | ns |

Slave Timing

| tLR | $\overline{\mathrm{CS}}$ to L/R Output | - | 11 | - | 11 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tSEL | $\overline{\mathrm{CS}}$ to Select Output | - | 14 | - | 14 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| tAPS | Arbitration Priority Set-up Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter guaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF WRITE CYCLE ( $\overline{\mathrm{CS}}$ CONTROLLED )


TIMING WAVEFORM OF WRITE CYCLE ( $\overline{\mathrm{DS}}$ CONTROLLED )


## NOTES:

1. $\mathrm{R} \bar{W}=\mathrm{V}_{1} H$.
2. Transition is measured +200 mV from steady state with 5 pF load (including scope and jig. This parameter guaranteed by design, but not tested.

## TIMING WAVEFORM OF CONTENTION READ, ( $\overline{C S}$ ARBITRATION)

$\overline{\text { CSL }}$ VALID FIRST:


TIMING WAVEFORM OF CONTENTION WRITE, ( $\overline{\mathrm{CS}}$ ARBITRATION)
$\overline{\mathrm{CS}} \mathrm{R}$ VALID FIRST:


TIMING WAVEFORM OF SLAVE ${ }^{(2)}$


NOTES:

1. taps is only necessary to guarantee left side access. Within this set-up time, one side or the other will gain access, but neither will have priority.
2. $\overline{\mathrm{CS}}$ inputs are ignored when configured as a Slave, allowing the Master to control port selection with L/ $\overline{\mathrm{R}}$ _OUT and SEL_OUT signals.

## ORDERING INFORMATION



Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

FR-4 QIP (Quad In-line Package)


Standard Power
128K x 16 Dual-Port RAM Shared Memory Module $64 \mathrm{~K} \times 16$ Dual-Port RAM Shared Memory Module 32K x 16 Dual-Port RAM Shared Memory Module

| Integrated Device Technology，Inc． | $\begin{aligned} & 64 \mathrm{~K} \times 16 \\ & 32 \mathrm{~K} \times 16 \end{aligned}$ <br> CMOS DUAL－PORT STATIC RAM MODULE | PRELIMINARY IDT7MB1006 IDT7MB1008 |
| :---: | :---: | :---: |

## FEATURES

－High density 1 megabit／512K CMOS Dual－Port static RAM module
－Fast access times
－commercial：40，45，55，65， 80 ns
－military： $45,55,65,80,100 \mathrm{~ns}$
－Fully asynchronous read／write operation from either port
－Easy to expand data bus width to 32 bits or more using the master／slave function
－Separate upper and lower byte control
－On－chip port arbitration logic
－INT flag for port－to－port communication
－Full on－chip hardware support of semaphore signaling between ports
－Surface mounted PQFP（plastic quad flatpack）compo－ nents allow a through－hole module to fit into a 132－pin FR－4 QIP（Quad In－line Package）
－Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
－Input／outputs directly TTL compatible

## DESCRIPTION：

The IDT7MB1006／IDT7M1008 is a $64 \mathrm{~K} \times 16 / 32 \mathrm{~K} \times 16$ high－ speed CMOS dual－port static RAM module constructed on a multilayer epoxy laminate（FR－4）substrate using eight IDT7025 （ $8 \mathrm{~K} \times 16$ ）dual－port RAMs or depopulated with four IDT7025 dual－port RAMs．The IDT7MB1006／1008 module is designed to be used as stand－alone dual－port RAM or as a combination master／slave dual－port RAM for 32－bit or more word width systems．Using the IDT master／slave approach in such system applications results in full－speed，errorj－free operation without the need for additional discrete logic．

This module provides two independent ports with separate control，address，and I／O pins that permit independent and asynchronous access for reads or writes to any location in memory．System performance is enhanced by facilitating port－to－port communication via additional control signals $\overline{\text { SEM }}$ and INT．

The IDT7MB1006／1008 module is packaged on a FR－4 132－pin QIP（Quad In－line Package）．Maximum access times as fast as 40 ns are available over the commercial temperature range．

## PIN CONFIGURATION ${ }^{(1)}$

| GND ${ }^{-}$ | 1••67 | GND | GND | 132••66 | $\square \mathrm{GND}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MS ${ }^{\text {C }}$ | 2 ••68 | GND | GND | 131＊＊65 | $\square \mathrm{GND}$ ， |
| Vcc | 3 － 69 | Vcc | Vcc | 130． 64 | 1 Vac |
| L＿BUSY $\square$ | － 70 | L＿INT | R＿BUSY | 129••63 | $\square$ R＿INT |
| La（0）［］ | － 71 | L＿A（1） | R＿A $(0)$ | 128＊＊62 | 7 R＿A 1 ） |
| L＿A 2 ）${ }^{\text {a }}$ | 72 | L＿A（3） | R＿A ${ }^{\text {2 }}$ ） | 127．．61 | 7 R＿A 3 ） |
| L＿A（4） | － 73 | L＿A ${ }^{\text {（5）}}$ | R＿A（4） | 126••60 | $\cap$ R＿A ${ }^{\text {a }}$ ） |
| GND $\square^{-1}$ | 8 •• 74 | GND | GND | 125＊ 59 | $\bigcirc$ GND |
| L＿A（6） | － 75 | L＿A $(7)$ | R＿A（6） | 124－－ 58 | $\square \mathrm{R}$－${ }^{\text {（7）}}$ |
| L＿A $(8)$ | 10．． 76 | $\mathrm{L}-\mathrm{A}(9)$ | R＿A $(8)$ | 123．． 57 | $\square$ R＿A ${ }^{\text {（9）}}$ |
| vac ${ }^{\text {c }}$ | 11．． 77 | Vcc | Vcc | 122．－ 56 | $\square \mathrm{Vcc}$ |
| L＿A 10 ）$]_{1}$ | 12． 78 | L＿A（11） | R A ${ }^{\text {（10）}}$ | 121＊ 55 | R ${ }^{\text {a }}$ A（11） |
| L＿A（12）${ }^{\text {a }}$ | 13． 79 | L＿A（13） | R＿A（12） | 120． 54 | $\square \mathrm{R}$ A 13 ） |
| L＿A（14）$\square^{\text {a }}$ | 14 －． 80 | L＿A（15） | R＿A（14） | 119．． 53 | 万 R＿A 15 ） |
| L＿LB | 15 －． 81 | L＿U日 | L＿LE | 118．－ 52 | R－UB |
| GND | 16 －． 82 | GND | GND | 117．－ 51 | $\bigcirc$ GND |
| GND | 17．－ 83 | GND | GND | 116．． 50 | $\bigcirc$ GND |
| Vcc ${ }^{\text {a }}$ | $18 . .84$ | Vcc | VCC | 115．．49 | $\square \mathrm{Vac}$ |
| L＿CS | 19. ． 85 | L＿SEM | R＿CS | 114．－ 48 | R $\square_{\text {S }}$ SEM |
| L＿RW | 20. ． 86 | L $\overline{O E}$ | R＿RW | 113． 47 | $\bigcirc$ R－OE |
| L－10（0）$\square^{1}$ | 21．－ 87 | L＿IO（1） | R＿I／O（0）． | 112．－ 46 | 7 R－10（1） |
| LIO（2）$\square$ | $22 \cdot$－ 88 | L＿I／O（3） | R＿IO（2） | 111 •－ 45 | R＿10（3） |
| vcc | 23．－ 89 | Vcc | VCC | 110．． 44 | Vcc |
| L－IO（4） | 24 － 90 | L＿IO（5） | R－I／O（4） | 109－． 43 | 7 R －10（5） |
| LIO（6）$\square^{1}$ | 25 － 91 | L＿IO（7） | R－1／O（6） | 108．－ 42 | $\square \mathrm{R}$－10（7） |
| GND | $26 \cdot$－ 92 | GND | GND | 107． 41 | $\square \mathrm{GND}$ |
| LTIO（8） | 27 －－93 | L＿IO（9） | R－I／O（8） | 106．． 40 | 日 R＿IO（9） |
| L＿／V（10）$\square^{1}$ | 28 － 94 | L＿I／O（11） | R＿IO（10） | 105－ 39 | $\square$ R＿VO（11） |
| L＿I／O（12）${ }^{\text {C }}$ | 29－－95 | L＿I／O（13） | R＿I／O（12） | 104． 38 | R－1／O（13） |
| L＿I／O（14） | 30 • 96 | L＿I／O（15） | R＿L／O（14） | 103 •－ 37 | RIV（15） |
| Vcc | 31 － 97 | Vcc | $V_{\text {cc }}$ | 102．－ 36 | $\square \mathrm{Vcc}$ |
| GND - | 32 － 98 | GND | GND | 101．－ 35 | $\square \mathrm{GND}$ |
| GND 4 | 33 －－ 99 | GND | GND | 100． 34 | ］GND |

## PIN NAMES

| $A 0-A_{15}$ | Address Lines |
| :--- | :--- |
| $\mathrm{I} / \mathrm{O}_{0}-\mathrm{I} / \mathrm{O}_{7}$ | Data Inputs／Outputs |
| $\mathrm{R} \bar{W}$ | Read／Write Selects |
| $\overline{\mathrm{CS}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\overline{\mathrm{BUSY}}$ | $\overline{\mathrm{BUSY}}$ Flag |
| $\overline{\mathrm{INT}}$ | Interrupt Line |
| $\overline{\mathrm{SEM}}$ | Semaphore Control |
| $\overline{\mathrm{UB}}$ | Upper Byte Select |
| $\overline{\mathrm{LB}}$ | Lower Byte Select |
| $\bar{M} / \bar{S}$ | Master／Slave Control |
| VCC | Power Supply |
| GND | Ground |

## NOTE：

1．Dimensions for these modules are currently not available，please consult the factory．

## FUNCTIONAL BLOCK DIAGRAM



7MB1008


2803 drw 03

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal <br> Voltage with <br> Respect to GND | -0.5 to $\pm 7.0$ | -0.5 to $\pm 7.0$ | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| COUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

2803 th 03

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

CAPACITANCE $^{(2)}\left(\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{t}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Test Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN1 | Input Capacitance <br> (CS, $\overline{B U S Y})$ | $\mathrm{ViN}=0 \mathrm{~V}$ | 5 | pF |
| CiN1 | Input Capacitance <br> (SEM, $\overline{\mathrm{INT})}$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 15 | pF |
| CIN2 | Input Capacitance <br> (Data, Address, <br> All Other Controls) | $\mathrm{VIN}=0 \mathrm{~V}$ | 40 | pF |
| CouT | Output Capacitance <br> (Data) | $\mathrm{VoUT}=0 \mathrm{~V}$ | 40 | pF |

NOTE:
2803 tbl 05

1. This parameter is guaranteed by design but not tested.

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7MB1006 |  | IDT7MB1008 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| Icc2 | Dynamic Operating Current <br> (Both Ports Active) | Vcc $=$ Max., $\overline{\mathrm{CS}} \geq$ VIL, SEM $=$ Don't Care Outputs Open, $\mathrm{f}=\mathrm{fmax}$ | - | 900 | - | 620 | mA |
| IsB | Standby Supply Current | $V C C=$ Max., $L_{-} \overline{C S}$ and $R_{-} \overline{C S} \geq V i H$, Outputs Open, $f=\mathrm{fmax}$ | - | 580 | - | 300 | mA |
| IsB1 | Standby Supply Current (One Port Active) | $\begin{aligned} & \text { Vcc }=\text { Max., L_ } \overline{C S} \text { or R_} \overline{C S} \geq V_{I H} \\ & \text { Outputs Open, } f=\text { fmax } \end{aligned}$ | - | 760 | - | 480 | mA |
| ISB2 | Full Standby Supply Current | L_ $\overline{C S}$ and $R-\overline{C S} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{VIN}>\mathrm{Vcc}-0.2 \mathrm{~V}$ or $<0.2 \mathrm{~V}$ <br> L_SEM and R_SEM $\geq$ Vcc - 0.2 V | - | 125 | - | 65 | mA |

DC ELECTRICAL CHARACTERISTICS
( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7MB1006 |  | IDT7MB1008 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \||L| | Input Leakage (Address \& Control) | $\begin{aligned} V C C & =M a x . \\ V I N & =G N D \text { to } V c c \end{aligned}$ | - | 80 | - | 40 | mA |
| \| 141 | Input Leakage (Data) | $\begin{aligned} & V C C=M a x . \\ & V I N=G N D \text { to } V c c \end{aligned}$ | - | 20 | - | 20 | mA |
| \|ILO| | Output Leakage (Data) | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \overline{C S} \geq \mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 20 | - | 20 | mA |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} . \quad \mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | mA |
| VOH | Output High Voltage | $\mathrm{VCC}=$ Min. $\quad \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | mA |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load (for tclz, tchz, tolz. tohz, twhz, tow)

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7MB1006S40 1DT7MB1008S40 |  | IDT7MB1006S45 IDT7MB1008S45 |  | IDT7MB1006S55IDT7MB1008S55 |  | DT7MB1006S65DT7MB1008S65 |  | IDT7MB1006S80 <br> IDT7MB1008S80 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tre | Read Cycle Time | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | ns |
| tas | Address Access Time | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | ns |
| tacs $^{(2)}$ | Chip Select Access Time | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | ns |
| toe | Output Enable Access Time | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| toh | Output Hold From Address Change | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tccz ${ }^{(1)}$ | Chip Select to Output in Low Z | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 18 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| toLz ${ }^{(1)}$ | Output Enable to Output in Low $\mathbf{Z}$ | 3 | - | 3 | - | 5 | - | 5 | - | 5 | - | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 18 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tpu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tpo ${ }^{(1)}$ | Chip Disable to Power Down Time | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |
| tsop | $\overline{S E M}$ Flag Update Pulse ( $\overline{\mathrm{OE}}$ or $\overline{S E M})$ | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | ns |


| twc | Write Cycle Time | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{tcw}^{(2)}$ | Chip Select to End of Write | 35 | - | 40 | - | 45 | - | 50 | - | 55 | - | ns |
| taw | Address Valid to End of Write | 35 | - | 40 | - | 45 | - | 50 | - | 55 | - | ns |
| tasi | Address Set-up to Write Pulse Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tas2 | Address Set-up to $\overline{\mathrm{CS}}$ Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 30 | - | 35 | - | 40 | - | 45 | - | 50 | - | ns |
| twn | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 25 | - | 27 | - | 30 | - | 40 | - | 45 | - | ns |
| toh ${ }^{(1)}$ | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tOHz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 18 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| twhz ${ }^{(1)}$ | Write Disable to Output in High Z | - | 18 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tow | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tswro | $\overline{\text { SEM Flag Write to Read Time }}$ | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| tsps | $\overline{\text { SEM Flag Contention Window }}$ | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | ns |

## NOTES:

1. This parameter is quaranteed by design but not tested.
2. To access RAM, $\overline{C S} \leq V I L$ and $\overline{S E M} \geq V_{I H}$. To access semaphore, $\overline{C S} \geq V_{I H}$ and $\overline{S E M} \leq V_{I L}$.

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | $\left\lvert\, \begin{aligned} & \text { IDT7MB1006S40 } \\ & \text { IDT7MB1008S40 } \end{aligned}\right.$ |  | IDT7MB1006S45 IDT7MB1008S45 |  | IDT7MB1006S55 IDT7MB1008S55 |  | IDT7MB1006S65 IDT7MB1008S65 |  | IDT7MB1006S80 IDT7MB1008S80 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| BUSY Cycle - MASTER MODE ${ }^{(3)}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | $\overline{\text { BUSY }}$ Access Time from Address | - | 40 | - | 45 | - | 45 | - | 55 | - | 55 | ns |
| tBDA | $\overline{\text { BUSY }}$ Disable Time from Address | - | 30 | - | 35 | - | 40 | - | 45 | - | 45 | ns |
| tBAC | BUSY Access Time to Chip Select | - | 35 | - | 40 | - | 40 | - | 50 | - | 55 | ns |
| tBDC | $\overline{\text { BUSY }}$ Disable Time to Chip Select | - | 30 | - | 35 | - | 35 | - | 45 | - | 45 | ns |
| twDo ${ }^{(5)}$ | Write Pulse to Data Delay | - | 60 | - | 70 | - | 80 | - | 85 | - | 95 | ns |
| todo | Write Data Valid to Read Data Delay | - | 40 | - | 45 | - | 55 | - | 70 | - | 80 | ns |
| UPPS $^{(6)}$ | Arbitration Priority Set-up Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tBD | $\overline{\text { BUSY }}$ Disable to Valid Time | - | Note 9 | - | Note 9 | - | Note 9 | - | Note 9 | - | Note 9 | ns |
|  |  |  |  |  |  |  |  |  |  |  |  |  |
| twi $^{(7)}$ | Write to BUSY Input | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twh ${ }^{(8)}$ | Write Hold After $\overline{\text { BUSY }}$ | 25 | - | 30 | - | 30 | - | 30 | - | 30 | - | ns |
| twod ${ }^{(5)}$ | Write Pulse to Data Delay | - | 60 | - | 70 | - | 80 | - | 85 | - | 100 | ns |
| tDOD ${ }^{(5)}$ | Write Data Valid to Read Data Valid | - | 45 | - | 50 | - | 60 | - | 70 | - | 85 | ns |
| Interrupt Timing |  |  |  |  |  |  |  |  |  |  |  |  |
| tas | Address Set-up Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twr | Write Recovery Time . ... | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tins | Interrupt Set Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 55 | ns |
| ting | Interrupt Reset Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 55 | ns |

NOTES:

1. This parameter is quaranteed by design but not tested.
2. To access RAM, $\overline{C S} \leq V_{I L}$ and $\overline{S E M} \geq V_{I H}$. To access semaphore, $\overline{C S} \geq V_{I H}$ and $\overline{S E M} \leq V_{I L}$.
3. When the module is being used in the Master Mode ( $\left.M / \bar{S} \geq V_{1 H}\right)$.
4. When the module is being used in the Slave Mode ( $M / \bar{S} \leq V_{I L}$ ).
5. Port-to-Port delay through the RAM cells from the writing port to the reading port.
6. To ensure that the earlier of the two ports wins.
7. To ensure that the write cycle is inhibited during contention.
8. To ensure that a write cycle is completed after contention.
9. tBDD is a calculated parameter and is the greater of 0, tWDD-twP (actual), or tDDD - WPP (actual).

TIMING WAVEFORM OF READ CYCLE NO. 1 (EITHER SIDE) ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2 (EITHER SIDE) ${ }^{(1,3,5)}$


NOTES:

1. $\mathrm{R} \bar{W}$ is High for Read Cycles
2. Device is continuously enabled. $\overline{C S}=$ Low. $\overline{U B}$ or $\overline{L B}=$ Low. This waveform cannot be used for semaphore reads.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=$ Low.
5. To access RAM, $\overline{C S}=L o w, \overline{U B}$ or $\overline{L B}=L o w, \overline{S E M}=H$. To access semaphore, $\overline{C S}=H$ and $\overline{S E M}=$ Low.
6. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. 3 ( $\overline{\mathrm{UB}}$ OR $\overline{\mathrm{LB}}$ CONTROLLED TIMING) ${ }^{(1,3,4,5)}$


1. $R \bar{W}$ is High for Read Cycles
2. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
3. $\overline{O E}=$ Low.
4. To access RAM, $\overline{\mathrm{CS}}=$ Low $\overline{\mathrm{UB}}$ or $\overline{\mathrm{LB}}=$ Low, $\overline{\mathrm{SEM}}=\mathrm{H}$. To access semaphore, $\overline{\mathrm{CS}}=H$ and $\overline{\mathrm{SEM}}=$ Low.
5. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\mathrm{R} / \overline{\mathrm{W}}$ CONTROLLED TIMING) $)^{(1,3,5,8)}$


## NOTES:

1. $\mathrm{R} \bar{W}$ is High for Read Cycles
2. Device is continuously enabled. $\overline{\mathrm{CS}}=$ Low. $\overline{\mathrm{UB}}$ or $\overline{\mathrm{LB}}=$ Low. This waveform cannot be used for semaphore reads.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{\mathrm{OE}}=$ Low.
5. To access RAM, $\overline{\mathrm{CS}}=$ Low, $\overline{\mathrm{UB}}$ or $\overline{\mathrm{LB}}=$ Low, $\overline{\mathrm{SEM}}=H$. To access semaphore, $\overline{\mathrm{CS}}=H$ and $\overline{\mathrm{SEM}}$ = Low.
6. Timing depends on which enable signal is asserted last.
7. Timing depends on which enable signal is de-asserted first.
8. If $\overline{O E}$ is Low during a $R / \bar{W}$ controlled write cycle, the write pulse width must be larger of twP or (twz + tow) to allow the l/O drivers to turn off and data to be placed on the bus for the required tDW. If $\overline{O E}$ is High during a $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse width be as short as the specified twp.
9. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\mathrm{CS}}, \overline{\mathrm{UB}}, \overline{\mathrm{LB}}$ CONTROLLED TIMING) $)^{(1,3,5,8)}$


2803 drw 09

## NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a Low $\overline{U B}$ or $\overline{L B}$ and a Low $\overline{C S}$ and a Low $\mathrm{A} \bar{W}$ for memory array writing cycle.
3. twR is measured from the earlier of $\overline{C S}$ or $R \bar{W}$ (or $\overline{S E M}$ or $R \bar{W}$ ) going high to the end of write cycle.
4. During this period, the $/ / O$ pins are in the output state and input signals must not be applied.
5. If the $\overline{\mathrm{CS}}$ or $\overline{\mathrm{SEM}}$ low transition occurs simultaneously with or after the $\mathrm{R} / \overline{\mathrm{W}}$ low transition, the outputs remain in the high impedance state.
6. Timing depends on which enable signal is asserted last.
7. Timing depends on which enable signal is de-assented first.
8. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or (twz + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.
9. This parameter is guaranteed by design but not tested.

## TIMING WAVEFORM OF SEMAPHORE READ AFTER WRITE TIMING (EITHER SIDE) ${ }^{(1)}$



## TIMING WAVEFORM OF SEMAPHORE CONTENTION ${ }^{(1,3,4)}$



## NOTES:

1. $\operatorname{Dof}=\mathrm{DOL}=$ Low, $\mathrm{L} \overline{C E}=\mathrm{R} \mathbf{C E}=$ High. Semaphore Flag is released form both sides (reads as ones from both sides) at cycle start.
2. "A" may be either left or right port. " $B$ " is the opposite port from " $A$ ".
3. This parameter is measured from $R \bar{W}_{A}$ or $\overline{S E M}_{A}$ going High to $R / \bar{W}_{B}$ or SEM $\bar{B}$ going High.
4. If tsps is violated, the semaphore will fall positively to one side or the other, but there is no guarantee which side will obtain the flag.

TIMING WAVEFORM OF READ WITH $\overline{\operatorname{BUSY}}(\mathrm{M} / \overline{\mathrm{S}} \geq \mathrm{VIH})^{(2)}$


NOTES:

1. To ensure that the earlier of the two ports wins.
2. $\mathrm{L} \overline{C E}=\mathrm{R} \overline{\mathrm{CE}}=\mathrm{LOW}$
3. $\overline{\mathrm{OE}}=$ Low for the reading port.

TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DELAY (M/S $\leq$ VIL) $)^{(1,2)}$


NOTES:

1. $\overline{\mathrm{BUSY}}$ input equals High for the writing port.
2. $L_{-} \overline{C S}=R_{-} \overline{C S}=$ Low

TIMING WAVEFORM OF WRITE WITH BUSY INPUT (M/ $\bar{S} \leq$ VIL)


## WAVEFORM OF BUSY ARBITRATION CONTROLLED BY $\overline{\mathbf{C S}}$ TIMING ${ }^{(1)}$



## WAVEFORM OF BUSY ARBITRATION CYCLECONTROLLEDBY ADDRESS MATCH TIMING ${ }^{(1)}$



## NOTES:

1. All timing is the same for left and right ports. Port "A" may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. If taps is violated, the busy signal will be asserted on one side or another but there is no guarantee on which side busy will be asserted.

WAVEFORM OF INTERRUPT TIMING ${ }^{(1)}$


NOTES:

1. All timing is the same for left and right ports. Port " A " may be either the left or right port. Port " B " is the port opposite from " A ".
2. See InterruptTruth Table.
3. Timing depends on which enable signal is asserted last.
4. Timing depends on which enable is de-asserted first.

## TRUTH TABLES

TABLE I: NON-CONTENTION READ/WRITE CONTROL ${ }^{(1,2,3)}$


NOTES:
2803 tbl 12

1. $A O L-A_{12} \neq A 0 R-A_{12 R}$
2. $\overline{\mathrm{CS}}=$ True represents $L \overline{C S}=R_{-} \overline{C S}=$ Low.
3. $\overline{\mathrm{CS}}=$ False represents $\overline{L_{-}} \overline{\mathrm{CS}}=\overline{R_{-}} \overline{\mathrm{CS}}=$ High .

## TABLE II: SEMAPHORE READ/WRITE CONTROL

| Inputs |  |  |  |  |  | Outputs |  | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CS}}$ | R/W | $\overline{O E}$ | $\overline{\text { UB }}$ | $\overline{L B}$ | $\overline{\text { SEM }}$ | I/O8 - I/O15 | I/O0-1/O7 |  |
| F | H | L | X | X | L | DATAOUT | DATAout | Read Data in Semaphore Flag |
| X | H | L | H | H | L | DATAOUT | DATAOUT | Read Data in Semaphore Flag |
| F | 5 | X | X | X | L | DATAIN | DATAIN | Write Dino into Semaphore Flag |
| X | 5 | X | H | H | $L$ | DATAIN | DATAIN | Write Dino into Semaphore Flag |
| T | X | X | L | X | L | - | - | Not Allowed |
| T | X | X | X | L | L | - | - | Not Allowed |

NOTES:

1. $A O L-A_{12} \neq A O R-A_{12 R}$
2. $\overline{\mathrm{CS}}=$ True represents $L_{-} \overline{\mathrm{CS}}=R-\overline{C S}=$ Low.
3. $\overline{\mathrm{CS}}=$ False represents $\overline{L_{-}} \overline{\mathrm{CS}}=\overline{R_{-}} \overline{\mathrm{CS}}=$ High.

## TABLE III: INTERRUPT FLAG ${ }^{(1)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | $\overline{\text { CS }}$ | $\overline{O E}$ | A0-A15 | $\overline{\text { INTL }}$ | R/ $\bar{W}$ | $\overline{\text { CS }}$ | $\overline{O E}$ | A0-A15R | INT |  |
| L | $L$ | X | 1FFF | X | X | X | X | X | $L^{(2)}$ | Set Right $\overline{\mathrm{NT}}$ T $_{\text {F Flag }}$ |
| X | X | X | $X$ | X | X | L | L | 1FFF | $H^{(3)}$ | Reset Right $\overline{N T}$ R Flag |
| X | X | X | X | $L^{(2)}$ | L | L | X | 1FFE | X | Set Left INTL Flag |
| X | L | L | 1FFE | $\mathrm{H}^{(3)}$ | X | X | X | X | X | Reset Left INTL Flag |

## NOTES:

2803 tbl 14

1. Assumes $L \overline{B U S Y}=R \_\overline{B U S Y}=$ High
2. If $L_{-} \overline{B U S Y}=$ Low then no change.
3. If $\mathrm{R} \overline{\mathrm{BUSY}}=$ Low then no change.
4. At the interrupt addresses 1FFE and 1FFF, address bits 13-15 are zero.

## TRUTH TABLES

## TABLE IV: ADDRESS BUSY ARBITRATION

| Inputs |  |  | Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| L_CS | R_CS | $\begin{aligned} & A 0 L-A 15 L \\ & A 0 R-A 15 R \end{aligned}$ | L_EUSY ${ }^{(1)}$ | R_EUSY ${ }^{(1)}$ |  |
| X | X | No Match | H | H | Normal |
| H | X | Match | H | H | Normal |
| X | H | Match | H | H | Normal |
| L | L | Match | Note 2 | Note 2 | Write Inhibit ${ }^{(3)}$ |

NOTES:
2803 tbi 15

1. Pins L_BUSY and R_BUSY are both outputs when the part is configured as a master. Both are inputs when configured as a slave. X_BUSY outputs on the IDT7MB10016/1008 are push pull, not open drain outputs. On slaves the X_BUSY input internally inhibits writes.
2. Lif the inputs to the opposite port were stable prior to the address and enable inputs of this port. H if the inputs to the opposite port became stable after the address and enable inputs of this port. If the primacy of stable inputs cannot be resolved, either L_BUSY = Low or R_BUSY = Low will result. L_BUSY and R_BUSY outputs cannot be low simultaneously.
3. Writes to the left port are internally ignored when L_BUSY outputs are driving low regardless of actual logic level the pin. Writes to the right port are internally ignored when R_BUSY outputs are driving low regardless of actual logic level on the pin.

TABLE V: EXAMPLE OF SEMAPHORE PROCUREMENT SEQUENCE ${ }^{(2)}$

| Function | D0 - D15 <br> Left | D0 - D15 <br> 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 sempahore 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 sempahore token |
| Left Port Writes "1" to Semaphore | 1 | 1 | Semaphore free |
| Right Port Writes "0" to Semaphore | 1 | 0 | Right port has sempahore 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 |

## NOTE:

1. This table denotes a sequence of events for only one of the eight semaphores available on the IDT7MB1006/1008

## FUNCTIONAL DESCRIPTIONAL

The IDT7MB1006/1008 provides two ports with separate control, address and $/ / O$ pins that permit independent access for reads or writes to any location in memory. The IDT7MB1006/ 1008 has an automatic power down feature controlied by $\overline{\mathrm{CS}}$. The $\overline{\mathrm{CS}}$ controls on-chip power down circuitry that permits the respective port to go into standby mode when not selected ( $\overline{\mathrm{CS}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. NON-CONTENTION READ/ WRITE conditions are illustrated in the Truth Tables.

## INTERRUPTS

The interrupt flag ( $\overline{\mathrm{INT}}$ ) permits communictaion between ports or systems. If the user chooses to use the interrupt function, a memory location (mail box or message center) is assigned to each port. The left port interrupt flag ( $\overline{\mathrm{NTL}})$ is set when the right port writes to memory location 1FFE (HEX). The left port clears the interrupt by reading address location 1 FFE. Likewise, the right port interrupt flag ( $\overline{\mathrm{NT}} \mathrm{R})$ is set when the left port writes to memory location 1FFF (HEX) and to clear the interrupt flag (INTR), the right port must read the memory location 1FFF. The message (16bits) at 1FFE or 1 FFF is userdefined. If the interrupt function is not used, address locations 1FFE and 1FFF are not used as mail boxes, but as part of the random access memory. Refer to Table III for the interrupt operation. Interrupts in the least significant IDT7025 of the module are used. To address them, the most significant address bits (A13-15) must be 0 .

## BUSY LOGIC

The arbitration logic will resolve an address match or a chip enable match down to 5 ns minimum and determine which port has access. In all cases, an active $\overline{B U S Y}$ flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{B U S Y}$ flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold
the operation and its respective address and data. It is important to note that the operation is invalid for the port that has $\overline{B U S Y}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{C S}$, on-chip control logic arbitrates between $\overline{C S L}$ and $\overline{\mathrm{CS}}$ R for access; or (2) if the $\overline{\mathrm{CS}}$ s are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's $\overline{B U S Y}$ flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION, MASTER/SLAVE DESCRIPTION

Expanding the data bus width to thirtytwo-or-more-bits in a dual-port RAM system implies that several modules will be active at the same time. If each module includes a hardware arbitrator, and the addresses for each module arrive at the same time, it is possible that one will activate its L_BUSY while another activates its R_ $\overline{B U S Y}$ signal. Both sides are now busy and the CPU's will wait indefinitely for their port to become free.

To avoid this "Busy Lock-out" problem, IDT has developed a MASTER/SLAVE approach where only one hardware arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RMs in width, the writing of the SLAVE modules must be delayed, until after the BUSY input has settled. Otherwise, the SLAVE module may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{\mathrm{BUSY}}$ to ensure that a write takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than one module is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

## 32-BIT MASTER/SLAVE DUAL-PORT MEMORY SYSTEMS



## SEMAPHORES

The IDT7MB1006/1008 is an extremely fast dual-port 64K/ $32 \mathrm{~K} \times 16$ CMOS static RAM module with an additional 8 address locations dedicated to binary semaphore flags. These flags allow either processor on the left or right side of the dualport RAM to claim a privilege over the other processor for functions defined by the system designer's software. As an example, the semaphore can be used by one processor to inhibit the other from accessing a portion of the dual-port RAM or any shared resource.

The dual-port RAM module features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Both ports are identical in function to standard CMOS static RAM modules and can be read from, or written to, at the same time with the only possible conflict arising from the simultaneous writing of, or a simultanious READ/WRITE of, a non-semaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the nonsemaphore portion of the dual-port RAM. These devices have an automatic power-down feature controlled by $\overline{C S}$ the dualport RAM enable, and $\overline{S E M}$, the semaphore enable. The $\overline{C S}$ and $\overline{\text { SEM }}$ pins control on-chip power down circuitry that permits the respective port to go into standby mode when not selected. This is the condition which is shown in Truth Table where $\overline{C S}$ and $\overline{S E M}$ are both high.

Systems which can best use the IDT7MB1006/1008 contain multiple processors or controllers and are typically very high-speed systems which are software controlled or software intensive. These systems can benefit from a performance increase offered by the IDT7MB1006/1008's hardware semaphores which provide a lockout mechanism without requiring complex programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be allocated in varying configurations. The IDT7MB1006/ 1008 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture.

An advantage of using semaphores rather than the more common methods of hardware arbitration is that wait states are never incurred in either processor. This can prove to be a major advantage in very high-speed systems.

## HOW SEMPAHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independent of the dual-port RAM. These latches can be used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment method called "Token Passing Allocation." In this method, the state of a semaphore latch is used as a token indicating that a shared resource is in use. If the left processor wants to use this resource, it requests the token by setting the latch. This processor then verifies its success in setting the latch by reading it. If it was successful, it proceeds to assume control over the shared resource. If it
was not successful in setting the latch, it determines that the right side processor had set the latch first, has the token and is using the shared resource. The left processor can then either repeatedly request that semaphore's status or remove its request for that semaphore to perform another task and occasionally attempt again to gain control of the token via the set and test sequence. Once the right side had relinquished the token, the left side should succeed in gaining control.

The semaphore flags are active low. A token is requested by writing a zero into a semaphore latch and is released when the same side writes a one to that latch.

The eight semaphore flags reside within the IDT7MB1006/ 1008 in a separate memory space from the dual-port RAM. This address space is accessed by placing a low input on the SEM pin (which acts as a chip select for the semaphore flags) and using the other control pins (Address, $\overline{O E}$, and $R \bar{W}$ ) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through address pins Ao-A2. When accessing the semaphores, none of the other address pins has any effect.

When writing to a semaphore, only data pin Do is used. If a low level is written into an unused semaphore location, that flag will be set to a zero on that side and a one on the other (Table V). That semaphore can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be set to a one forboth sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. (A thorough discussion on the use of this feature follows shortly.) A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.

When a semaphore flag is read, its value is spread into all data bits so that flag this is a one reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE}}$ ) signals go active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal (SEM or $\overline{\mathrm{OE}}$ ) to go active or the output will never change.

A sequence of WRITE/READ must be used by the semaphore in order to guarantee that no system level contention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the samaphore flag will appear as a one, a fact which the processor will verify by the subsequent read. (see Table V). As an example, assume a processor writes a zero to the left port at a free semaphore location. On a subsequent read; the processor will verify that it has written successfully to that location and will assume control over the resource in question. Meanwhile, if a processor on the right
side attempts to write a zero to the same samaphore flag it will fail, as will be verified by the fact that a one will be read from that semaphore on the right side during a subsequent read. Had a sequence of READ/WRITE been used instead, system contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed by either repeated reads or by writing a one into the same location. The reason for this is easily understood by looking at the simple logic diagram of the semaphore flag in Figure 1. Two semaphore request latches feed into a semaphore flag. Whichever latch is first to present a zero to the semaphore flag will force its side of the semaphore flag low and the other side high. This condition will continue until a one is written to the same semaphore request latch. Should the other side's semaphore latch have been written to a zero in the meantime, the samaphore flag will flip over to the other side as soon as a one is written into the first side's request latch. The second side's flag will now stay low until its semaphore request latch is written to a one. From this it is easy to understand that, if a semaphore is requested and the processor which requested it no longer needs the resource, the entire system can hang up until a one is written into that semaphore request latch.

The ciritcal case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is especially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side is earlier than the other in making the request, the first side to make the request will receive the token. If both requests arrive at the same time, the assignment will be arbitrarily made to one port or the other.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a recource secure. As with any powerful programming technique, if semaphores are misused or misinterpreted, a software error can easily happen. Code integrity is of the utmost importance when semaphores are used instead of slower, more restrictive hardware intensive schemes.

Initialization of the samaphores is not automatic and must be handled via the initialization program at power-up. Since any sempahore request flag which contains a zero must be reset to a one, all semaphores on both sides should have a one written into them at initialization from both sides to assure that they will be free when needed.

## USING SEMAPHORES - SOME EXAMPLES

Perhaps the simplest application of semaphores is their application as resource markers for the IDT7MB1006/1008's dual-port RAM module. Say that a $8 \mathrm{~K} \times 16$ RAM block was to be divided into two $4 \mathrm{~K} \times 16$ blocks which were to be dedicated at any one time to servicing either the left or right port. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of memory.

To take a resource, in this example the lower 4 K of dual-port

RAM, the processor on the left port could write and then read a zero into Semaphore 0. If this task were successfully completed (a zero was read back rather than a one), the left processor would assume control of the lower 4 K . Meanwhile the right processor would attempt to perform the same function. Since this processor was attempting to gain control of the resource after the left processor, it would read back a one in response to the zero it had attempted to write into Semaphore 0 . At this point, the software could choose to try and gain control of the second 4 K section by writing, then reading azero into Semaphore 1. If it succeeded in gaining control, it would lock out the left side.

Once the left side was finished with its task, it would write a one to Semaphore 0 and may then try to gain access to Semaphore 1. If Semaphore 1 was still occupied by the right side, the left side could undo its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1. If the right processor performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 4K blocks of dual-port RAM with each other.

The blocks do not have to be any particular size and can even be variable, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphore can even assigned different meanings on different sides rather than being given a common meaning as was shown in the example above.

Semaphores are a useful form of arbitration in systems like disk interface where the CPU must be locked out of a section of memory during a transfer and the I/O device cannot tolerate any wait states. With the use of semaphores, once the two devices had determined which memory area was "off limits" to the CPU, both the CPU and the I/O devices could access their assigned portions of memory continuously without any wait states.

Semaphores are also useful in applications where no memory "WAIT" state is available to one or both sides. Once a semaphore handshake has been periormed, both processors can access their assigned RAM segments at full speed.

Another application is in the area of complex data structures. In this case, block arbitration is very important. For this application, one processor may be responsible for building and updating a data structure. The other processor then reads. and interprets that data structure. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the two different processors. The building processor arbitrates for the block, locks it and then is able to go in and update the data structure. When the update is completed, the data structure block is released. This allows the interpreting processor to come back and read the complete data structure, thereby guaranteeing a consistent data structure.


Figure 1. IDT7MB1006/1008 Semaphore Loglc

## ORDERING INFORMATION




Integrated Device Technology, Inc.
$128 \mathrm{~K} \times 18,64 \mathrm{~K} \times 18,32 \mathrm{~K} \times 18$ CMOS DUAL-PORT RAM (SHARED MEMORY MODULE)

PRELIMINARY
IDT7MB6136
IDT7MB6146
IDT7MB6156

## FEATURES:

- High density 2 megabit/1 megabit/512K-bit CMOS DualPort static RAM (shared memory modules)
- 18-bit wide shared memory array for those applications requiring parity, tags, or extra width
- Fully asynchronous read/write operation from either port
- Port arbitration/multiplexing logic by custom FCT chip set
- Memory array comprised of industry standard static RAM components
- Versatile controls: $\overline{\text { BUSY }}$ ouput flag and separate write controls for lower and upper byte on each port
- Master/Slave control on-board for expanding word width
- Multiple GND and Vcc pins for maximum noise immunity
- Inputs and outputs directly TTL-compatible
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## DESCRIPTION:

The Shared Memory Module provides two ports with separate control, address and data I/O pins that permit independent access for reads or writes to any location in the memory array. Using the on-board Master/Slave input allows these module to be used as building blocks in 32-bit or more-bit systems requiring full speed operation without additional discrete logic.

In the Master Mode, the Shared Memory Module arbitrates asynchronously between the left and right port $\overline{\mathrm{CS}}$ inputs. The first to arrive is granted exclusive access to the entire RAM array for as long as its $\overline{\mathrm{CS}}$ is asserted. If both ports attempt simultaneous access, the losing port will have its $\overline{B U S Y}$ asserted until the winning port completes its access, at which time the second port will be granted its own exclusive access to the entire RAM array. See application note AN-74 for more details regarding proper module operating modes.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1,2,3)}$

| Vcc | 1 - 53 GND | GND 104 - 52 | GND |
| :---: | :---: | :---: | :---: |
|  | 2 - $54 \overline{\text { BSY }}_{\text {R or SELIN }}$ | L/ $\overline{\text { Rout }} 103 \bullet \bullet 51$ | SELout |
| $\overline{\mathrm{CS}} \mathrm{L}$ | $3 \bullet$ - $55 \overline{\mathrm{CS}}_{\mathrm{R}}$ | GND 102 - 50 | M/S |
| $\mathrm{R} / \bar{W}_{L}$ | 4- $56 \mathrm{R} / \bar{W}_{\mathrm{R}}$ | D17. 101 - 49 | D17R |
| $\overline{\text { DSLL }}$ | 5 - $57 \overline{\mathrm{DSL}}_{R}$ | $\mathrm{D}_{16 \mathrm{~L}} 100 \cdot 48$ | $\mathrm{D}_{16 \mathrm{R}}$ |
| $\overline{\overline{D S U}_{L}}$ | $6 \bullet 58 \overline{\text { DSU }}_{\text {R }}$ | $\mathrm{D}_{15 \mathrm{~L}} 99 \bullet$ • 47 | $\mathrm{D}_{15 \mathrm{R}}$ |
| A16L | 7 - - 59 A 16 R | D14L $98 \bullet$ - 46 | $\mathrm{D}_{14 \mathrm{R}}$ |
| $A_{15 L}$ | 8 - $60 \mathrm{~A}_{15 R}$ | $\mathrm{D}_{13 \mathrm{~L}} 97$ - ${ }^{\text {¢ }}$ | $\mathrm{D}_{13 \mathrm{R}}$ |
| A14L | $9 \bullet \bullet 1$ A14R | D12L $96 \bullet$ - 44 | D12R |
| GND | 10 - 62 GND | GND 95 - 43 | Vcc |
| $A_{13 L}$ | $11 \cdot 63$ A ${ }_{13 R}$ | D11L $94 \bullet 42$ | D $\mathrm{D}_{1} \mathrm{R}$ |
| A 12 L | 12 - $64 \mathrm{~A}_{12 R}$ | Diol 93- 41 | D 10 R |
| $A_{11 L}$ | 13 - 65 A 11 R | Dgl 92• © 40 | D9R |
| A 10 L | 14 - 66 A 10 R | $\overline{\text { OEUL } 91 \bullet \bullet 39}$ | $\overline{O E U}_{R}$ |
| AgL | 15-67 A9R | D8L 90• 38 | D8R |
| Asl | $16 \bullet$ - 68 A8R | D7. $89 \bullet$ - 37 | D7R |
| A7L | 17 - 69 A7R | D6L 88 - ${ }^{\text {a }} 3$ | $\mathrm{D}_{6} \mathrm{R}$ |
| A6L | $18 \cdot$ - 70 A6R | D5L 87• 35 | D5R |
| A5L | 19 - 71 A5R | D4L $86 \bullet$ - 34 | $\mathrm{D}_{4 \mathrm{R}}$ |
| Vcc | $20 \cdot 72$ GND | GND $85 \cdot$ - 33 | GND |
| A4L | 21 - 73 A4R | $\mathrm{D}_{3 L} 84 \cdot{ }^{\text {e }}$ | D3R |
| $\mathrm{A}_{3}$ | 22 - 74 A3R | $\mathrm{D}_{2 \mathrm{~L}} 83 \cdot{ }^{\text {• }} 3$ | $\mathrm{D}_{2 R}$ |
| A 2 L | 23 - $75 \mathrm{~A}_{2 R}$ | $\mathrm{D}_{1} \mathrm{~L} 82$ - 30 | $\mathrm{D}_{1} \mathrm{R}$ |
| A1L | 24 - 76 A1R | Dol 81 - 29 | Dor |
| Aol | 25 - 77 Aor | $\overline{\text { OELL } 80 \bullet 28 ~}$ | OELR |
| GND | $26 \cdot$ - 78 GND | GND 79 - 27 | V cc |

NOTES:

1. For module dimensions, please refer to drawing M23, M24, and M25 in the packaging section.
2. Pins ( 8 and 60 ) must be grounded for proper operation of the IDT7MB6146 module ( $64 \mathrm{~K} \times 18$ version). Pins 7 and 59 become A15L and A15R respectively.
3. Pins ( $7,8,59$, and 60 ) must be grounded for proper operation of the IDT7MB6156 module ( $32 \mathrm{~K} \times 18$ version).

## PIN DESCRIPTIONS

| Symbol | Description |
| :---: | :---: |
| Vcc | Power |
| GND | Ground |
| AoL-A 16L | Left Port Address |
| DoL-D17L | Left Port Data |
| Aor-A16R | Right Port Address |
| Dor-D17R | Right Port Data |
| $\mathrm{R} \bar{W}$ | Read/Write Control |
| $\overline{\overline{C S}}$ | Chip Select |
| DSL | Data Strobe for lower byte |
| $\overline{\text { DSU }}$ | Data Strobe for upper byte |
| $\overline{\mathrm{OEL}}$ | Output Enable for lower byte |
| OEU | Output Enable for upper byte |
| $\overline{B S Y} \mathrm{~L}$ or L/ $\overline{\mathrm{R}} \mathrm{N}$ | Left Busy Output for Stand Alone or Master Mode. Left or Right Port Select Input for Slave Mode |
| $\overline{\text { BSYR}}$ or SELIN | Right Busy Output for Stand Alone or Master Mode. RAM Array Select Input for Slave Mode |
|  | Left or Right Port Select Output on Master to be connected to L/Rin Input on one or more slaves when width expansion is required |
| SELOUT | RAM Array Select Output on Master to be connected to SELIN Input on one or more slaves when width expansion is required |
| M/ $\bar{S}$ | Master/Slave signal for cascading master with one or more slaves |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | mA |

NOTE:
2701 to 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{VIH}^{(1)}$ | Input High Voltage | 2.2 | - | 6.0 | V |
| $\mathrm{VII}^{(1)}$ | Input Low Voltage | -0.5 | - | 0.8 | V |

NOTE:
2700 को 03

1. $\mathrm{V}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING <br> TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS ( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, T \mathrm{~A}=0^{\circ} \mathrm{C} \mathrm{TO}+70^{\circ} \mathrm{C}$ )

| Symbol | Description | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \||니| | Input Leakage Current | Vcc = Max., VIN = GND to Vcc | - | 15 | $\mu \mathrm{A}$ |
| \|liol | Output Leakage Current | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{CS}=\mathrm{VIH}, \mathrm{VIN}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 15 | $\mu \mathrm{A}$ |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOH}=-15 \mathrm{~mA}$ | 2.4 | - | V |
| Vol | Output Low Voltage | $\mathrm{VCC}=$ Min., $\mathrm{lOL}=32 \mathrm{~mA}$ | - | 0.4 | V |
| Icc | Dynamic Operating Current | $\begin{aligned} & V C C=\text { Max., } \overline{C S} \leq V_{I L} \\ & f=\text { fMAX, Outputs Open } \end{aligned}$ | - | 520 | mA |
| ISB | Standby Supply Current (TTL) | $\begin{aligned} & \text { VcC = Max., } \overline{\mathrm{CS}} \geq V_{I H} \\ & \mathrm{f}=\mathrm{fMAX}, \text { Outputs Open } \end{aligned}$ | - | 170 | mA |

2701 tbl 05

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |  |
| :--- | :---: | :---: |
| Input Rise/Fall Times | 10 ns |  |
| Input Timing Reference Levels | 1.5 V |  |
| Output Reference Levels | .1 .5 V |  |
| Output Load | See Figures 1, 2 \& 3 |  |
| $2701 \pm 106$ |  |  |



Figure 1. Output Load


Flgure 2. Output Load (for totre and tozz)

## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | IDT7MB6136S40 IDT7MB6146S40 IDT7MB6156S40 |  | IDT7MB6136S45 IDT7MB6146S45 IDT7MB6156S45 |  | IDT7MB6136S55 IDT7MB6146S55 IDT7MB6156S55 |  | IDT7MB6136S70 IDT7MB6146S70 IDT7MB6156S70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． |  |
| No Contention Read |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 40 | － | 45 | － | 55 | － | 70 | － | ns |
| tAA | Address Access Time | － | 40 | － | 45 | － | 55 | － | 70 | ns |
| tacs | Chip Select Access Time | － | 40 | － | 45 | － | 55 | － | 70 | ns |
| toe | Output Enable to Data Valid | － | 31 | － | 33 | － | 36 | － | 41 | ns |
| tor | Output Hold from Address Change | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| tolz ${ }^{(1)}$ | OE to Output to Low Z | 11 | － | 11 | － | 11 | － | 11 | － | ns |
| tohz ${ }^{\text {（1）}}$ | $\overline{\mathrm{OE}}$ to Output to High Z | － | 9 | － | 9 | － | 9 | － | 9 | ns |
| No Contention Write |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 40 | － | 45 | － | 55 | － | 70 | － | ns |
| tAW | Address Valid to End of Write | 35 | － | 40 | － | 50 | － | 65 | － | ns |
| tcw | $\overline{\mathrm{CS}}$ to End of Write | 35 | － | 40 | － | 50 | － | 65 | － | ns |
| tas | Address Set Up Time | 0 | － | 0 | － | 0 | － | 0 | － | ns |
| tCDS | $\overline{\mathrm{CS}}$ to Data Strobe | 15 | － | 15 | － | 15 | － | 15 | － | ns |
| tDS | Data Strobe Width | 19 | － | 22 | － | 26 | － | 33 | － | ns |
| tWR | Write Recovery Time | 2 | － | 2 | － | 2 | － | 2 | － | ns |
| tDW | Data Valid to End of Write | 19 | － | 21 | － | 24 | － | 29 | － | ns |
| tDH | Data Hold from End of Write | 2 | － | 2 | － | 2 | － | 2 | － | ns |
| Contention Read |  |  |  |  |  |  |  |  |  |  |
| tcB | $\overline{C S}$ to BUSY | － | 12 | － | 12 | － | 12 | － | 12 | ns |
| tBD | $\overline{\text { BUSY }}$ Negate to Data Valid | － | 40 | － | 45 | － | 55 | － | 55 | ns |
| Contention Write |  |  |  |  |  |  |  |  |  |  |
| tCB | $\overline{\mathrm{CS}}$ to BUSY | － | 12 | － | 12 | － | 12 | － | 12 | ns |
| tBDS | $\overline{\text { BUSY }}$ Negate to Data Strobe | 7 | － | 7 | － | 7 | － | 7 | － | ns |
| Slave Timing |  |  |  |  |  |  |  |  |  |  |
| tLR | $\overline{\text { CS }}$ to L／̄ROuT | 二 | 11 | － | 11 | 二 | 11 | － | 11 | ns |
| tSEL | $\overline{\mathrm{CS}}$ to SELOUT | － | 14 | 二 | 14 | － | 14 | － | 14 | ns |
| tAPS | Arbitration Prioity Set－Up Time | 5 | － | 5 | － | 5 | 二 | 5 | 一 | ns |

NOTE：
1．This parameter is guaranteed by design，but not tested．

## timing waveform of read cycle ${ }^{(1)}$



TIMING WAVEFORM OF READ CYCLE ( $\overline{\mathrm{CS}}$ ARBITRATION)

## $\overline{\text { CSL }}$ Valid First:



NOTES:

1. $\mathrm{R} \overline{\mathrm{W}}=\mathrm{V}_{1 H}$ for all address transitions.
2. Transitions is measured $\pm 200 \mathrm{mV}$ from steady state with 5 pF load (including scope and jig).
3. This parameter is garanteed by design, but not tested.
4. taps is only necessary to guarantee left side access (in this example). Within this set-uptime, one side or the other will gain access, but neither will have priority.

TIMING WAVEFORM OF WRITE CYCLE ( $\overline{\text { DS }}$ CONTROLLED) ${ }^{(1)}$


TIMING WAVEFORM OF WRITE CYCLE ( $\overline{\mathrm{CS}}$ CONTROLLED) ${ }^{(1)}$


NOTE:

1. $R \bar{W}=V_{I H}$ for all address transitions.

## TIMING WAVEFORM OF CONTENTION WRITE CYCLE

## CSR Valid First:



## TIMING WAVEFORM OF SLAVE ${ }^{(2)}$



NOTES:

1. taps is only necessary to guarantee right side access (in this example). Within this set-up time, one side or the other will gain access, but neither will have priority.
2. $\overline{\mathrm{CS}}$ inputs to the Slave are ingnored when configured as a Slave. This allows the Master to control port selection of the Slave with the URIOut and SELOUT signals.

## ORDERING INFORMATION



2701 dw 11

Integrated Device Technology, Inc.

## $16 \mathrm{~K} \times 32$ <br> CMOS DUAL-PORT STATIC RAM MODULE

## FEATURES

- High density 512K CMOS dual-port RAM modules
- Fast access times
-commercial: $40,45,55,65,80 \mathrm{~ns}$
—military: 45, 55, 65, 80, 100 ns
- Fully asynchronous read/write operation from either port
- Easy to expand data bus width to 64 bits or more using the Master/Slave function
- Separate byte read/write signals for byte control
- On-chip port arbitration logic
- INT flag for port-to-port communication
- Full on-chip hardware support of semaphore signaling between ports
- Surface mounted fine pitch ( 25 mil) LCC packages allow through-hole module to fit into 121 pin PGA footprint
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs/outputs directly TTL compatible


## DESCRIPTION

The IDT7M1002 is a $16 \mathrm{~K} \times 32$ high speed CMOS Dual-Port static RAM Module constructed on a co-fired ceramic substrate using four $16 \mathrm{~K} \times 8$ (IDT7006) Dual-Port static RAMs in surface-mounted LCC packages. The IDT7M1002 module is designed to be used as stand-alone 512K dual-port RAM or as a combination Master/Slave dual-port RAM for 64-bit or more word width systems. Using the IDT Master/Slave approach in such system applications results in full-speed, error-free operation without the need for additional discreet logic.

The module provides two independent ports with separate control, address, and I/O pins that permit independent and asynchronous access for reads or writes to any location in memory. System performance is enhanced by facilitating port-to-port communication via additional control signals $\overline{\text { SEM }}$ \& TNT.

The IDT7M1002 module is packaged in a ceramic 121 pin PGA (Pin Grid Array)1.3 inchs square . Maximum access times as fast as 40 ns are available over the commercial temperature range and 45 ns over the military temperature range.

All IDT military modules are constructed with semiconductor components manufactured in compliance with the latest revision of MIL-STD-883, Class B making them ideally suited to applications demanding the highest level of performance and reliability.

PIN CONFIGURATION ${ }^{(1)}$

|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | L_I/O(24) | L_I/O(26) | L-1/O(28) | L_//O(30) | L_CS | L_OE | L_RWW ${ }^{\text {( }}$ ) | R_OE | R_CS | R_10(30) | R_10(28) | R_10(26) | R_10(24) |
| B | LII/O(23) | L_I/O(25) | L_VO(27) | L_I/O(29) | L_IO(31) | L_A $(0)$ | L_RW ${ }^{\text {(4) }}$ | R_A(0) | R_VO(31) | R_/O(29) | R_VO(27) | R VOO(25) | R_10(23) |
| C | L. $1 / 0$ (21) | L1/O(22) | Vcc | L_A ${ }^{\text {(3) }}$ | L_A 2 ) | LA(1) | GND | R_A(1) | R. A(2) | R_A ${ }^{\text {(3) }}$ | GND | R_LO(22) | R_LO(21) |
| D | LIIO(19) | LI/O(20) | L_A 4 ) | GND | $\begin{gathered} \text { PGA } \\ \text { TOP VIEW } \end{gathered}$ |  |  |  |  |  | R_A(4) | R_LO(20) | R VO(19) |
| E | LV/(17) | LIV(18) | L_A(5) |  |  |  |  |  |  |  | R_A(5) | R_LO(18) | R VO(17) |
| F | L_SEM | L_I/O(16) | L_A(6) |  |  |  |  |  |  |  | B. A 6 ) | R_10(16) | R_SEM |
| G | L_- $\overline{\text { BUSY }}$ | L_INT | GND |  |  |  |  |  |  |  | GND | R_INT | R_BUSY |
|  | L_RW(1) | L_RW(2) | L_A ${ }^{\text {(7) }}$ |  |  |  |  |  |  |  | R_A ${ }^{\text {(7) }}$ | R_R $\bar{W} \bar{W}^{(2)}$ | R_R $\bar{W}^{(1)}$ |
| H | L_V/O(15) | L_V/O(14) | L_A $(8)$ |  |  |  |  |  |  |  | R_A 8 ) | R_10(14) | R_W(15) |
| J | L_VO(13) | L_VO(12) | L_A 9 ) |  |  |  |  |  |  |  | R_A ${ }^{\text {(9) }}$ | R VO(12) | R_VO(14) |
|  | L_IVO(11) | M $\bar{S}$ | GND | L_A ${ }^{\text {(10) }}$ | L_A(11) | L_A(12) | GND | R_A(12) | R_A(11) | R_A(10) | VCC | GND | R_LO(13) |
| K | L_IOO(10) | L_VO(8) | L_/V(6) | L.10(4) | L_IV(2) | L_A(13) | R_RWW (4) | R_A(13) | R_1O(2) | R_lO(4) | R_VO(6) | R_VO(8) | R_LO(10) |
| L | L_VO(9) | L_I/O(7) | L_/V(5) | L_/O(3) | L_IO(1) | L_VO(0) | R_RW ${ }^{(3)}$ | R_I/O(0) | R_1/O(1) | R_VO(3) | R_IV(5) | R_VO(7) | R_VO(9) |

NOTE:

1. For module dimensions, please refer to drawing M33 in the packaging section.

## FUNCTIONAL BLOCK DIAGRAM



PIN NAMES

| Left Port | Right Port | Description |
| :---: | :---: | :---: |
| L_A (0-13) | R_A (0-13) | Address Inputs |
| L_I/O (0-31) | R_I/O (0-13) | Data Inputs/Outputs |
| L_R $\bar{W}(1-4)$ | R_R/ $\bar{W}(1-4)$ | Read/Write Enables |
| L_CS | R_CS | Chip Select |
| L_OE | R_OE | Output Enable |
| L_BUSY | R BUSY | Busy Flag |
| L_INT | R_INT | Interrupt Flag |
| L_SEM | R_SEM | Semaphore Control |
| M/S |  | Master/Slave Control |
| VCC |  | Power |
| GND |  | Ground |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerical | Military | Unit |
| :---: | :---: | :---: | :---: | :---: |
| VTERM | Terminal Voltage with Respect to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating Temperature | $010+70$ | $-5510+125$ | C |
| TBIAS | Temperature Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| Tstg | Storage Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| TOUT | DC Output Current | 50 | 50 | mA |

NOTE:
2795 tb 02
Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | VCC |
| :--- | :--- | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED DC

 OPERATING CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. VIL $\geq-3.0 \mathrm{~V}$ for pulse width less than 20 ns

## DC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7M1002 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |
| \| $\mathrm{LL} \mid$ | Input Leakage (Address \& Control) | $\begin{aligned} & \text { Vcc }=\text { Max. } \\ & \text { VIN }=\text { GND to Vcc } \end{aligned}$ | - | 40 | $\mu \mathrm{A}$ |
| \||LIU | Input Leakage (DATA) | $\begin{aligned} & V C C=\text { Max. } \\ & V I N=G N D \text { to } V c C \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| \|lıO| | Output Leakage <br> (DATA) | $\begin{aligned} & V C C=M a x . \\ & C S \geq V I H, V \text { OUT }=G N D \text { to } V C C \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} . \mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min}, \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |

2795 か 05

## DC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7M1002 (Commercial) |  | IDT7M1002 <br> (Military) |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| ICC2 | Dynamic Operating Current (Both Ports Active) | $\begin{aligned} & \text { VCC = Max., } \overline{\mathrm{CS}} \leq \text { VIL, } \overline{\text { SEM }}=\text { Don't Care } \\ & \text { Outputs Open, } \mathrm{f}=\mathrm{fMAX} \end{aligned}$ | - | 1360 | - | 1400 | mA |
| IsB | Standby Supply Current (Both Ports Inactive) | $V C C=M a x ., L_{-} \overline{C S}$ and $R_{-} \overline{C S} \geq V_{I H}$ Outputs Open, $\mathrm{f}=\mathrm{f}$ max | - | 280 | - | 340 | mA |
| ISB1 | Standby Suppy Current (One Port Inactive) | $\begin{aligned} & \text { VCC }=\text { Max., L_ } \overline{\mathrm{CS}} \text { or R_CS } \geq \mathrm{VIH} \\ & \text { Outputs Open, } \mathrm{f}=\mathrm{f} \text { MAX } \end{aligned}$ | - | 1000 | - | 1160 | mA |
| ISB2 | Full Standby Supply Current (Both Ports Inactive) | L_ $\overline{C S}$ and R_$\overline{C S} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{VIN}>\mathrm{Vcc}-0.2 \mathrm{~V}$ or $<0.2 \mathrm{~V}$ <br> L_ $\overline{S E M}$ and $R \quad \overline{S E M} \geq \mathrm{VCc}-0.2 \mathrm{~V}$ | - | 60 | - | 120 | mA |

CAPACITANCE ${ }^{(1)}\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Condition | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Cin (1) | Input Capacitance ( $\overline{\mathrm{CS}}, \overline{\mathrm{OE}}, \overline{\mathrm{SEM}}$, Address) | $\mathrm{ViN}=0 \mathrm{~V}$ | 40 | pF |
| CIN(2) | Input Capacitance ( $\mathrm{R} \overline{\mathrm{W}}, \overline{\mathrm{I}} \mathrm{O}, \overline{\mathrm{N}} \mathrm{N})$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 12 | pF |
| $\mathrm{ClN}(3)$ | Input Capacitance ( $\overline{B U S Y}, \mathrm{M} / \mathrm{S}$ ) | V IN $=0 \mathrm{~V}$ | 45 | pF |
| Cour | Output Capacitance $(I / O)$ | VOUT $=0 \mathrm{~V}$ | 12 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures $1 \& 2$ |

2795 tol 08

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{array}{\|c\|} \hline \text { 7M1002S40 } \\ \text { (Com'l Only } \\ \hline \end{array}$ |  | 7M1002S45 |  | 7M1002S55 |  | 7M1002S65 |  | 7M1002S80 |  | $\begin{array}{\|c} \text { 7M1002S100 } \\ \text { (MiI OnJv) } \\ \hline \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | - | ns |
| tAA | Address Access Time | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |
| tACS ${ }^{(2)}$ | Chip Select Access Time | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |
| toe | Output Enable Access Time | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tPU ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(7)}$ | Chip Deselect to Power Up Time | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | - | 50 | ns |
| tSop | Sem. Flag Update Puise ( $\overline{\mathrm{OE}}$ or $\overline{\mathrm{SEM}}$ ) | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | - | ns |
| tcw ${ }^{(2)}$ | Chip Select to End of Write | 35 | - | 40 | - | 45 | - | 50 | - | 55 | - | 60 | - | ns |
| taw | Address Valid to End of Write | 35 | - | 40 | - | 45 | - | 50 | - | 55 | - | 60 | - | ns |
| tas | Address Set-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 35 | - | 35 | - | 40 | - | 50 | - | 55 | - | 60 | - | ns |

(Continued on next page)

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} 7 M 1002 S 40 \\ \text { (Com'I Only) } \end{gathered}$ |  | 7M1002S45 |  | 7M1002S55 |  | 7M1002S65 |  | 7M1002S80 |  | $\begin{gathered} \text { 7M1002S100 } \\ \text { (Mil Only) } \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Write Cycle (continued) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| twr | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data Valid to End of Write | 25 | - | 25 | - | 30 | - | 40 | - | 45 | - | 50 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| twhz ${ }^{(1)}$ | Write Disable to Output in High Z | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tSWAD | SEM Flag Write to Read Time | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tSPS | SEM Flag Contention Window | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| Busy Cycle-Master Mode (3) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tBAA | BUSY Access Time to Address | - | 30 | - | 35 | - | 45 | - | 45 | - | 50 | - | 50 | ns |
| tBDA | BUSY Disable Time to Address | - | 30 | - | 30 | - | 40 | - | 40 | - | 45 | - | 45 | ns |
| tBAC | BUSY Access Time to Chip Select | - | 30 | - | 30 | - | 40 | - | 40 | - | 45 | - | 45 | ns |
| tBDC | BUSY Disable Time to Chip Deselect | - | 25 | - | 25 | - | 35 | - | 35 | - | 40 | - | 40 | ns |
| tWDD ${ }^{(5)}$ | Write Pulse to Data Delay | - | 60 | - | 70 | - | 80 | - | 85 | - | 90 | - | 100 | ns |
| tDDD | Write Data Valid to Read Data Delay | - | 40 | - | 50 | - | 60 | - | 70 | - | 75 | - | 85 | ns |
| taps ${ }^{(6)}$ | Arbitration Priority Set-Up Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tBDD | $\overline{\text { BUSY }}$ Disable to Valid Time | - | NOTE 9 | - | NOTE 9 | - | NOTE 9 | - | NOTE 9 | - | NOTE 9 | - | NOTE 9 | ns |
| Busy Cycle-Slave Mode (4) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tw ${ }^{\text {(7) }}$ | Write to BUSY Input | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tWH ${ }^{(8)}$ | Write Hold after BUSY | 25 | - | 25 | - | 25 | - | 25 | - | 25 | - | 25 | - | ns |
| tWDD ${ }^{(5)}$ | Write Pulse to Data Delay | - | 60 | - | 70 | - | 80 | - | 85 | - | 100 | - | 120 | ns |
| toDD ${ }^{(5)}$ | Write Data Valid to Read Data Valid | - | 45 | - | 50 | - | 60 | - | 70 | - | 85 | - | 105 | ns |
| Interrupt TIming |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tAS | Address Set-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twn | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tins | Interrupt Set Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | ns |
| tiNR | Interrupt Reset Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | ns |

NOTE:

1. This parameter is guaranteed by design but not tested.
2. To access RAM, $\overline{C S} \leq V_{I L}$ and $\overline{S E M} \geq V_{I H}$. To access semaphore, $\overline{C S} \geq V_{I H}$ and $\overline{S E M} \leq V_{I L}$.
3. When the module is being used in the Master Mode ( $M / \bar{S} \geq \mathrm{V} I \mathrm{H}$ ).
4. When the module is being used in the Slave Mode ( $M S \leq V_{I L}$ ).
5. Port-to-Port delay through the RAM cells from the writing port to the reading port.
6. To ensure that the earlier of the two ports wins.
7. To ensure that the write cycle is inhibited during contention.
8. To ensure that a write cycle is completed after contention.
9. $t B D D$ is a calculated parameter and is the greater of 0 , tWDD - IWP (actual), or tDDD - IWP (actual).

TIMING WAVEFORM OF READ CYCLE NO. 1, EITHER SIDE ${ }^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. 2, EITHER SIDE ${ }^{(1,3,5)}$


## NOTES:

1. $\mathrm{R} W$ W is high for Read Cycles
2. Device is continuously enabled $\overline{C S} \leq V$ IL. This waveform cannot be used for semaphore reads.
3. Addresses valid prior to or coincident with $\overline{C S}$ transition low.
4. $\overline{O E} \leq \mathrm{VIL}$
5. To access RAM, CS $\leq V_{I L}$ and $\overline{S E M} \geq V_{I H}$. To accesss semaphore, $\overline{C S} \geq V_{I H}$ and $\overline{S E M} \leq V_{I L}$.
6. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 (R/ $\bar{W}$ CONTROLLED TIMING) ${ }^{(1,2,4)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\operatorname{CS}}$ CONTROLLED TIMING) ${ }^{(1,2,4)}$


## NOTES:

1. $R \mathbb{W}$ must be high during all address transitions
2. A write occurs during the overlap (twp) of a low $\overline{C S}$ and a low R/W.
3. TWR is measured from the earlier of CS or RW (or SEM or RWW) going high to the end of write cycle.
4. During this period, the I/O pins are in the output state and input signals must be applied.
5. If the CS or SEM low transition occurs simultaneously with or after the $\mathrm{R} \bar{W}$ low transition, the outputs remain in the high impedance state.
6. Timing depends on which enable signal is asserted last.
7. Timing depends on which enable signal is de-asserted first.
8. If $\overline{O E}$ is low during a $R W$ controlled write cycle, the write pulse width must be the larger of twp or ( $\mathrm{WZ}+$ tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ 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 twp.

## TIMING WAVEFORM OF SEMAPHORE READ AFTER WRITE, EITHER SIDE ${ }^{(1)}$



NOTE:

1. $\overline{C S} \geq V_{\mathbb{H}}$ for the duration of the above timing (both write and read cycle).

## TIMING WAVEFORM OF SEMAPHORE CONTENTION ${ }^{(1,3,4)}$



2795 drw 08

## NOTES:

1. DOR = DOL $\leq V I L$, (L_ $\left.\overline{C S}=R_{\_} \overline{C S}\right) \geq V_{I H}$ Semaphore Flag is released from both sides (reads as ones from both sides) at cycle start.
2. " $A$ " may be either left or right port. " $B$ " is the opposite port from " $A$ ".
3. This parameter is measured from $R / W_{A}$ or SEMA going high to $R / W_{B}$ or SEMB going high.
4. If tSPS is violated, the semaphore will fall positively to one side or the other, but there is no guarantee which side will obtain the flag.

TIMING WAVEFORM OF READ WITH $\overline{B U S Y}(M / \overline{\mathbf{S}} \geq \text { VIH })^{(2)}$


NOTES:

1. To ensure that the earlier of the two ports wins.
2. $\left(\mathrm{L}, \overline{C S}=R \_\overline{C S}\right) \leq V_{I}$
3. $O E \leq V I L$ for the reading port.

TIMING WAVEFORM OF WRITE WITH PORT-TO-PORT DELAY (M/ $\overline{\mathbf{S}} \leq$ VIH $) ~(1,2)$


NOTES:

1. BUSY input equals High for the writing port.
2. $\left(L_{-} \overline{C S}=R_{-} \overline{C S}\right) \leq V_{I L}$

## TIMING WAVEFORM OF WRITE WITH $\overline{B U S Y}$ INPUT (M/ $\overline{\mathbf{S}} \leq$ VIL)



## TIMING WAVEFORM OF BUSY ARBITRATION ( $\overline{C S}$ CONTROLLED TIMING)



TIMING WAVEFORM OF BUSY ARBITRATION (CONTROLLED BY ADDRESS MATCH TIMING) ${ }^{(1)}$


NOTES:

1. All timing is the same for the left and right ports. Port " $A$ " may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. If taps is violated, the busy signal will be asserted on one side or another but there is no guarantee on which side busy will be asserted.

TIMING WAVEFORM OF INTERRUPT CYCLE ${ }^{(1)}$


NOTES:

1. All timing is the same for left and right ports. Port " $A$ " may be either the left or right port. Port " $B$ " is the port opposite from " $A$ ".
2. See Interrupt truth table.
3. Timing depends on which enable signal is asserted last.
4. Timing depends on which enable signal is de-asserted first.

## TRUTH TABLE I: Non-Contention Read/Write Control ${ }^{(1)}$

| Inputs |  |  |  | Outputs | Mode |
| :---: | :---: | :---: | :---: | :---: | :--- |
| CS | RWW | OE | SEM | KO | Description |
| H | X | X | H | High-Z | Deselected or Power Down |
| L | L | X | H | Data_In | Write |
| L | H | L | H | Data_OUT | Read |
| X | X | H | X | High-Z | Outputs Disabled |

NOTE:

1. The conditions for non-contention are $L \_A(0-13) \neq R \_A(0-13)$.

TRUTH TABLE II: Semaphore Read/Write Control

| Inputs ${ }^{(1)}$ |  |  |  | Outputs | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CS | RWW | OE | SEM | ए | Description |
| H | H | L | L | Data_OUT | Read Data in Semaphore Flag |
| H | - | X | L | Data_IN | Write Data_IN (0, 8, 16, 24) |
| L | X | X | L | - | Not Allowed |

NOTE:

1. _ـ_ denotes a LOW to HIGH waveform transition.

TABLE III: Interrupt Flag ${ }^{(1)}$

| Left Port |  |  |  |  | Right Port |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { RWW }}^{(1)}$ | CS | OE | A (0-13) | INT | $\overline{\mathrm{RW}}^{(1)}$ | CS | OE | A (0-13) | INT |  |
| L | L | X | 1FFF | X | X | X | X | X | $L^{(2)}$ | Set Right INT Flag |
| X | X | X | X | X | X | L | L | 1FFF | $\mathrm{H}^{(3)}$ | Reset Right INT Flag |
| X | X | X | X | $L^{(3)}$ | L | L | X | 1FFE | X | Set Left INT Flag |
| X | L | L | 1FFE | $\mathrm{H}^{(2)}$ | X | X | X | X | X | Reset Left INT Flag |

NOTE:

1. Assuming L_BUSY $=$ R_BUSY $\geq V_{I H}$.
2. If $L$ BUSY $\leq V I L$ then no change.
3. If R_BUSY $\leq$ VIL then no change.

TRUTH TABLE IV: Address BUSY Arbitration

| Inputs |  |  | Outputs ${ }^{(1)}$ |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| L_CS | R_CS | $\begin{aligned} & L_{-} A(0-13) \\ & R_{1} A(0-13) \\ & \hline \end{aligned}$ | L_BUSY | R_BUSY |  |
| X | X | No Match | H | H | Normal |
| H | X | Match | H | H | Normal |
| X | H | Match | H | H | Normal |
| L | L | Match | Note 2 | Note 2 | Write Inhibit ${ }^{(3)}$ |

## NOTES:

1. Pins L_BUSP and R_BUSP are both outputs when the part is configured as a master. Both are inputs when configured as a slave. BUSP outputs on the IDT7M1002 are push pull, not open drain outputs. On slaves the BUSY input internally inhibits writes.
2. "L" if the inputs to the opposite port were stable prior to the address and enable inputs of this port. "H" if the inputs to the opposite port became stable after the address and enable inputs of this port. If the primacy of stable inputs cannot be resolved, either L_BUSP $\leq$ VIL or R_BUSP $\leq$ VIL will result in L_BUSY and R_BUSY outputs cannot be low simultaneously.
3. Writes to the left port are internallly ignored when L_BUSY outputs are driving low regardless of the actual logic levels on the pin. Writes to the right port are intemally ignored when R_BUSY outputs are driving low regardless of the actual logic levels on the pin.

TABLE V: Example of Semaphore Procurement Sequence ${ }^{(1)}$

| Functions | I/O <br> Left | I/O <br> Right | Status |
| :--- | :---: | :---: | :--- |
| No Action | 1 | 1 | Semaphore is 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 is free |
| Right Port Writes "0" to Semaphore | 1 | 0 | Right port has semaphore token |
| Right Port Writes "1" to Semaphore | 1 | 1 | Semaphore is free |
| Left Port Writes "0" to Semaphore | 0 | 1 | Left port has semaphore token |
| Left Port Writes "1" to Semaphore | 1 | 1 | Semaphore is free |

## NOTE:

2795 tol 15

1. This table denotes a hypothetical sequence of events for only one of the eight semaphores available on the IDT7M1002.

## FUNCTIONAL DESCRIPTION

The IDT7M1002 provides two ports with separate control, address and I/Opins that permit independent access for reads or writes to any location in memory. The IDT7M1002 has an automatic power down feature controlled by $\overline{\mathrm{CS}}$. The $\overline{\mathrm{CS}}$ controls on-chip power down circuitry that permits the respective port to go into a standby mode when not selected ( $\overline{\mathrm{CS}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control $(\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. Non-contention READ/WRITE conditions are illustrated in the Truth Tables.

## INTERRUPTS

The interrupt flag (INT) permits communication between ports or systems. If the user chooses to use the interrupt function, a memory location (mail box or message center) is assigned to each port. The left port interrupt flag ( $\overline{\operatorname{NTL}})$ is set when the right port writes to memory location 1FFE (HEX). The left port clears the interrupt by reading address location 1FFE. Likewise, the right port interrupt flag (INTR) is set when the left port writes to memory location 1FFF (HEX) and to clear the interrupt flag (INTR), the right port must read the memory location 1FFF. The message ( 16 bits) at 1FFE or 1 FFF is user-defined. If the interrupt function is not used, address locations 1FFE and 1FFF are not used as mail boxes, but as part of the random access memory. Refer to Table 1 for the interrupt operation. These interrupts are set by either L_R/W1 or $R \_R / \bar{W} 1$ All other $R / \bar{W}$ controls have no affect on the interrupt function.

## BUSY LOGIC

The arbitration logic will resolve an address match or a chip select match down to 5 ns minimum and determine which port has access. In all cases, an active $\overline{B U S Y}$ flag will be set for the delayed port.

The BUSY flags are provided for the situation when both ports simultaneously access the same memory location. When this situation occurs, on-chip arbitration logic will determine which port has access and sets the delayed port's $\overline{\mathrm{BUSY}}$


64-Blt Master/Slave Dual-Port Memory Systems
flag. $\overline{B U S Y}$ is set at speeds that permit the processor to hold the operation and its respective address and data. It is important to note that the operation is invalid for the port that has $\overline{B U S Y}$ set LOW. The delayed port will have access when $\overline{B U S Y}$ goes inactive.

Contention occurs when both left and right ports are active and both addresses match. When this situation occurs, the on-chip arbitration logic determines access. Two modes of arbitration are provided: (1) if the addresses match and are valid before $\overline{C S}$, on-chip control logic arbitrates between $\overline{C S} L$ and $\overline{\mathrm{CS}}$ R for access; or (2) if the $\overline{\mathrm{CS}}$ s are low before an address match, on-chip control logic arbitrates between the left and right addresses for access (refer to Table II). In either mode of arbitration, the delayed port's $\overline{B U S Y}$ flag is set and will reset when the port granted access completes its operation.

## DATA BUS WIDTH EXPANSION, MASTER/ SLAVE DESCRIPTION

Expanding the data bus width to sixtyfour-or-more-bits in a dual-port RAM system implies that several modules will be active at the same time. If each module includes a hardware arbitrator, and the addresses for each module arrive at the same time, it is possible that one will activate its $\overline{B U S Y} L$ while another activates its BUSYR signal. Both sides are now busy and the CPUs will wait indefinitely for their port to become free.

To avoid this "Busy Lock-Out" problem, IDT had developed a MASTER/SLAVE approach where only one hardware arbitrator, in the MASTER, is used. The SLAVE has BUSY inputs which allow an interface to the MASTER with no external components and with a speed advantage over other systems.

When expanding dual-port RAMs in width, the writing of the SLAVE modules must be delayed, until after the BUSYinput has settled. Otherwise, the SLAVE module may begin a write cycle during a contention situation. Conversely, the write pulse must extend a hold time past $\overline{B U S Y}$ to ensure that a write takes place after the contention is resolved. This timing is inherent in all dual-port memory systems where more than one module is active at the same time.

The write pulse to the SLAVE should be delayed by the maximum arbitration time of the MASTER. If, then, a contention occurs, the write to the SLAVE will be inhibited due to $\overline{B U S Y}$ from the MASTER.

## SEMAPHORES

The IDT7M1002 is an extremely fast dual-port $16 \mathrm{~K} \times 32$ CMOS Static RAM Module with an additional 8 address locations dedicated to binary semaphore flags. These flags allow either processor on the left or right side of the dual-port RAM module to claim a privilege over the other processor for functions defined by the system designer's software. As an example, the semaphore can be used by one processor to inhibit the other from accessing a portion of the dual-port RAM or any other shared resource.

The dual-port RAM module features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Both ports are identical in function to standard CMOS static RAM and can be read from,
or written to, at the same time with the only possible conflict arising from the simultaneous writing of, or a simultaneous READ/WRITE of, a non-semaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the nonsemaphores portion of the dual-port RAM. These devices have an automatic power-down feature controlled by $\overline{\mathrm{CS}}$ and $\overline{\text { SEM }}$. The $\overline{\mathrm{CS}}$ and $\overline{\text { SEM }}$ pins control on-chip power down circuitry that permits the respective port to go into standby mode when not selected. This is the condition which is shown in the Truth Table where $\overline{\mathrm{CS}}$ and $\overline{\mathrm{SEM}}$ are both high.

Systems which can best use the IDT7M1002 contain multiple processors or controllers and are typically very highspeed systems which are software controlled or software intensive. These systems can benefit from a performance increase offered by the IDT7M1002's hardware semaphores, which provide a lockout mechanism without requiring complex programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be allocated in varying configurations. The IDT7M1002 does not use its semaphore flags to control any resources through hardware, thus allowing the system designer total flexibility in system architecture.

An advantage of using semaphores rather than the more common methods of hardware arbitration is that wait states are never incurred in either processor. This can prove to be a major advantage in very high-speed systems.

## HOW THE SEMAPHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independent of the dual-port RAM. These latches can be used to pass a flag, or token, from one port to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment method called "Token Passing Allocation." In this method, the state of a semaphore latch is used as a token indicating that a shared resource is in use. If the left processorwants to use this resource, it requests the token by setting the latch. This processor then verifies its success in setting the latch by reading it. If it was successful, it proceeds to assume control over the shared resource. If it was not successful in setting the latch, it determines that the right side processor had set the latch first, has the token and is using the shared resource. The left processor can then either repeatedly request that semaphore's status or remove its request for that semaphore to perform another task and occasionally attempt again to gain control of the token via the set and test sequence. Once the right side has relinquished the token, the left side should succeed in gaining control.

The semaphore flags are active low. A token is requested by writing a zero into a semaphore latch and is released when the same side writes a one to that latch.

There are 4 semaphores at each of 8 addresses. Write to the semaphores at $1 / O 0,1 / O 8,1 / O 16$, and $1 / O 24$. Read the semaphores at I/O0-7, I/O8-15, I/O16-23, and I/O24-31.

The eight semaphore flags reside within the IDT7M1002 in a separate memory space from the dual-port RAM. This address space is accessed by placing a low input on the $\overline{S E M}$
pin (which acts as a chip select for the semaphore flags) and using the other control pins (Address, $\overline{O E}$ and R/W) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through address pins A0-A2. When accessing the semaphores, none of the other address pins has any effect.

When writing to a semaphore, only data pin I/Oo is used. If a low level is written into an unused semaphore location, that flag will be set to a zero on that side and a one on the other (see Table V). That semaphore can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be set to a one forboth sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. (A thorough discussion on the use of this feature follows shortly.) A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.

When a semaphore flag is read, its value is spread into all data bits so that a flag that is a one reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE})}$ signals go active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal ( $\overline{\mathrm{SEM}}$ or $\overline{\mathrm{OE}}$ ) to go inactive or the output will never change.

A sequence of WRITE/READ must be used by the semaphore in order to guarantee that no system level contention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as a one, a fact which the processor will verify by the subsequent read (see Table III). As an example, assume a processor writes a zero to the left port at a free semaphore location. On a subsequent read, the processor will verify that it has written successfully to that location and will assume control over the resource in question. Meanwhile, if a processor on the right side attempts to write a zero to the same semaphore flag it will fail, as will be verified by the fact that a one will be read from that semaphore on the right side during a subsequent read. Had a sequence of READ/WRITE been used instead, system contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed by either repeated reads or by writing a one into the same location. The reason for this is easily understood by looking at the simple logic diagram of the semaphore flag in Figure 1. Two semaphore request latches feed into a semaphore flag. Whichever latch is first to present a zero to the semaphore flag will force its side of the semaphore flag low and the other side high. This condition will continue until a one
is written to the same semaphore request latch. Should the other side's semaphore request latch have been written to a zero in the meantime, the semaphore flag will flip over to the other side as soon as a one is written into the first side's request latch. The second side's flag will now stay low until its semaphore request latch is written to a one. From this it is easy to understand that, if a semaphore is requested and the processor which requested it no longer needs the resource, the entire system can hang up until a one is written into that semaphore request latch.

The critical case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is specially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side is earlier than the other in making the request , the first side to make the request will receive the token. If both requests arrive at the same time, the assignment will be arbitrarily made to one port or the other.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, if semaphores are misused or misinterpreted, a software error can easily happen. Code integrity is of the utmost importance when semaphores are used instead of slower, more restrictive hardware intensive schemes.

Initialization of the semaphores is not automatic and must be handled via the initialization program at power-up. Since any semaphore request flag which contains a zero must be reset to a one, all semaphores on both sides should have a one written into them at initialization from both sides to assure that they will be free when needed.

## USING SEMAPHORES—Some Examples

Perhaps the simplest application of semaphors is their application as rescurce markers for the IDT7M1002's DualPort RAM Module. Say that $8 \mathrm{~K} \times 16$ of RAM was to be divided into two $4 \mathrm{~K} \times 16$ blocks which were to be dedicated at any one time to servicing either the left or right port. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of memory.

To take a resource, in this example the lower 4 K of dual-port RAM, the processor on the left port could write and then read a zero into Semaphore 0. If this task were successfully completed (a zero was read back rather than a one), the left processor would assume control of the lower 4 K . Meanwhile, the right processor would attempt to perform the same function. Since this processor was attempting to gain control of the resource after the left processor it would read back a one in response to the zero it had attempted to write into Semaphore 0 . At this point, the software could choose to try and gain control of the second 4 K section by writing, then reading a zero into Semaphore 1. If it succeeded in gaining control, it would lock out the left side.

Once the left side was finished with its task, it would write a one to Semaphore 0 and may then try to gain access to Semaphore 1. If Semaphore 1 was still occupied by the right side, the left side could undo its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1. If the right processor performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 4 K blocks of dual-port RAM with each other.


Figure 1. IDT7M1002 Semaphore Logic

The blocks do not have to be any particular size and can even be variable, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts. Semaphores can even be assigned different meanings on different sides rather than being given a common meaning as was shown in the example above.

Semaphores are a useful form of arbitration in systems like disk interfaces where the CPU must be locked out of a section of memory during a transfer and the I/O device cannot tolerate any wait states. With the use of semaphores, once the two devices had determined which memory area was "off limits" to the CPU, both the CPU and the I/O devices could access their assigned portions of memory continuously without any wait states.

Semaphores are also useful in applications where no memory "WAIT" state is available on one or both sides. Once a semaphore handshake has been performed, both processors can access their assigned RAM segments at full speed.

Another application is in the area of complex data structures. In this case, block arbitration is very important. For this applicationone processor may be responsible for building and updating a data structure. The otherprocessor then reads and interprets that data structure. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the two different processors. The building processor arbitrates for the block, locks it and then is able to go in and update the data structure. When the update is completed, the data structure block is released. This allows the interpreting processor to come back and read the complete data structure, thereby guaranteeing a consistent data structure.

## ORDERING INFORMATION



## FEATURES:

- High-density $64 \mathrm{~K} / 32 \mathrm{~K}$-bit CMOS FourPort RAM Modules
- $8 \mathrm{~K} \times 8$ (IDT7MB1041) or $4 \mathrm{~K} \times 8$ (IDT7MB1042) option
- Fast access times
- maximum: $35,40,45,55,65,80,100 \mathrm{~ns}$
- Fully asynchronous operation from any four ports: P1, P2, P3, P4
- Versatile control for write-inhibit: separate $\overline{B U S Y}$ input to control write-inhibit for each of the other 3 ports
- Battery backup operation-2V data retention (low power version only)
- Surface mounted fine pitch (25 mil) PQFP (Plastic Quad FlatPack) components on a FR-4 120-pin QIP (Quad Inline Package) substrate
- TTL compatible I/Os
- Single 5V ( $\pm 10 \%$ ) power supply
- Multiple ground pins provide maximum noise immunity
- Input/outputs directly TTL compatible


## DESCRIPTION:

The IDT7MB1041/1042 are 64/32K-bit high-speed CMOS FourPort RAM modules constructed on a multi-layer FR-4 substrate using 4 IDT7052 ( $2 \mathrm{~K} \times 8$ ) FourPort RAMs or a depopulated version with2 IDT7052 FourPort RAMs. The IDT7MB1041/ 1042 modules are designed to be used as stand-alone 64 K 32 K -bit fourport RAM. Using the IDT FourPort Module in such system applications as multiprocessor or real time data acquisition result in dramatically increased system performance by providing four independent ports with separate control, address, and I/O pins that permit independent and asynchronous access for reads or writes to any location in memory. Upper and lower byte module signals for each port provide the system additional memory control capability.

The IDT7MB1041/1042 modules are packaged in a 120-pin FR-4 QIP (Quad In-line Package) and have maximum access times of 35 ns over the commercial temperature range.

## PIN NAMES ${ }^{(1,2)}$

| P1-4A0-12 | Ports 1-4, Address Inputs |
| :--- | :--- |
| P1-4l/O0-7 | Port 1-4, Data Inputs/Outputs |
| R $\bar{W}$ P1 | ReadWrite - Port 1 |
| R $\bar{W}$ P2 | Read/Write - Port 2 |
| R $\bar{W}$ P3 | Read/Write - Port 3 |
| R $\bar{W}$ P4 | Read/Write - Port 4 |
| $\overline{\text { CS P1 }}$ | Chip Select - Port 1 |
| $\overline{\text { CS P2 }}$ | Chip Select - Port 2 |
| $\overline{\text { CS P3 }}$ | Chip Select - Port 3 |
| $\overline{\text { CS P4 }}$ | Chip Select - Port 4 |
| $\overline{\text { OE P1 }}$ | Output Enable - Port 1 |
| $\overline{\text { OE P2 }}$ | Output Enable - Port 2 |
| $\overline{\text { OE P3 }}$ | Output Enable - Port 3 |
| $\overline{\text { OE P4 }}$ | Output Enable - Port 4 |
| $\overline{B U S Y}$ P1 | Port Busy Write Disable - Port 1 |
| $\overline{B U S Y}$ P2 | Port Busy Write Disable - Port 2 |
| $\overline{\text { BUSY P3 }}$ | Port Busy Write Disable - Port 3 |
| $\overline{\text { BUSY P4 }}$ | Port Busy Write Disable - Port 4 |
| VcC | Power |
| GND | Ground |

## PIN CONFIGURATION

Note: Pin configurations for these modules are currently not available, please consult the factory.

## Notes:

1. For valid readoperation, no other part may write to the same address location at the same time.
2. For the IDT7MB1042 ( $4 \mathrm{~K} \times 8$ ) version, P1A12, P2A12, P3A12, P4A12 must be connected to GND for proper operation of the module.

CEMOS and FourPort are trademarks of Integrated Device Technology, inc.

FUNCTIONAL BLOCK DIAGRAM


## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :--- | :---: |
| VTERM | Terminal <br> Voltage with <br> Respect to GND | -0.5 to $\pm 7.0$ | -0.5 to $\pm 7.0$ | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2802 tbl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

DC ELECTRICAL CHARACTERISTICS
(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :--- | :--- | :---: | :---: | :---: |
| $\|\mathrm{ILI}\|$ | Input Leakage <br> Current | $\mathrm{VCC}=5.5 \mathrm{~V}$, <br> $\mathrm{VIN}=0 \mathrm{~V}$ to VCC | - | 40 | $\mu \mathrm{~A}$ |
| \|loI| | Output <br> Leakage <br> Current | $\overline{\mathrm{CS}}=\mathrm{VIH}$, <br> VOUT $=0 \mathrm{~V}$ to VCC | - | 40 | $\mu \mathrm{~A}$ |
| VOL | Output Low <br> Voltage | $\mathrm{IOL}=4 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High <br> Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

03

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL. | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2802 tbl 04

1. VIL. (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{F}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Test <br> Conditions |  | IDT7MB1041/1042 |  |
| :--- | :--- | :--- | :--- | :---: | :---: |
| Max. | Max. | Unit |  |  |  |
| CIN1 | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 12 | 12 | pF |
| CIN2 | Input Capacitance <br> (Data, Address, <br> All Other Controls) | $\mathrm{VIN}=\mathrm{OV}$ | 50 | 25 | pF |
| Cout | Output Capacitance <br> (Data) | VouT $=0 \mathrm{~V}$ | 45 | 25 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

|  |  |  | IDT7MB1041 |  | IDT7MB1042 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Test Conditions | Min. | Max. | Min. | Max. |  |
| Iccl | Operating Power Supply Current (All Ports Active) | $\overline{\mathrm{CS}} \geq \mathrm{VIL}$, Outputs Open $\mathrm{f}=0$ | - | 550 | - | 400 | mA |
| ICC2 | Dynamic Operating Current | $\overline{\mathrm{CS}} \geq$ VIL, Outputs Open $f=f \text { MAX }$ | - | 600 | - | 430 | mA |
| ISB | Standby current (All Ports - TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{VIH} \text {, Outputs Open } \\ & \mathrm{f}=\mathrm{fMAX} \end{aligned}$ | - | 340 | - | 170 | mA |
| ISB1 | Full Standby Current (All Ports - All CMOS Level Inputs) | All Ports $\overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ <br> $\mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or <br> $\mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0$ | - | 20 | - | 10 | mA |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 2. Output Load (for tcLZ, tCHZ, tolz, tohz, tWHz, tow)
*Including scope and jig.
2802 drw 02

## AC ELECTRICAL CHARACTERISTICS ${ }^{(1)}$

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )


## Read Cycle

| trc | Read Cycle Time | 35 | - | 40 | - | 45* | - | 55 | - | 65 | - | 80 | - | 100 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LA | Address Access Time | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |
| tacs | Chip Select Access Time | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |
| toe | Output Enable Access Time | - | 25 | - | 25 | - | 30 | - | 40 | - | 50 | - | 65 | - | 85 | ns |
| $\mathrm{tOH}^{2}$ | Output Hold From Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tCLz ${ }^{(2)}$ | Chip Select to Output in Low Z | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tol. ${ }^{(2)}$ | Output Enable to Output in Low Z | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tCHz ${ }^{(2)}$ | Chip Deselect to Output in High Z | 20 | - | 20 | - | 25 | - | 25 | - | 25 | - | 30 | - | 30 | - | ns |
| tohz ${ }^{(2)}$ | Output Disable to Output in High Z | 20 | - | 20 | - | 25 | - | 25 | - | 25 | - | 30 | - | 30 | - | ns |
| tpu ${ }^{(2)}$ | Chip Enable to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(2)}$ | Chip Disable to Power Down Time | - | 35 | - | 55 |  | 55 | - | 50 | - | 70 | - | 70 | - | 70 | ns |

## NOTES:

2802 tbl 09

1. Transition is measured by $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is quaranteed by design but not tested.

## AC ELECTRICAL CHARACTERISTICS ${ }^{(1)}$

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7MB1041S35 7MB1042S35 Min. Max. |  | $\begin{gathered} 041540 \\ 042540 \\ \text { Max. } \end{gathered}$ | 7MB1041S45 7MB1042S45 <br> Min. Max. | 7MB1041555 7MB1042S55 Min. Max. | 7M1041565 <br> 7MB1042S65 <br> Min. Max. | 7MB1041580 <br> 7MB1042S80 <br> Min. Max. | 7MB1041S100 7MB1042S100 <br> Min. Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 35 - | 40 | - | 45 | 55 - | 65 | 80 | 100 | ns |
| tcw | Chip Select to End of Write | $30-$ | 35 | - | 35 | 45 - | 55 | 70 - | 90 | ns |
| taw | Address Valid to End of Write | 30 - | 35 | - | 35 | 45 - | 55 - | 70 - | 90 | ns |
| tas | Address Set-up to $\overline{\mathrm{CS}}$ Time | 0 - | 0 | - | 0 - | 0 - | 0 - | 0 - | 0 - | ns |
| tAS2 | Address Set-up to R $\bar{W}$ Time | 5 - | 5 | - | 5 - | 5 - | 5 - | 5 - | 5 - | ns |
| twp | Write Pulse Width | 25 | 30 | - | 35 | 45 | 45 | 45 | 45 | ns |
| twe | Write Recovery Time | $5:-$ | 5 | - | 5 - | 5 - | 5 - | 5 - | 5 | ns |
| tow | Data Valid to End of Write | 20 - | 20 | - | 20 - | 20 - | 20 - | $30-$ | 30 - | ns |
| toh | Data Hold Time | 0 | 0 | - | 0 | 0 - | 0 | 0 - | 0 - | ns |
| TWHz ${ }^{(2)}$ | Write Enabled to Output in High Z | - 18 | - | 18 | - 20 | - 20 | - 20 | - 30 | - 30 | ns |
| tow. | Output Active from <br> End of Write | 0 - | 0 | - | 0 - | 0 - | 0 - | 0 - | 0 - | ns |
| twod | Write Pulse to Data Delay | - 50 | - | 65 | - . 70 | - 80 | - 80 | - 90 | - 100 | ns |
| todo | Write Data Valid to <br> Read Data Delay | - 40 | - | 45 | - 45 | $-\quad 55$ | - 65 | - 80 | - 100 | ns |
| Busy Input Timing |  |  |  |  |  |  |  |  |  |  |
| twe * . ${ }^{\text {a }}$ | Write to BUSY | 0 - | 0 | - | 0 - | 0 - | 0 - | 0 - | 0 - - | ns |
| tw | Write Hold After $\overline{B U S Y}$ | 20 - | 20 | - | 25 - | 25 - | 25 - | $30-$ | $30-$ | ns |

NOTES:

1. Transition is measured by $\pm 500 \mathrm{mV}$. from low or high impedance voltage with load (Figures 1 and 2 ).
2. This parameter is quaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. 1, ANY PORT ${ }^{(1,2,4)}$


2802 drw 03

TIMING WAVEFORM OF READ CYCLE NO. 2, ANY PORT ${ }^{(1,3)}$


2802 drw 04

## NOTES:

1. RWW is high for Read Cycles
2. Device is continuously enabled. $\overline{\mathrm{CS}} \geq \mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E} \geq \mathrm{VIL}$.
5. This parameter is guaranteed by design but not tested.

## TIMING WAVEFORM OF WRITE CYCLE NO. $1, \mathrm{R} / \overline{\mathbf{W}}$ CONTROLLED TIMING ${ }^{(1,2,3,7)}$



TIMING WAVEFORM OF WRITE CYCLE NO. $2, \overline{\mathrm{CS}}$ CONTROLLED TIMING ${ }^{(1,2,3,5)}$


2802 drw 06

## NOTES:

1. $\mathrm{R} \overline{\mathrm{W}}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low $R \bar{W}$.
3. tWR is measured from the earlier of $\overline{C S}$ or $R / \bar{W}$ going high to the end of the write cycle.
4. During this period, the $l / O$ pins are in the output state, and input signals must not be applied.
5. If the $\overline{C S}$ low transition occurs simultaneously with or after the $R \bar{W}$ low transition, the ouputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.
7. If $\overline{O E}$ is low during a $R \bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or (twz + tow) to allow the l/O drivers to turn off data to be placed on the busfor the required tDW. If $\overline{O E}$ is high during a $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY ${ }^{(1,2,3)}$


NOTES:
2802 drw 07

1. Assume $\overline{B U S Y}$ input at High and $\overline{C S}$ at Low for the writing port.
2. Write cycle parameters should be adhered to, to ensure proper writing.
3. Device is continuously enabled for any of the reading ports which has its $\overline{O E}$ at Low.

TIMING WAVEFORM OF WRITE WITH $\overline{B U S Y}$ INPUT


2802 drw 08

## FUNCTIONAL DESCRIPTION

The IDT7MB1041/1042 provides four ports with separate control, address and $\mathrm{I} / \mathrm{O}$ pins that permit independent access for reads or writes to any location in memory. These devices have an automatic power down feature controlled by $\overline{\mathrm{CS}}$. The $\overline{\mathrm{CS}}$ controls on-chip power down circuitry that permits the
respective port to go into standby mode when not selected ( $\overline{\mathrm{CS}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{\mathrm{OE}})$. In the read mode, the port's $\overline{\mathrm{OE}}$ turns on the output drivers when set LOW. READNRITE conditions are illustrated in the table below.

READ/WRITE CONTROL

| ANY PORT |  |  |  | FUNCTION |  |
| :--- | :---: | :---: | :---: | :---: | :--- |
| $\overline{\text { CS }}$ | R/ $\bar{W}$ | $\overline{\text { OE }}$ | $\overline{\text { BUSY }}$ |  |  |
| H | X | X | X | HI-Z | Port Disabled and in Power Down Mode |
| L | L | X | H | DATAIN | Write Cycle |
| X | L | X | L | HI-Z | Write is Blocked |
| L | H | L | X | DATAOUT | Read Cycle |
| X | X | H | X | HI-Z | High Impedance Outputs |

NOTES:
2802 drw 11

1. $\mathrm{H}=$ High, $\mathrm{L}-$ Low, $\mathrm{X}=$ Don't Care, $Z=$ High Impedance.
2. If $\overline{\mathrm{BUSY}}=$ Low, Data is not written.
3. For valid write operation, no more than one port can write to the same address location at the same time.

## ORDERING INFORMATION




Integrated Device Technology, Inc.
$4 \mathrm{~K} \times 16$
$2 \mathrm{~K} \times 16$
CMOS FourPort ${ }^{\text {™ }}$ RAM MODULE

## PRELIMINARY

 IDT7MB1043 IDT7MB1044
## FEATURES:

- High density $64 \mathrm{~K} / 32 \mathrm{~K}$ CMOS FourPort RAM Modules
- $4 \mathrm{~K} \times 16$ (IDT7MB1043) or $2 \mathrm{~K} \times 16$ (IDT7MB1044) option
- Fast access times
- maximum: $35,40,45,55,65,80,100 \mathrm{~ns}$
- Fully asynchronous operation from any four ports: P1, P2, P3, P4
- Versatile control for write-inhibit: separate $\overline{B U S Y}$ input to control write-inhibit for each of the other 3 ports
- Battery backup operation - 2V data retention (low power version only)
- Surface mounted fine pitch ( 25 mil) PQFP (Plastic Quad FlatPack) components on a FR-4 162-pin HIP (Hex Inline Package) substrate
- TTL compatible I/Os
- Single 5V ( $\pm 10 \%$ ) power supply
- Multiple ground pins provide maximum noise immunity
- Input/outputs directly TTL compatible


## DESCRIPTION:

The IDT7MB1043/1044 are 64/32K-bit high speed CMOS FourPort RAM modules constructed on a multi-layer FR-4 substrate using 4 IDT7052 ( $2 \mathrm{~K} \times 8$ ) FourPort RAMs or a depopulated version with 2 IDT7052 FourPort RAMs. The IDT7MB1043/ 1044 modules are designed to be used as stand-alone $64 \mathrm{~K} /$ 32K-bit fourport RAM. Using the IDT FourPort Module in such system applications as multiprocessor or realtime data acquistion result in dramatically increased system performance by providing four independent ports with separate control, address, and I/O pins that permit independent and asynchronous access for reads or writes to any location in memory. Upper and lower byte module signals for each port provide the system additional memory control capability.

The IDT7MB1043/1044 modules are packaged in a 162 pin FR-4 HIP (Hex In-line Package) and have maximum access times of 30 ns over the commercial temperature range.

## PIN NAMES ${ }^{(1,2)}$

| P1-4A0-11 | Ports 1-4, Address Inputs |
| :--- | :--- |
| P1-41/O0 - 15 | Port 1-4, Data Inputs/Outputs |
| R $\bar{W}$ UP1, LP1 | ReadWrite - Upper/Lower Byte Port 1 |
| R $\bar{W}$ UP2, LP2 | Read/Write - Upper/Lower Byte Port 2 |
| R $\bar{W}$ UP3, LP3 | Read/Write - Upper/Lower Byte Port 3 |
| R $\bar{W}$ UP4, LP4 | Read/Write - Upper/Lower Byte Port 4 |
| $\overline{\text { CS UP1, LP1 }}$ | Chip Select - Upper/Lower Byte Port 1 |
| $\overline{\text { CS UP2, LP2 }}$ | Chip Select - Upper/Lower Byte Port 2 |
| $\overline{\text { CS UP3, LP3 }}$ | Chip Select - Upper/Lower Byte Port 3 |
| $\overline{\text { CS UP4, LP4 }}$ | Chip Select - Upper/Lower Byte Port 4 |
| $\overline{\text { OE UP1, LP1 }}$ | Output Enable - Upper/Lower Byte Port 1 |
| $\overline{\text { OE UP2, LP2 }}$ | Output Enable - Upper/Lower Byte Port 2 |
| $\overline{\text { OE UP3, LP3 }}$ | Output Enable - Upper/Lower Byte Port 3 |
| $\overline{\text { OE UP4, LP4 }}$ | Output Enable - Upper/Lower Byte Port 4 |
| $\overline{\text { BUSY P1 }}$ | Port Busy Write Disable - Port 1 |
| $\overline{B U S Y ~ P 2 ~}$ | Port Busy Write Disable - Port 2 |
| $\overline{B U S Y ~ P 3 ~}$ | Port Busy Write Disable - Port 3 |
| $\overline{B U S Y ~ P 4 ~}$ | Port Busy Write Disable - Port 4 |
| VcC | Power |
| GND | Ground |

## PIN CONFIGURATION

Note: Pin configurations for these modules are currently not available, please consult the factory.

## Notes:

1. For valid read operation, no other partmay write to the same address location at the same time.
2. For the IDT7MB1044 (2K x 16) version, P1A11, P2A11, P3A11, P4A11 must be connected to GND for proper operation of the module.

FUNCTIONAL BLOCK DIAGRAM


ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with Respect <br> to GND | -0.5 to $\pm 7.0$ | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

2801 tol 03

## RECOMMENDED DC OPERATING

 CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2801 tbl 04

1. $\mathrm{VIL}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

CAPACITANCE ${ }^{(1)} \quad\left(\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Test Conditions | IDT7M 1043/1044 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Max. | Max. |  |
| Cin1 | Input Capacitance | $V \mathbb{I N}^{\prime}=0 \mathrm{~V}$ | 12 | 12 | pF |
| CIN2 | Input Capacitance (Data, Address, All Other Controls) | $\mathrm{V} \mathrm{IN}^{\text {a }}$ O OV | 40 | 20 | pF |
| Cout | Output Capacitance <br> (Data) | VOUT $=0 \mathrm{~V}$ | 45 | 25 | pF |

NOTE:
2801 tol 06

1. This parameter is guaranteed by design but not tested.

DC ELECTRICAL CHARACTERISTICS
( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7MB1043 |  | IDT7MB1044 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| IcCI | Operating Power Supply Current (All Ports Active) | $\overline{\mathrm{CS}} \geq$ VIL, Outputs Open $f=0$ | - | 750 | - | 600 | mA |
| Icc2 | Dynamic Operating Current | $\overline{\mathrm{CS}} \geq \mathrm{VIL}$, Outputs Open $f=f$ MAX | - | 850 | - | 700 | mA |
| IsB | Standby current (All Ports - TTL Level Inputs) | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{VIH} \text {, Outputs Open } \\ & \mathrm{f}=\mathrm{fMAX} \end{aligned}$ | - | 340 | - | 170 | mA |
| ISB1 | Full Standby Current (All Ports - All CMOS Level Inputs) | $\begin{aligned} & \text { All Ports } \overline{\mathrm{CS}} \geq \text { Vcc }-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \\ & \mathrm{VIN} \leq 0.2 \mathrm{~V}, \mathrm{f}=0 \end{aligned}$ | - | 20 | - | 10 | mA |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |

2801 tbl 08


Figure 1. Output Load


Figure 2. Output Load (for tclz, tChz, tolz, tohz, twhz, tow)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS ${ }^{(1)}$

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | 7MB1043S35 7MB1044S35 |  | 7MB1043S40 <br> 7MB1044S40 |  | 7MB1043S45 <br> 7MB1044S45 |  | 7MB1043S55 7MB1044S55 |  | 7MB1043S65 <br> 7MB1044S65 |  | 7MB1043S80 <br> 7MB1044S80 |  | 7MB1043S100 7MB1044S100 Min. Max. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tsc | Read Cycle Time | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | - | ns |
| tas | Address <br> Access Time | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |
| hacs | Chip Select Access Time | - | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |
| toe | Output Enable Access Time | - | 25 |  | 25 | - | 30 | - | 40 | - | 50 | - | 65 | - | 85 | ns |
| 8OH | Output Hold From Address Change | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tcliz ${ }^{(2)}$ | Chip Select to Output in Low Z | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tolz ${ }^{(2)}$ | Output Enable to Outputin Low Z | 3 | - | 5 | - | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tCHz ${ }^{(2)}$ | Chip Deselect to Output in High Z | 20 | - | 20 | - | 25 | - | 25 | - | 25 | - | 30 | - | 30 | - | ns |
| tohz ${ }^{(2)}$ | Output Disable to Output in High Z | 20 | - | 20 | - | 25 | - | 25 | - | 25 | - | 30 | - | 30 | - | ns |
| tpu ${ }^{(2)}$ | Chip Enable to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tpo ${ }^{(2)}$ | Chip Disable to Power Down Time | - | 35 | - | 55 | - | 55 | - | 50 | - | 70 | - | 70 | - | 70 | ns |

## NOTES:

2801 tbl 09

1. Transition is measured by $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2).
2. This parameter is quaranteed by design but not tested.

## AC ELECTRICAL CHARACTERISTICS ${ }^{(1)}$

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

|  |  | 7MB1043535 7MB1044S35 | 7MB1043540 7MB1044S40 | 7MB1043S45 7MB1044S45 | 7MB1043555 7MB1044S55 | 7MB1043S65 7MB1044S65 | 7MB1043580 7MB1044S80 | 7MB10435100 7MB1044S100 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameters | Min. Max. | Min. Max. | Min. Max. | Min. Max. | Min. Max. | Min. Max. | Min. Max. | Uni |


| twc | Write Cycle Time | 35 | - | 40 | - | 45 | - | 55 | - | 65 | - | 80 | - | 100 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tcw | Chip Select to End of Write | 30 | - | 35 | - | 35 | - | 45 | - | 55 | - | 70 | - | 90 | - | ns |
| taw | Address Valid to End of Write | 30 | - | 35 | - | 35 | - | 45 | - | 55 | - | 70 | - | 90 | - | ns |
| tas | Address Set-up <br> to $\overline{\mathrm{CS}}$ Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tas2 | Address Set-up to $R \bar{W}$ Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twp | Write Pulse Width | 25 | - | 30 | - | 35 | - | 45 | - | 45 | - | 45 | - | 45 | - | ns |
| twr | Write Recovery Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tow | Data Valid to End of Write | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | 30 | - | 30 | - | ns |
| toh | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twhz ${ }^{(2)}$ | Write Enabled to Output in High Z | - | 18 |  | 18 | - | 20 | - | 20 | - | 20 | - | 30 | - | 30 | ns |
| tow | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twoo | Write Pulse to Data Delay | - | 50 | - | 65 | - | 70 | - | 80 | - | 80 | - | 90 | - | 100 | ns |
| todo | Write Data Valid to Read Data Delay | - | 40 | - | 45 | -- | 45 | - | 55 | - | 65 | - | 80 | - | 100 | ns |

## Busy Input Timing

| W日 | Write to $\overline{\text { BUSY }}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| WWH | Write Hold After <br> BUSY | 20 | - | 20 | - | 25 | - | 25 | - | 25 | - | 30 | - | 30 | - | ns |

## NOTES:

1. Transition is measured by $\pm 500 \mathrm{mV}$ from low or high impedance voltage with load (Figures 1 and 2 ).
2. This parameter is quaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. 1 , ANY PORT ${ }^{(1,2,4)}$


2801 drw 03

TIMING WAVEFORM OF READ CYCLE NO. 2, ANY PORT ${ }^{(1,3)}$


NOTES:
2801 drw 04

1. $R \bar{W}$ is high for Read Cycles.
2. Device is continuously enabled. $\overline{\mathrm{CS}} \geq \mathrm{VIL}$.
3. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{\mathrm{OE}} \geq \mathrm{VIL}$.
5. This parameter is guaranteed by design but not tested.
timing waveform of write cycle no. 1, R/ $\bar{W}$ Controlled timing $(1,2,3,7)$


2801 drw 05

TIMING WAVEFORM OF WRITE CYCLE NO. $2, \overline{\operatorname{CS}}$ CONTROLLED TIMING $(1,2,3,5)$


2801 drw 06

NOTES:

1. $R \bar{W}$ must be high during all address transitions.
2. A write occurs during the overiap (twf) of a low $\overline{C S}$ and a low $R / \bar{W}$.
3. tWR is measured from the earlier of $\overline{C S}$ or $\mathrm{R} W \mathrm{~W}$ going high to the end of the write cycle.
4. During this period, the $I / O$ pins are in the output state, and input signals must not be applied.
5. If the $\overline{\mathrm{CS}}$ low transition occurs simultaneously with or after the R $\bar{W}$ low transition, the ouputs remain in the high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.
7. If $\overline{O E}$ is low during a $\mathrm{R} \bar{W}$ controlled write cycle, the write pulse width must be the larger of twp or ( $\mathrm{Wz}+\mathrm{tow}$ ) to allow the I/O drivers to turn off data to be placed on the busfor the required tow. If $\overline{O E}$ is high during a $R \bar{W}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## TIMING WAVEFORM OF READ WITH PORT-TO-PORT DELAY $(1,2,3)$



NOTES:

1. Assume BUSY input at High and $\overline{C S}$ at Low for the writing port.

2801 drw 07
2. Write cycle parameters should be adhered to, to ensure proper writing.
3. Device is continuously enabled for any of the reading ports which has its $\overline{O E}$ at Low.

## TIMING WAVEFORM OF WRITE WITH BUSY INPUT



## FUNCTIONAL DESCRIPTION

The IDT7MB1043/1044 provides four ports with separate control, address and I/O pins that permit independent access for reads or writes to any location in memory. These devices have an automatic power down feature controlled by $\overline{\mathrm{CS}}$. The $\overline{\mathrm{CS}}$ controls on-chip power down circuitry that permits the
respective port to go into standby mode when not selected ( $\overline{\mathrm{CS}}$ high). When a port is enabled, access to the entire memory array is permitted. Each port has its own Output Enable control ( $\overline{O E}$ ). In the read mode, the port's $\overline{O E}$ turns on the output drivers when set LOW. READ/WRITE conditions are illustrated in the table below.

READ/WRITE CONTROL

| ANY PORT |  |  |  |  |  |  |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CS | LBYTE | UBYTE | R/ $\bar{W}$ | $\overline{O E}$ | BUSY | V/00:7 | V/08:15 |  |
| H | X | X | X | X | $X$ | Hi-Z | HI-Z | Port Disabled and in Power Down Mode |
| H | X | X | X | X | X | $\mathrm{HI}-\mathrm{Z}$ | HI-Z | $\mathrm{CSP} 1=\mathrm{CSP} 2=\mathrm{CSP} 3=\mathrm{CSP} 4=\mathrm{H}$ <br> Power Down Mode, ISB or ISB1 |
| L | L | L | L | X | H | DATAIN | DATAIN | Write Cycle - Upper \& Lower Bytes |
| L | L | H | L | X | H | DATAIN | HI-Z | Write Cycle - Lower Byte only |
| L | H | L | L | X | H | HI-Z | DATAIN | Write Cycle - Upper Byte only |
| X | X | X | L | X | L | HI-Z | HI-Z | Write is Blocked |
| L | L | L | H | L | X | DATAOUT | DATAOUT | Read Cycle - Upper \& Lower Bytes |
| L | L | H | H | L | X | DATAOUT | HI-Z | Read Cycle - Lower Byte only |
| L | H | L | H | L | X | HI-Z | DATAOUT | Read Cycle - Upper Byte only |
| X | X | X | X | H | X | HI-Z | $\mathrm{HI}-\mathrm{Z}$ | High Impedance Outputs |

NOTES:

1. $\mathrm{H}=$ High, $\mathrm{L}-$ Low, $\mathrm{X}=$ Don't Care, $\mathrm{Z}=$ High Impedance.
2. If $\overline{B U S Y}=$ Low, Data is not written.
3. For valid write operation, no more than one port can write to the same address location at the same time.

## ORDERING INFORMATION



## FEATURES:

- First-In/First-Out memory module
- $8 \mathrm{~K} \times 9$ organization (IDT7M205S)
- $16 \mathrm{~K} \times 9$ organization (IDT7M206S)
- High speed: 20ns (max.) access time
- Asynchronous and simultaneous read and write
- Fully expandable by both word depth and/or bit width
- MASTER/SLAVE multiprocessing applications
- Bidirectional and rate buffer applications
- Empty and Full warning-flags
- High-performance CEMOS technology
- Single 5 V ( $\pm 10 \%$ ) power supply


## DESCRIPTION:

IDT7M205S/206S are FIFO memory modules constructed on a multi-layered ceramic substrate using four IDT7203 (2K x 9) or four IDT7204 (4K x 9) FIFOs in leadless chip carriers. Extremely high speeds are achieved in this fashion due to the use of IDT7203s and IDT7204s fabricated in IDT's high performance CEMOS technology. These devices utilize an
algorithm that loads and empties data on a first-In/first-out basis. The device uses Full and Empty flags to prevent data overflow and underflow and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the device through the use of the WRITE $(\bar{W})$ and READ $(\overline{\mathrm{R}})$ pins. The devices have a read/write cycle time of 30 ns (min.) for commercial and 40 ns (min.) for military temperature ranges.

The devices utilize a 9-bit wide data array to allow for control and parity bits at the user's option. This feature is especially useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking.

IDT's Military FIFO modules have semiconductor components manufactued incompliance with the latest revision of MIL-STD-883 Class B, making them ideally suited to applications demanding the highest level of performance and reliability.

## PIN CONFIGURATION ${ }^{(1)}$



1. For module dimensions, please refer to drawing M1 in the packaging section.

## PIN NAMES

| $\bar{W}=$ | $\overline{\mathrm{FL}}=$ | $\overline{\mathrm{XI}}=$ | $\overline{\mathrm{F}}=$ |
| :--- | :--- | :--- | :--- |
| WRITE | FIRST LOAD | EXPANSION IN | EMPTY FLAG |
| $\overline{\mathrm{R}}=$ | $\mathrm{D}=$ | $\overline{\mathrm{XO}}=$ | $\mathrm{VCC}=$ |
| READ | DATAIN | EXPANSION OUT | POWER |
| $\overline{\mathrm{RS}}=$ | $\mathrm{Q}=$ | $\mathrm{FF}=$ | GND $=$ |
| RESET | DATAOUT | FULL FLAG | GROUND |

FUNCTIONAL BLOCK DIAGRAM


[^13]ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Mil. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE: 2717 tbl 02

1. Stresses greater than those listedunder ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

## RECOMMENDED DC

OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCCM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| VCC | Commercial <br> Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH $^{(1)}$ | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH $^{\text {Coltane }}$ | Input High Voltage <br> Military | 2.2 | - | - | V |
| VIL $^{(1)}$ | Input Low Voltage <br> Commercial and <br> Military | - | - | 0.8 | V |

NOTE:

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{t}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 40 | pF |
| COUT | Output Capacitance | VoUT $=0 \mathrm{~V}$ | 60 | pF |

NOTE:
2717 tbl 04

1. This parameter is guaranteed by design but not tested.

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7M205S ${ }^{(5)}$ IDT7M206S ${ }^{(5)}$ |  | IDT7M205S ${ }^{(4)}$ IDT7M206S ${ }^{(4)}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\|\|L\|\|^{(1)}$ | Input Leakage Current (Any Input) | - | 5 | - | 10 | $\mu \mathrm{A}$ |
| \|lou| ${ }^{(2)}$ | Output Leakage Current | - | 10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage lour = -2mA | 2.4 | - | 2.4 | - | V |
| Vol | Output Logic "0" Voltage 10ut $=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| $\mathrm{lcCl}^{(3)}$ | Average Vcc Power Supply Current | - | 640 | - | 350 | mA |
| $\operatorname{lcc}^{(3)}$ | Average Standby Current ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RST}}=\overline{\mathrm{FL}} / \overline{\mathrm{RT}}=\mathrm{VIH}$ ) | - | 60 | - | 100 | mA |
| $\mathrm{ICc3}^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | 32 | - | 48 | mA |

NOTES:
2717 tud 04

1. Measurements with $0.4 \leq \mathrm{V}_{\mathrm{N}} \leq$ Vout.
2. $\overline{\mathrm{R}} \geq \mathrm{V} \mathrm{H}, 0.4 \leq$ Vout $\leq \mathrm{V} \subset \mathrm{C}$.
3. l $\propto \subset$ measurements are made with outputs open.
4. $t A A=40,50,60,70,85,120 \mathrm{~ns}$
5. $t A A=20,25,30,35 \mathrm{~ns}$

## AC TEST CONDITIONS

Input Pulse Levels Input Rise/Fall Times Input Timing Reference Levels Output Reference Levels
Output Load

GND to 3.0V
5ns
1.5 V
1.5 V

See Figure 1, 2 \& 3


FIgure 1. Output Load


Figure 2. Output Load (for tRLZ, twLZ, and tRHZ)

* Includes scope and jig capacitances.


## AC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { 7M205S20 } \\ \text { 7M206S20 } \\ \text { (Com'l Only) } \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { 7M205S25 } \\ \text { 7M206S25 } \\ \text { (Com'l Only) } \\ \hline \end{gathered}$ |  | $\begin{aligned} & \text { 7M205S30 } \\ & \text { 7M206S30 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { 7M205S35 } \\ & \text { 7M206S35 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| tre | Read Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tA | Access Time | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tRR | Read Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tRPW ${ }^{(1)}$ | Read Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| trlz ${ }^{(2)}$ | Read Pulse Low to Data Bus at Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twLz ${ }^{(2)}$ | Write Pulse High to Data Bus at Low Z | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tDV | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| trhz ${ }^{(2)}$ | Read Pulse High to Data Bus at High Z | - | 13 | - | 20 | - | 20 | - | 20 | ns |
| twc | Write Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tWPW ${ }^{(1)}$ | Write Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| twr | Write Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tDS | Data Set-up Time | 15 | - | 18 | - | 18 | - | 20 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tRSC | Reset Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| trs ${ }^{(1)}$ | Reset Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tRSR | Reset Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tEFL | Reset to Empty Flag Low | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tref | Read Low to Empty Flag Low | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tRFF | Read High to Full Flag High | - | 23 | - | 25 | - | 30 | - | 35 | ns |
| tWEF | Write High to Empty Flag High | - | 23 | - | 25 | - | 30 | - | 35 | ns |
| tWFF | Write Low to Full Flag Low | 一 | 20 | - | 25 | - | 30 | - | 35 | ns |

## NOTES:

1. Pulse widths less than minimum value are not allowed.
2. This parameter is guaranteed by design but not tested.

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}^{2}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{aligned} & \text { 7M205S40 } \\ & 7 \mathrm{M} 206 \mathrm{~S} 40 \end{aligned}$ | $\begin{array}{\|l\|} \hline 7 \mathrm{M} 205 \mathrm{~S} 50 \\ \text { 7M206S50 } \end{array}$ | $\begin{array}{\|l\|} \hline 7 \mathrm{M} 205 \mathrm{~S} 60 \\ 7 \mathrm{M} 206 \mathrm{~S} 60 \end{array}$ | $\begin{aligned} & \hline \text { 7M205S70 } \\ & \text { 7M206S70 } \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 7 \mathrm{M} 205 \mathrm{~S} 85 \\ \text { 7M206S85 } \end{array}$ | $\begin{array}{\|l\|} \hline 7 \mathrm{M} 205 \mathrm{~S} 120 \\ \text { 7M206S120 } \\ \hline \end{array}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. Max. | Min. Max. | Min. Max | Min. Max. | Min. Max. |  |
| tRC | Read Cycle Time | 50 | 65 | 75 | 85 | 105 | 140 | ns |
| ta | Access Time | 40 | 50 | - 60 | - 70 | - 85 | - 120 | ns |
| tRR | Read Recovery Time | 10 | 15 | 15 | 15 | 20 | 20 | ns |
| tRPW ${ }^{(1)}$ | Read Pulse Width | 40 - | 50 | 60 - | 70 - | 85 - | 120 | ns |
| triz ${ }^{(2)}$ | Read Pulse Low to Data Bus at Low Z | 5 - | 10 | 10 | 10 - | 10 | 10 | ns |
| twLz ${ }^{(2)}$ | Write Pulse High to Data Bus at Low Z | 10 | 15 | 15 | 15 | 20 | 20 | ns |
| tov | Data Valid from Read Pulse High | 5 | 5 | 5 | 5 | 5 | 5 | ns |
| tRHZ ${ }^{(2)}$ | Read Pulse High to Data Bus at High Z | - 25 | - 30 | - 30 | - 30 | - 30 | - 35 | ns |
| twe | Write Cycle Time | 50 | 65 | 75 | 85 | 105 | 140 | ns |
| twPW ${ }^{(1)}$ | Write Pulse Width | 40 | 50 | 60 | 70 | 85 | 120 | ns |
| tWR | Write Recovery Time | 10 | 15 | 15 | 15 | 20 | 20 | ns |
| tDS | Data Set-up Time | 20 | 30 | 30 | 30 | 40 | 40 | ns |
| tor | Data Hold Time | 0 - | 5 | 5 | 10 | 10 | 10 | ns |
| trsc | Reset Cycle Time | 50 | 65 | 75 | 85 | 105 | 140 | ns |
| tts ${ }^{(1)}$ | Reset Pulse Width | 40 - | 50 | 60 | 70 | 85 | 120 | ns |
| tRSR | Reset Recovery Time | 10 | 15 | 15 | 15 | 20 | 20 | ns |
| tEFL | Reset to Empty Flag Low | - 55 | 65 | - 75 | - 85 | - 105 | - 140 | ns |
| tref | Read Low to Empty Flag Low | - 40 | 50 | - 60 | - 70 | - 85 | - 120 | ns |
| tRFF | Read High to Full Flag High | - 40 | - 50 | - 60 | - 70 | - 85 | 120 | ns |
| twEF | Write High to Empty Flag High | - 40 | 50 | - 60 | - 70 | - 85 | 120 | ns |
| twFF | Write Low to Full Flag Low | - 40 | - 50 | - 60 | - 70 | - 85 | - 120 | ns |

NOTES:

1. Pulse widths less than minimum value are not allowed.
2. This parameter is guaranteed by design but not tested.

## SIGNAL DESCRIPTIONS:

## INPUTS:

## DATA IN (D0-D8)

Data Inputs for 9-bit wide data path.

## CONTROLS:

## RESET ( $\overline{\mathrm{RS}}$ )

Reset is accomplished whenever the RESET ( $\overline{\mathrm{RS}}$ ) input is taken to a low state. During RESET, both internal read and write pointers are set to the first location. A reset is required after power up before a write operation can take place. Both the READ ENABLE $(\overline{\mathrm{R}})$ and WRITE ENABLE $(\overline{\mathrm{W}})$ inputs must be in the high state during reset.

## WRITE ENABLE ( $\bar{W}$ )

A write cycle is initiated on the falling edge of this input if the FULL FLAG ( $\overline{\mathrm{FF}}$ ) is not set. Data set-up and hold times must be adhered to with respect the the rising edge of the WRITE ENABLE $(\bar{W})$. Data is stored in the RAM array sequentially and independently of any ongoing read operation.

To prevent data overflow, the FULL FLAG ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operations. Upon the completion of a valid read operation, the FULL FLAG ( $\overline{\mathrm{FF}})$ will go high after tRFF, allowing a valid write to begin.

## READ ENABLE ( $\overline{\mathrm{R}}$ )

A read cycle is initiated on the falling edge of the READ ENABLE ( $\bar{R}$ ) provided the EMPTY FLAG ( $\overline{\mathrm{EF}}$ ) is not set. The data is accessed on a first-in/first-out basis independent of any ongoing write operations. After READ ENABLE ( $\overline{\mathrm{R}})$ goes high, the Data Outputs (Qo through Q8) will return to a high impedance condition until the next READ operation. When all the data has been read from the FIFO, the EMPTY FLAG (EF) will go low, inhibiting further read operations with the data
outputs remaining in a high impedance state. Once a valid write operation has been accomplished, the EMPTY FLAG ( $\overline{E F}$ ) will go high after tWEF and a valid READ can then begin.

## FIRST LOAD ( $\overline{\mathrm{FL}})$

This pin is grounded to indicate that it is the first device. In the multiple module (depth expansion mode) application, this pin on the rest of devices should connect to Vcc for proper operation.

## EXPANSION IN (伩)

EXPANSION IN $(\overline{X I})$ is connected to EXPANSION OUT ( $\overline{\mathrm{XO}) \text { of the previous (in depth expansion) or same device for }}$ proper applications.

## OUTPUTS:

## FULL FLAG (FF)

The FULL FLAG ( $\overline{F F}$ ) will go low, inhibiting further write operation, when the write pointer is one location from the read pointer, indicating that the device is full. If the read pointer is not moved after RESET ( $\overline{\mathrm{RS}}$ ), the FULL FLAG ( $\overline{\mathrm{FF}}$ ) will go low after 8,192 writes for the IDT7M205 and 16,384 writes for the IDT7M206.

## EXPANSION OUT ( $\overline{X O}$ )

EXPANSION OUT $(\overline{\mathrm{XO}})$ is connected to the EXPANSION IN $(\overline{\mathrm{XI}})$ of the same device (single device mode) or the EXPANSION IN (哽) of the next device (multiple device, depth expansion mode) for proper operation. This output acts as a signal to the next device by providing a pulse to the next device when the current device reaches the last location of memory.

## DATA OUTPUTS (Q0-Q8)

Data outputs for a 9-bit wide data. This output is in a high impedance condition whenever READ $(\overline{\mathrm{R}})$ is in a high state.

## TIMING WAVEFORM OF RESET CYCLE ${ }^{(1,2)}$



NOTES:

1. thsc $=$ tRS + tRSR
2. $\bar{W}$ and $\bar{R}=V \mathbb{V}$ during RESET.

TIMING WAVEFORM FOR ASYNCHRONOUS WRITE AND READ OPERATION


TIMING WAVEFORM OF THE FULL FLAG FROM LAST WRITE TO FIRST READ


TIMING WAVEFORM OF THE EMPTY FLAG FROM LAST READ TO FIRST WRITE


NOTE:

1. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM FOR THE EMPTY FLAG
trPE EFFECTIVE READ PULSE WIDTH AFTER FULL FLAG HIGH ${ }^{(1)}$


NOTE:

1. (tRPE $=$ tRPW $)$

TIMING WAVEFORM FOR THE FULL FLAG

$$
\text { tRPE EFFECTIVE READ PULSE WIDTH AFTER FULL FLAG HIGH }{ }^{(1)}
$$



NOTE:

1. ( T WPF $=$ tWPW)

## OPERATING MODES

## SINGLE DEVICE MODE

A single IDT7M205/206 may be used when the application requirements are for $8,192 / 16,384$ words or less. The IDT7M205/206 is in a Single Device Configuration when the EXPANSION IN ( $\overline{\mathrm{XI}) \text { control input is connected to the }}$ EXPANSION OUT ( $\overline{\mathrm{XO}}$ ) of the device and the FIRST LOAD $(\overline{\mathrm{FL}})$ control pin is grounded (see Figure 8).

## WIDTH EXPANSION MODE

Word width may be increased simply by connecting the corresponding input control signals of multiple devices. Status flags ( $\overline{\mathrm{EF}}$ and $\overline{\mathrm{FF}}$ ) can be detected from any one device. Figure 9 demonstrates an 18-bit word width by using two IDT7M205/ 206s. Any word width can be attained by adding additional IDT7M205/206s.

## DEPTH EXPANSION (DAISY CHAIN) MODE

The IDT7M205/206 can easity be adapted to applications when the requirements are for greater than 8,192/16,384 words. Figure 10 demonstrates Depth Expansion using three IDT7M205/206s. Any depth can be attained by adding additional IDT7M205/206s. The IDT7M205/206 operate in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the FIRST LOAD ( $\overline{\mathrm{FL}}$ ) control input.
2. All other devices must have $\overline{F L}$ in the high state.
3. The EXPANSION OUT ( $\overline{\mathrm{XO}}$ ) pin of each device must be tied to the EXPANSION $\mathbb{N}(\overline{\mathrm{XI}})$ pin of the next device.
(See Figure 10.)
4. External logic is needed to generate a composite FULL FLAG ( $\overline{\mathrm{FF}})$ and EMPTY FLAG ( $\overline{\mathrm{EF}}$ ). This requires the logical ANDing of all EFs and logical ANDing of all FFs (i.e. all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{\mathrm{EF}}$ ). (See Figure 10.)

## COMPOUND EXPANSION MODE

The two expansion techniques described above can be applied together in a straight forward manner to achieve large FIFO arrays (see Figure 11).

## BIDIRECTIONAL MODE

Applications which require data buffering between two systems (each system capable of Read and Write operations) can be achieved by pairing IDT7M205/206s as shown in Figure 12. Care must be taken to assure that the appropriate flag is monitored by each system (i.e., $\overline{F F}$ is monitored on the device where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\bar{R}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## DATA FLOW-THROUGH MODES

Two types of flow-through modes are permitted with the IDT7M205/206: a read flow-through mode and write flowthrough mode. For the read flow-through mode (Figure 13), the FIFO permits a reading of a single word of data immediately after writing one word of data into the completely empty FIFO.

In the write flow-through mode (Figure 14), the FIFO permits a writing of a single word of data immediately after reading one word of data from a completely full FIFO.


Figure 8. Block Dlagram of Single IDT7M205/206 FIFO


2717 drw 11

NOTE:

1. Flag detection is accomplished by monitoring the $\overline{F F}$ and $\overline{E F}$ signals on either (any) device used in the width expansion configuration. Do not connect any output control signals together.

Figure 9. Block Diagram of $8,192 \times 18 / 16,384 \times 18$ FIFO Memory Used In Width Expansion Mode

## TRUTH TABLES

## TABLE I-RESET

Single Device Configuration/Width Expansion Mode

| Mode |  | Inputs |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :--- | :--- | :---: | :---: | :---: |
|  |  | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | $\overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ |  |
| Reset | 0 | 0 | Location Zero | Location Zero | 0 | 1 |  |
| Read $/$ Write | 1 | 0 | Increment ${ }^{(1)}$ | Increment $^{(1)}$ | X | X |  |

NOTE:
2717 tы 08

1. Pointer will increment if flag is High.

## TABLE II—RESET AND FIRST LOAD TRUTH TABLE

Depth Expansion/Compound Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{RS}}$ | $\overline{\mathrm{FL}}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | $\overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ |
| Reset First Device | 0 | 0 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Reset All Other Devices | 0 | 1 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | $(1)$ | X | X | X | X |

NOTE:

1. $\overline{X I I}$ is connected to $\overline{X O}$ of previous device. See Figure 10.
2. $\overline{\mathrm{RS}}=$ Reset Input $\overline{\mathrm{FL}}=$ First Load, $\overline{\mathrm{EF}}=$ Empty Flag Output, $\overline{F F}=$ Flag Full Output, $\overline{\mathrm{XI}}=$ Expansion Input.


Figure 10. Block Diagram of $24,576 \times 9 / 49,152 \times 9$ FIFO Memory (Depth Expansion)


Figure 11. Compound FIFO Expansion

## NOTES:

1. For depth expansion block see DEPTH EXPANSION Section and Figure 10.
2. For Flag detection see WIDTH EXPANSION Section and Figure 9.


Figure 12. Bidirectional FIFO Mode


Figure 13. Read Data Flow-Through Mode


Figure 14. Write Data Flow-Through Mode

## ORDERING INFORMATION



## FEATURES:

- First-In/First-Out memory module
- $8 \mathrm{~K} \times 9$ organization (IDT7MP2005)
- 16K x 9 organization (IDT7MP2011)
- High speed: $20 n s$ (max.) access time
- Asynchronous and simultaneous read and write
- Fully expandable by both word depth and/or bit width
- MASTER/SLAVE multiprocessing applications
- Bidirectional and rate buffer applications
- Empty and Full warning-flags
- High-performance CEMOS ${ }^{\text {rM }}$ technology
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## DESCRIPTION:

IDT7MP2005/7MP2011 are FIFO memory modules constructed on multi-layered epoxy laminate (FR-4) substrate by mounting two IDT7204 (4K $\times 9$ ) or IDT7205 ( $8 \mathrm{~K} \times 9$ ) FIFOs in plastic leaded chip carriers. Extremely high speeds are
achieved in this fashion due to the use of IDT7203s and IDT7204s fabricated in IDT's high performance CEMOS technology. These devices utilize an algorithm that loads and empties data on a first-In/first-out basis. The device uses Full and Empty flags to prevent data overflow and underflow and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the device through the use of the WRITE ( $\bar{W}$ ) and READ ( $\overline{\mathrm{R}})$ pins. The devices have a read/write cycle time of 30 ns (min.) for commercial temperature ranges.

The devices utilize a 9-bit wide data array to allow for control and parity bits at the user's option. This feature is especially useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking.

## PIN CONFIGURATION ${ }^{(1)}$



NOTE:

1. For module dimensions, please refer to drawing M34 in the packaging section.

## PIN NAMES

| $\bar{W}=$ | $\overline{\mathrm{FL}}=$ | $\overline{\mathrm{XI}}=$ | $\overline{\mathrm{EF}}=$ |
| :--- | :--- | :--- | :--- |
| WRITE | FIRST LOAD | EXPANSION IN | EMPTY FLAG |
| $\overline{\mathrm{R}}=$ | $\mathrm{D}=$ | $\overline{\mathrm{XO}}=$ | VCC $=$ |
| READ | DATAIN | EXPANSION OUT | POWER |
| $\overline{\mathrm{RS}}=$ | $\mathrm{Q}=$ | $\overline{\mathrm{FF}}=$ | GND $=$ |
| RESET | DATAOUT | FULL FLAG | GROUND |

## FUNCTIONAL BLOCK DIAGRAM



ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'I. | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with Respect <br> to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output Current | 50 | mA |

NOTE:
2709 to 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

RECOMMENDED DC
OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{c c c}$ | Commercial <br> Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{~V}_{1{ }^{(1)}}$ | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| $\mathrm{VIL}^{(1)}$ | Input Low Voltage <br> Commercial | - | - | 0.8 | V |

NOTE:
2709 क1 03

1. 1.5 V undershoots are allowed for 10 ns once per cycle

CAPACITANCE ( $T_{A}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Conditions | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 20 | pF |
| COUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 25 | pF |

## NOTE:

2709 ti 04

1. This parameter is guaranteed by design but not tested.

DC ELECTRICAL CHARACTERISTICS
( $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

|  | Parameter | IDT7MP2005 ${ }^{(4)}$ |  | IDT7MP2011 ${ }^{(5)}$ |  | DT7MP2005 ${ }^{(6)}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mid$ \|tu| ${ }^{(1)}$ | Input Leakage Current (Any Input) | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \|lot| ${ }^{(2)}$ | Output Leakage Current | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage lout = $=2 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | 2.4 | - | V |
| Va | Output Logic "0" Voltage lout $=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | - | 0.4 | V |
| $\mathrm{lcci}^{(3)}$ | Operating Current | - | 320 | - | 300 | - | 132 | mA |
| $\mathrm{kcc}^{(3)}$ | Average Standby Current ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{F}} / \overline{\mathrm{RT}}=\mathrm{VIH})$ | - | 30 | - | 24 | - | 24 | mA |
| $\mathrm{lcca}^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | 16 | - | 16 | - | 16 | mA |

NOTES:

1. Measurements with $0.4 \leq V \mathbb{N} \leq$ Vout.
2. $R \geq V_{H}, 0.4 \leq$ Vout $\leq V \subset c$.
3. Icc measurements are made with outputs open.
4. $\mathrm{tAA}=20,25,30,35 \mathrm{~ns}$.
5. $\mathrm{LAA}=30,35,40,50,60,70,85,120 \mathrm{~ns}$.
6. $L A A=40,50,60,70,85,120 \mathrm{~ns}$.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure $1,2 \& 3$ |



Figure 1. Output Load


Figure 2. Output Load (for tRLZ, twLZ, and tRHz)

* Includes scope and jig capacitances.


## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7MP2005S20 |  | 7MP2005S25 |  | 7MP2005S30 <br> 7MP2011S30 <br> Min. Max. |  | 7M205SS35 7M2011S35 Min. Max. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRC | Read Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| ta | Access Time | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tRR | Read Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tRPW ${ }^{(1)}$ | Read Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| trlz ${ }^{(2)}$ | Read Pulse Low to Data Bus at Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twLz ${ }^{(2)}$ | Write Pulse High to Data Bus at Low Z | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tDV | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tRHZ ${ }^{(2)}$ | Read Pulse High to Data Bus at High Z | - | 13 | - | 20 | - | 20 | - | 20 | ns |
| twe | Write Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tWPW ${ }^{(1)}$ | Write Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| twr | Write Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tDS | Data Set-up Time | 15 | - | 18 | - | 18 | - | 20 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tRSC | Reset Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tRS ${ }^{(1)}$ | Reset Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tRSR | Reset Recovery Time | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tEFL | Reset to Emtpy Flag Low | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| treF | Read Low to Emtpy Flag Low | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tRFF | Read High to Full Flag High | - | 23 | - | 25 | - | 30 | - | 35 | ns |
| tWEF | Write High to Empty Flag High | - | 23 | - | 25 | - | 30 | - | 35 | ns |
| tWFF | Write Low to Full Flag Low | - | 20 | - | 25 | - | 30 | - | 35 | ns |

## NOTES:

1. Pulse widths less than minimum value are not allowed.
2. This parameter is guaranteed by design but not tested.

## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\left\lvert\, \begin{aligned} & 7 \mathrm{MP2005S40} \\ & \text { 7MP2011S40 } \\ & \text { Min. Max. } \end{aligned}\right.$ |  | $\begin{aligned} & \text { 7MP2005S50 } \\ & \text { 7MP2011S50 } \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 7 \mathrm{MP2005S} 60 \\ 7 \mathrm{MP2011S60} \\ \text { Min. Max. } \end{array}$ |  | $\left\lvert\, \begin{gathered} \text { 7MP2005S70 } \\ \text { 7MP2011S70 } \\ \text { Min. Max. } \end{gathered}\right.$ |  | $\begin{aligned} & \text { 7MP2005S85 } \\ & \text { 7MP2011S85 } \\ & \text { Min. Max. } \end{aligned}$ |  | 7MP2005S1207MP2011S120Min. Max. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRC | Read Cycle Time | 50 | - | 65 | - | 75 | - | 85 | - | 105 | - | 140 | - | ns |
| tA | Access Time | - | 40 | - | 50 | - | 60 | - | 70 | - | 85 | - | 120 | ns |
| tRR | Read Recovery Time | 10 | - | 15 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tRPW ${ }^{(1)}$ | Read Pulse Width | 40 | - | 50 | - | 60 | - | 70 | - | 85 | - | 120 | - | ns |
| trla ${ }^{(2)}$ | Read Pulse Low to Data Bus at Low Z | 5 | - | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| twLz ${ }^{(2)}$ | Write Pulse High to Data Bus at Low Z | 10 | - | 15 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tDV | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| trhz ${ }^{(2)}$ | Read Pulse High to Data Bus at High Z | - | 25 | - | 30 | - | 30 | - | 30 | - | 30 | - | 35 | ns |
| twc | Write Cycle Time | 50 | - | 65 | - | 75 | - | 85 | - | 105 | - | 140 | - | ns |
| tWPW $^{(1)}$ | Write Pulse Width | 40 | - | 50 | - | 60 | - | 70 | - | 85 | - | 120 | - | ns |
| tWR | Write Recovery Time | 10 | - | 15 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tDS | Data Set-up Time | 20 | - | 30 | - | 30 | - | 30 | - | 40 | - | 40 | - | ns |
| IDH | Data Hold Time | 0 | - | 5 | - | 5 | - | 10 | - | 10 | - | 10 | - | ns |
| IRSC | Reset Cycle Time | 50 | - | 65 | - | 75 | - | 85 | - | 105 | - | 140 | - | ns |
| trs ${ }^{(1)}$ | Reset Pulse Width | 40 | - | 50 | - | 60 | - | 70 | - | 85 | - | 120 | - | ns |
| tRSR | Reset Recovery Time | 10 | - | 15 | - | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tEFL | Reset to Emtpy Flag Low | - | 50 | - | 65 | - | 75 | - | 85 | - | 105 | - | 140 | ns |
| tref | Read Low to Emtpy Flag Low | - | 40 | - | 50 | - | 60 | - | 70 | - | 85 | - | 120 | ns |
| tRFF | Read High to Full Flag High | - | 40 | - | 50 | - | 60 | - | 70 | - | 85 | - | 120 | ns |
| tWEF | Write High to Empty Flag High | - | 40 | - | 50 | - | 60 | - | 70 | - | 85 | - | 120 | ns |
| tWFF | Write Low to Full Flag Low | - | 40 | - | 50 | - | 60 | - | 70 | - | 85 | - | 120 | ns |

## NOTES:

1. Pulse widths less than minimum value are not allowed.
2. This parameter is guaranteed by design but not tested.

## SIGNAL DESCRIPTIONS：

## INPUTS：

## DATA IN（Do－D8）

Data Inputs for 9 －bit wide data path．

## CONTROLS：

## RESET（ $\overline{\mathrm{RS}}$ ）

Reset is accomplished whenever the RESET（ $\overline{\mathrm{RS}}$ ）input is taken to a low state．During RESET，both internal read and write pointers are set to the first location．A reset is required after power up before a write operation can take place．Both the READ ENABLE $(\overline{\mathrm{R}})$ and WRITE ENABLE $(\overline{\mathrm{W}})$ inputs must be in the high state during reset．

## WRITE ENABLE（ $\bar{W}$ ）

A write cycle is initiated on the falling edge of this input if the FULL FLAG（FF）is not set．Data set－up and hold times must be adhered to with respect the the rising edge of the WRITE ENABLE $(\bar{W})$ ．Data is stored in the RAM array sequentially and independently of any ongoing read operation．

To prevent data overtlow，the FULL FLAG（产）will go low， inhibiting further write operations．Upon the completion of a valid read operation，the FULL FLAG（ $\overline{F F}$ ）will go high after tRFF，allowing a valid write to begin．

## READ ENABLE（ $\overline{\mathrm{R}})$

A read cycle is initiated on the falling edge of the READ ENABLE $(\bar{R})$ provided the EMPTY FLAG（ $\overline{\mathrm{EF}}$ ）is not set．The data is accessed on a first－in／first－out basis independent of any ongoing write operations．Atter READ ENABLE（ $\overline{\mathrm{R}})$ goes high，the Data Outputs（Qo through Q8）will return to a high impedance condition until the next READ operation．When all the data has been read from the FIFO，the EMPTY FLAG（EF） will go low，inhibiting further read operations with the data
outputs remaining in a high impedance state．Once a valid write operation has been accomplished，the EMPTY FLAG （ $\overline{E F}$ ）will go high after tWEF and a valid READ can then begin．

## FIRST LOAD（FI）

This pin is grounded to indicate that it is the first device．In the multiple module（depth expansion mode）application，this pin on the rest of devices should connect to Vcc for proper operation．

## EXPANSION IN（佣）

EXPANSION IN（ $\overline{\mathrm{XI}})$ is connected to EXPANSION OUT （ $\overline{\mathrm{XO}}$ ）of the previous（in depth expansion）or same device for proper applications．

## OUTPUTS：

## FULL FLAG（启）

The FULL FLAG（ $\overline{\mathrm{FF}}$ ）will go low，inhibiting further write operation，when the write pointer is one location from the read pointer，indicating that the device is full．If the read pointer is not moved after RESET（ $\overline{\mathrm{RS}}$ ），the FULL FLAG（ $\overline{\mathrm{FF}}$ ）will go iow after 8,192 writes for the IDT7MP2005 and 16,384 writes for the IDT7MP2011．

## EXPANSION OUT（ $\overline{\mathrm{XO}})$

EXPANSION OUT（ $\overline{\mathrm{XO}}$ ）is connected to the EXPANSION IN（ $\overline{\mathrm{XI}})$ of the same device（single device mode）or the EX－ PANSION IN（XI）of the next device（multiple device，depth expansion mode）for proper operation．This output acts as a signal to the next device by providing a pulse to the next device when the current device reaches the last location of memory．

## DATA OUTPUTS（Qo－Q8）

Data outputs for a 9 －bit wide data path．This output is in a high impedance condition whenever READ $(\overline{\mathrm{R}})$ is in a high state．

## TIMING WAVEFORM OF RESET CYCLE ${ }^{(1,2)}$



## NOTES：

[^14]TIMING WAVEFORM OF ASYNCHRONOUS WRITE AND READ OPERATION


TIMING WAVEFORM FOR THE FULL FLAG FROM LAST WRITE TO FIRST READ


TIMING WAVEFORM FOR THE EMPTY FLAG FROM LAST READ TO FIRST WRITE


NOTE:

1. This parameter is guaranteed by design but not tested.

## TIMING WAVEFORM OF THE EMPTY FLAG CYCLE



NOTE:

1. (tRPE $=\mathrm{t}$ RPW)

TIMING WAVEFORM OF THE FULL FLAG CYCLE
$t_{\text {RPE }}$ EFFECTIVE READ PULSE WIDTH AFTER FULL FLAG HIGH ${ }^{\text {(1) }}$


NOTE:

1. $($ tWPF $=\mathrm{t}$ WPW)

## OPERATING MODES

## SINGLE DEVICE MODE

A single IDT7MP2005/2011 may be used when the application requirements are for $8,192 / 16,384$ words or less. The IDT7MP2005/2011 is in a Single Device Configuration when the EXPANSION IN $(\overline{\mathrm{XI}})$ control input is connected to the EXPANSION OUT $(\overline{\mathrm{XO}})$ of the device and the FIRST LOAD $(\overline{\mathrm{FL}})$ control pin is grounded (see Figure 8).

## WIDTH EXPANSION MODE

Word width may be increased simply by connecting the corresponding input control signals of multiple devices. Status flags ( $\overline{\mathrm{EF}}$ and $\overline{\mathrm{FF}}$ ) can be detected from any one device. Figure 9 demonstrates an 18-bit word width by using two IDT7MP2005/ 2011. Any word width can be attained by adding additional IDT7MP2005/2011s.

## DEPTH EXPANSION (DAISY CHAIN) MODE

The IDT7MP2005/2011 can easily be adapted to applications when the requirements are forgreater than $8,192 / 16,384$ words. Figure 10 demonstrates Depth Expansion using three IDT7MP2005/2011. Any depth can be attained by adding additional IDT7MP2005/2011s. The IDT7MP2005/2011 operate in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the FIRST LOAD ( $\overline{\mathrm{FL}}$ ) control input.
2. All other devices must have $\overline{F L}$ in the high state.
3. The EXPANSION OUT ( $\overline{\mathrm{XO}})$ pin of each device must be tied to the EXPANSION IN (位) pin of the next device. (See Figure 10.)
4. External logic is needed to generate a composite FULL FLAG ( $\overline{\mathrm{FF}}$ ) and EMPTY FLAG ( $\overline{\mathrm{EF}}$ ). This requires the logical ANDing of all EFs and logical ANDing of all FFs (i.e. all must be set to generate the correct composite $\overline{F F}$ or $\overline{\mathrm{EF}}$ ). (See Figure 10.)

## COMPOUND EXPANSION MODE

The two expansion techniques described above can be applied together in a straight forward manner to achieve large FIFO arrays. (See Figure 11.)

## BIDIRECTIONAL MODE

Applications which require data buffering between two systems (each system capable of READ and WRITE operations) can be achieved by pairing IDT7MP2005/2011s as shown in Figure 12. Care must be taken to assure that the appropriate flag is monitored by each system (i.e. $\overline{\mathrm{FF}}$ is monitored on the device where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\overline{\mathrm{R}}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## DATA FLOW-THROUGH MODES

Two types of flow-through modes are permitted with the IDT7MP2005/2011: a read flow-through mode and write flowthrough mode. For the read flow-through mode (Figure 13), the FIFO permits a reading of a single word of data immediately after writing one word of data into the completely empty FIFO.

In the write flow-through mode (Figure 14), the FIFO permits a writing of a single word of data immediately after reading one word of data from a completely full FIFO.


Figure 8. Block Diagram of Single IDT7MP2005/7MP2011 FIFO


NOTE:

1. Flag detection is accomplished by monitoring the $\overline{F F}$ and $\overline{E F}$ signals on either (any) device used in the width expansion configuration. Do not connect any output control signals together.

Figure 9. Block Diagram of $8,192 \times 18 / 16,384 \times 18$ FIFO Memory Used in Width Expansion Mode

## TRUTH TABLES <br> TABLE -RESET

Single Device Configuration/Width Expansion Mode

| Mode | Inputs |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :--- | :--- | :---: | :---: |
|  | $\overline{\text { RS }}$ | $\overline{\text { XI }}$ | Read Pointer | Write Pointer | EF | $\overline{\mathrm{FF}}$ |
| Reset | 0 | 0 | Location Zero | Location Zero | 0 | 1 |
| Read $/$ Write | 1 | 0 | Increment ${ }^{(1)}$ | Increment $^{(1)}$ | X | X |

NOTE:
2709 tol 08

1. Pointer will increment if flag is High.

## TABLE II—RESET AND FIRST LOAD TRUTH TABLE

Depth Expansion/Compound Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{RS}}$ | $\overline{\mathrm{FL}}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | $\overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ |
| Reset First Device | 0 | 0 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Reset All Other Devices | 0 | 1 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | $(1)$ | X | X | X | X |

## NOTE:

2709 tol 09

1. $\bar{X}$ is connected to $\overline{X O}$ of previous device. See Figure 10.
2. $\overline{R S}=$ Reset Input, $\mathrm{FL}=$ First Load, $\mathrm{EF}=$ Empty Flag Output, $\mathrm{FF}=$ Flag Full Output, $\overline{\mathrm{XT}}=$ Expansion Input.


Figure 10. Block Diagram of $24,576 \times 9 / 49,152 \times 9$ FIFO Memory (Depth Expansion)


Figure 11. Compound FIFO Expansion

NOTES:

1. For depth expansion block see DEPTH EXPANSION Section and Figure 10.
2. For Flag detection see WIDTH EXPANSION Section and Figure 9.


FIgure 12. Bidirectional FIFO Mode


2709 dw 15
Figure 13. Read Data Flow-Through Mode


Figure 14. Write Data Flow-Through Mode

## ORDERING INFORMATION



32K x 9
IDT7M207S
CMOS PARALLEL IN-OUT FIFO MODULE

## FEATURES:

- First-In/First-Out memory module
- $32 \mathrm{~K} \times 9$ organization
- High speed: 30ns (max.) access time
- Asynchronous and simultaneous read and write
- Fully expandable by both word depth and/or bit width
- MASTER/SLAVE multiprocessing applications
- Bidirectional and rate buffer applications
- Empty and Full warning-flags
- High-performance CEMOS ${ }^{\text {TM }}$ technology
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## DESCRIPTION:

IDT7M207S is a FIFO memory modules constructed on a multi-layered ceramic substrate using four IDT7205 (8K x 9) FIFOs in leadless chip carriers. Extremely high speeds are achieved in this fashion due to the use of IDT7205s fabricated in IDT's high performance CEMOS technology. These devices utilize a algorithm that loads and empties data on a first-
in/first-out basis. The device uses Full and Empty flags to prevent data overilow and underflow and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the device through the use of the WRITE ( $\bar{W}$ ) and READ ( $\overline{\mathrm{R}})$ pins. The devices have a read/write cycle time of 30 ns (min.) for commercial and 35 ns (min.) for military temperature ranges.

The devices utilize a 9 -bit wide data array to allow for control and parity bits at the user's option. This feature is especially useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking.

IDT's Military FIFO modules have semicondutor components manufactued in compliance with the latest revision of MIL-STD-883, Class B, making them ideally suited to applications demanding the highest level of performance and reliability.

## FUNCTIONAL BLOCK DIAGRAM



PIN CONFIGURATION ${ }^{(1)}$


NOTE:

1. For module dimensions, please refer to drawing M1 in the packaging section.

PIN NAMES

| $\overline{\mathrm{W}}=$ WRITE | $\overline{\overline{F L}}=$ FIRST LOAD | $\overline{\overline{x I}}=$ <br> EXPANSION IN | EF $=$ <br> EMPTY FLAG |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{R}}=$ READ | $\mathrm{D}=$ DATAIN | $\overline{\mathrm{XO}}=$ <br> EXPANSIONOUT | $\mathrm{VcC}=$ POWER |
| $\overline{\mathrm{RS}}=$ RESET | Q = DATAOUT | $\overline{F F}=$ <br> FULL FLAG | GND = GROUND |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Mil. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

 2718 tbl 021. Stresses greater than those listedunder ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

## RECOMMENDED DC

OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unlt |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCcM | Military Supply <br> Voltage | 4.5 | 5.0 | 5.5 | V |
| Vcc | Commercial <br> Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH $^{(1)}$ | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| VIH $^{\text {Comput High Voltage }}$ | Input <br> Military | 2.2 | - | - | V |
| Input Low Voltage <br> Commercial and <br> Military | - | - | 0.8 | V |  |

NOTE:
2718 ه 03

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Condition | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=\mathrm{OV}$ | 40 | pF |
| COUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 60 | pF |

NOTE:
2718 tbl 04

1. This parameter is guaranteed by design but not tested.

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7M207S Commercial |  | IDT7M207S Miltary |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{ILI}^{(1)}$ | Input Leakage Current (Any Input) | -5 | 5 | -10 | 10 | $\mu \mathrm{A}$ |
| $1 \mathrm{la}^{(2)}$ | Output Leakage Current | -10 | 10 | -10 | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage 10uT $=-2 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |
| Va | Output Logic "0" Voltage 10 0 = $=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |
| $\mathrm{KCC1}^{(3)}$ | Average Vcc Power Supply Current | - | 600 | - | 720 | mA |
| $\mathrm{KCC2}^{(3)}$ | Average Standby Current ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{F}} \overline{\mathrm{RT}}=\mathrm{V} \mathrm{IH}$ ) | - | 48 | - | 100 | mA |
| $\mathrm{ICC3}^{(3)}$ | Power Down Current (All Input = Vcc-0.2V) | - | 32 | - | 48 | mA |

NOTES:
2718 tb 04

1. Measurements with $0.4 \leq$ VIN $\leq$ Vout.
2. $R \geq \mathrm{V}_{\mathrm{H}}, 0.4 \leq$ Vout $\leq \mathrm{Vcc}$.
3. ICc measurements are made with outputs open.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure $1,2 \& 3$ |



Figure 1. Output Load


Figure 2. Output Load (for trLz, twLZ, and trHz)

* Includes scope and jig capacitances.


## AC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7M207S30 (Com'I. Only) <br> Min. Max. |  | 7M207S35 |  | 7M207S40 |  | 7M207S50 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| tre | Read Cycle Time | 40 | - | 45 | - | 50 | - | 65 | - | ns |
| tA | Access Time | - | 30 | - | 35 | - | 40 | - | 50 | ns |
| tRR | Read Recovery Time | 10 | - | 10 | - | 10 | - | 15 | - | ns |
| tRPW ${ }^{(1)}$ | Read Pulse Width | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| triz ${ }^{(2)}$ | Read Pulse Low to Data Bus at Low Z | 5 | - | 5 | - | 5 | - | 10 | - | ns |
| twLz ${ }^{(2)}$ | Write Pulse High to Data Bus at Low Z | 10 | - | 10 | - | 10 | - | 15 | - | ns |
| tov | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | 一 | 5 | - | ns |
| tRHZ ${ }^{(2)}$ | Read Pulse High to Data Bus at High Z | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| twc | Write Cycle Time | 40 | - | 45 | - | 50 | - | 65 | - | ns |
| tWPW ${ }^{(1)}$ | Write Pulse Width | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| tWR | Write Recovery Time | 10 | - | 10 | - | 10 | - | 15 | - | ns |
| tDS | Data Set-up Time | 18 | - | 20 | - | 23 | - | 30 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 5 | - | ns |
| tRSC | Reset Cycle Time | 40 | - | 45 | - | 50 | - | 65 | - | ns |
| trs ${ }^{(1)}$ | Reset Pulse Width | 30 | - | 35 | - | 40 | - | 50 | - | ns |
| tRSR | Reset Recovery Time | 10 | - | 10 | - | 10 | - | 15 | - | ns |
| tEFL | Reset to Emtpy Flag Low | - | 40 | - | 45 | - | 55 | - | 65 | ns |
| tREF | Read Low to Emtpy Flag Low | - | 30 | - | 35 | - | 40 | - | 50 | ns |
| tRFF | Read High to Full Flag High | - | 30 | - | 35 | - | 40 | - | 50 | ns |
| tWEF | Write High to Empty Flag High | - | 30 | - | 35 | - | 40 | - | 50 | ns |
| tWFF | Write Low to Full Flag Low | - | 30 | - | 35 | - | 40 | - | 50 | ns |
| NOTES: |  |  |  |  |  |  |  |  |  | 2718 tol |

NOTES:

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7M207S60 |  | 7M207S70 |  | 7M207S85 |  | 7M207S120 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| tRC | Read Cycle Time | 75 | - | 85 | - | 105 | - | 140 | - | ns |
| tA | Access Time | - | 60 | - | 70 | - | 85 | - | 120 | ns |
| tRR | Read Recovery Time | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tRPW ${ }^{(1)}$ | Read Pulse Width | 60 | - | 70 | - | 85 | - | 120 | - | ns |
| triz ${ }^{(2)}$ | Read Pulse Low to Data Bus at Low Z | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| twLz ${ }^{(2)}$ | Write Pulse High to Data Bus at Low Z | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tov | Data Valid from Read Pulse High | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| trhz ${ }^{(2)}$ | Read Pulse High to Data Bus at High Z | - | 30 | - | 30 | - | 30 | - | 35 | ns |
| twc | Write Cycle Time | 75 | - | 85 | - | 105 | - | 140 | - | ns |
| tWPW ${ }^{(1)}$ | Write Pulse Width | 60 | - | 70 | - | 85 | - | 120 | - | ns |
| twr | Write Recovery Time | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tDs | Data Set-up Time | 30 | - | 30 | - | 40 | - | 40 | - | ns |
| tDH | Data Hold Time | 5 | - | 10 | - | 10 | - | 10 | - | ns |
| tRSC | Reset Cycle Time | 75 | - | 85 | - | 105 | - | 140 | - | ns |
| tRS ${ }^{(1)}$ | Reset Pulse Width | 60 | - | 70 | - | 85 | - | 120 | - | ns |
| tRSR | Reset Recovery Time | 15 | - | 15 | - | 20 | - | 20 | - | ns |
| tEFL | Reset to Emtpy Flag Low | - | 75 | - | 85 | - | 105 | - | 140 | ns |
| tREF | Read Low to Emtpy Flag Low | - | 60 | - | 70 | - | 85 | - | 120 | ns |
| tRFF ${ }^{\text {\% }}$ | Read High to Full Flag High | - | 60 | - | 70 | - | 85 | - | 120 | ns |
| tWEF | Write High to Empty Flag High | - | 60 | - | 70 | - | 85 | - | 120 | ns |
| tWFF | Write Low to Full Flag Low | - | 60 | - | 70 | - | 85 | - | 120 | ns |

NOTES:

1. Pulse widths less than minimum value are not allowed
2. Values guaranteed by design, not currently tested.

## SIGNAL DESCRIPTIONS:

## INPUTS:

## DATA IN (Do-Ds)

Data Inputs for 9-bit wide data path.

## CONTROLS:

## RESET ( $\overline{\mathrm{RS}}$ )

Reset is accomplished whenever the RESET ( $\overline{\mathrm{RS}}$ ) input is taken to a low state. During RESET, both internal read and write pointers are set to the first location. A reset is required after power up before a write operation can take place. Both the READ ENABLE $(\overline{\mathrm{R}})$ and WRITE ENABLE $(\overline{\mathrm{W}})$ inputs must be in the high state during reset.

## WRITE ENABLE ( $\bar{W}$ )

A write cycle is initiated on the falling edge of this input if the FULL FLAG ( $\overline{\mathrm{FF}}$ ) is not set. Data set-up and hold times must be adhered to with respect the the rising edge of the WRITE $\operatorname{ENABLE}(\bar{W})$. Data is stored in the RAM array sequentially and independently of any ongoing read operation.

To prevent data overflow, the FULL FLAG (茞) will go low, inhibiting further write operations. Upon the completion of a
 tRFF, allowing a valid write to begin.

## READ ENABLE ( $\overline{\mathrm{R}}$ )

A read cycle is initiated on the falling edge of the READ ENABLE $(\overline{\mathrm{R}})$ provided the EMPTY FLAG ( $\overline{\mathrm{EF}}$ ) is not set. The data is accessed on a first-in/first-out basis independent of any ongoing write operations. After READ ENABLE ( $\overline{\mathrm{R}})$ goes high, the Data Outputs (Qo through Q8) will return to a high impedance condition until the next READ operation. When all the data has been read from the FIFO, the EMPTY FLAG ( $\overline{E F}$ )
will go low, inhibiting further read operations with the data outputs remaining in a high impedance state. Once a valid write operation has been accomplished, the EMPTY FLAG ( $\overline{E F}$ ) will go high after tWEF and a valid READ can then begin.
FIRST LOAD (F)
This pin is grounded to indicate that it is the first device. In the multiple module (depth expansion mode) application, this pin on the rest of devices should connect to Vcc for proper operation.

## EXPANSION $\operatorname{IN}(\bar{X})$

EXPANSION IN ( $\overline{\text { II }}$ ) is connected to EXPANSION OUT ( $\overline{\mathrm{XO}}$ ) of the previous (in depth expansion) or same device for proper applications.

## OUTPUTS:

## FULL FLAG (FF)

The FULL FLAG ( $\overline{\mathrm{FF}}$ ) will go low, inhibiting further write operation, when the write pointer is one location from the read pointer, indicating that the device is full. If the read pointer is
 after 32,768 writes for the IDT7M207.

## EXPANSION OUT ( $\overline{\mathrm{XO}})$

EXPANSION OUT ( $\overline{\mathrm{XO}}$ ) is connected to the EXPANSION $\operatorname{IN}(\overline{\mathrm{X}})$ of the same device (single device mode) or the EXPANSION IN (XI) of the next device (multiple device, depth expansion mode) for proper operation. This output acts as a signal to the next device by providing a pulse to the next device when the current device reaches the last location of memory.

## DATA OUTPUTS ( $\mathrm{Qo}_{0}-\mathrm{Q}_{8}$ )

Data outputs for a 9 -bit wide data path. This output is in a high impedance condition whenever READ $(\overline{\mathrm{R}})$ is in a high state.

## TIMING WAVEFORM OF RESET CYCLE ${ }^{(1,2)}$



## NOTES:

1. tRSC $=\mathrm{tRS}+\mathrm{tRSR}$
2. $\mathbb{W}$ and $\stackrel{\rightharpoonup}{\mathrm{A}}=V_{I H}$ during RESET.

## TIMING WAVEFORM OF ASYNCHRONOUS WRITE AND READ OPERATION



TIMING WAVEFORM FOR THE FULL FLAG FROM LAST WRITE TO FIRST READ


TIMING WAVEFORM FOR THE EMPTY FLAG FROM LAST READ TO FIRST WRITE


NOTE:

1. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM FOR THE EMPTY FLAG CYCLE
t tPE EFFECTIVE READ PULSE WIDTH AFTER FULL FLAG HIGH ${ }^{(1)}$


NOTE:

1. (tRPE $=$ tRPW)

TIMING WAVEFORM FOR THE FULL FLAG CYCLE
tRPE EFFECTIVE READ PULSE WIDTH AFTER FULL FLAG HIGH ${ }^{(1)}$


NOTE:

1. $($ twPF $=$ twPW)

## OPERATING MODES

## SINGLE DEVICE MODE

A single IDT7M207 may be used when the application requirements are for 32,768 words or less. The IDT7M207 is in a Single Device Configuration when the EXPANSION IN $(\overline{\mathrm{XI}})$ control input is connected to the EXPANSION OUT ( $\overline{\mathrm{XO}}$ ) of the device and the FIRSTLOAD ( $\overline{\mathrm{FL}})$ controlpin is grounded (see Figure 8).

## WIDTH EXPANSION MODE

Word width may be increased simply by connecting the corresponding input control signals of multiple devices. Status flags ( $\overline{\mathrm{EF}}$ and $\overline{\mathrm{FF}}$ ) can be detected from any one device. Figure 9 demonstrates an 18-bit word width by using two IDT7M207s. Any word width can be attained by adding additional IDT7M207s.

## DEPTH EXPANSION (DAISY CHAIN) MODE

The IDT7M207 can easily be adapted to applications when the requirements are for greater than 32,768 words. Figure 10 demonstrates Depth Expansion using three IDT7M207s. Any depth can be attained by adding additional IDT7M207s. The IDT7M207 operate in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the FIRST LOAD ( $\overline{\mathrm{FL}}$ ) control input.
2. All other devices must have $\overline{F L}$ in the high state.
3. The EXPANSION OUT ( $\overline{\mathrm{XO}})$ pin of each device must be tied to the EXPANSION IN $(\overline{\mathrm{XI}})$ pin of the next device. (See Figure 10.)
4. External logic is needed to generate a composite FULL FLAG $(\overline{\mathrm{FF}})$ and EMPTY FLAG ( $\overline{\mathrm{EF}}$ ). This requires the logical ANDing of all EFs and logical ANDing of all $\overline{F F}$ s
(i.e. all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{E F}$ ). (See Figure 10.)

## COMPOUND EXPANSION MODE

The two expansion techniques described above can be applied together in a straight forward manner to achieve large FIFO arrays (see Figure 11).

## BIDIRECTIONAL MODE

Applications which require data buffering between two systems (each system capable of READ and WRITE operations) can be achieved by pairing IDT7M207s as shown in Figure 12. Care must be taken to assure that the appropriate flag is monitored by each system (i.e. FF is monitored on the device where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\overline{\mathrm{R}}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## DATA FLOW-THROUGH MODES

Two types of flow-through modes are permitted with the IDT7M207: a read flow-through mode and write flow-through mode. For the read flow-through mode (Figure 13), the FIFO permits a reading of a single word of data immediately after writing one word of data into the completely empty FIFO.

In the write flow-through mode (Figure 14), the FIFO permits a writing of a single word of data immediately after reading one word of data from a completely full FIFO.


Figure 8. Block Dlagram of Single IDT7M207 FIFO


NOTE:

1. Flag detection is accomplished by monitoring the $F F$ and $E F$ signals on either (any) device used in the width expansion configuration. Do not connect any output control signals together.

Figure 9. Block Diagram of 32,768 $\times 18$ FIFO Memory Used In Width Expansion Mode

## TRUTH TABLES

TABLE 1 -RESET
Single Device Configuration/Width Expansion Mode

| Mode |  | Inputs |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\overline{\text { XI }}$ | Read Pointer | Write Pointer | EF | FF |  |
| Reset | 0 | 0 | Location Zero | Location Zero | 0 | 1 |  |
| Read/Write | 1 | 0 | Increment ${ }^{(1)}$ | Increment $^{(1)}$ | X | X |  |

NOTE:
2718 tol 08

1. Pointer will increment if flag is High.

## TABLE II—RESET AND FIRST LOAD TRUTH TABLE

Depth Expansion/Compound Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{R S}$ | $\overline{F L}$ | $\overline{X I}$ | Read Pointer | Wrlte Pointer | EF | FF |
| Reset First Device | 0 | 0 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Reset All Other Devices | 0 | 1 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Read Write | 1 | $X$ | $(1)$ | $X$ | X | $X$ | $X$ |

## NOTE:

1. $\overline{X T}$ is connected to $\overline{X O}$ of previous device. See Figure 10.
2. $\overline{\mathrm{RS}}=$ Reset Input, $\overline{\mathrm{FL}}=$ First Load, $\overline{\mathrm{EF}}=$ Empty Flag Output, $\overline{\mathrm{FF}}=$ Flag Full Output, $\overline{\mathrm{XI}}=$ Expansion Input.


Figure 10. Block Diagram of $98,304 \times 9$ FIFO Memory (Depth Expansion)


Figure 11. Compound FIFO Expansion

## NOTES:

1. For depth expansion block see DEPTH EXPANSION Section and Figure 10.
2. For Flag detection see WIDTH EXPANSION Section and Figure 9.


Figure 12. Bidirectional FIFO Mode


Figure 13. Read Data Flow-Through Mode


Figure 14. Write Data Flow-Through Mode

## ORDERING INFORMATION




## FEATURES:

- First-In/First-Out memory module
- $32 \mathrm{~K} \times 18$ organization (IDT7MP2009)
- $16 \mathrm{~K} \times 18$ organization (IDT7MP2010)
- High speed: 20ns (max.) access time
- Separate upper and lower 9-bit $\overline{\mathrm{XI}}$ and $\overline{\mathrm{XO}}$
- Asynchronous and simultaneous read and write
- Fully expandable by both word depth and/or bit width
- MASTER/SLAVE multiprocessing applications
- Bidirectional and rate buffer applications
- Empty and Full warning-flags
- High-performance CEMOS ${ }^{\text {тM }}$ technology
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## DESCRIPTION:

IDT7MP2009/7MP2010 are FIFO memory modules constructed on multi-layered epoxy laminate (FR-4) substrate by mounting eight IDT7205 (8K x 9) or IDT7204 (4K x 9) FIFOs
in plastic leaded chip carriers. Extremely high speeds are achieved in this fashion due to the use of IDT7205s and IDT7204s fabricated in IDT's high performance CEMOS technology. These devices utilize an algorithm that loads and empties data on a first-in/first-out basis. The device uses Full and Empty flags to prevent data overflow and underflow and expansion logic to allow for unlimited expansion capability in both word size and depth.

The reads and writes are internally sequential through the use of ring pointers, with no address information required to load and unload data. Data is toggled in and out of the device through the use of the WRITE ( $\bar{W}$ ) and READ ( $\overline{\mathrm{R}})$ pins. The devices have a read/write cycle time of 30 ns (min.) for commercial temperature ranges:

The devices utilize a 18-bit wide data array to allow for control and parity bits at the user's option. This feature is especially useful in data communications applications where it is necessary to use a parity bit for transmission/reception error checking.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1)}$

| GND $\square^{1}$ |  |  |
| :---: | :---: | :---: |
| 䆄 | 2 | $\square \mathrm{Vcc}$ |
|  | 4 | $\square \overline{\text { XoL }}$ |
| Do $\square^{5}$ |  | $\square \square^{\circ}$ |
| D1 $\square 7$ |  | - |
| D2 - 9 | 8 | $\square{ }^{\square}$ |
| D3 - 11 | 10 | $\square \square^{\square}$ |
| 13 | 12 | $\square C_{3}$ |
| D4 -1 | 14 | $\square \square^{\square}$ |
| Ds $\square^{15}$ |  |  |
| $\mathrm{D}_{6} \mathrm{H}_{17}$ | 16 | $\square 0^{\circ}$ |
| D7 19 | 18 | $\square \square_{6}$ |
|  | 20 | $\mathrm{Q}_{7}$ |
|  | 22 | $\square \mathrm{CB}_{8}$ |
| FL $\square^{23}$ |  |  |
| $\bar{W}-25$ | 24 | $\square \overline{\mathrm{PS}}$ |
| Vcc - 27 | 26 | $\square \mathrm{GND}$ |
|  | 28 | $\square \overline{\mathrm{A}}$ |
|  | 30 | $\square \overline{\text { EF }}$ |
| $\overline{X I H}_{14} \square^{31}$ |  | OH |
| D9 - ${ }^{33}$ | 32 |  |
| D10 $\square^{35}$ | 34 | $\sqsupset \mathrm{CB}_{0}$ |
| D11 ${ }^{37}$ | 36 | $\square$ aı |
| D12 39 | 38 | $\square \square_{1}$ |
|  | 40 | $\square \mathrm{al}_{12}$ |
| D13 - 41 | 42 | $\square{ }^{1}$ |
| D14 $\square 43$ | 42 |  |
| $\mathrm{D}_{15} \square 45$ | 44 | $\square_{\text {Q14 }}$ |
| D16 $\square_{47}$ | 46 | $\square \mathrm{O}_{15}$ |
| $\square 49$ | 48 | $\square \square_{16}$ |
| Vcc $\square 51$ | 50 | $\square \mathrm{Q} 7$ |
| S1 | 52 | $\square \mathrm{GND}$ |

ZIP
2799 drw 02 TOP VIEW

PIN NAMES

| $\bar{W}=$ <br> WRITE | $\overline{\mathrm{FL}}=$ | $\overline{\mathrm{X} I H, \bar{X} I L=}$ | $\overline{\mathrm{EF}}=$ |
| :--- | :--- | :--- | :--- |
| FIRST LOAD | EXPANSION IN | EMPTY FLAG |  |
| $\overline{\mathrm{R}}=$ | DO-17 $=$ | $\overline{\mathrm{X} O H, \bar{X} O L=}$ | VCC $=$ |
| READ | DATAIN | EXPANSION OUT | POWER |
| $\overline{\mathrm{RS}}=$ | Q0-17 $=$ | $\overline{\mathrm{FF}}=$ | GND $=$ |
| RESET | DATAOUT | FULL FLAG | GROUND |

NOTE:

1. For module dimensions, please refer to drawing M45 in the packaging section.

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with Respect <br> to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTE:
2709 tbl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

## RECOMMENDED DC

OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vccc | Commercial <br> Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| $\mathrm{VIH}^{(1)}$ | Input High Voltage <br> Commercial | 2.0 | - | - | V |
| $\mathrm{VIL}^{(1)}$ | Input Low Voltage <br> Commercial | - | - | 0.8 | V |

NOTE:

1. 1.5 V undershoots are allowed for 10 s once per cycle.

2709 tol 03

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 80 | pF |
| COUT | Output Capacitance | VOUT $=0 \mathrm{~V}$ | 120 | pF |

## NOTE:

2709 :04

1. This parameter is guaranteed by design but not tested.

DC ELECTRICAL CHARACTERISTICS
$\left(\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT7MP2010 ${ }^{(4)}$ |  | IDT7MP2009 ${ }^{(5)}$ |  | IDT7MP2010 ${ }^{(6)}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Unit |
| $\\|^{\|L L\|^{(1)}}$ | Input Leakage Current (Any Input) | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| $\|10\|^{(2)}$ | Output Leakage Current | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage lout = -2mA | 2.4 | - | 2.4 | - | 2.4 | - | V |
| Va | Output Logic "0" Voltage lour $=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | - | 0.4 | V |
| Icci ${ }^{(3)}$ | Operating Current | - | 1280 | - | 1200 | - | 975 | mA |
| Icc2 $^{(3)}$ | Average Standby Current ( $\overline{\mathrm{R}}=\overline{\mathrm{W}}=\overline{\mathrm{RS}}=\overline{\mathrm{FL}} / \overline{\mathrm{R}} \overline{\mathrm{T}}=\mathrm{VIH}$ ) | - | 115 | - | 100 | - | 100 | mA |
| lcca $^{(3)}$ | Power Down Current (All Input $=$ Vcc -0.2 V ) | - | 65 | - | 65 | - | 65 | mA |

NOTES:

1. Measurements with $0.4 \leq \mathrm{VIN} \leq$ Vout.
2. $\overline{\mathrm{R}} \geq \mathrm{V} \mathbb{H}, 0.4 \leq$ Vout $\leq \mathrm{V} \subset C$.
3. I $\propto$ c measurements are made with outputs open.
4. $t A A=20,25,30,35 \mathrm{~ns}$.
5. $t A A=30,35,40,50,60,70,85,120 \mathrm{~ns}$.
6. $t A A=40,50,60,70,85,120 \mathrm{~ns}$.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise／Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure $1,2 \& 3$ |



Figure 2．Output Load （for triz，twLz，and trHz） fances．
＊Includes scope and jig capacitances．

## AC ELECTRICAL CHARACTERISTICS

（ $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | 7MP2010S20 |  | 7MP2010S25 |  | 7MP2010S30 <br> 7MP2009S30 |  | $\begin{aligned} & \text { 7MP2010S35 } \\ & \text { 7MP2009S35 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． |  |
| tRC | Read Cycle Time | 30 | － | 35 | － | 40 | － | 45 | － | ns |
| tA | Access Time | － | 20 | － | 25 | － | 30 | － | 35 | ns |
| tRR | Read Recovery Time | 10 | － | 10 | － | 10 | － | 10 | － | ns |
| trPW ${ }^{(1)}$ | Read Pulse Width | 20 | － | 25 | － | 30 | － | 35 | － | ns |
| thlz ${ }^{(2)}$ | Read Pulse Low to Data Bus at Low Z | 5 | － | 5 | － | 5 | 一 | 5 | － | ns |
| twLz ${ }^{(2)}$ | Write Pulse High to Data Bus at Low Z | 5 | － | 5 | － | 10 | － | 10 | － | ns |
| tDV | Data Valid from Read Pulse High | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| tRHZ ${ }^{(2)}$ | Read Pulse High to Data Bus at High Z | － | 13 | － | 20 | － | 20 | － | 20 | ns |
| twe | Write Cycle Time | 30 | － | 35 | － | 40 | － | 45 | － | ns |
| tWPW ${ }^{(1)}$ | Write Pulse Width | 20 | － | 25 | 一 | 30 | － | 35 | － | ns |
| twr | Write Recovery Time | 10 | － | 10 | － | 10 | － | 10 | － | ns |
| tDS | Data Set－up Time | 15 | － | 18 | － | 18 | － | 20 | － | ns |
| tDH | Data Hold Time | 0 | － | 0 | － | 0 | － | 0 | － | ns |
| tRSC | Reset Cycle Time | 30 | － | 35 | － | 40 | － | 45 | － | ns |
| tRS ${ }^{(1)}$ | Reset Pulse Width | 20 | － | 25 | － | 30 | － | 35 | － | ns |
| tRSR | Reset Recovery Time | 10 | － | 10 | － | 10 | － | 10 | － | ns |
| tEFL | Reset to Empty Flag Low | － | 30 | － | 35 | － | 40 | － | 45 | ns |
| tREF | Read Low to Empty Flag Low | － | 20 | － | 25 | － | 30 | － | 35 | ns |
| traf | Read High to Full Flag High | － | 23 | － | 25 | － | 30 | － | 35 | ns |
| tWEF | Write High to Empty Flag High | － | 23 | － | 25 | － | 30 | － | 35 | ns |
| tWFF | Write Low to Full Flag Low | － | 20 | － | 25 | － | 30 | 一 | 35 | ns |

## NOTES：

1．Pulse widths less than minimum value are not allowed．
2．This parameter is guaranteed by design but not tested．

## AC ELECTRICAL CHARACTERISTICS（Continued）

（ $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | $\begin{gathered} \text { 7MP2010S40 } \\ \text { 7MP2009S40 } \\ \text { Min. Max. } \end{gathered}$ |  | $\begin{aligned} & \text { 7MP2010S50 } \\ & \text { 7MP2009S50 } \\ & \text { Min. Max. } \end{aligned}$ |  | $\begin{gathered} \text { 7MP2010S60 } \\ \text { 7MP2009S60 } \\ \text { Min. Max. } \end{gathered}$ |  | $\begin{aligned} & \text { 7MP2010S70 } \\ & \text { 7MP2009S70 } \\ & \text { Min. Max. } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| trc | Read Cycle Time | 50 | － | 65 | － | 75 | － | 85 | － | ns |
| tA | Access Time | － | 40 | － | 50 | － | 60 | － | 70 | ns |
| tRR | Read Recovery Time | 10 | － | 15 | － | 15 | － | 15 | － | ns |
| tRPW ${ }^{(1)}$ | Read Pulse Width | 40 | － | 50 | － | 60 | － | 70 | － | ns |
| tRL $z^{(2)}$ | Read Pulse Low to Data Bus at Low Z | 5 | － | 10 | － | 10 | － | 10 | － | ns |
| twL ${ }^{(2)}$ | Write Pulse High to Data Bus at Low Z | 10 | － | 15 | － | 15 | － | 15 | － | ns |
| tDV | Data Valid from Read Pulse High | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| trhz ${ }^{(2)}$ | Read Pulse High to Data Bus at High Z | － | 25 | － | 30 | － | 30 | － | 30 | ns |
| twc | Write Cycle Time | 50 | － | 65 | － | 75 | 二 | 85 | － | ns |
| twPW ${ }^{(1)}$ | Write Pulse Width | 40 | － | 50 | － | 60 | － | 70 | － | ns |
| twR | Write Recovery Time | 10 | － | 15 | － | 15 | － | 15 | － | ns |
| tDS | Data Set－up Time | 20 | － | 30 | － | 30 | － | 30 | － | ns |
| tDH | Data Hold Time | 0 | － | 5 | － | 5 | － | 10 | － | ns |
| tRSC | Reset Cycle Time | 50 | － | 65 | － | 75 | － | 85 | － | ns |
| tRS ${ }^{(1)}$ | Reset Pulse Width | 40 | － | 50 | － | 60 | － | 70 | － | ns |
| tRSR | Reset Recovery Time | 10 | － | 15 | － | 15 | － | 15 | － | ns |
| tEFL | Reset to Empty Flag Low | － | 50 | － | 65 | － | 75 | － | 85 | ns |
| treF | Read Low to Empty Flag Low | － | 40 | － | 50 | － | 60 | － | 70 | ns |
| tRFF | Read High to Full Flag High | － | 40 | － | 50 | － | 60 | － | 70 | ns |
| tWEF | Write High to Empty Fiag High | － | 40 | － | 50 | 一 | 60 | 一 | 70 | ns |
| tWFF | Write Low to Full Flag Low | － | 40 | 二 | 50 | － | 60 | － | 70 | ns |

NOTES：
1．Pulse widths less than minimum value are not allowed．
2．This parameter is guaranteed by design but not tested．

## SIGNAL DESCRIPTIONS:

## INPUTS:

## DATA IN (Do-D17)

Data Inputs for 18-bit wide data path.

## CONTROLS:

## RESET ( $\overline{\mathrm{RS}}$ )

Reset is accomplished whenever the RESET ( $\overline{\mathrm{RS}}$ ) input is taken to a low state. During RESET, both internal read and write pointers are set to the first location. A reset is required after power up before a write operation can take place. Both the READ ENABLE $(\overline{\mathrm{R}})$ and WRITE ENABLE $(\bar{W})$ inputs must be in the high state during reset.

## WRITE ENABLE ( $\bar{W}$ )

A write cycle is initiated on the falling edge of this input if the FULL FLAG ( $\overline{\mathrm{FF}})$ is not set. Data set-up and hold times must be adhered to with respect the the rising edge of the WRITE ENABLE $(\bar{W})$. Data is stored in the RAM array sequentially and independently of any ongoing read operation.

To prevent data overflow, the FULL FLAG ( $\overline{\mathrm{FF}})$ will go low, inhibiting further write operations. Upon the completion of a valid read operation, the FULL FLAG ( $\overline{\mathrm{FF}})$ will go high after tRFF, allowing a valid write to begin.

## READ ENABLE ( $\overline{\mathrm{R}}$ )

A read cycle is initiated on the falling edge of the READ ENABLE $(\bar{R})$ provided the EMPTY FLAG ( $\overline{\mathrm{EF}})$ is not set. The data is accessed on a first-in/first-out basis independent of any ongoing write operations. After READ ENABLE $(\overline{\mathrm{R}})$ goes high, the Data Outputs (Q0 through Q17) will return to a high impedance condition until the next READ operation. When all the data hasbeen read from the FIFO, the EMPTY FLAG ( $\overline{\mathrm{EF}}$ ) will go low, inhibiting further read operations with the data
outputs remaining in a high impedance state. Once a valid write operation has been accomplished, the EMPTY FLAG ( $\overline{E F}$ ) will go high after tWEF and a valid READ can then begin.

## FIRST LOAD ( $\overline{\mathrm{FL}}$ )

This pin is grounded to indicate that it is the first device. In the multiple module (depth expansion mode) application, this pin on the rest of devices should connect to Vcc for proper operation.

## EXPANSION IN ( $\overline{\mathrm{XI}})$

EXPANSION IN ( $\overline{\mathrm{XI}})$ is connected to EXPANSION OUT ( $\overline{\mathrm{XO}}$ ) of the previous (in depth expansion) or same device for proper applications.

## OUTPUTS:

## FULL FLAG ( $\overline{\mathrm{FF}}$ )

The FULL FLAG $(\overline{\mathrm{FF}})$ will go low, inhibiting further write operation, when the write pointer is one location from the read pointer, indicating that the device is full. If the read pointer is not moved after RESET ( $\overline{\mathrm{RS}})$, the FULL FLAG ( $\overline{\mathrm{FF}})$ will go low after 32,768 writes for the IDT7MP2009 and 16,384 writes for the IDT7MP2010.

## EXPANSION OUT ( $\overline{\mathrm{XO}})$

EXPANSION OUT $(\overline{X O})$ is connected to the EXPANSION IN (XI) of the same device (single device mode) or the EXPANSION IN ( $\overline{\mathrm{XI}})$ of the next device (multiple device, depth expansion mode) for proper operation. This output acts as a signal to the next device by providing a pulse to the next device when the current device reaches the last location of memory.

## DATA OUTPUTS (Q0-Q17)

Data outputs for a 18-bit wide data path. This output is in a high impedance condition whenever READ $(\overline{\mathrm{R}})$ is in a high state.

## TIMING WAVEFORM OF RESET CYCLE ${ }^{(1,2)}$



## NOTES:

1. $\mathrm{tRSC}=\mathrm{t}$ RS +tRSR
2. $\bar{W}$ and $\overline{\mathrm{R}}=\mathrm{V}_{H}$ during RESET.

## TIMING WAVEFORM OF ASYNCHRONOUS WRITE AND READ OPERATION



TIMING WAVEFORM FOR THE FULL FLAG FROM LAST WRITE TO FIRST READ


2799 drw 06

TIMING WAVEFORM FOR THE EMPTY FLAG FROM LAST READ TO FIRST WRITE


1. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF THE EMPTY FLAG CYCLE


NOTE:

1. (tRPE $=$ tRPW $)$

TIMING WAVEFORM OF THE FULL FLAG CYCLE


NOTE:

1. ( $\mathrm{t} W \mathrm{PF}=\mathrm{t} W \mathrm{FW}$ )

## OPERATING MODES

## SINGLE DEVICE MODE

A single IDT7MP2009/2010 may be used when the application requirements are for $32,768 / 16,384$ words or less. The IDT7MP2009/2010 is in a Single Device Configuration when the EXPANSION IN ( $\overline{\mathrm{XI}})$ control input is connected to the EXPANSION OUT ( $\overline{\mathrm{XO}})$ of the device and the FIRST LOAD $(\overline{\mathrm{FL}})$ control pin is grounded (see Figure 8).

## WIDTH EXPANSION MODE

Word width may be increased simply by connecting the corresponding input control signals of multiple devices. Status flags ( $\overline{E F}$ and $\overline{F F}$ ) can be detected from any one device. Figure 9 demonstrates an 36 -bitword width by using two IDT7MP2009/ 2010. Any word width can be attained by adding additional IDT7MP2009/2010s.

## DEPTH EXPANSION (DAISY CHAIN) MODE

The IDT7MP2009/2010 can easily be adapted to applications when the requirements are for greater than 32,768 / 16,384 words. Figure 10 demonstrates Depth Expansion using three IDT7MP2009/2010. Any depth can be attained by adding additional IDT7MP2009/2010s. The IDT7MP2009/ 2010 operate in the Depth Expansion configuration when the following conditions are met:

1. The first device must be designated by grounding the FIRST LOAD ( $\overline{\mathrm{FL}}$ ) control input.
2. All other devices must have $\overline{F L}$ in the high state.
3. The EXPANSION OUT ( $\overline{\mathrm{XO}}$ ) pin of each device must be tied to the EXPANSION IN $(\overline{\mathrm{XI}})$ pin of the next device.
(See Figure 10.)
4. External logic is needed to generate a composite FULL FLAG ( $\overline{\mathrm{FF}}$ ) and EMPTY FLAG ( $\overline{\mathrm{EF}}$ ). This requires the logical ANDing of all EFs and logical ANDing of all $\overline{F F} S$ (i.e. all must be set to generate the correct composite $\overline{\mathrm{FF}}$ or $\overline{E F}$. (See Figure 10.)

## COMPOUND EXPANSION MODE

The two expansion techniques described above can be applied together in a straight forward manner to achieve large FIFO arrays (see Figure 11).

## BIDIRECTIONAL MODE

Applications which require data buffering between two systems (each system capable of READ and WRITE operations) can be achieved by pairing IDT7MP2005/2011s as shown in Figure 12. Care must be taken to assure that the appropriate flag is monitored by each system (i.e. $\overline{\mathrm{FF}}$ is monitored on the device where $\bar{W}$ is used; $\overline{E F}$ is monitored on the device where $\overline{\mathrm{R}}$ is used). Both Depth Expansion and Width Expansion may be used in this mode.

## DATA FLOW-THROUGH MODES

Two types of flow-through modes are permitted with the IDT7MP2009/2010: a read flow-through mode and write flowthrough mode. For the read flow-through mode (Figure 13), the FIFO permits a reading of a single word of data immediately after writing one word of data into the completely empty FIFO.

In the write flow-through mode (Figure 14), the FIFO permits a writing of a single word of data immediately after reading one word of data from a completely full FIFO.


Figure 8. Block Diagram of Single IDT7MP2009/7MP2010 FIFO


2799 drw 11
NOTE:

1. Flag detection is accomplished by monitoring the FF and EF signals on either (any) device used in the width expansion configuration. Do not connect any output control signals together.

Figure 9. Block Diagram of $32,768 / 16,384 \times 36$ FIFO Memory Used In Width Expansion Mode

TRUTH TABLES
TABLE - - RESET
Single Device Configuration/Width Expansion Mode

| Mode | Inputs |  | Internal Status |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS | XI | Read Pointer | Write Pointer | EF | FF |
| Reset | 0 | 0 | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | 0 | Increment ${ }^{(1)}$ | Increment ${ }^{(1)}$ | X | X |

NOTE:
2709 tol 08

1. Pointer will increment if flag is High.

## TABLE II-RESET AND FIRST LOAD TRUTH TABLE

Depth Expansion/Compound Expansion Mode

| Mode | Inputs |  |  | Internal Status |  | Outputs |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathrm{RS}}$ | $\overline{\mathrm{F}}$ | $\overline{\mathrm{XI}}$ | Read Pointer | Write Pointer | $\overline{\mathrm{EF}}$ | $\overline{\mathrm{FF}}$ |
| Reset First Device | 0 | 0 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Reset All Other Devices | 0 | 1 | $(1)$ | Location Zero | Location Zero | 0 | 1 |
| Read/Write | 1 | X | $(1)$ | X | X | X | X |

## NOTE:

1. $X$ I is connected to $X O$ of previous device. See Figure 10.
2. $\overline{R S}=$ Reset Input, $F[=$ First Load, $E F=$ Empty Flag Output, $\overline{F F}=$ Flag Full Output, $\overline{X T}=$ Expansion Input.


Figure 10. Block Dlagram of 93,304/49,152 x 18 FIFO Memory (Depth Expansion)


Flgure 11. Compound FIFO Expansion

## NOTES:

1. For depth expansion block see DEPTH EXPANSION Section and Figure 10.
2. For Flag detection see WIDTH EXPANSION Section and Figure 9.


2799 drw 14

Figure 12. Bldirectional FIFO Mode


Figure 13. Read Data Flow-Through Mode


Figure 14. Write Data Flow-Through Mode

ORDERING INFORMATION


2799 drw 17


## FEATURES:

- High-density separate I/O, 1 megabit CMOS static RAM module
- Fast access times: 35ns (max.)
- Surface mounted LCC components mounted on a co-fired ceramic substrate
- Available in low profile 30-pin ceramic SIP (Single In-line Package)
- Low power consumption
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT7MC4001 is a $1024 \mathrm{~K} \times 1$ high-speed static RAM module with separate I/O. The module is constructed on a cofired ceramic substrate using four $256 \mathrm{~K} \times 1$ static RAMs in surface mount packages. Extremely fast speeds can be achieved by using RAMs fabricated in IDT's high-performance, high-reliability CEMOS ${ }^{\top M}$ technology.

The IDT7MC family of ceramic SIPs offers the optimum in packing density and profile height. The IDT7MC4001 is offered in a 30 -pin ceramic SIP (Single In-line Package). At only 420 mils high, this low profile package is ideal for systems with minimal board spacing.

The IDT7MC4001 is available with maximum access times as fast as 35 ns, with maximum power consumption of 1.35 watts. The module also offers a full standby mode of 330 mW (max.).

All inputs and outputs of the IDT7MC4001 are TTL-compatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1)}$



NOTE:

1. For module dimensions, please refer to module drawing M35 in the packaging section.

## PIN NAMES

| AO-A17 | Address |
| :--- | :--- |
| DATAIn | Data Input |
| DATAout | Data Output |
| $\overline{C S}_{0-3}$ | Chip Select |
| $\overline{\text { WE }} 0-3$ | Write Enable |
| Vcc | Power |
| GND | Ground |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Ratlng | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TbIAS | TemperatureUnder Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| lour | DC Output Current | 50 | mA |

NOTE:
$2710 * 03$

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Test | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{ViN}=\mathrm{OV}$ | 35 | pF |
| Cout | Output Capacitance | Vout $=\mathrm{OV}$ | 20 | pF |

NOTE:
2710 tbl 04

1. This parameter is guaranteed by design but not tested.

RECOMMENDED DC.OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2710 허 05

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING

 TEMPERATURE AND SUPPLY VOLTAGE| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

TRUTH TABLE

| Mode | $\overline{\mathrm{CS}}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :--- | :--- |
| Standby | H | X | HighZ | Standby |
| Read | L | H | Dout | Active |
| Write | L | L | High Z | Active |

DC ELECTRICAL CHARACTERISTICS
$\left(V C C=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \||니 | Input Leakage Current | Vcc = Max., VIN = GND to Vcc | - | 20 | $\mu \mathrm{A}$ |
| \|ILO| | Output Leakage Current | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V O U T=G N D \text { to } V C C \end{aligned}$ | - | 20 | $\mu \mathrm{A}$ |
| Icct | Operating Power Supply Current | $\begin{aligned} & f=0, \overline{C S}=V I L, V C C=M a x ., \\ & \text { Output Open } \end{aligned}$ | - | 225 | mA |
| ICC2 | Dynamic Operating Current | $\begin{aligned} & \text { Vcc = Max., } \overline{C S}=\text { VIL, } \\ & \mathrm{f}=\mathrm{fmax}, \text { Output Open } \end{aligned}$ | - | 245 | mA |
| ISB | Standby Power Supply Current | $\overline{\mathrm{CS}} \geq \mathrm{VIH}$ or TTL Level, $V C C=$ Max., $f=$ fmax, Output Open | - | 180 | mA |
| ISB1 | Full Standby Power Supply Current | $\overline{\mathrm{CS}} \geq$ VHC, VIN $\geq$ VHC or $\leq$ VLC Vcs = Max., Output Open | - | 60 | mA |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min}$., $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load (for tclz, tchz, tow, and twhz)
*Including scope and jig.

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | IDT7MC4001S35 |  | IDT7MC4001S45 |  | IDT7MC4001S55 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 35 | - | 45 | - | 55 | - | ns |
| tAA | Address Access Time | - | 35 | - | 45 | - | 55 | ns |
| tacs | Chip Select Access Time | - | 35 | - | 45 | - | 55 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 10 | - | 10 | - | 10 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 25 | - | 35 | - | 45 | ns |
| 1 OH | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{tPu}^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 35 | - | 45 | - | 55 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |
| twe | Write Cycle Time | 35 | - | 45 | - | 55 | - | ns |
| tcw | Chip Selection to End of Write | 30 | - | 40 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 30 | - | 40 | - | 50 | - | ns |
| tas | Address Set-up Time | 5 | - | 5 | - | 5 | - | ns |
| twp | Write Pulse Width | 25 | - | 35 | - | 45 | - | ns |
| twr | Write Recovery Time | 5 | - | 5 | - | 5 | - | ns |
| twhz ${ }^{(1)}$ | Write Enable to Ouput in High Z | - | 25 | - | 30 | - | 40 | ns |
| tDw | Data Valid to End of Write | 20 | - | 25 | - | 35 | - | ns |
| tDH | Data Hold from Write Time | 5 | - | 5 | - | 5 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design but not tested.

## TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$



TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3)}$


NOTES:

1. WE is high for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{V}$ V.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\text { WE CONTROLLED TIMING) }}{ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{C S}$ CONTROLLED TIMING) ${ }^{(1,2,3,5)}$


## NOTES:

1. WE or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low $\overline{W E}$.
3. twR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going High to the end of write cycle.
4. During this period, I/O pins are in the output state and inputs signals must not be applied.
5. If the $\overline{\mathrm{CS}}$ Low transition occurs simultaneously with or after the $\bar{W} E$ Low transitions, the outputs remain in a high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state. This parameter is graranteed by design, but not tested.

## ORDERING INFORMATION




## 256K X 4 CMOS STATIC RAM MODULE

## FEATURES:

- High density 1 megabit CMOS static RAM module
- Equivalent to the JEDEC standard for future monolithic 256K $\times 4$ with output enable static RAMs
- Fast access time
- Commercial: 30ns (max.)
- Military: 35ns (max.)
- Surface mounted leadless chip carriers on an 28-pin 400 mil ceramic DIP substrate
- Single 5 V ( $\pm 10 \%$ ) power supply
- Inputs/outputs directly TTL compatible
- Modules available with semiconductor components compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7M4042 is a ( $256 \mathrm{~K} \times 4$ with output enable) static RAM module constructed on a co-fired ceramic substrate using four ( $64 \mathrm{~K} \times 4$ ) static RAMs and an IDT74FCT139 decoder in leadless chip carriers. Extremely fast speeds can be achieved using 256K static RAMs and logic fabricated in , IDT's high performance, high-reliability CEMOS ${ }^{\text {M }}$ technology. The IDT7M4042 is available with access times as fast as 30 ns commercial and 35ns military with minimal power consumption.

The IDT7M4042 is packaged in a 28 -pin ceramic DIP. This results in a package 1.6 inches long, 400 mils wide and only 280 mils thick.

All inputs and outputs of the IDT7M4042 are TTL compatible and operate from a single 5V supply. Full asynchronous circuitry requires no clocks or refresh for operation.

All IDT7M4042 military module semiconductor components are compliant to the latest revision of MIL-STD-883, Class B, making them ideally suited for applications demanding the highest levels of performance and reliability.

PIN CONFIGURATION ${ }^{(1)}$


## NOTE:

1. For module dimensions, please refer to module drawing M2 in the packaging section.

FUNCTIONAL BLOCK DIAGRAM


2670 drw 02
PIN NAMES

| $1 / O_{1-4}$ | Data Inputs/Outputs |
| :--- | :--- |
| $A 0-17$ | Addresses |
| $\overline{\mathrm{CS}}$ | Chip Select |
| $\overline{\text { WE }}$ | Write Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| VCC | Power |
| GND | Ground |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2670 tol 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at the se or any other conditions above those indicated in the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED

DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :--- | :--- | :---: | :---: | :---: |
| ILI | Input Leakage | $\mathrm{VCC}=$ Max. <br> $\mathrm{VIN}=\mathrm{GND}$ to VCC | - | 40 | UA |
| ILO | Output Leakage | $\mathrm{VCC}=\mathrm{Max}$. <br> $\mathrm{CS}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND}$ to VCC | - | 40 | UA |
| VOL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} . \mathrm{IOL}=8 \mathrm{~mA}$ |  |  |  |
|  |  | $\mathrm{VCC}=\mathrm{Min} \mathrm{IOL}=.10 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} . \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | 0.5 | V |


| Symbol | Parameter | Test Conditions | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| ICC | Dynamic Operating Current | $\begin{aligned} & V C C=\text { Max. } \overline{C S}=V \text { VIL } \\ & \mathrm{f}=\mathrm{fMAX} ; \text { Outputs Open } \end{aligned}$ | 320 | mA |
| IsB | Standby Supply Current | $\begin{aligned} & \text { VCC = Max. } \overline{C S}=V \text { IH } \\ & f=\text { fMAX; Outputs Open } \end{aligned}$ | 148 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & C S \geq V C C-0.2 V \\ & V I N>V C C-0.2 V \text { or }<0.2 V \end{aligned}$ | 122 | mA |

TRUTH TABLE

| Mode | $\overline{\text { CSxx }}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: |
| Standby | H | X | High Z | Standby |
| Read | L | H | DATAOUT | Active |
| Write | L | L | High Z | Active |

CAPACITANCE $^{(1)}\left(\mathrm{TA}^{(1)}+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Condltions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{CIN}^{(1)}$ | Input Capacitance | V IN $=0 \mathrm{~V}$ | 40 | pF |
| $\mathrm{CIN}^{(2)}$ | Input Capacitance <br> $\left(\overline{\mathrm{CS}}, A_{16-17)}\right.$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 10 | pF |
| CouT | Output Capacitance | VOUT $=0 \mathrm{~V}$ | 40 | pF |

NOTE:
2670 ы 11

1. This parameter guaranteed by design, but not tested.

## AC ELECTRICAL CHARACTERISTICS

$\left(V C C=5 \mathrm{~V} \pm 10 \%, T A=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

|  |  | 7M4042S30 | 7M4042S35 | 7M4042S45 | 7M4042S55 | 7M4042S65 | 7M4042S80 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameters | Min. Max. <br> Min. Max. | Min. Max. | Min. Max. | Min. Max. | Min. Max. | Unit |


| tRC | Read Cycle Time | 30 | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| taA | Address Access Time | - | 30 | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |
| tacs | Chip Select Access Time | - | 30 | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |
| tCLI ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 12 | - | 15 | - | 27 | - | 32 | - | 37 | - | 47 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Select to Output in High Z | - | 18 | - | 21 | - | 23 | - | 28 | - | 33 | - | 38 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 10 | - | 13 | - | 15 | - | 15 | - | 20 | - | 25 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tPU ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to PowerDown Time | - | 30 | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | ns |

## Write Cycle

| twc | Write Cycle Time | 30 | - | 35 | - | 45 | - | 55 | - | 65 | - | 80 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tcw | Chip Select to End of Write | 30 | - | 30 | - | 40 | - | 50 | - | 60 | - | 70 | - | ns |
| taw | Address Valid to End of Write | 30 | - | 30 | - | 40 | - | 50 | - | 60 | - | 70 | - | ns |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 20 | - | 22 | - | 30 | - | 40 | - | 50 | - | 60 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 2 | - | 2 | - | 2 | - | ns |
| twHZ ${ }^{(1)}$ | Write Enable to Output in High Z | - | 13 | - | 13 | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| tDW | Data to Write Time Overlap | 15 | - | 17 | - | 22 | - | 27 | - | 32 | - | 40 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design, but not tested.

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load
(for $\mathrm{TCLZ}, \mathrm{tOLZ}, \mathrm{tchz}$, tohz, tow, twHz)

* Including scope and jig.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


NOTES:
1 WE is High for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{VIL}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low
4. $\overline{O E}=V / L$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter guaranteed by design, but not tested.
timing Waveform of write cycle no. 1 (产E CONTROLLED timing) ${ }^{(1,2,3,7)}$


## TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{C S}$ CONTROLLED TIMING) ${ }^{(1,2,3,5)}$



NOTES:

1. $\overline{W E}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (tcw or twP) of a low $\overline{C S}$ and a low $\overline{W E}$.

3 tWR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of the write cycle.
4. During this period, the I/O pins are in the output state, and input signals must not be applied.
5. If the $\overline{C S}$ low transition occurs simultaneously with or after the $\bar{W} E$ low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter guaranteed by design, but not tested.
7. If $\overline{O E}$ is low during a $\overline{W E}$ controlled write cycle, the write pulse width must be the larger of twP or (twHZ + tow) to allow the l/O drivers to turn off and data to be placed on the bus for the required tDW. If $\overline{O E}$ is high during a $\overline{W E}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified tw.

## ORDERING INFORMATION



## 64K x 8

IDT7M812
IDT7M912

## FEATURES:

- High-density 512K CMOS static RAM module
- $64 \mathrm{~K} \times 8$ (IDT7M812) or $64 \mathrm{~K} \times 9$ (IDT7M912) configuration
- Fast access times
- Military: 25ns (max.)
- Commercial: 15ns (max.)
- Low power consumption
- Active: 2.4 W (typ. in $64 \mathrm{~K} \times 8$ organization)
- Standby: $240 \mu \mathrm{~W}$ (typ. in $64 \mathrm{~K} \times 8$ organization)
- Available in $40-\mathrm{pin}, 600 \mathrm{mil}$ center sidebraze DIP
- Single 5V ( $\pm 10 \%$ ) power supply
- Dual VCC and GND pins for maximum noise immunity
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT7M812/IDT7M912 are 512 K high-speed CMOS static RAMs constructed on a multi-layered co-fired ceramic substrate using 8 IDT7187 ( $64 \mathrm{~K} \times 1$ ) static RAMs (IDT7M812) or 9 IDT7187 static RAMs (IDT7M912) in leadless chip carriers. Extremely high speeds can be achieved by the use of IDT7187s fabricated in IDT's high-performance, high-reliability technology, CEMOS™.

The IDT7M812/IDT7M912 are available with maximum access times as fast as 15 ns commercial and 25 ns military temperature ranges, with maximum operating power consumption of only 8.9 W (IDT7M912, 25ns, $64 \mathrm{~K} \times 9$ option). The module also offers a standby power mode of 3.2W (max.) and a full standby mode of 1.2W (max.).

The IDT7M812/IDT7M912 are offered in a high-density 40-pin, 600 mil center sidebraze DIP to take full advantage of the compact IDT7187s in leadlesschip carriers. The IDT7M912 ( $64 \mathrm{~K} \times 9$ ) option can provide more flexibility in system application for error detection, parity bit, etc.

All inputs and outputs of the IDT7M812/IDT7M912 are TTL-compatible and operate from a single 5V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

All IDT military module semiconductor components are compliant to the latest revision of MIL-STD-883, Class B, making them ideally suited to applications demanding the highest level of performance and reliability.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1,2)}$



NOTES:

1. For the IDT7M912 (64K $\times 9$ version)Pin 18 and $P$ in 23 are D8 and $Y 8$ respectively. For the IDT7M812 ( $64 \mathrm{~K} \times 8$ version), these pins are No Connects.
2. For module dimensions, please refer to drawing M9 and M10 in the packaging section.

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commerical | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

267202

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2672 tbl 03

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## PIN NAMES

| A0-A15 | Address |
| :---: | :---: |
| D0-D8 | Data Input |
| Yo-Y8 | Data Output |
| $\overline{\mathrm{CS}}$ | Chip Select |
| WE | Write Enable |
| Vcc | Power |
| GND | Ground |
| NC | No Connect |

2672 tbl 08

## TRUTH TABLE

| Mode | $\overline{\text { CS }}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: |
| Standby | H | X | High Z | Standby |
| Read | L | H | DATAouT | Active |
| Write | L | L | High Z | Active |

2672 ゅ1 06

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | 50 | mA |

NOTE:
2672 tا 01

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ${ }^{(1)}\left(T A=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | 7M812 ${ }^{(2)}$ | 7M912 ${ }^{\text {22 }}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CIN(D) | Input Capacitance (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 12 | 12 | pF |
| CIN(A) | Input Capacitance (Address) | $\mathrm{VIN}=0 \mathrm{~V}$ | 72 | 80 | pF |
| $\mathrm{CIN}(\mathrm{C})$ | Input Capacitance ( $\overline{\mathrm{CS}}, \overline{\mathrm{WE}})$ | $\mathrm{V} / \mathrm{N}=0 \mathrm{~V}$ | 72 | 80 | pF |
| Cout | Output Capacitance | VOUT $=0 \mathrm{~V}$ | 12 | 12 | pr |

NOTES:

1. This parameter is guaranteed by design but not tested.
2. Maximum rated values

DC ELECTRICAL CHARACTERISTICS
(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \| $\mid$ III | Input Leakage (Address \& Control) | Vcc = Max.; VIN =GND to Vcc | - | 40 | $\mu \mathrm{A}$ |
| \| In | | Input Leakage (Data) | Vcc = Max.; VIN =GND to Vcc | - | 5 | $\mu \mathrm{A}$ |
| \| ilo | Output Leakage | Vcc = Max.; $\overline{\mathrm{CS}}=\mathrm{VIH}$, Vout = GND to Vcc | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} . ; \mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=$ Min. $; \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |


| Symbol | Parameter | Test Conditions | IDT7M812 |  |  |  | IDT7M912 |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. ${ }^{\text {(1) }}$ | Max. ${ }^{(3)}$ | Max. ${ }^{(2)}$ | Min. | Typ. ${ }^{(1)}$ | Max. ${ }^{(3)}$ | Max. ${ }^{(2)}$ |  |
| Icc1 | Operating Current | $\begin{aligned} & f=0 ; \overline{C S}=V_{I L} \\ & V c c=M a x . ; \text { Output Open } \end{aligned}$ | - | 520 | 1080 | 1120 | - | 580 | 1215 | 1260 | mA |
| ICC2 | Dynamic Operating Current | $\begin{aligned} & \text { VCC }=\text { Max. } ; \overline{C S}=\text { VIL; } f=f \text { max } \\ & \text { Output Open } \end{aligned}$ | - | 520 | 1440 | 1400 | - | 580 | 1620 | 1575 | mA |
| ISB | Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \text { VIH, VCC = Max. } \\ & \mathrm{f}=\mathrm{fMAX}, \text { Outputs Open } \end{aligned}$ | - | 280 | 520 | 520 | - | 310 | 585 | 585 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{C S} \geq V C C-0.2 V ; \\ & V I N>V C C-0.2 V \text { or }<0.2 V \end{aligned}$ | - | 0.1 | 200 | 200 | - | 0.4 | 225 | 225 | mA |

NOTES:

1. $\mathrm{VcC}=5.0 \mathrm{~V}, \mathrm{TA}=+25^{\circ} \mathrm{C}$.
2. $\angle A A=20,25,30,35,45,55,65 \mathrm{~ns}$.
3. $t A A=15 \mathrm{~ns}$.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1,2 and 3 |



Figure 1. Output Load


Figure 2. Output Load (for tohz, tolz, twhz and tow)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { 7M812S15 } \\ \text { 7M912S15 } \\ \text { (Com'l. Only) } \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { 7M812S20 } \\ \text { 7M912S20 } \\ \text { (Com'I. Only) } \end{gathered}$ |  | 7M812S25 <br> 7M912S25 |  | $\begin{aligned} & \text { 7M812S30 } \\ & \text { 7M912S30 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 15 | - | 20 | - | 25 | - | 30 | - | ns |
| taA | Address Access Time | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| tacs | Chip Select Access Time | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| tor | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tolz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| torz ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 6 | - | 6 | - | 20 | - | 25 | ns |
| $\mathrm{tPu}^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power-Down Time | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |
| two | Write Cycle Time | 12 | - | 15 | - | 25 | - | 30 | - | ns |
| tcw | Chip Select to End of Write | 12 | - | 15 | - | 23 | - | 28 | - | ns |
| taw | Address Valid to End of Write | 12 | - | 15 | - | 23 | - | 28 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 3 | - | 3 | - | ns |
| twp | Write Pulse Width | 12 | - | 15 | - | 20 | - | 25 | - | ns |
| twh | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow | Data to Write Time Overlap | 8 | - | 10 | - | 15 | - | 20 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 5 | - | 5 | - | ns |
| twhz ${ }^{(1)}$ | Write Enable to Output in High Z | - | 6 | - | 8 | 0 | 20 | 0 | 25 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTE:

1. This parameter is guaranteed by design, but not tested.

## AC ELECTRICAL CHARACTERISTICS (Cont'd.)

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{aligned} & \hline \text { 7M812S35 } \\ & \text { 7M912S35 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { 7M812S45 } \\ & 7 \text { M912S45 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { 7M812S55 } \\ & \text { 7M912S55 } \end{aligned}$ |  | $\begin{aligned} & \text { 7M812S65 } \\ & 7 \text { M912S65 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 35 | - | 45 | - | 55 | - | 65 | - | ns |
| tAA | Address Access Time | - | 35 | - | 45 | - | 55 | - | 65 | ns |
| tacs | Chip Select Access Time | - | 35 | - | 45 | - | 55 | - | 65 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tolz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{OOHz}^{(1)}$ | Chip Deselect to Output in High Z | - | 25 | - | 30 | - | 30 | - | 30 | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD $^{(1)}$ | Chip Deselect to Power-Down Time | - | 35 | - | 35 | - | 35 | - | 35 | ns |


| Write Cycle |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twc | Write Cycle Time | 35 | - | 45 | - | 55 | - | 65 | - | ns |
| tcw | Chip Select to End of Write | 35 | - | 40 | - | 50 | - | 55 | - | ns |
| taw | Address Valid to End of Write | 35 | - | 40 | - | 50 | - | 55 | - | ns |
| tas | Address Set-up Time | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twp | Write Pulse Width | 30 | - | 30 | - | 35 | - | 40 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tDW | Data to Write Time Overlap | 20 | - | 25 | - | 25 | - | 30 | - | ns |
| tDH | Data Hold from Write Time | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twhz ${ }^{(1)}$ | Write Enable to Output in High Z | 0 | 25 | 0 | 30 | 0 | 30 | 0 | 35 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTE:

1. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1,2)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,3)}$


## NOTES:

1. WE is high for READ cycle.
2. $\bar{C}$ is low for READ cycle.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. Transition is measured $\pm 200 \mathrm{mV}$ from steady state voltage with specified loading in Figure 2. This parameter is guaranteed by design, but not tested.
5. All READ cycle timings are referenced from the last valid address to the first transitioning address.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\mathrm{WE}}$ CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{C S}$ CONTROLLED TIMING) ${ }^{(1,2,3,5)}$


## NOTES:

1. WE or $\overline{\mathrm{CS}}$ must be high during all address transactions.
2. A write occurs during the overlap (twP) of a low $\overline{\mathrm{CS}}$ and a low $\overline{\mathrm{WE}}$
3. twR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of write cycle.
4. During this period, I/O pins are in the output state and input signals must not be applied.
5. If the $\overline{C S}$ low transition occurs simultaneously with or after the $\overline{W E}$ low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design, but not tested.

## ORDERING INFORMATION




## FEATURES:

- High-density 1 megabit ( $128 \mathrm{~K} \times 8$ )CMOS static RAM module
- High-speed
- Military: 35ns (max.)
- Commercial: 25ns (max.)
- Low power consumption
- Active: less than 550 mW (typ.)
- Standby: less than 20 mW (typ.)
- Offered in the JEDEC standard 32-pin, 600 mil wide ceramic sidebraze DIP
- Single 5V ( $\pm 10 \%$ ) power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT8M824S is a $128 \mathrm{~K} \times 8$ high-speed CMOS static RAM constructed on a co-fired ceramic substrate using four $32 \mathrm{~K} \times 8$ static RAMs and a FCT139 decoder in leadless chip carriers. Functional equivalence to monolithic one megabit static RAMs is achieved by utilization of an on board decoder that interprets the higher order address A15 and A16 to select one of the four $32 \mathrm{~K} \times 8$ RAMs. Extremely fast speeds can be achieved with this technique due to use of 256 K static RAMs and the decoder fabricated in IDT's high-performance, highreliability CEMOS technology.

The IDT8M824S is available with maximum access times as fast as 25 ns for commercial temperature range, with maximum power consumption of 2.5 watts. The module offers a full standby mode of 440 mW (max.).

The IDT8M824S is offered in a 32-pin, 600 mil center sidebraze DIP, adhering to JEDEC standards for one megabit monolithic pinouts.

All inputs and outputs of the IDT8M824S are TTL-compatible and operate from a single 5V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

All IDT military module semiconductor components are manufactured in compliance to the latest revision of MIL-STD883 , Class B , making them ideally suited to applications demanding the highest level of performance and reliability.

[^15]ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias <br> Storage | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED

DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unlt |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | -0.5 (1) | - | 0.8 | V |

NOTE:

1. VII (min.) = -3.0V for pulse width less than 20ns.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | IDT8M824S |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ ${ }^{(1)}$ | Max. ${ }^{(2)}$ | Max ${ }^{(3)}$ |  |
| \| 1 L| | Input Leakage Current | $\begin{aligned} & \mathrm{Vcc}=\mathrm{Max} . \\ & \mathrm{VIN}=\text { GND to } \mathrm{VCC} \end{aligned}$ | - | - | 20 | 40 | $\mu \mathrm{A}$ |
| \|lıO| | Output Leakage Current | $\begin{aligned} & V C C=M a x . \\ & \overline{C S}=V_{I H}, V O U T=G N D \text { to } V C C \end{aligned}$ | - | - | 20 | 40 | UA |
| Icc | Dynamic Operating Current | $\begin{aligned} & \text { Vcc = Max., } \overline{\mathrm{CS}}=\mathrm{VIL}, \\ & \mathrm{f}=\text { fMAX, Output Open } \end{aligned}$ | - | 150 | 450 | 265 | mA |
| ISB | Standby Supply Current | $\begin{aligned} & \text { VCC = MAX. } \overline{C S}=V_{I H} \\ & f=\text { fmax, Outputs open } \end{aligned}$ | - | 10 | 280 | 85 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VCC}-0.2 \mathrm{~V} \\ & \mathrm{VIN}>\mathrm{VCc}-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V} \end{aligned}$ | - | 10 | 80 | 80 | mA |
| Vol | Output Low Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{lOL}=8 \mathrm{~mA} \end{aligned}$ | - | - | 0.4 | 0.4 | V |
| VOH | Output High Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{OH}=-4 \mathrm{~mA} \end{aligned}$ | 2.4 | - | - | - | V |

NOTES:
2656 b 05

1. $V C C=5 V, T A=+25^{\circ} \mathrm{C}$.
2. $t A A=25 \mathrm{~ns}$.
3. $t A A=30,35,40,45,50,60,70,85,100 \mathrm{~ns}$.

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load (for telzi,2, toLz, tCHZ1,2, tOHz, tow, twhz)

- Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ or $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { 8M824S25 } \\ \text { (Com'l. Only) } \end{gathered}$ |  | 8 M 824 S 30(Com'l. Only) |  | 8M824S35 |  | 8M824S40 |  | 8M824S45 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tAA | Address Access Time | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tacs | Chip Select Access Time | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tCLZ 1, , $^{\text {¹ }}$ ) | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 10 | - | 11 | - | 13 | - | 25 | - | 25 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 2 | - | 2 | - | 2 | - | 5 | - | 5 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Select to Output in High Z | - | 15 | - | 16 | - | 20 | - | 20 | - | 20 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 8 | - | 10 | - | 15 | - | 20 | - | 20 | ns |
| tor | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tpu(1) | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{1}$ ) | Chip Deselect to Power-Down Time | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twC | Write Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tCW | Chip Select to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAW | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 5 | - | 5 | - | ns |
| twp | Write Pulse Width | 15 | - | 20 | - | 23 | - | 30 | - | 35 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 2 | - | 5 | - | 5 | - | ns |
| tWHZ ${ }^{\text {(1) }}$ | Write Enable to Output in High Z | - | 10 | - | 11 | - | 15 | - | 15 | - | 15 | ns |
| tDW | Data to Write Time Overlap | 11 | - | 13 | - | 14 | - | 15 | - | 20 | - | ns |
| tDH | Data Hold from Write Time | 3 | - | 3 | - | 3 | - | 3 | - | 5 | - | ns |
| tow(1) | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |


| Symbol | Parameter | 8M824S50 |  | $\begin{aligned} & \hline \text { 8M824S60 } \\ & \text { (Mil. Only) } \end{aligned}$ |  | $\begin{aligned} & \hline \text { 8M824S70 } \\ & \text { (MII. Only) } \end{aligned}$ |  | $\begin{aligned} & \text { 8M824S85 } \\ & \text { (MII. Only) } \end{aligned}$ |  | $\begin{aligned} & \text { 8M824S100 } \\ & \text { (Mil. Only) } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Mln. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 50 | - | 60 | - | 70 | - | 85 | - | 100 | - | ns |
| tAA | Address Access Time | - | 50 | - | 60 | - | 70 | - | 85 | - | 100 | ns |
| tacs | Chip Select Access Time | - | 50 | - | 60 | - | 70 | - | 85 | - | 100 | ns |
| tCLZ1,2 ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 30 | - | 35 | - | 40 | - | 50 | - | 60 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Select to Output in High Z | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| to $\mathrm{HZ}^{(1)}$ | Output Disable to Output in High Z | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tPU(1) | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power-Down Time | - | 50 | - | 60 | - | 70 | - | 85 | - | 100 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 50 | - | 60 | - | 70 | - | 85 | - | 100 | - | ns |
| tcw | Chip Select to End of Write | 45 | - | 55 | - | 65 | - | 75 | - | 90 | - | ns |
| taw | Address Valid to End of Write | 45 | - | 55 | - | 65 | - | 75 | - | 90 | - | ns |
| tAS | Address Set-up Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twp | Write Pulse Width | 40 | - | 50 | - | 60 | - | 70 | - | 80 | - | ns |
| tWR | Write Recovery Time | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | ns |
| tWHZ ${ }^{(1)}$ | Write Enable to Output in High Z | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tow | Data to Write Time Overlap | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tDH | Data Hold from Write Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter guaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


NOTES:
2656 dww 06

1. WE is High for Read Cycle.
2. Device is continuously selected, $\overline{C S}=$ VIL.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 (WE CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\text { CS }}$ CONTROLLED TIMING) $)^{(1,2,3,5)}$


NOTES:

1. $\overline{W E}$ or $\overline{C S}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low $\bar{W} E$.

3 twR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of the write cycle.
4. During this period, the l/O pins are in the output state, and input signals must not be applied.
5. If the $\overline{C S}$ low transition occurs simultaneously with or after the $\overline{W E}$ low transition, the outputs remain in the high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter guaranteed by design, but not tested.
7. During a $\bar{W} E$ controlled write cycle, write pulse (twP $>t W H Z+t D W$ ) to allow the $I / O$ drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during a $\overline{W E}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\text { OE }}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | High Z | Standby |
| Read | L | L | H | DouT | Active |
| Read | L | H | H | High Z | Active |
| Write | L | X | L | Din | Active |

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter(1) | Conditions | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| CIN(D) | Input <br> Capacitance <br> (data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 35 | 50 | pF |
| CIN(AC1) | Input <br> Capacitance <br> (A0-14, $\overline{\mathrm{OE}, \overline{\mathrm{WE}})}$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 35 | 50 | pF |
| CIN(AC2) | Input <br> Capacitance <br> (A15-16, $\overline{\mathrm{CS}})$ | VoUT $=0 \mathrm{~V}$ | - | 14 | pF |
| COUT | Output <br> Capacitance | VOUT $=0 \mathrm{~V}$ | 35 | 50 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

ORDERING INFORMATION



## FEATURES:

- High-density 1 megabit CMOS static RAM module
- Fast access time
- 25ns (max.)
- Low-power consumption
- Active: less than 500 mW (typ.)
— Standby: less than 8.8 mW (typ.)
- Cost-effective plastic surface-mounted RAM packages on an epoxy laminate (FR-4) substrate
- Offered in a 30-pin SIP (Single In-line Package ) for maximum space-saving
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible


## PIN CONFIGURATION ${ }^{(1)}$



2715 ctw 01
SIP BACK VIEW

## DESCRIPTION:

The IDT8MP824S is ( $128 \mathrm{~K} \times 8$ ) high-speed CMOS static RAM module constructed on an epoxy laminate substrate using four $32 \mathrm{~K} \times 8$ static RAMs in plastic surface mount packages. Functional equivalence to proposed monolithic one megabit static RAMs is achieved by utilization of an onboard decoder that interprets the higher order address A15 and A 16 to select one of the four $32 \mathrm{~K} \times 8$ RAMs. Extremely fast speeds can be achieved with this technique due to use of 256K static RAMs and decoder fabricated in IDT's highperformance, high-reliability CEMOS ${ }^{\top M}$ technology.

The IDT8MP824S is available with maximum access times as fast as 25 ns over the commercial temperature range, with maximum operating power consumption of 825 mW . The module also offers a full standby mode of 330 mW (max.).

The IDT8MP824S is offered in a $30-\mathrm{pin}$ SIP (single in-line) package. For the 32-pin JEDEC standard DIP, refer to the IDT8M824S module.

All inputs and outputs of the IDT8MP824S are TTLcompatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation, and providing equal access and cycle times for ease of use.

FUNCTIONAL BLOCK DIAGRAM


2715 drw 02

## NOTE:

1. For module dimensions, please refer to module drawing M36 in the
packaging section.

## PIN NAMES

| A0-16 | Addresses |
| :--- | :--- |
| I/O1-8 | Data Input/Output |
| $\overline{\mathrm{CS}}$ | Chip Select |
| Vcc | Power |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| GND | Ground |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TbIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation | 1.0 | W |
| IOUT | DC Output Current | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{V}_{\mathrm{IL}}(\mathrm{min})=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND VOLTAGE SUPPLY

| Grade | Amblent Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT8MP824S |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | $\text { Typ. }{ }^{(1)}$ | Max. |  |
| \|lu| | Input Leakage Current | Vcc $=$ Max., VIN = GND to Vcc | - | - | 15 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage Current | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V O U T=G N D \text { to } V C C \end{aligned}$ | - | - | 15 | $\mu \mathrm{A}$ |
| Icc | Dynamic Operating Current | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{VIL} \\ & \mathrm{VcC}=\text { Max., Output Open } \\ & \mathrm{f}=\mathrm{fmAX} \end{aligned}$ | - | 100 | 200 | mA |
| ISB | Standby Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VIH} \\ & \mathrm{VCC}=\text { Max. } \\ & \text { Output Open } \end{aligned}$ | - | 2 | 80 | mA |
| IsB1 | Full Standby Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \text { VHC, VIN } \geq \text { VHC or } \leq \text { VLC } \\ & \text { VCC }=\text { Max., Output Open } \end{aligned}$ | - | 1.6 | 60 | mA |
| VOL | Output Low Voltage | $\mathrm{IOL}=8 \mathrm{~mA}, \mathrm{VCC}=\mathrm{Min}$. | - | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}, \mathrm{VcC}=$ Min. | 2.4 | - | - | V |

## NOTE:

1. $\mathrm{VCC}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


2715 dmw 03
Figure 2. Output Load (for tclz, tolz, tchz, totz, tow, twhz)

* Including scope and jig


## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | 8MP824S25 <br> Min. Max. | 8MP824S30 <br> Min. Max. | 8MP824S35 <br> Min. Max. | 8MP824S40 <br> Min. Max. | 8MP824S45 <br> Min. Max. | 8MP824S50 <br> Min. Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| READ CYCLE |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | 30 | 35 | 40 | 45 | 50 | ns |
| tas | Address Access Time | 25 | 30 | 35 | 40 | 45 | 50 | ns |
| tacs | Chip Select Access Time | 25 | 30 | 35 | 40 | 45 | 50 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | 5 | 5 | 5 | 5 | 5 | ns |
| toe | Output Enable to Output Valid | 10 | 11 | 13 | 25 | 25 | - 30 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 2 | 2 | 2 | 5 | 5 | 5 | ns |
| tchz ${ }^{(1)}$ | Chip Select to Output in High Z | 15 | 16 | 20 | 20 | 20 | - 20 | ns |
| $\mathrm{tOHz}^{(1)}$ | Output Disable to Output in High Z | 8 | 10 | 15 | 20 | 20 | 20 | ns |
| tor | Output Hold from Address Change | 5 | 5 | 5 | 5 | 5 | 5 | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | 0 | 0 | 0 | 0 | 0 | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | 25 | - 30 | - 35 | - 40 | - 45 | - 50 | ns |


| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twc | Write Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | $50-$ | ns |
| tcw | Chip Select to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| taw | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tAS | Address Setup Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 - | ns |
| twp | Write Pulse Width | 15 | - | 20 | - | 23 | - | 30 | - | 35 | - | $40-$ | ns |
| tWh | Write Recovery Time | 0 | - | 0 | - | 2 | - | 5 | - | 5 | - | 5 - | ns |
| tWHZ ${ }^{(1)}$ | Write Enable to Output in High Z | - | 10 | - | 11 | - | 15 | - | 15 | - | 15 | - 20 | ns |
| tDW | Data to Write Time Overlap | 11 | - | 13 | - | 14 | - | 15 | - | 20 | - | 20 | ns |
| tDH | Data Hold from Write Time | 3 | - | 3 | - | 3 | - | 3 | 二 | 5 | - | 5 - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 - | ns |

NOTE:

1. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $\mathbf{2}^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


2715 drw 06

NOTES:

1. $\overline{W E}$ is High for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{VII}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=V \mathrm{IL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$


## TIMING WAVEFORM OF WRITE CYCLE NO. $2^{(1,6)}$



## NOTES:

1. $\overline{\mathrm{WE}}, \overline{\mathrm{CS}}$ must be high during all address transitions,
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low $\overline{W E}$.
3. twP is measured from the earlier of $\overline{C S}$ or WE going high to the end of the write cycle.
4. During this period, I/O pins are in the output state so that the input signals of opposite phase to the output must not be applied.
5. If the CS low transition occurs simultaneously with the $\bar{W} E$ low transition or after the $\bar{W} E$ transition, outputs remain in a high impedance state.
6. $\overline{O E}$ is continuously low $(\overline{O E}=V i L)$.
7. Dout is the same phase of write data of this write cycle.
8. If $\overline{\mathrm{CS}}$ is low during this period, I/O pins are in the output state. Then the data input signals of opposite phase to the outputs must not be applied to them.
9. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :--- | :--- |
| Standby | H | X | X | High Z | Standby |
| Read | L | L | H | DouT | Active |
| Read | L | H | H | High Z | Active |
| Write | L | X | L | Din | Active |

CAPACITANCE ( $T A=+25^{\circ} \mathrm{C}, \mathrm{t}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=$ OV | 35 | pF |
| COUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 40 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION




## FEATURES:

- High-density 1 megabit CMOS static RAM module
- Fast access time - 70 ns (max.)
- Low-power consumption
- Active: less than 400 mW (typ.)
- Standby: less than $50 \mu \mathrm{~W}$ (typ.)
- Cost-effective plastic surface-mounted RAM packages on an epoxy laminate (FR-4) substrate
- Offered in a 30 -pin SIP (Single In-line Package) for maximum space-savings
- Single 5V ( $\pm 10 \%$ ) power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT8MP824L is $128 \mathrm{~K} \times 8$ high-speed CMOS static RAM constructed on an epoxy laminate substrate using four $32 \mathrm{~K} \times 8$ static RAMs in plastic surface mount packages. Functional equivalence to proposed monolithic one megabit static RAMs is achieved by utilization of an on-board decoder that interprets the higher order address A15 and A16 to select one of the four $32 \mathrm{~K} \times 8$ RAMs.

The IDT8MP824L is available with maximum access times as fast as $70 n \mathrm{n}$ for commercial range, with maximum power consumption of 660 mW . The module also offers a full standby mode of 2.2 mW (max.).

The IDT8MP824L is offered in a 30 -pin SIP (Single In-line Package). For the 32-pin JEDEC sidebrazed DIP, refer to the IDT8M824S module.

All inputs and outputs of the IDT8MP824L are TTLcompatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiringno clocks or refreshing for operation.

PIN CONFIGURATION ${ }^{(1)}$


NOTE:

1. For module dimensions, please refer to module drawing M36 in the packaging section.

FUNCTIONAL BLOCK DIAGRAM


2716 drw 02
PIN NAMES

| $\mathrm{A0}-16$ | Addresses |
| :--- | :--- |
| $\mathrm{I} / \mathrm{O} 1-8$ | Data Input/Output |
| $\overline{\mathrm{CS}}$ | Chip Select |
| VCC | Power Supply |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| GND | Ground |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation | 1.0 | W |
| IOUT | DC Output Current | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATING may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC OPERATING

 CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2716 tb 03

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND VOLTAGE SUPPLY

| Grade | Ambient Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| $2716 \pm 104$ |  |  |  |

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT8MP824L |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. ${ }^{(1)}$ | Max. |  |
| \| $\mathrm{L} \mid$ \| | Input Leakage Current | Vcc = Max., VIN = GND to Vcc | - | - | 15 | $\mu \mathrm{A}$ |
| \|ll. ${ }^{\text {\| }}$ | Output Leakage Current | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{CS}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | - | 15 | $\mu \mathrm{A}$ |
| Iccı | Operating Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \leq \mathrm{VIL} \\ & \mathrm{VCC}=\text { Max., Output Open } \\ & t=0 \end{aligned}$ | - | 10 | 80 | mA |
| Icc2 | Dynamic Operating Current | $\begin{aligned} & \overline{\mathrm{CS}} \leq \mathrm{VIL} \\ & \mathrm{VCC}=\text { Max., Output Open } \\ & \mathrm{f}=\mathrm{fmax} \end{aligned}$ | - | 80 | 120 | mA |
| IsB | Standby Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VIH} \\ & \mathrm{VCC}=\mathrm{Max} ., \text { Output Open } \\ & \mathrm{f}=\mathrm{fMAX} \end{aligned}$ | - | 6 | 12 | mA |
| ISB1 | Full Standby Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}}>\mathrm{VCC}-0.2 \mathrm{~V} \\ & \mathrm{VIN}>\mathrm{VCC}-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V} \end{aligned}$ | - | 10 | 400 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathrm{lOL}=2.1 \mathrm{~mA}, \mathrm{Vcc}=$ Min. | - | - | 0.4 | V |
| Voh | Output High Voltage | $\mathrm{IOH}=-1 \mathrm{~mA}, \mathrm{VcC}=$ Min. | 2.4 | - | 二 | V |

NOTE:
2716 tol 05

1. $V C C=5 V, T_{A}=+25^{\circ} \mathrm{C}$

## AC TEST CONDITIONS

| In Pulse Levels |
| :--- |
| Input Rise/Fall Times |
| Input Timing Reference Levels |
| Output Reference Levels |
| Output Load |


| GND to 3.0 V |
| :---: |
| 10 ss |
| 1.5 V |
| 1.5 V |
| See Figures 1 and 2 |



Figure 1. Output Load


2716 drw 03
Figure 2. Output Load (for tclz, tolz, tchz, totz, tow, twhz)

- Including scope and jig


## AC ELECTRICAL CHARACTERISTICS

$\left(V C C=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | IDT8 <br> Min. | $\begin{aligned} & 24 L 70 \\ & \text { Max. } \end{aligned}$ | IDT8 <br> Min. | $\begin{aligned} & \text { 4L85 } \\ & \text { Max. } \end{aligned}$ | IDT8 Min. | $\begin{aligned} & \text { 4L100 } \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| READ CYCLE |  |  |  |  |  |  |  |  |
| tre | Read Cycle Time | 70 | - | 85 | - | 100 | - | ns |
| tAA | Address Access Time | - | 70 | - | 85 | - | 100 | ns |
| tacs | Chip Select Access Time | - | 70 | - | 85 | - | 100 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 10 | - | 10 | - | 10 | - | ns |
| toe | Output Enable to Output Valid | - | 40 | - | 50 | - | 60 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Select to Output in High Z | - | 30 | - | 35 | - | 40 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 30 | - | 35 | - | 40 | ns |
| tOH | Output Hold from Address Change | 5. | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | ns |
| $t P D^{(1)}$ | Chip Deselect to Power Down Time | - | 70 | - | 85 | - | 100 | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 70 | - | 85 | - | 100 | - | ns |
| tcw | Chip Select to End of Write | 65 | - | 75 | - | 90 | - | ns |
| taw | Address Valid to End of Write | 65 | - | 75 | - | 90 | - | ns |
| tAS | Address Setup Time | 5 | - | 5 | - | 5 | - | ns |
| tWP | Write Pulse Width | 60 | - | 70 | - | 80 | - | ns |
| tWR | Write Recovery Time | 5 | - | 5 | - | 5 | - | ns |
| tWHZ ${ }^{(1)}$ | Write Enable to Output in High Z | - | 30 | - | 35 | - | 40 | ns |
| tDw | Data to Write Time Overlap | 30 | - | 35 | - | 40 | - | ns |
| tDH | Data Hold from Write Time | 5 | - | 5 | - | 5 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


2716 drw 06

NOTES:

1. WE is High for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{V} / \mathrm{LL}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$


2716 dw 07

TIMING WAVEFORM OF WRITE CYCLE NO. $2^{(1,6)}$


## NOTES:

1. $\overline{\mathrm{WE}}, \overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (WP) of a low CS.
3. twP is measured from the earlier of CS or WE going high to the end of the write cycle.
4. During this period, $1 / O$ pins are in the output state so that the input signals of opposite phase to the output must not be applied.
5. If the $\overline{C S}$ low transition occurs simultaneously with the $\overline{W E}$ low transition or after the $\overline{W E}$ transition, outputs remain in a high impedance state.
6. $\overline{O E}$ is continuously low ( $\overline{O E}=V$ VIL $)$.
7. Dout is the same phase of write data of this write cycle.
8. If $\overline{\mathrm{CS}}$ is low during this period, I/O pins are in the output state. Then the data input signals of opposite phase to the outputs must not be applied to them.
9. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

## TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Standby | H | X | X | High Z | Standby |
| Read | L | L | H | Dout | Active |
| Read | L | H | H | High Z | Active |
| Write | L | X | L | Din | Active |

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | VIN $=0 \mathrm{~V}$ | 35 | pF |
| COUT | Output Capacitance | VoUT $=0 \mathrm{~V}$ | 40 | pF |
| NOTE: |  |  |  |  |
| 1. This parameter is guaranteed by design but not tested. |  |  |  |  |$.$| $2716 \pm 109$ |
| :--- | :--- |

## ORDERING INFORMATION



Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
FR-4 SIP (Single In-line Package)
Speed in Nanoseconds
Low Power
$128 \mathrm{~K} \times 8$ CMOS Static RAM Module

## 256K x 8 <br> CMOS STATIC RAM MODULE

## PRELIMINARY IDT7MP4034

## FEATURES:

- High density separate I/O, 2 megabit CMOS static RAM module
- Fast access time: 20ns (max.)
- Low profile 42-pin ZIP (Zig-zag In-line Package)
- Surface mounted plastic components on an epoxy laminate (FR-4) substrate
- Single 5 V (+10\%) power supply
- Inputs/outputs directly TTL compatible
- Multiple GND pins for maximum noise immunity


## DESCRIPTION:

The IDT7MP4034 is a separate l/O 2 megabit CMOS static RAM module constructed on an epoxy laminate (FR-4) substrate using $8256 \mathrm{~K} \times 1$ static RAMs in plastic SOJ packages. Availability of two chip select lines (one for each
group of four RAM) provides nibble access and allows the user to configure the memory into a $256 \mathrm{~K} \times 8$ or a $512 \mathrm{~K} \times 4$ organization. Extremely fast speeds can be achieved using 256K static RAMs fabricated in IDT's high performance, high reliability CEMOST technology. The IDT7MP4034 is available with access times as fast as $20 n s$ with minimal power consumption.

The 7MP family of ZIPs, DSIPs and SIPs offers the optimum in packing density and profile height. The IDT7MP4034 is packaged in a 42 pin FR-4 ZIP (Zig-zag In-line vertical Package). The memory configuration results in a package 2.65 inches long and 0.35 inches wide. At only 0.50 inches high, this low profile package is ideal for high performance systems with minimum board spacing.

All inputs and outputs of the IDT7MP4034 are TTL compatible and operate from a single 5 V supply. Full asynchronous circuitry requires no clocks or refresh for operation.

## PIN CONFIGURATION ${ }^{(1)}$

| GND | 1 | 2 | Vcc |
| :---: | :---: | :---: | :---: |
| $\mathrm{DI}(0)$ | 3 | 4 | DO(0) |
| $\mathrm{DI}(1)$ | 5 | 6 | DO(1) |
| $\mathrm{DI}(2)$ | 7 | 8 | DO(2) |
| DI(3) | 9 | 10 | DO(3) |
| A(0) | 11 | 12 | A(1) |
| A(2) | 13 | 14 | A(3) |
| A(4) | 15 | 16 | A(5) |
| A(6) | 17 | 18 | A(7) |
| $\overline{\mathrm{CS}(0)}$ | 19 | 20 | GND |
| WE | 21 | 22 | $\overline{\mathrm{CS}(1)}$ |
| A(8) | 23 | 24 | A(9) |
| A(10) | 25 | 26 | A(11) |
| A(12) | 27 | 28 | A(13) |
| A(14) | 29 | 30 |  |
| A(16) | 31 | 32 | A(17) |
| DI(4) | 33 | 34 | DO(4) |
| DI(5) | 35 | 36 | DO(5) |
| $\mathrm{DI}(6)$ | 37 | 38 | DO(6) |
| DI(7) | 39 | 40 | DO(7) |
| Vcc | 41 | 42 | GND |
| 2745 drw 01 |  |  |  |
|  |  |  |  |

NOTE:

1. For module dimensions, please refer to drawing M44 in the packaging section.

FUNCTIONAL BLOCK DIAGRAM


PIN NAMES

| Dlo-7 | Data Inputs |
| :---: | :--- |
| DO0-7 | Data Outputs |
| A0-17 | Addresses |
| $\overline{\mathrm{CS} 0-1}$ | Chip Selects |
| $\overline{\mathrm{WE}}$ | Write Enable |
| Vcc | Power |
| GND | Ground |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TbIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |
| 2745 tol 02 |  |  |  |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| $\mathrm{VIH}_{\mathrm{IH}}$ | Input High Voltage | 2.2 | - | 6.0 | V |
| $\mathrm{~V}_{\text {IL }}$ | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $V_{I L}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING <br> TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS ( $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ TO $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | MIn. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \| 1 L| | Input Leakage <br> (Address and Control) | $\begin{aligned} & \mathrm{Vcc}=\mathrm{Max} . \\ & \mathrm{Vin}=\text { GND to } \mathrm{Vcc} \end{aligned}$ | - | 40 | $\mu \mathrm{A}$ |
| \||니| | Input Leakage (Data) | $\begin{aligned} & \text { VcC = Max. } \\ & \text { VIN = GND to Vcc } \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V O U T=G N D \text { to } V C C \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| VoL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{Vcc}=\mathrm{Min} ., \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |
| IcC | Dynamic Operating Current | $\begin{aligned} & \overline{\mathrm{CS}}=\text { VIL, Output Open } \\ & \text { VCC }=\text { Max., } F=F M A X \end{aligned}$ | - | 1,280 | mA |
| IsB | Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VIH}, \mathrm{VCC}=\text { Max. } \\ & \text { Outputs Open, } F=F \text { MAX } \end{aligned}$ | - | 280 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VCC}-0.2 \mathrm{~V}, \\ & \mathrm{VIN}>\mathrm{VCC}-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V}, \mathrm{~F}=0 \end{aligned}$ | - | 240 | mA |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1,2 and 3 |



Figure 1. Output Load


2745 drw 03
Figure 2. Output Load (for tchz, tclz, low and twhz)

- Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7MP4034S20 |  | 7MP4034S25 |  | 7MP4034S35 |  | 7MP4034S45 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. |  |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 20 | - | 25 | - | 35 | - | 45 | - | ns |
| tAA | Address Access Time | - | 20 | - | 25 | - | 35 | - | 45 | ns |
| tacs | Chip Select Access Time | - | 20 | - | 25 | - | 35 | - | 45 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 3 | - | 5 | 一 | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 10 | - | 13 | - | 20 | - | 25 | ns |
| toh | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tpu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 20 | - | 25 | - | 35 | - | 45 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 20 | - | 25 | - | 35 | - | 45 | - | ns |
| tcw | Chip Select to End of Write | 17 | - | 22 | - | 30 | - | 40 | - | ns |
| taw | Address Valid to End of Write | 17 | - | 22 | - | 30 | - | 40 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 17 | - | 22 | - | 30 | - | 40 | - | ns |
| tWR | Write Recovery Time | 0 | - | 3 | - | 3 | - | 3 | - | ns |
| twhz $^{(1)}$ | Write Enable to Output in High Z | - | 10 | - | 13 | - | 20 | - | 25 | ns |
| tDw | Data to Write Time Overlap | 13 | - | 15 | - | 20 | - | 25 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3)}$


## NOTES:

1. $\overline{W E}$ is high for read cycle.
2. Device is continuously selected, $\overline{\mathrm{C}}=\mathrm{V} / \mathrm{L}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.
timing Waveform of write cycle no. $1^{(1,2,3)}$ (WE CONTROLLED TIMING)


2745 dnw 07

## timing waveform of write cycle no. $1^{(1,2,3,4)}$ (CS CONTROLLED TIMING)



2745 drw 08

NOTES:

1. $\overline{W E}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (tCW or twP) of a low $\overline{C S}$ and a low $\bar{W} E$.
3. twR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of the write cycle.
4. If the $\overline{\mathrm{CS}}$ low transition occurs simultaneous with or after the $\overline{\mathrm{WE}}$ low transition, the outputs remain in the high impedance state.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.

## TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :--- | :--- |
| Standby | H | X | High-Z | Standby |
| Read | L | H | DATAOUT | Active |
| Write | L | L | DATAIN | Active |

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| CIN(D) | Input Capacitance <br> (Data) | $\mathrm{V} \operatorname{IN}=\mathrm{OV}$ | 15 | pF |
| $\mathrm{CIN}(\mathrm{A})$ | Input Capacitance <br> (Address and Control) | $\mathrm{V} \operatorname{IN}=\mathrm{OV}$ | 92 | pF |
| Cout | Output Capacitance | Vout $=0 \mathrm{~V}$ | 15 | pF |

## NOTE:

1. This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION



Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
FR-4 ZIP (Zig-zag In-line Package)


Standard Power
256K x 8 Static RAM Module

512K x 8
CMOS STATIC RAM MODULE

## PRELIMINARY <br> IDT7M4048 <br> IDT7MB4048

multilayer epoxy laminate (FR-4) substrate using four 1 Megabit static RAMS and a decoder. The IDT7M4048/ 7 MB 4048 is available with access times as fast as 30 ns . For battery backup applications, a very low power version is available, offering a data retention current of $200 \mu \mathrm{~A}$.

The IDT7M4048 is packaged in a 32-pin ceramic DIP. This results in a package 1.7 inches long and 600 mils wide, packing 4 megabits into the JEDEC DIP footprint. The IDT7MB4048 likewise is packaged in a 32-pin FR-4 DIP resulting in the same JEDEC footprint in a package 1.6 inches long and 600 mils wide.

All inputs and outputs of the IDT7M4048 and 7MB4048 are TTL compatible and operate from a single 5 V supply. Fully asynchronous circuitry requires no clocks or refresh for operation and provides equal access and cycle times for ease of use. All IDT military module semiconductor components are manufactured in compliance to the latest revision of MIL-STD-883 Class B, making them ideally suited for applications demanding the highest level of performance and reliability.

## PIN CONFIGURATION ${ }^{(1)}$



NOTE:

1. For module dimensions, please refer to module drawing M3, M4, or M5 (7M4048L, 7M4048S, 7MB4048S) in the packaging section.

## TRUTH TABLE

| Mode | CS | $\overline{\text { OE }}$ | WE | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | High-Z | Standby |
| Read | L | L | H | Dout | Active |
| Read | L | H | H | High-Z | Active |
| Write | L | X | L | DIN | Active |

CAPACITANCE ${ }^{(1)}\left(\right.$ TA $\left.^{2}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 35 | pF |
| $\mathrm{CIN}(\mathrm{C})$ | Input Capacitance ( $\overline{\mathrm{CS}})$ | $\mathrm{ViN}=0 \mathrm{~V}$ | 8 | pF |
| COUT | Output Capacitance | Vout $=0 \mathrm{~V}$ | 35 | pF |

NOTE:
10

1. This parameter is guaranteed by design, but not tested.

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output Current | 50 | 50 | mA |

NOTE:
2675 tbl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2675 あ 03

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5 \mathrm{~V} \pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5 \mathrm{~V} \pm 10 \%$ |

1. $\mathrm{V}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 7M404 | xxN | 7MB4048SxxP 7M4048SxxC 7M4048SxxCB |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | (COM'L ONLY) |  | (COM'L) |  | (MILITARY) |  |  |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| \||LI| | Input Leakage | $V C C=M a x ., V$ IN $=$ GND to Vcc | - | 4 | - | 8 | - | 40 | $\mu \mathrm{A}$ |
| \|liLo | Output Leakage | $\begin{aligned} & \text { VCC = Max., } \overline{\mathrm{CS}}=\mathrm{VIH}, \\ & \text { Vout }=\text { GND to } \mathrm{VCC} \end{aligned}$ | - | 4 | - | 8 | - | 40 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\begin{aligned} & \mathrm{VCC}=\operatorname{Min}_{.,}, \mathrm{IOL}=2 \mathrm{~mA}^{(2)}, \\ & \mathrm{OL}=8 \mathrm{~mA}^{(3)} \end{aligned}$ | - | 0.4 | - | 0.4 | - | 0.4 | V |
| VOH | Output High Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min}, \mathrm{OOH}=-1 \mathrm{~mA}^{(2)}, \\ & \mathrm{IOH}=-4 \mathrm{~mA}^{(3)} \end{aligned}$ | 2.4 | - | 2.4 | - | 2.4 | - | V |
| Icc | Dynamic Operating Current | $\begin{aligned} & \text { Vcc }=\text { Max., } \overline{\mathrm{CS}} \leq \text { VIL; } ;=\text { fmax, } \\ & \text { Outputs Open } \end{aligned}$ | - | 110 | - | 360 | - | 480 | mA |
| ISB | Standby Supply Current (TTL Levels) | $\overline{C S} \geq V I H, V C C=M a x ., f=f M A X,$ Outputs Open | - | 12 | - | 240 | - | 240 | mA |
| \|SB1 ${ }^{1{ }^{1)}}$ | Full Standby Supply Current (CMOS Levels) | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}, \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 8 | - | 40 | - | 80 | mA |

NOTES:

1. For low power version $\operatorname{ISB} 1=400 \mu \mathrm{~A}$, refer to SCD 4591 when ordering. For Commercial grade 7 M 4048 L version only
2. For Commercial grade 7M4048L version only.
3. For 7 MB 4048 SxxP, 7M4048SxxC, and 7 M 4048 SxxCB versions.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load (for tolz, tchz, tohz, twhz, tow and tclz)

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7M4048S30C <br> 7MB4048S30P |  | $\begin{aligned} & \text { 7M4048S35C } \\ & \text { 7MB4048S35P } \end{aligned}$ |  | 7M4048S40C 7M4048S40CB 7MB4048S40P |  | 7M4048S45C7M4048S45CB7MB4048S45P |  | $7 M 4048 S 50 C$ <br> $7 M 4048550 C B$ <br> $7 M B 4048550 P$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tre | Read Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | 50 | - | ns |
| tAA | Address Access Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| tacs | Chip Select Access Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| toe | Output Enable to Output Valid | - | 11 | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 10 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 2 | - | 2 | - | 5 | - | 5 | - | 5 | - | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 16 | - | 20 | - | 20 | - | 20 | - | 20 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 5 | - | 5 | - | 5 | - | ns |
| tPU ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power-Down Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 50 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | 50 | - | ns |
| twp | Write Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 5 | - | 5 | - | 5 | - | ns |
| taw | Address Valid to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tcw | Chip Select to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tDS | Data Set-up Time | - | - | - | - | - | - | - | - | - | - | ns |
| tDH | Data Hold Time | 3 | - | 3 | - | 3 | - | 5 | - | 5 | - | ns |
| tWR | Write Recovery Time | 3 | - | 3 | - | 5 | - | 5 | - | 5 | - | ns |
| twhz $^{(1)}$ | Write Enable to Output in High Z | - | 11 | - | 15 | - | 15 | - | 15 | - | 20 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design, but not tested.

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $7 M 4048 S 60 C$ <br> 7M4048S60CB <br> 7MB4048S60P |  | 7M4048S70C 7M4048S70CB 7M4048L70N |  | 7M4048S85C 7M4048S85CB 7M4048L85N |  | 7M4048S100C 7M4048S100CB 7M4048L100N |  | 7M4048S120C M4048S120CB 7M4048L120N |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |


| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRC | Read Cycle Time | 60 | - | 70 | - | 85 | - | 100 | - | 120 | - | ns |
| taA | Address Access Time | - | 60 | - | 70 | - | 85 | - | 100 | - | 120 | ns |
| tacs | Chip Select Access Time | - | 60 | - | 70 | - | 85 | - | 100 | - | 120 | ns |
| toe | Output Enable to Output Valid | - | 35 | - | 45 | - | 48 | - | 50 | - | 60 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 25 | - | 30 | - | 33 | - | 35 | - | 40 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{CCHz}^{(1)}$ | Chip Deselect to Output in High Z | - | 25 | - | 40 | - | 43 | - | 45 | - | 50 | ns |
| toh | Output Hold from Address Change | 5 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power-Down Time | - | 60 | - | 70 | - | 85 | - | 100 | - | 120 | ns |


| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twc | Write Cycle Time | 60 | - | 70 | - | 85 | - | 100 | - | 120 | - | ns |
| twp | Write Pulse Width | 50 | - | 55 | - | 65 | - | 75 | - | 90 | - | ns |
| tAS | Address Set-up Time | 5 | - | 0 | - | 2 | - | 5 | - | 5 | - | ns |
| taw | Address Valid to End of Write | 55 | - | 65 | - | 82 | - | 90 | - | 100 | - | ns |
| tcw | Chip Select to End of Write | 55 | - | 65 | - | 80 | - | 85 | - | 100 | - | ns |
| tos | Data Set-up Time |  |  | 35 | - | 38 | - | 40 | - | 45 | - | ns |
| tDH | Data Hold Time | 5 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twR | Write Recovery Time | 5 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twhz ${ }^{(1)}$ | Write Enable to Output in High Z | - | 25 | - | 30 | - | 33 | - | 35 | - | 40 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTE:

1. This parameter is guaranteed by design, but not tested.

## DATA RETENTION CHARACTERISTICS ${ }^{(1,4)}$

( $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Condition | Min. | $\begin{gathered} \text { Max. } \\ \text { Vcc @ 2.0V } \end{gathered}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | - | 2.0 | - | V |
| ICCDR | Data Retention Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VcC}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \leq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \\ & \mathrm{VIN} \geq 0.2 \mathrm{~V} \end{aligned}$ | - | 200 | $\mu \mathrm{A}$ |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  | 0 | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time |  | trc ${ }^{(2)}$ | - | ns |

NOTES:

1. $V C C=2 V, T_{A}=+25^{\circ} \mathrm{C}$.
2. $\mathrm{tRC}=$ Read Cycle Time.
3. This parameter is guaranteed by design, but not tested.
4. This option is only offered when ordering to 7M4048LxxN SCD4591.

## DATA RETENTION WAVEFORM



2675 drw 03

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


2675 drw 04

TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


## NOTES:

1. WE is High for Read Cycle.
2. Device is continuously selected, $\overline{C S}=V I L$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=V I L$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guranateed by design, but not tested.

## TIMING WAVEFORM OF WRITE CYCLE NO. 1 (产E CONTROLLED TIMING) ${ }^{(1,2,3,7)}$



## TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\mathrm{CS}}$ CONTROLLED TIMING) $)^{(1,2,3,5)}$



NOTES:

1. WE or $\overline{C S}$ must be high during all address transitions.
2. A write occurs during the overlap (WW) of a low CS and a low WE.
3. TWR is measured from the earlier of CS or WE going high to the end of write cycle.
4. During this period, I/O pins are in the output state, and input signals must not be applied.
5. If the CS low transition occurs simultaneously with or after the WE low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design, but not tested.
7. During a WE controlled write cycle, write pulse ( $(\mathrm{twP})>\mathrm{tWHz}+\mathrm{DW})$ to allow the $/ / O$ drivers to turn off and data to be placed on the bus for the required tow. If $O E$ is high during a $W E$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## ORDERING INFORMATION




## FEATURES:

- High-density 4 megabit CMOS static RAM module
- Fast access times
- 30ns (max.)
- Cost effective plastic surface mount RAM packages on a epoxy laminate (FR-4) substrate
- Available in 36-pin SIP (Single In-line Package)
- Low power consumption
- Dynamic: 2.6W (max.)
- Full standby: 1.9W (max.)
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT7MP4008 is a $512 \mathrm{~K} \times 8$ high-speed CMOS static RAM module constructed on an epoxy laminate surface using sixteen $32 \mathrm{~K} \times 8$ static RAMs in plastic surface mount packages. Extremely fast speeds can be achieved with this technique due to the use of 256K static RAMs fabricated in IDT's highperformance, high-reliability CEMOS ${ }^{\text {TM }}$ technology.

The IDT7MP family of surface-mounted SIP modules is a cost-effective solution allowing for very high packing density and the IDT7MP4008 is offered in a 36-pin SIP. The IDT7MP4008 can be stacked on 300 mil centers, yielding greater than 12 megabits of RAM in less than 5 square inches of board space.

The IDT7MP4008 is available with minimum access times as fast as 30ns over the commercial temperature range with maximumpower consumption of 2.6 watts. The IDT7MP4008 also offers a full standby mode of 1.9 W (max.).

All inputs and outputs of the IDT7MP4008 are TTLcompatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

## PIN CONFIGURATION ${ }^{(1)}$



## FUNCTIONAL BLOCK DIAGRAM



2658 drw 02

PIN NAMES

| A0-18 | Addresses |  |  |
| :--- | :--- | :---: | :---: |
| $\mathrm{I} / \mathrm{O} 0-7$ | Data Inputs/Outputs |  |  |
| $\overline{\mathrm{OE}}$ | Output Enable |  |  |
| $\overline{\mathrm{WE}}$ | Write Enable |  |  |
| $\overline{\mathrm{CS}}$ | Chip Select |  |  |
| VcC | Power |  |  |
| GND | Ground |  |  |
|  |  |  |  |

## NOTE:

1. For module dimensions, please refer to module drawing M37 in the packaging section.

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

## NOTE:

1. Stresses greater than those listedunder ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is notimplied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{ViL}_{\mathrm{IL}}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
$\left(V C C=5.0 \mathrm{~V} \pm 10 \%, T A=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7MP4008S |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. ${ }^{(2)}$ | Max. ${ }^{(3)}$ |  |
| \|lu| | Input Leakage Current ${ }^{(1)}$ | $V C C=M a x . ; V I N=G N D ~ t o ~ V C C ~$ | - | 80 | 80 | $\mu \mathrm{A}$ |
| \|liol | Output Leakage Current | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V O U T=G N D \text { to } V C C \end{aligned}$ | - | 80 | 80 | $\mu \mathrm{A}$ |
| ICC | Dynamic Operating Current | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{\text {IL }} \\ & \mathrm{VCC}=\text { Max. Output Open } \\ & \mathrm{f}=\mathrm{fmAx} \end{aligned}$ | - | 550 | 500 | mA |
| ISB | Standby Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VIH} \text { or (TTL Level) } \\ & \text { Vcc }=\text { Max., } \mathrm{f}=\mathrm{fmax} \\ & \text { Outputs Open } \\ & \hline \end{aligned}$ | - | 480 | 350 | mA |
| ISB1 | Full Standby Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \text { VHC, VIN } \geq \text { VHC or } \leq \text { VLC } \\ & \text { VCS }=\text { Max., Output Open } \end{aligned}$ | - | 285 | 285 | mA |
| VOL | Output Low Voltage | $\mathrm{OLL}=8 \mathrm{~mA}, \mathrm{VCC}=\mathrm{Min}$. | - | 0.4 | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-4 \mathrm{~mA}, \mathrm{VCC}=$ Min. | 2.4 | - | - | V |

## NOTES:

1. |lL| for A15-A16 and $\overline{C S}=400 \mu A$ (max.).
2. $t A A=30 \mathrm{~ns}$.
3. $t A A=35,45,55,70 \mathrm{~ns}$.

## AC TEST CONDITIONS

In Pulse Levels Input Rise／Fall Times Input Timing Reference Levels Output Reference Levels Output Load

GND to 3．0V
10ns
1.5 V
1.5 V

See Figures 1 and 2
2658 tol 06


Figure 1．Output Load


2658 drw 03
Figure 2．Output Load （for tclzi，2，tolz，tchzi，2，totz， tow，twhz）
＊Including scope and jig．

AC ELECTRICAL CHARACTERISTICS（ $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, T \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | 7MP4008S30 |  | 7MP408S35 |  | 7MP4008S45 |  | 7MP4008S55 |  | 7MP4008S70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min． | Max． | Min． | Max | Min． | Max． | Min． | Max． | Min． | Max． |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tre | Read Cycle Time | 30 | － | 35 | － | 45 | － | 55 | － | 70 | － | ns |
| taA | Address Access Time | － | 30 | － | 35 | － | 45 | － | 55 | － | 70 | ns |
| tacs | Chip Select Access Time | － | 30 | － | 35 | － | 45 | － | 55 | － | 70 | ns |
| tclz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| toe | Output Enables to Output Valid | － | 13 | － | 15 | － | 20 | － | 25 | － | 30 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | － | 5 | － | 0 | － | 0 | － | 0 | － | ns |
| $\mathrm{tchz}^{(1)}$ | Chip Select to Output in High Z | － | 20 | － | 21 | － | 25 | － | 30 | － | 35 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High $\mathbf{Z}$ | － | 11 | － | 13 | － | 25 | － | 25 | － | 30 | ns |
| tor | Output Hold from Address Change | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 30 | 一 | 35 | － | 45 | 一 | 55 | － | 70 | － | ns |
| tcw | Chip Select to End of Write | 25 | － | 30 | － | 40 | － | 50 | － | 60 | － | ns |
| taw | Address Valid to End of Write | 25 | － | 30 | － | 40 | － | 50 | － | 60 | － | ns |
| tas | Address Set－up Time | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| twp | Write Pulse Width | 20 | － | 25 | － | 35 | － | 45 | － | 55 | － | ns |
| twh | Write Recovery Time | 0 | － | 0 | － | 5 | － | 5 | － | 10 | － | ns |
| t $\mathrm{WHz}{ }^{(1)}$ | Write Enable to Output in High Z | － | 13 | － | 14 | － | 15 | － | 20 | － | 25 | ns |
| tDW | Data Valid to End of Write | 14 | － | 16 | － | 20 | － | 25 | － | 30 | 一 | ns |
| tD | Data Hold from Write Time | 3 | － | 3 | － | 5 | － | 5 | － | 5 | － | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |

## NOTE：

1．This parameter is guaranteed by design but not tested．

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


2658 drw 06

NOTES:

1. WE is High for Read Cycle.
2. Device is continuously selected, $\overline{C S}=\mathrm{VIL}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=$ VIL.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.
timing waveform of write cycle no. 1 ( $\overline{\text { WE CONTROLLED TIMING) }}{ }^{(1,2,3,7)}$


2658 dmw 07
TIMING WAVEFORM OF WRITE CYCLE NO. $2(\overline{\operatorname{CS}} \operatorname{CONTROLLED~TIMING)})^{(1,2,3,5)}$


## NOTES:

1. WE or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{\mathrm{CS}}$ and a low $\overline{\mathrm{WE}}$.
3. twR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ high to the end of write cycle.
4. During this period, I/O pins are in the output state, and input signals must not be applied.
5. If the $\overline{\mathrm{CS}}$ low transition occurs simultaneously with or after the WE low transition, the outputs remain in a high impedance state.
6. Transition is measured by $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.
7. During a $\bar{W} E$ controlled write cycle, write pulse (twP $>+W H Z+t D W$ ) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during a $\overline{W E}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | High Z | Standby |
| Read | L | L | H | DATAOUT | Active |
| Read | L | H | H | High Z | Active |
| Write | L | X | L | DATAIN | Active |

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}^{2}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| CIN(D) | Input Capacitance <br> (Data) | VIN $=0 \mathrm{~V}$ | 188 | pF |
| CIN(A) | Input Capacitance <br> (Address and Control) | $\mathrm{VIN}=0 \mathrm{~V}$ | 188 | pF |
| Cout | Output Capacitance | Vout $=0 \mathrm{~V}$ | 128 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION



## 512K x 8 CMOS STATIC RAM MODULE

PRELIMINARY

## FEATURES:

- High-density 4 Meg CMOS static RAM module
- Fast access time: 70ns (max.)
- Low power consumption
- Active: 110 mA (max.)
- CMOS standby: 8mA (max.)
- Very low power version (SCD4602)
- Data Retention: $400 \mu$ ( (max.)
- CMOS Standby: $200 \mu \mathrm{~A}$ (max.)
- Cost-effective plastic surface-mounted RAM packages on an epoxy laminate FR-4 substrate
- Offered in a 36 -pin SIP (Single In-line Package) for maximum space-saving
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT7MP4058L is a $512 \mathrm{~K} \times 8$ high-speed CMOS static RAM module constructed on an epoxy laminate substrate (FR-4) using four $128 \mathrm{~K} \times 8$ static RAMS and a one-of-four decoder in plastic surface mount packages.

The IDT7MP4058L is available with maximum access times as fast as 70 ns , with maximum operating power consumption of 605 mW .

The IDT7MP4058L is offered in a 36 -pin SIP (Single In-line Package). This vertically mounted SIP module is a cost-effective solution allowing for very high packing density.

All inputs and outputs of the IDT7MP4058L are TTLcompatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.


1. For module dimensions, please refer to drawing M38 in the packaging section.

FUNCTIONAL BLOCK DIAGRAM


PIN NAMES

| A0-18 | Address Inputs |
| :--- | :--- |
| $/ / 0_{0-7}$ | Data Inputs/Outputs |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\overline{\mathrm{CS}}$ | Chip Select |
| VcC | Power |
| GND | Ground |
| NC | No Connect |

## ABSOLUTE MAXIMUM RATINGS

| Symbol | Rating ${ }^{(1)}$ | Commerclal | Unit |
| :---: | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTE:
2798 tbl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC

OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6 | V |
| VIL | Input Low Voltage | -0.5 | - | 0.8 | V |

NOTE:
2798 tbl 03

1. $\mathrm{VIL}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5 \mathrm{~V} \pm 10 \%$ |

2798 tol 04

## DC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ILI | Input Leakage | VCC $=$ Max., VIN = GND to Vcc | - | 4 | $\mu \mathrm{A}$ |
| 120 | Output Leakage | $\begin{aligned} & \mathrm{VCC}=\text { Max., } \overline{\mathrm{CS}}=\mathrm{VIH}, \text { Vout }=\mathrm{GND} \\ & \text { to } \mathrm{VCC} \end{aligned}$ | - | 4 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $V C C=M i n,, 10 L=2 m A^{(2)}, 10 \mathrm{~L}=8 \mathrm{~mA}^{(3)}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOH}=-1 \mathrm{~mA}^{(2)}, \mathrm{IOH}=-4 \mathrm{~mA}^{(3)}$ | 2.4 | - | V |
| Icc | Dynamic Operating Current | $\begin{aligned} & \text { VCC }=\text { Max., } \overline{\mathrm{CS}} \leq V_{\mathrm{IL}} ; f=f \text { max }, \\ & \text { Outputs Open } \end{aligned}$ | - | 110 | mA |
| ISB | Standby Supply Current (TTL Levels) | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VIH}, \mathrm{VCC}=\mathrm{Max} ., \mathrm{f}=\mathrm{fmax}, \\ & \text { Outputs Open } \end{aligned}$ | - | 12 | mA |
| ISB1 $1^{(1)}$ | Full Standby Supply Current (CMOS Levels) | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc} 0.2 \mathrm{~V}, \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 8 | mA |

NOTE:
2798 tol 05

1. For low power version $\mathrm{ISB1}=40 \mu \mathrm{~A}$ refer to $\operatorname{SCD4602}$ when ordering.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter $^{(1)}$ | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | Vin $=0 \mathrm{~V}$ | 35 | pF |
| CIN (C) | Input Capacitance ( $\overline{\mathrm{CS})}$ | $\mathrm{ViN}=0 \mathrm{~V}$ | 8 | pF |
| Cour | Output Capacitance | Vout $=0 \mathrm{~V}$ | 35 | pF |

NOTE:

1. This parameter is guaranteed by design, but not tested.

## TRUTH TABLE

| Mode | CS | $\overline{\text { OE }}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | High-Z | Standby |
| Read | L | L | H | DouT | Active |
| Read | L | H | H | High-Z | Active |
| Write | L | X | L | Din | Active |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |

LOGIC SYMBOL


Figure 1. Output Load
AC ELECTRICAL CHARACTERISTICS
(VCC $=5 \mathrm{~V} \pm 10 \%, T A=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )


NOTE:

1. This parameter is guaranteed by design, but not tested.

DATA RETENTION CHARACTERISTICS ${ }^{(1,4)}$
( $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Condition | Min. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VDR | VCC for Data Retention | - | 2.0 | - | V |
| ICCDR | Data Retention Current | $\overline{\mathrm{CS}} \geq \mathrm{VCC} 0.2 \mathrm{~V}$ | - | 200 | $\mu \mathrm{~A}$ |
| $\mathrm{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time | $\mathrm{VIN} \leq \mathrm{VCC} 0.2 \mathrm{~V}$ or | 0 | - | ns |
| $\mathrm{tR}^{(3)}$ | Operation Recovery Time | $\mathrm{VIN} \geq 0.2 \mathrm{~V}$ | $\mathrm{TRC}^{(2)}$ | - | ns |

## NOTES:

1. $\mathrm{Vcc}=2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$
2. t R $\mathrm{C}=$ Read Cycle Time
3. This parameter is guaranteed by design, but not tested.
4. This option is only offered when ordering to SCD4602.

## DATA RETENTION WAVEFORM



TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


NOTES:

1. WE is High for Read Cycle
2. Device is continuously selected $\overline{\mathrm{CS}}=\mathrm{VIIL}_{\text {IL }}$
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low
4. $\overline{O E}=V \mathrm{IL}$
5. Transition is measured $=200 \mathrm{mV}$ from steady state. This parameter is guaranateed by design but not tested.

## TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\text { WE }}$ CONTROLLED TIMING) ${ }^{(1,2,3,7)}$



TIMING WAVEFORM OF WRITE CYCLE NO. $2(\overline{\mathrm{CS}} \text { CONTROLLED TIMING) })^{(1,2,3,5)}$


NOTES:

1. $\overline{W E}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlay ( WP ) of a low $\overline{\mathrm{CS}}$ and a low $\overline{W E}$.
3. twR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of write cycle.
4. During this period, $I / O$ pins are in the output state, and input signals must not be applied.
5. If the $\overline{C S}$ low transition occurs simultaneously with or after the $\bar{W} E$ low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.
7. During a WE controlled write cycle, write pulse ((twP) >tWHZ + tDW) to allow the I/O drivers to turn off and data to be placed on the bus for the required tDW. If $\overline{O E}$ is high during a $\overline{W E}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## ORDERING INFORMATION



|  | $256 \mathrm{~K} \times 9$ <br> CMOS STATIC RAM MODULE | PRELIMINARY IDT7MB4040 |
| :---: | :---: | :---: |

## FEATURES:

- High density separate I/O, 2 megabit CMOS static RAM module
- Low profile 44 pin, 600 mil DIP
- Fast access time: 20ns (max.)
- Surface mounted plastic SOJ packages on a multilayer epoxy laminate (FR-4) substrate
- Multiple ground pins for maximum noise immunity
- Inputs/outputs directly TTL compatible
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## DESCRIPTION:

The IDT7MB4040 is a separate I/O, $256 \mathrm{~K} \times 9$ CMOS static RAM module constructed on a multilayer epoxy laminate (FR4) substrate using $9256 \mathrm{~K} \times 1$ static RAMs in plastic SOJ packages. Extremely fast speeds can be achieved using 256K static RAMs fabricated in IDT's high performance, high reliability CEMOS ${ }^{\text {M }}$ technology. The IDT7MB4040 is available with access times as fast as 20ns with minimal power consumption.

The IDT7MB4040 is packaged in a 44 pin FR-4 DIP. The memory configuration results in a package 3.4 inches long, 600 mils wide, and only 350 mils in height. Provision of a ninth bit results in a optimal package for high reliability applications where parity is a must.

All inputs and outputs of the IDT7MB4040 are TTL compatible and operate from a single 5 V supply. Full asynchronous circuitry requires no clocks or refreshing for operation.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1)}$



NOTE:

1. For module dimension, please refer to module drawing M14 in the packaging section.

## PIN NAMES

| Dlo-Dl8 | Data Inputs |
| :--- | :--- |
| DO0-DO8 | Data Outputs |
| A0-A17 | Addresses |
| $\overline{\mathrm{CS}}$ | Chip Select |
| $\overline{\text { WE }}$ | Write Enable |
| Vcc | Power |
| GND | Ground |

## TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | Output | Power |
| :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | High-Z | Standby |
| Read | L | H | DATAOUT | Active |
| Write | L | L | DATAIN | Active |

2700 tbl 04

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | mA |

NOTE:
2700 कl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN(D) | Input Capacitance <br> (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 15 | pF |
| CIN(A) | Input Capacitance <br> (Address and Control) | $\mathrm{ViN}=0 \mathrm{~V}$ | 100 | pF |
| Cout | Output Capacitance | VouT $=0 \mathrm{~V}$ | 15 | pF |

NOTE:
2700 tol 03

1. This parameter is guaranteed by design, but not tested.

## RECOMMENDED DC OPERATING

CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
(VCC $=5.0 \mathrm{~V} \pm 10 \%, T A=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \| $\mathrm{LL} \mid$ | Input Leakage (Address and Control) | $\mathrm{Vcc}=$ = Max., VIN = GND to Vcc | - | 45 | $\mu \mathrm{A}$ |
| \|ll| | Input Leakage (Data) | $V C C=M a x ., V$ IN = GND to Vcc | - | 10 | $\mu \mathrm{A}$ |
| \|ILO| | Output Leakage | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V O U T=G N D \text { to } V C C \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=$ Min., $\mathrm{JOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |


| Symbol | Parameter | Test Conditions | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Icc | Dynamic Operating Current | $\text { Vcc }=\text { Max., } \overline{\mathrm{CS}} \leq \mathrm{V}_{\mathrm{IL}}$ <br> Outputs Open, $f=$ fmax. | 1440 | mA |
| IsB | Standby Supply Current | $\overline{\mathrm{CS}} \geq \mathrm{V}_{\mathrm{IH}}, \mathrm{VCC}=\mathrm{Max}$., Outputs Open, $f=f$ max. | 315 | mA |
| IS81 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | 270 | mA |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 \& 2 |



Figure 1. Output Load


Figure 2. Output Load (for tclz, tchz, twhz, tow)
*Including scope and jig

## AC ELECTRICAL CHARACTERISTICS ( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | 7MB4040S20 |  | 7MB4040S25 |  | 7MB4040S35 |  | 7MB4040S45 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 20 | - | 25 | - | 35 | - | 45 | - | ns |
| tAA | Address Access Time | - | 20 | - | 25 | - | 35 | - | 45 | ns |
| tacs | Chip Select Access Time | - | 20 | - | 25 | - | 35 | - | 45 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 3 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 10 | - | 13 | - | 20 | - | 25 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD $^{(1)}$ | Chip Deselect to Power Down Time | - | 20 | - | 25 | - | 35 | - | 45 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 20 | - | 25 | - | 35 | - | 45 | - | ns |
| tcw | Chip Selection to End of Write | 17 | - | 22 | - | 30 | - | 40 | - | ns |
| taw | Address Valid to End of Write | 17 | - | 22 | - | 30 | - | 40 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 17 | - | 22 | - | 30 | - | 40 | - | ns |
| tWR | Write Recovery Time | 0 | - | 3 | - | 3 | - | 3 | - | ns |
| twhz ${ }^{(1)}$ | Write Enable to Ouput in High Z | - | 10 | - | 13 | - | 20 | - | 25 | ns |
| tow | Data to Write Time Overlap | 13 | - | 15 | - | 20 | - | 25 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1,2)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,3)}$


## NOTES:

1. $\overline{W E}$ is high for Read Cycle.
2. $\overline{\mathrm{CS}}$ is low for Read Cycle.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. Transition is measured $\pm 200 \mathrm{mV}$ from steady state voltage with specified loading on Figure 2. This parameter is guaranteed by design, but not tested.
5. All Read Cycle timings are referenced from the last valid address to the first transitioning address.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\text { WE CONTROLLED }}{ }^{(1,2,3,7)}$


## TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{C S}$ CONTROLLED) ${ }^{(1,2,3,5)}$



NOTES:

1. $\overline{W E}$ or $\bar{C} \bar{S}$ must be high during all address transitions.
2. A write occurs during the overlap (tWP) of a low $\overline{C S}$ and a low $\overline{W E}$.
3. twe is measured from the earlier of CS or WE going High to the end of write cycle.
4. During this period, $V / O$ pins are in the output state, input signals must not be applied.
5. If the CS Low transition occurs simultaneously with or after the $\overline{\mathrm{WE}}$ Low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 500 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design, but, not tested.
7. During a $\overline{W E}$ controlled write cycle, write pulse (twp $>\mathrm{twHz}+\mathrm{tDW}$ ) to allow the I/O drivers to turn off data and to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $\overline{W E}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## ORDERING INFORMATION


$16 \mathrm{~K} \times 16$
IDT7MC4005 CMOS STATIC RAM MODULE

## FEATURES:

- High-density 256K CMOS static RAM module
- Fast access time: 15ns (max.)
- Low profile 36-pin sidebraze ceramic DSIP (Dual Single Inline Package)
- Surface mounted LCC components mounted on a co-fired ceramic substrate
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs/outputs directly TTL-compatible
- Multiple GND pins for maximum noise immunity


## DESCRIPTION:

The IDT7MC 4005 is a $16 \mathrm{~K} \times 16 \mathrm{CMOS}$ static RAM module constructed on a co-fired ceramic substrate using four $16 \mathrm{~K} x$ 4 static RAMs in leadless chip carriers. Extremely fast speeds

PIN CONFIGURATION ${ }^{(1)}$


[^16]
## FUNCTIONAL BLOCK DIAGRAM



2706 dww 02

PIN NAMES

| $\mathrm{I} / \mathrm{O}_{0}-15$ | Data Inputs/Outputs |
| :--- | :--- |
| $\mathrm{A} 0-13$ | Address Inputs |
| $\overline{\mathrm{CS}}$ | Chip Select |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| Vcc | Power |
| GND | Ground |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Com'l. | Mil. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to Ground | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -10 to +85 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| OUT | DC Output Current | 50 | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specificationis not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING

 TEMPERATURE AND VOLTAGE SUPPLY| Grade | Amblent Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Condltions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \|lu| | Input Leakage Current (Address and Control) |  | - | 20 | $\mu \mathrm{A}$ |
| \| $1 \mathrm{~L} \mid$ | Input Leakage (Data) | $V C C=M a x ., V I N=G N D ~ t o ~ V c c ~$ | - | 5 | $\mu \mathrm{A}$ |
| \|LLO| | Output Leakage | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V O U T=G N D \text { to } V C C \end{aligned}$ | - | 5 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min}$, $\mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VcC}=$ Min., $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | $\begin{gathered} \text { IDT7MC4005 } \\ \text { Max. }{ }^{(1)} \end{gathered}$ | IDT7MC4005 $\text { Max. }{ }^{(2)}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Icc1 | Operating Current | $\begin{aligned} & f=0, \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}} \\ & \mathrm{Vcc}=\text { Max., Output Open } \end{aligned}$ | 480 | 400 | mA |
| Icc2 | Dynamic Operating Current | $\begin{aligned} & f=f \text { max } \overline{C S}=V_{\text {IL }} \\ & V C C=\text { Max., Outputs Open } \end{aligned}$ | 600 | 500 | mA |
| ISB | Standby Supply Current | $\begin{aligned} & f=\overline{f M A X}, \overline{C S} \geq V_{\mathbb{I H}} \\ & V C C=\text { Max., Outputs Open } \end{aligned}$ | 240 | 200 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{C S} \geq V C C-0.2 V \\ & V I N \geq V C C-0.2 V \text { or } \leq 0.2 V \end{aligned}$ | 80 | 60 | mA |

## NOTE:

1. For $\mathrm{t} A \mathrm{~A}=15,20,25 \mathrm{~ns}$ versions.
2. For $t A A=30,35 n \mathrm{n}$ versions.

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


2706 drw 03
Figure 2. Output Load (for tclz, tolz, tchz, tohz, tow, twHz)

* Including scope and jig


## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | $\begin{array}{\|l\|} \hline 7 \text { MC40 } \\ \text { Min. } \\ \hline \end{array}$ | $\begin{aligned} & \text { O5S15 } \\ & \text { Max. } \end{aligned}$ | 7MC4 Min. | $\begin{aligned} & 005 S 20 \\ & \text { Max. } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { 7MC4 } \\ \text { Min. } \end{array}$ | $\begin{gathered} 05 \mathrm{~S} 25 \\ \text { Max. } \end{gathered}$ | 7MC4 Min. | $\begin{aligned} & 05 S 30 \\ & \text { Max. } \end{aligned}$ | 7MC40 Min. | $\begin{gathered} \text { 05S35 } \\ \text { Max. } \end{gathered}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tas | Address Access Time | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tacs | Chip Select Access Time | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 12 | - | 15 | - | 15 | - | 20 | - | 20 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Select to Output in High Z | - | 8 | - | 8 | - | 10 | - | 13 | - | 15 | ns |
| tOHZ ${ }^{(1)}$ | Output Disable to Output in High Z | - | 8 | - | 8 | - | 15 | - | 15 | - | 15 | ns |
| tor | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 15 | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 13 | - | 17 | - | 20 | - | 25 | - | 30 | - | ns |
| tcw | Chip Select to End of Write | 13 | - | 17 | - | 20 | - | 25 | - | 25 | - | ns |
| taw | Address Valid to End of Write | 13 | - | 17 | - | 20 | - | 25 | - | 27 | - | ns |
| tas | Address Setup Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 12 | - | 17 | - | 20 | - | 25 | - | 25 | - | ns |
| twh | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tWHZ ${ }^{(1)}$ | Write Enable to Output in High Z | - | 6 | - | 7 | - | 7 | - | 10 | - | 10 | ns |
| tow | Data to Write Time Overlap | 8 | - | 10 | - | 13 | - | 15 | - | 15 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

## NOTE:

1. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


## NOTES:

1. $\overline{W E}$ is High for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{VIL}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=V \mathrm{IL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

## TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$



TIMING WAVEFORM OF WRITE CYCLE NO. $2^{(1,6)}$


2706 drw 08

## NOTES:

1. WE or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (tWP) of a low $\overline{\mathrm{CS}}$.
3. TWR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of the write cycle.
4. During this period, $/ / O$ pins are in the output state so that the input signals of opposite phase to the output must not be applied.
5. If the CS low transition occurs simultaneously with the $\overline{W E}$ low transition or after the $\overline{W E}$ transition, outputs remain in a high impedance state.
6. $\overline{\mathrm{OE}}$ is continuously low ( $\overline{\mathrm{OE}}=\mathrm{VIL}$ ).
7. Dout is the same phase of write data of this write cycle.
8. If $\overline{C S}$ is low during this period, I/O pins are in the output state. Then the data input signals of opposite phase to the outputs must not be applied to them.
9. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

TRUTH TABLE

| Mode | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Standby | H | X | X | High Z | Standby |
| Read | L | L | H | DouT | Active |
| Write | L | X | L | Din | Active |
| Read | L | H | H | High Z | Active |

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| CIN (D) | Input Capacitance <br> (Data) | $\mathrm{VIN}=\mathrm{OV}$ | 20 | pF |
| CIN (A) | Input Capacitance <br> Address and Control | $\mathrm{VIN}=\mathrm{OV}$ | 50 | pF |
| COUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 20 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION




## DESCRIPTION:

The IDT7MB4009 is a $2 \times 16 \mathrm{~K} \times 16$ high-speed static RAM module constructed on an epoxy laminate surface using 816 K $\times 4$ static RAMs packaged in surface mount packages. Extremely fast speeds can be obtained by using RAMs fabricated in IDT's highperformance, high reliability CEMOS ${ }^{\text {™ }}$ technology.

The IDT7MB4009 is organized as two separate banks of $16 \mathrm{~K} \times 16$ RAM with common address and data pins to minimize the module size. The IDT7MB4009 is packaged in a 44 pin, 600 mil wide DIP, packing 512 K of fast memory in 1.8 square inches.

The IDT7MB4009 is available with access time as fast as 15 ns , with maximum power consumption of 4.2 W .

All inputs and outputs of the IDT7MB4009 are TTLcompatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

FUNCTIONAL BLOCK DIAGRAM


2707 dnw 02
PIN NAMES

| A (2-13) | Address Input |
| :--- | :--- |
| B_A1 (0-1) | Burst address, Bank 1 |
| B_A2 (0-1) | Burst address, Bank 2 |
| D (0-15) | Data Inputs/Outputs |
| $\overline{\text { WEB1 }}$ | Write Enable, Upper |
| $\overline{\text { WEB2 }}$ | Write Enable, Lower |
| $\overline{\text { CS1, 2 }}$ | Chip Select - Bank 1, 2 |
| $\overline{\text { OE1, 2 }}$ | Output Enable - Bank 1, 2 |
| GND | Ground |
| Vcc | Power Supply |

2707 tol 01

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output Current | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC OPERATING

 CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIIL}^{=}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING <br> TEMPERATURE AND VOLTAGE SUPPLY

| Grade | Ambient Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{Vcc}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7MB4009 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |
| \|lu| | Input Leakage Current (Address and Control) | Vcc = Max., VIN = GND to Vcc | - | 40 | $\mu \mathrm{A}$ |
| \| $ا$ L\| | Input Leakage (Data) | Vcc = Max., Vin = GND to Vcc | - | 10 | $\mu \mathrm{A}$ |
| \|liol | Output Leakage | $\mathrm{VCC}=$ Max., $\overline{\mathrm{CS}}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND}$ to Vcc | - | 10 | $\mu \mathrm{A}$ |
| VoL | Output LOW Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output HIGH Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |
| IcC1 | Operating Current | $\begin{aligned} & f=0, \overline{C S} \leq \text { VIL } \\ & V C C=\text { Max., Outputs Open } \end{aligned}$ | - | 620 | mA |
| ICC2 | Dynamic Operating Current | $\begin{aligned} & f=\text { fMAX, } \overline{\mathrm{CS}} \leq \text { VIL, } \\ & \text { VCC = Max., Outputs Open } \end{aligned}$ | - | 760 | mA |
| ISB | Standby Supply Current | $f=f$ max, $\overline{C S} \geq \mathrm{VIH}, \mathrm{VCC}=$ Max.,Outputs Open | - | 440 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VIH}-0.2 \mathrm{~V} \\ & \mathrm{ViN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 120 | mA |

2707 \$1 05

## AC TEST CONDITIONS

| Input Pulse Levels |
| :--- |
| Input Rise/Fall Times |
| Input Timing Reference Levels |
| Output Reference Levels |
| Output Loads |

GND to 3.0 V
10 ns
1.5 V
1.5 V

See Figures 1 and 2


Figure 1. Output Load


2707 drw 03
Figure 2. Output Load (for $\mathrm{tcLz}, \mathrm{toLz}, \mathrm{tchz}, \mathrm{toHz}$, tow and twhz)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}^{\circ}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | 7MB4009S15 |  | 7MB4009S20 |  | 7MB4009S25 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |
| tre | Read Cycle Time | 15 | - | 20 | - | 25 | - | ns |
| tAA | Address Access Time | - | 15 | - | 20 | - | 25 | ns |
| tacs | Chip Select Access Time | - | 15 | - | 20 | - | 25 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 12 | - | 15 | - | 15 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Select to Output in High Z | - | 8 | - | 10 | - | 12 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High $\mathbf{Z}$ | - | 8 | - | 10 | - | 15 | ns |
| toh | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | ns |
| tpu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 15 | - | 20 | - | 25 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 13 | - | 18 | - | 20 | - | ns |
| tcw | Chip Select to End of Write | 13 | - | 18 | - | 20 | - | ns |
| taw | Address Valid to End of Write | 13 | - | 18 | - | 21 | - | ns |
| tas | Address Set Up Time | 0 | - | 0 | - | 1 | - | ns |
| twp | Write Pulse Width | 12 | - | 17 | - | 20 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
|  | Write Enable to Output in High Z | - | 6 | - | 7 | - | 8 | ns |
| tDW | Data to Write Time Overlap | 8 | - | 10 | - | 13 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | ns |

## NOTE:

1. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


## NOTES:

1. $\overline{W E}$ is High for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}_{1}=\mathrm{V}_{\mathrm{LL}}, \overline{\mathrm{CS}} 2=\mathrm{V}_{\mathrm{IL}}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}_{1}}$ and/or $\overline{\mathrm{CS}} 2$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 , ( $\overline{\text { WE CONTROLLED TIMING) }}{ }^{(1,2,3,7)}$


2707 dww 07

## TIMING WAVEFORM OF WRITE CYCLE NO. 2 , ( $\overline{\text { CS }}$ CONTROLLED TIMING) $)^{(1,2,3,5,8)}$



2707 drw O8

NOTES:

1. $\overline{\mathrm{WE}}, \overline{\mathrm{CS}}_{1}$ or $\overline{\mathrm{CS}} 2$ must be high during all address transitions.
2. A write occurs during the overlap (tWP) of a low $\overline{\mathrm{CS}} 1$, a low $\overline{\mathrm{CS}} 2$ and a low $\overline{\mathrm{WE}}$.
3. WWP is measured from the earlier of $\overline{\mathrm{CS}} 1, \overline{\mathrm{CS}} 2$ or $\overline{\mathrm{WE}}$ going high to the end of the write cycle.
4. During this period, $I / O$ pins are in the output state, and input signals must not be applied.
5. If the CS low transition occurs simultaneously with or after the WE low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.
7. If $\overline{O E}$ is low during a WE controlled write cycle, the write pulse width must be the greater of twP or (twhz +tDW ) to allow the I/O drivers turn off and data to be placed on the bus for the required tow. If $\overline{\mathrm{O}}$ is high during a $\overline{\mathrm{WE}}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twP.
8. $\overline{O E}=\mathrm{VIL}$.

CAPACITANCE ${ }^{(1)}\left(\right.$ TA $\left.^{2}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN(1) | Input Capacitance <br> (Address) | $\mathrm{VIN}=0 \mathrm{~V}$ | 40 | pF |
| CIN(1) | Input Capacitance <br> (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 20 | pF |
| COUT | Output Capacitance | VOUT $=0 \mathrm{~V}$ | 20 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

TRUTH TABLE

| Mode | $\overline{\text { CS1 }}$ | CS2 | $\overline{0 E 1}$ | OE2 | WEB1 | $\overline{\text { WEB2 }}$ | Output | Power |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Standby | H | H | X | X | $X$ | X | High Z | Standby |
| Read | L | H | L | X | H | H | Dout BANK (1) | Active |
| Read | L | H | H | X | H | H | High Z | Active |
| Read | H | L | X | L | H | H | DOUT BANK (2) | Active |
| Read | H | L | X | H | H | H | High Z | Active |
| Write | L | H | X | X | L | H | Din BANK (1) D (0-7) | Active |
| Write | L | H | X | X | H | L | DIN BANK (1) D (8-15) | Active |
| Write | H | L | X | X | L | H | DIN BANK (2) D (0-7) | Active |
| Write | H | L | X | X | H | L | DIN BANK (2) D (8-15) | Active |
| Write | L | H | X | X | L | L | DIN BANK (1) D (0-15) | Active |
| Write | H | L | X | X | L | L | DIN BANK (2) D (0-15) | Active |

## ORDERING INFORMATION




Integrated Device Technology, Inc.

## FEATURES:

- High-density CMOS static RAM module $64 \mathrm{~K} \times 16$ organization (IDT8M624S) or 32K x 16 option (IDT8M612S)
- Fast access time:
- Commercial - 25ns (max.)
- Military - 35ns (max.)
- Separate upper byte (l/O9-16) and lower byte (//O1-8) controls allow for greater application flexibility
- Offered in the JEDEC standard 40-pin DIP (dual in-line package)
- Leadless chip carriers (LCCs) mounted on an multi-layer ceramic substrate
- Single 5V ( $\pm 10 \%$ ) power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT8M624S/IDT8M612S are high-speed CMOS static RAM module constructed on an co-fired, multi-layer ceramic substrate using four $32 \mathrm{~K} \times 8$ static RAMs (IDT8M624S) or two $32 \mathrm{~K} x 8$ static RAMs (IDT8M612S) in hermetic LCC packages. Functional equivalence to proposed monolithic static RAMs is achieved by utilization of an on-board decoder that interprets the higher order address $\mathrm{A}_{15}$ to select one of the two $32 \mathrm{~K} \times$ 16 RAMs as the $\times 16$ output and using $\overline{\mathrm{LB}}$ and $\overline{\mathrm{UB}}$ as two extra
chip select functions for lower byte (//O1-8) and upper byte (I/O9-16) control, respectively. Extremely high speeds can be achieved by the use of IDT71256 (32K x 8) static RAMs fabricated in IDT's high-performance, high-reliability technology, CEMOS™ .

The IDT8M624S/IDT8M612S are available with access times as fast as 25ns over the commercial temperature range and 35 ns over the military termperature range, with maximum operating power consumption of only $3.4 \mathrm{~W}(64 \mathrm{~K} \times 16 \mathrm{com}-$ mercial option). The module also offers a full standby mode of 451 mW (max.).

The IDT8M624S/IDT8M612S modules are offered in the JEDEC standard 40-pin sidebrazed DIP.

All inputs and outputs of the IDT8M624S/ IDT8M612S are TTL-compatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation, and providing equal access and cycle times for ease of use.

All military module semiconductor components are manufactured in compliance with the latest revision of MIL-STD-883 Class B, making them ideally suited for applications demanding the highest level of performance and reliability.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION ${ }^{(1)}$



NOTE:

1. For module dimensions, please refer to module drawing M11 ( 8 M 624 S ) and M 12 ( 8 M 612 S ) in the packaging section.
2. For $32 \mathrm{~K} \times 16$ option (IDT8M612S), A15 (Pin 1) must be connected to GND for proper operation of the module.

## PIN NAMES

| A0-15 | Addresses |
| :--- | :--- |
| $I / O_{1-16}$ | Data Input/Output |
| $\overline{\mathrm{CS}}$ | Chip Select |
| $\overline{\mathrm{WE}}$ | Write Enable |
| VCC | Power |
| GND | Ground |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\overline{U B}$ | Upper Byte Control |
| $\overline{\mathrm{LB}}$ | Lower Byte Control |

2673 か 01

## TRUTH TABLE

| Mode | $\overline{\text { CS }}$ | $\overline{\text { UB }}$ | $\overline{\text { LB }}$ | $\overline{O E}$ | WE | Output | Power |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | X | X | High Z | Standby |
| Standby | L | H | H | X | X | High Z | Standby |
| Read | L | L | L | L | H | Dout 1-16 | Active |
| Lower Byte Read | L | H | L. | L | H | Dout 1-8 | Active (X8) |
| Upper Byte Read | L | L | H | L | H | Dour 9-16 | Active (X8) |
| Read | $L$ | L | L | H | H | High Z | Active |
| Lower Byte Read | L | H | L | H | H | High Z | Active (X8) |
| Upper Byte Read | L | L | H | H | H | High Z | Active (X8) |
| Write | L | L | L | X | L | DIN 1-16 | Active |
| Lower Byte Write | L | H | L | X | L | Din 1-8 | Active (X8) |
| Upper Byte Write | L | L | H | X | L | DIN 9-16 | Active (X8) |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| Vterm | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Tsta | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTES:
2673 か 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Conditions | $\begin{array}{\|c\|} \hline \text { 8MP624 } \\ \text { Max. } \end{array}$ | $8 \mathrm{MP612}$ <br> Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{CIN}(\mathrm{D})$ | Input Capacitance (Data) | $\mathrm{ViN}=0 \mathrm{~V}$ | 25 | 14 | pF |
| $\operatorname{CIN}\left(A^{1}\right)$ | Input Capacitance ( $\mathrm{A} 0-14, \overline{\mathrm{OE}}, \overline{\mathrm{WE}}$ ) | V in $=0 \mathrm{~V}$ | 50 | 25 | pF |
| CIN(C) | Input Capacitance (A15, $\overline{\mathrm{CS}}$ ) | $\mathrm{VIN}=0 \mathrm{~V}$ | 23 | 23 | pF |
| CIN(C) | Input Capacitance $(\overline{\mathrm{LB}}, \overline{\mathrm{UB}})$ | V IN $=0 \mathrm{~V}$ | 13 | 13 | pF |
| Cout | Output Capacitance | VOUT $=0 \mathrm{~V}$ | 25 | 14 | pF |

NOTE:

1. This parameter is guaranteed by design, but not tested.

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIL}(\mathrm{min})=-3.0 \mathrm{~V}$ for pulse width less than $20 n \mathrm{~s}$.

## DC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ or $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT8M624S |  |  | IDT8M612S |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. ${ }^{(1)}$ | Max. ${ }^{(2)}$ | Min. | Max. ${ }^{(1)}$ | Max. ${ }^{(2)}$ |  |
| \|ILI| | Input Leakage Current | $\begin{aligned} & V C C=M a x . ; \\ & V I N=G N D \text { to } V C C \end{aligned}$ | - | 20 | 15 | - | 10 | 15 | $\mu \mathrm{A}$ |
| \|lıO| | Output Leakage Current | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . ; \\ & \mathrm{CS}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 10 | 15 | - | 5 | 15 | $\mu \mathrm{A}$ |
| IcCX ${ }_{16}$ | Dynamic Operating Current in X16 Mode | $V C C=$ Max., $\overline{C S}, \overline{U B}$ and $\overline{L B}=V I L$, $f=$ fmax; Output Open | - | 450 | 340 | - | 400 | 300 | mA |
| ICCX8 | Dynamic Operating Current in X8 Mode | $\begin{aligned} & \overline{\mathrm{CS}}, \overline{\mathrm{UB}} \text { or } \overline{\mathrm{LB}}=\mathrm{VIL}, \\ & \text { VCC }=\text { Max., } \mathrm{f}=\mathrm{fMAX}, \\ & \text { Output Open } \end{aligned}$ | - | 275 | 200 | - | 225 | 170 | mA |
| ISB | Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{V}_{\text {IH }} \text { or } \overline{\mathrm{UB}} \geq \mathrm{V}_{\text {IL }} \text { and } \\ & \overline{\mathrm{LB}} \geq \mathrm{V}_{\mathrm{H}} \end{aligned}$ | - | 100 | 80 | - | 50 | 40 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V} ; \\ & \mathrm{VIN}>V c c-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V} \end{aligned}$ | - | 60 | 80 | - | 30 | 40 | mA |
| Vol | Output Low Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{lOL}=8 \mathrm{~mA} \end{aligned}$ | - | 0.4 | 0.4 | - | 0.4 | 0.4 | mA |
| VOH | Output High Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{IOH}=-4 \mathrm{~mA} \end{aligned}$ | 2.4 | - | - | 2.4 | - | - | mA |

NOTES:

1. $t A A=25,30,35 \mathrm{~ns}$.
2. $t A A=40,45,50,60,70,85,100 \mathrm{~ns}$.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Flgure 2. Output Load (for tolz, toHiz, twhz, and tow)
*Including scope and jig.

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ or $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 25 \\ & 8 \mathrm{M} 624 \mathrm{~S} 25 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 30 \\ & 8 \mathrm{M} 624 \mathrm{~S} 30 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 35 \\ & 8 \mathrm{M} 624 \mathrm{~S} 35 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 40 \\ & 8 \mathrm{M} 624 \mathrm{~S} 40 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 45 \\ & \text { 8M624S45 } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | MIn. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| taA | Address Access Time | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tacs | Chip Select Access Time | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 10 | - | 11 | - | 13 | - | 25 | - | 25 | ns |
| tolz ${ }^{(1)}$ | Chip Deselection to Output in High Z | 2 | - | 2 | - | 2 | - | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Select to Output in High Z | - | 15 | - | 16 | - | 20 | - | 20 | - | 20 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 8 | - | 10 | - | 15 | - | 20 | - | 20 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{tPD}^{(1)}$ | Chip Deselect to Power-Down Time | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| tcw | Chip Select to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAS | Address Set-up Time | 3 | - | 3 | - | 3 | - | 5 | - | 5 | - | ns |
| twp | Write Pulse Width | 15 | - | 20 | - | 23 | - | 30 | - | 35 | - | ns |
| twR | Write Recovery Time | 2 | - | 2 | - | 2 | - | 5 | - | 5 | - | ns |
| tWHz ${ }^{(1)}$ | Write Enable to Output in High Z | - | 10 | - | 11 | - | 15 | - | 15 | - | 15 | ns |
| tDw | Data to Write Time Overlap | 11 | - | 13 | - | 14 | - | 15 | - | 20 | - | ns |
| tDH | Data Hold from Write Time | 3 | - | 3 | - | 3 | - | 3 | - | 5 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

## AC ELECTRICAL CHARACTERISTICS（Continued）

（Vcc $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ}$ to $+70^{\circ} \mathrm{C}$ or $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 50 \\ & 8 \mathrm{M} 624 \mathrm{~S} 50 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 60 \\ & 8 \mathrm{M} 624 \mathrm{~S} 60 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 70 \\ & \text { 8M624S70 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{M} 612 \mathrm{~S} 85 \\ & 8 \mathrm{M} 624 \mathrm{~S} 85 \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 8 \mathrm{M} 612 \mathrm{~S} 100 \\ \text { 8M624S100 } \\ \hline \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 50 | － | 60 | － | 70 | － | 85 | － | 100 | － | ns |
| tAA | Address Access Time | － | 50 | － | 60 | － | 70 | － | 85 | － | 100 | ns |
| tacs | Chip Select Access Time | － | 50 | － | 60 | － | 70 | － | 85 | － | 100 | ns |
| tclz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| toe | Output Enable to Output Valid | － | 30 | － | 35 | － | 40 | － | 50 | － | 60 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| $\mathrm{tCHz}^{(1)}$ | Chip Select to Output in High Z | － | 20 | － | 25 | － | 30 | － | 35 | － | 40 | ns |
| torzz ${ }^{(1)}$ | Output Disable to Output in High Z | － | 20 | － | 25 | － | 30 | － | 35 | － | 40 | ns |
| toh | Output Hold from Address Change | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power－Up Time | 0 | － | 0 | － | 0 | － | 0 | － | 0 | － | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power－Down Time | － | 50 | － | 60 | － | 70 | － | 85 | － | 70 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 50 | － | 60 | － | 70 | － | 85 | － | 100 | － | ns |
| tcw | Chip Select to End of Write | 45 | － | 55 | － | 65 | － | 75 | － | 90 | － | ns |
| taw | Address Valid to End of Write | 45 | － | 55 | － | 65 | － | 75 | － | 90 | － | ns |
| tas | Address Set－up Time | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| twp | Write Pulse Width | 40 | － | 50 | － | 60 | － | 70 | － | 80 | － | ns |
| tWR | Write Recovery Time | 5 | － | 5 | － | 5 | － | 10 | － | 10 | － | ns |
| twhz $^{(1)}$ | Write Enable to Output in High Z | － | 20 | － | 25 | － | 30 | － | 35 | － | 40 | ns |
| tDw | Data to Write Time Overlap | 20 | － | 25 | － | 30 | － | 35 | － | 40 | － | ns |
| ton | Data Hold from Write Time | 5 | 二 | 5 | 二 | 5 | 二 | 5 | 二 | 5 | － | ns |
| tow ${ }^{(1)}$ ． | Output Active from End of Write | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |

NOTE：
1．This parameter is guaranteed by design，but not tested．

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


2673 dnw 03
TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


NOTES:
2673 drw 05

1. $\overline{W E}$ is high for Read cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=V_{I L}$ and $\overline{U B}, \overline{\mathrm{LB}}=V_{\mathbb{L}}$ for 16 output active.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $O E=V I L$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\text { WE CONTROLLED TIMING) }}{ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. $2(\overline{\operatorname{CS}} \text { CONTROLLED TIMING) })^{(1,2,3,5)}$


## NOTES:

1. $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CS}}$ must be high during all address transactions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low $\overline{W E}$
3. TWR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of write cycle.
4. During this period, $I / O$ pins are in the output state and input signals must not be applied.
5. If the CS low transition occurs simultaneously with or after the WE low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design, but not tested.
7. During a WE controlled write cycle, write pulse ((twP) > twHz + tow) to allow the $/ / O$ drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during a $\overline{W E}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## ORDERING INFORMATION



## FEATURES:

- High-density CMOS static RAM module $64 \mathrm{~K} \times 16$ organization (IDT8MP624) or 32K x 16 option (IDT8MP612)
- Fast access time: 25ns (max.)
- Separate upper byte (I/O9-16) and lower byte (//O1-8) controls allows for greater application flexibility
- Offered in a 40-pin SIP (single in-line package) for maximum space-savings
- Cost-effective plastic SO's mounted on an epoxy laminate (FR-4) substrate
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT8MP624S/IDT8MP612S are high-speed CMOS static RAM modules constructed on an epoxy laminate substrate using four 32K x 8 static RAMs (IDT8MP624S) or two 32K x 8 static RAMs (IDT8MP612S) in plastic surface-mount packages. Functional equivalence to proposed monolithic static RAMs is achieved by utilization of an on-board decoder that interprets the higher order address $A_{15}$ to select one of the two $32 \mathrm{~K} \times 16$ RAMs as the by- 16 output and using $\overline{\mathrm{LB}}$ and
$\overline{U B}$ as two extra chip select functions for lower byte ( $/ / O_{1-8}$ ) and upper byte (I/O9-16) control, respectively. Extremely high speeds can be achieved by the use of IDT71256 ( $32 \mathrm{~K} \times 8$ ) static RAMs fabricated in IDT's high-performance, high-reliability technology, CEMOS ${ }^{\mathrm{m}}$.

The IDT8MP624S/IDT8MP612S are available with access times as fast as 25 ns over the commercial temperature range, with maximum operating power consumption of only 3.4 W ( $64 \mathrm{~K} \times 16$ option). The module also offers a full standby mode of 451 mW (max.)

The IDT8MP624S/IDT8MP612S modules are offered in a vertically mounted 40-pin FR-4 SIP. For the 40-pin JEDEC sidebrazed DIP, refer to the IDT8M624S/IDT8M612S.

All inputs and outputs of the IDT8MP624S/ IDT8MP612S are TTL-compatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation, and providing equal access and cycle times for ease of use.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION ${ }^{(1)}$



## PIN NAMES

| A0-15 | Addresses |
| :--- | :--- |
| $I / O_{1-16}$ | Data Input/Output |
| $\overline{\mathrm{CS}}$ | Chip Select |
| $\overline{\mathrm{WE}}$ | Write Enable |
| Vcc | Power |
| GND | Ground |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\overline{\mathrm{UB}}$ | Upper Byte Control |
| $\overline{\mathrm{LB}}$ | Lower Byte Control |

2673 tol 01

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commerical | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | UnIt |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2673 ыы 08

1. $\mathrm{VIL}_{\mathrm{IL}}(\min )=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## TRUTH TABLE

| Mode | $\overline{\mathrm{CS}}$ | $\overline{\text { UB }}$ | $\overline{\text { LB }}$ | $\overline{O E}$ | $\overline{\text { WE }}$ | Output | Power |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | X | X | High Z | Standby |
| Standby | L | H | H | X | X | High $Z$ | Standby |
| Read | L | L | L | L | H | DOUT 1.16 | Active |
| Lower Byte Read | L | H | L | L | H | DOUT 1-8 | Active (X8) |
| Upper Byte Read | L | L | H | L | H | DOUT 9-16 | Active (X8) |
| Read | L | L | L | H | H | High Z | Active |
| Lower Byte Read | $L$ | H | L | H | H | High Z | Active (X8) |
| Upper Byte Read | $L$ | L | H | H | H | High Z | Active (X8) |
| Write | L | L | L | X | L | Din 1-16 | Active |
| Lower Byte Write | $L$ | H | L | X | L | Din 1-b | Active (X8) |
| Upper Byte Write | L | L | H | X | L | Din 9-16 | Active (X8) |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Ratlng | Value | Unit |
| :--- | :--- | :---: | :---: |
| Vterm | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTES:
2673 का 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Conditions | $\begin{array}{\|c\|} \hline \text { 8MP624 } \\ \text { Max. } \end{array}$ | 8MP612 Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\operatorname{Cin}(\mathrm{D})$ | Input Capacitance (Data) | ViN $=0 \mathrm{~V}$ | 25 | 14 | pF |
| $\operatorname{CIN}\left(A_{1}\right)$ | Input Capacitance (AO-14, OE, WE) | $\mathrm{VIN}=0 \mathrm{~V}$ | 50 | 25 | pF |
| CIN(C) | Input Capacitance (A15, CS) | $\mathrm{VIN}=0 \mathrm{~V}$ | 23 | 23 | pF |
| CIN(C) | Input Capacitance $(\overline{L B}, \overline{U B})$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 13 | 13 | pF |
| Cout | Output Capacitance | Vout $=0 \mathrm{~V}$ | 25 | 14 | pF |

NOTE:
2673 허 07

1. This parameter is guaranteed by design, but not tested.

DC ELECTRICAL CHARACTERISTICS
(Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT8MP624S |  |  | IDT8MP612S |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. ${ }^{(1)}$ | Max. ${ }^{(2)}$ | Min. | Max. ${ }^{(1)}$ | Max. ${ }^{(2)}$ |  |
| \|lı| | Input Leakage Current | $\begin{aligned} & V C C=M a x . ; \\ & \text { VIN }=\text { GND to VCC } \end{aligned}$ | - | 20 | 15 | - | 10 | 15 | $\mu \mathrm{A}$ |
| \|ILO| | Output Leakage Current | $\begin{aligned} & V C C=M a x . ; \\ & C S=V I H, V O U T=G N D \text { to VCC } \end{aligned}$ | - | 10 | 15 | - | 5 | 15 | $\mu \mathrm{A}$ |
| ICCX16 | Dynamic Operating Current in X16 Mode | $\mathrm{VcC}=\mathrm{Max}$., $\overline{C S}, \overline{U B}$ and $\overline{L B}=V_{I L}$, $f=$ fmax; Output Open | - | 450 | 340 | - | 400 | 300 | mA |
| Iccx8 | Dynamic Operating Current in X8 Mode | $\begin{aligned} & \overline{\overline{C S}, \overline{U B} \text { or } \overline{\mathrm{LB}}=\mathrm{VIL},} \\ & \mathrm{VCC}=M a x ., \mathrm{f}=\mathrm{fmAx}, \\ & \text { Output Open } \end{aligned}$ | - | 275 | 200 | - | 225 | 170 | mA |
| ISB | Standby Supply Current | $\begin{aligned} & \overline{C S} \geq V_{I H} \text { or } \overline{U B} \geq V_{I L} \text { and } \\ & \overline{L B} \geq V_{H H} \end{aligned}$ | - | 100 | 80 | - | 50 | 40 | mA |
| IsBt | Full Standby Supply Current | $\begin{aligned} & \overline{C S} \geq V C C-0.2 V ; \\ & V I N>V c C-0.2 V \text { or }<0.2 V \end{aligned}$ | - | 60 | 80 | - | 30 | 40 | mA |
| Vol | Output Low Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{lO}=8 \mathrm{~mA} \end{aligned}$ | - | 0.4 | 0.4 | - | 0.4 | 0.4 | mA |
| VOH | Output High Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{IOH}=-4 \mathrm{~mA} \end{aligned}$ | 2.4 | - | - | 2.4 | - | - | mA |

NOTES:

1. $\mathrm{tAA}=25,30,35 \mathrm{~ns}$.
2. $t A A=40,45,50,60,70 \mathrm{~ns}$.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load (for tolz, toHz, twhz, and tow)

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{aligned} & 8 M P 612 S 25 \\ & \text { 8MP624S25 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \hline \text { 8MP612S30 } \\ & \text { 8MP624S25 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{MP612S35} \\ & \text { 8MP624S35 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{MP612S} 40 \\ & 8 \mathrm{MP624S} 40 \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| tre | Read Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAA | Address Access Time | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tacs | Chip Select Access Time | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tclz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 10 | - | 11 | - | 13 | - | 25 | ns |
| tolz ${ }^{(1)}$ | Chip Deselection to Output in High Z | 2 | - | 2 | - | 2 | - | 5 | - | ns |
| $\mathrm{tCHZ}^{(1)}$ | Chip Select to Output in High Z | - | 15 | - | 16 | - | 20 | - | 20 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High $\mathbf{Z}$ | - | 8 | - | 10 | - | 15 | - | 20 | ns |
| tor | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power-Down Time | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tcw | Chip Select to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tas | Address Set-up Time | 3 | - | 3 | - | 3 | - | 5 | - | ns |
| twp | Write Pulse Width | 15 | - | 20 | - | 23 | - | 30 | - | ns |
| tWR | Write Recovery Time | 2 | - | 2 | - | 2 | - | 5 | - | ns |
| twhz $^{(1)}$ | Write Enable to Output in High Z | - | 10 | - | 11 | - | 15 | - | 15 | ns |
| tow | Data to Write Time Overlap | 11 | - | 13 | - | 14 | - | 15 | - | ns |
| tDH | Data Hold from Write Time | 3 | - | 3 | 一 | 3 | - | 3 | 二 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | ns |

AC ELECTRICAL CHARACTERISTICS (Continued)
(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{aligned} & 8 \mathrm{MP612S45} \\ & \text { 8MP624S45 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { 8MP612S50 } \\ & \text { 8MP624S50 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \hline \text { 8MP612S60 } \\ & \text { 8MP624S60 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 8 \mathrm{MP612S70} \\ & \text { 8MP624S70 } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | MIn. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 45 | - | 50 | - | 60 | - | 70 | - | ns |
| tAA | Address Access Time | - | 45 | - | 50 | - | 60 | - | 70 | ns |
| tacs | Chip Select Access Time | - | 45 | - | 50 | - | 60 | - | 70 | ns |
| tclz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 25 | - | 30 | - | 35 | - | 40 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Select to Output in High Z | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tor | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD $^{(1)}$ | Chip Deselect to Power-Down Time | - | 45 | - | 50 | - | 60 | - | 70 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 45 | - | 50 | - | 60 | - | 70 | - | ns |
| tcw | Chip Select to End of Write | 40 | - | 45 | - | 55 | - | 65 | - | ns |
| taw | Address Valid to End of Write | 40 | - | 45 | - | 55 | - | 65 | - | ns |
| tas | Address Set-up Time | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twp | Write Pulse Width | 35 | - | 40. | - | 50 | - | 60 | - | ns |
| tWR | Write Recovery Time | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| twhz ${ }^{(1)}$ | Write Enable to Output in High Z | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| tow | Data to Write Time Overlap | 20 | - | 20 | - | 25 | - | 30 | - | ns |
| tDH | Data Hold from Write Time | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:
2673 th 12

1. This parameter is guaranteed by design, but not tested

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


2673 drw 03
TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


2673 dw 04

TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


NOTES:
2673 drw 05

1. $\overline{W E}$ is high for Read cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{VIIL}_{\text {IL }}$ and $\overline{\mathrm{UB}}, \overline{\mathrm{LB}}=\mathrm{V}_{\mathrm{IL}}$ for 16 output active.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=V \mathrm{IL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\text { WE }}$ CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


2673 dw 06

TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{C S}$ CONTROLLED TIMING) $)^{(1,2,3,5)}$


2673 dw 07
NOTES:

1. $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CS}}$ must be high during all address transactions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low $\overline{W E}$.
3. twR is measured from the earlier of $\overline{C S}$ or WE going high to the end of write cycle.
4. During this period, $\mathrm{V} / \mathrm{O}$ pins are in the output state and input signals must not be applied.
5. If the $\overline{\mathrm{CS}}$ low transition occurs simultaneously with or after the $\overline{\mathrm{WE}}$ low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design, but not tested.
7. During a $\overline{W E}$ controlled write cycle, write pulse ( (tWP) > tWHZ + tow) to allow the I/O drivers to turn off and data to be placed on the bus for the required tow. If $\overline{O E}$ is high during a $\overline{W E}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## ORDERING INFORMATION



## FEATURES:

- High-density CMOS static RAM module $64 \mathrm{~K} \times 16$ organization (IDT8MP624) or 32K $\times 16$ option (IDT8MP612)
- Fast access time
- 70ns (max.) over commercial temperature range
- Separate Upper byte (I/O6-16) and Lower byte control allows for greater application flexibility
- Low-power consumption
- Offered in a vertically mounted 40-pin SIP (single in-line package) for maximum space-savings
- Cost-effective plastic SO's mounted on an epoxy laminate (FR-4) substrate
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT8MP624LIDT8MP612L are high-speed CMOS static RAMs constructed on an epoxy laminate substrate using four 32K x 8 static RAMs (IDT8MP624L) or two $32 \mathrm{~K} \times 8$ staticRAMs (IDT8MP612L.) inplastic surface-mount packages. Functional equivalence to proposed monolithic static RAMs is achieved by utilization of an on-board decoder that interprets the higher order address A15 to select one of the two $32 \mathrm{~K} \times 16$ RAMs as the by-16 output and using $\overline{\mathrm{LB}}$ and $\overline{\mathrm{UB}}$ as two extra chip select functions for lower byte (I/O1-8) and upper byte (I/ O9-16) control, respectively. (On the IDT8MP612L 32K x 16 option, A15 needs to be extremely grounded for proper operation.)

The IDT8MP624LIDT8MP612L are available with access times as fast as 70 ns for commercial temperature range, with maximum operating power consumption of only $825 \mathrm{~mW}(64 \mathrm{~K}$ $x 16$ option). The module also offers a full standby mode of 2.2 mW (max.).

The IDT8MP624LIDT8MP612L are offered in a 40-pin FR4 SIP package. For the 32-pin JEDEC sidebrazed DIP, refer to the IDT8M624S/IDT8M612S.

All inputs and outputs of the IDT8MP624L/IDT8MP612L are TTL-compatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation, and providing equal access and cycle times for ease of use.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1)}$



2708 drw 01
SIP
SIDE VIEW
NOTE:

1. For module dimensions, please refer to module drawing M39 (8MP624L) and M40 (8MP612L in the packaging section.
2. On the IDT8MP612L ( $32 \mathrm{~K} \times 16$ ) option, A15 (Pin 31) requires external grounding for proper operation of the module.

PIN NAMES

| A0-15 | Addresses |  |  |  |
| :--- | :--- | :---: | :---: | :---: |
| $/ O_{1-16}$ | Data Input/Output |  |  |  |
| $\overline{\mathrm{CS}}$ | Chip Select |  |  |  |
| $\overline{\mathrm{WE}}$ | Write Enable |  |  |  |
| Vcc | Power |  |  |  |
| GND | Ground |  |  |  |
| $\overline{\mathrm{OE}}$ | Output Enable |  |  |  |
| $\overline{U B}$ | Upper Byte Control |  |  |  |
| $\overline{\mathrm{LB}}$ | Lower Byte Control |  |  |  |
| 2708 |  |  |  |  |

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| PT | Power Dissipation | 1.0 | W |
| IOUT | DC Output Current | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING

 TEMPERATURE AND VOLTAGE SUPPLY| Grade | Amblent Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT8MP624L |  |  | IDT8MP612L |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. ${ }^{(1)}$ | Max. | Min. | Typ. ${ }^{(1)}$ | Max. |  |
| \|lı| | Input Leakage Current | $V C C=M a x ., V I N=$ GND to Vcc | - | - | 15 | - | - | 15 | $\mu \mathrm{A}$ |
| \|lıO| | Output Leakage Current | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{CS}=\mathrm{V} \mathrm{IH}, \mathrm{VOUT}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | - | 15 | - | - | 15 | $\mu \mathrm{A}$ |
| IcC1 | Operating Power Supply Current | $\overline{\mathrm{CS}}, \overline{\mathrm{UB}}$, and $\overline{\mathrm{LB}}=\mathrm{VIL}$ Vcc = Max., Output Open $t=0$ | - | 20 | 80 | - | 20 | 80 | mA |
| IcC2 | Dynamic Operating Current | $\overline{\mathrm{CS}}, \overline{\mathrm{UB}}$, and $\overline{\mathrm{LB}}=\mathrm{VIL}$ Vcc = Max., Output Open $f=\mathrm{fmax}$ | - | 80 | 150 | - | 80 | 150 | mA |
| ISB | Standby Power Supply Current | $\begin{aligned} & \overline{C S} \geq V_{\mathbb{I}} \\ & V C C=M a x ., \text { Output Open } \\ & f=f \operatorname{MAX} \end{aligned}$ | - | 6 | 15 | - | 6 | 15 | mA |
| ISB1 | Full Standby Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 10 | 400 | - | 10 | 300 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathrm{IOL}=2.1 \mathrm{~mA}, \mathrm{Vcc}=\mathrm{Min}$. | - | - | 0.4 | - | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-1.0 \mathrm{~mA}, \mathrm{VCC}=$ Min. | 2.4 | - | - | 2.4 | - | - | V |

NOTE:

1. $\mathrm{Vcc}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

## AC TEST CONDITIONS

| Input Pulse Levels |
| :--- |
| Input Rise/Fall Times |
| Input Timing Reference Levels |
| Output Reference Levels |
| Output Load |

GND to 3.0V
10 ns
1.5 V
1.5 V

See Figures 1 and 2


Figure 1. Output Load


Figure 2. Output Load (for tcLz, tOLZ, tCHz, tohz, tow, twhz)

## AC ELECTRICAL CHARACTERISTICS

| Symbol | Parameters | IDT8MP624L70 IDT8MP612L70 Min. Max |  | IDT8MP624L85 IDT8MP612L85 Min. Max |  | IDT8MP624L100 IDT8MP612L100 Min. <br> Max. |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Cycle |  |  |  |  |  |  |  |  |
| tRc | Read Cycle Time | 70 | - | 85 | - | 100 | - | ns |
| tAA | Address Access Time | - | 70 | - | 85 | - | 100 | ns |
| tacs | Chip Select Access Time | - | 70 | - | 85 | - | 100 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 10 | - | 10 | - | 10 | - | ns |
| toe | Output Enable to Output Valid | - | 40 | - | 50 | - | 60 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Select to Output in High Z | - | 30 | - | 35 | - | 40 | ns |
| tOHZ ${ }^{(1)}$ | Output Disable to Output in High Z | - | 30 | - | 35 | - | 40 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{tPu}^{(1)}$ | Chip Select to Power Up Time . | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 70 | - | 85 | - | 100 | ns |


| Write Cycle |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twC | Write Cycle Time | 70 | - | 85 | - | 100 | - | ns |
| tcw | Chip Select to End of Write | 65 | - | 75 | - | 90 | - | ns |
| taw | Address Valid to End of Write | 65 | - | 75 | - | 90 | - | ns |
| tAS | Address Sotup Time | 5 | - | 5 | - | 5 | - | ns |
| twP | Write Pulse Width | 60 | - | 70 | - | 80 | - | ns |
| twr | Write Recovery Time | 10 | - | 10 | - | 10 | - | ns |
| tWHz ${ }^{(1)}$ | Write Enable to Output in High Z | - | 30 | - | 35 | - | 40 | ns |
| tDw | Data to Write Time Overlap | 30 | - | 35 | - | 40 | - | ns |
| tDH | Data Hold from Write Time | 5 | - | 5 | - | 5 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


2708 dw 06

## NOTES:

1. WE is High for Read Cycle.
2. Device is continuously selected, $\overline{C S}=V_{I L}$ and $\overline{U B}, \overline{L B}=V_{I L}$ for $\times 16$ output active.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

## TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$



TIMING WAVEFORM OF WRITE CYCLE NO. $2^{(1,6)}$


## NOTES:

1. $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CS}}$ or $\overline{\mathrm{UB}}$ and $\overline{\mathrm{LB}}$ must be high during all address transitions.
2. A write occurs during the overlap (wPP) of a low CS. and a low $\overline{W E}$.
3. WWR is measured from the earlier of CS or WE going high to the end of the write cycle.
4. During this period, I/O pins are in the output state so that the input signals of opposite phase to the output must not be applied.
5. If the $\overline{\mathrm{CS}}, \overline{\mathrm{UB}}$ and $\overline{\mathrm{UB}}$ low transition occurs simultaneously with the $\overline{\mathrm{WE}}$ low transition or after the $\overline{\mathrm{WE}}$ transition, outputs remain in a high impedance state.
6. $\overline{O E}$ is continuously low ( $\overline{O E}=V / L)$.
7. Dout is the same phase of write data of this write cycle.
8. If $\overline{C S}, \overline{U B}$ and $\overline{U B}$ is low during this period, $/ / O$ pins are in the output state. Then the data input signals of opposite phase to the outputs must not be applied to them.
9. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

## TRUTH TABLE

| Mode | CS | UB | LB | OE | WE | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- | :--- |
| Standby | H | X | X | X | X | High Z | Standby |
| Standby | L | H | H | X | X | High Z | Standby |
| Read | L | L | L | L | H | Dout 1-16 | Active |
| Lower Byte <br> Read | L | H | L | L | H | Dout 1-8 | Active (XB) |
| Upper Byte <br> Read | L | L | H | L | H | Dout 9-16 | Active (XB) |
| Read | L | L | L | H | H | High Z | Active |
| Lower Byte <br> Read | L | H | L. | H | H | High Z | Active (XB) |
| Upper Byte <br> Read | L | L | H | H | H | High Z | Active (XB) |
| Write | L | L | L | X | L | DiN 1-16 | Active |
| Lower Byte <br> Read | L | H | L | X | L | DiN 1-8 | Active (XB) |
| Upper Byte <br> Read | L | L | H | X | L | DiN 9-16 | Active (XB) |

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{t}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{V} \operatorname{IN}=0 \mathrm{~V}$ | 35 | pF |
| Cour | Output Capacitance | VouT $=0 \mathrm{~V}$ | 40 | pF |

## NOTE:

1. This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION




## FEATURES:

- High-density 1 Megabit CMOS static RAM module
- Customer-configured to $64 \mathrm{~K} \times 16,128 \mathrm{~K} \times 8$ or $256 \mathrm{~K} \times 4$
- Fast access times
- Military: 30ns (max.)
- Commercial: 25ns (max.)
- Low power consumption
- Active: 4.8 W (typ. in $64 \mathrm{~K} \times 16$ organization)
- Standby: 1.6 mW (typ.)
- Offered in 40-pin, 900 mil center sidebraze DIP, achieving very high memory density
- Single 5V ( $\pm 10 \%$ ) power supply
- Dual GND pins for maximum noise immunity
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT7M624 is a 1 Megabit high-speed CMOS static RAM module constructed on a multi-layered ceramic substrate using sixteen $64 \mathrm{~K} \times 1$ static RAMs in leadless chip carriers. Making four chip select lines available (one for each group of 4 RAMs) allows the userto configure the memory into a $64 \mathrm{~K} \times 16,128 \mathrm{~K} \times 8$ or $256 \mathrm{~K} \times 4$ organization. In addition, extremely high speeds can be achieved by the use of IDT7187s fabricated in IDT's high-performance, highreliability technology, CEMOS ${ }^{\text {TM }}$.

The IDT7M624 is available with access times as fast as 25ns (max.) commercial and 30ns (max.) military temperature range, with maximum operating power consumption of only 12.3 W (significantly less if organized $128 \mathrm{~K} \times 8$ or $256 \mathrm{~K} x$ 4). The module also offers a standby power mode of 5.7 W (max.) and a full standby mode of 1.7W (max.).

The IDT7M624 is offered in a 40 -pin, 900 mil center sidebraze DIP.

All inputs and outputs of the IDT7M624 are TTL-compatible and operate from a single 5V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

All IDT military module semiconductor components are compliant with the latest revision of MIL-STD-883, Class B, making them ideally suited to applications demanding the highest level of performance and reliability.

## FUNCTIONAL BLOCK DIAGRAM



## IDT7M624

## 64K x 16 CONFIGURATION



NOTE:
2663 drw 08

1. All chip selects tied together since, in a by 16 configuration, all chips are either on or off.

## IDT7M624

128K x 8 CONFIGURATION


NOTE:

1. The chip selects are tied together in groups of two. The decoder uses the new higher order address pin (A16) to determine which of the two banks of memory are enabled.

## IDT7M624

## 256K x 4 CONFIGURATION



## PIN CONFIGURATION ${ }^{(1)}$



NOTE:

1. For module dimensions, please refer to module drawing M8 in the packaging section

## TRUTH TABLE

| Mode | $\overline{\text { CSxx }}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :--- | :--- |
| Standby | H | X | High Z | Standby |
| Read | L | H | DATAouT | Active |
| Write | L | L | High Z | Active |

## RECOMMENDED OPERATING

TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :--- | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C} \mathrm{to}+125^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

PIN NAMES

| A0-15 | Address |
| :--- | :--- |
| Do-15 | Data Input/Output |
| $\overline{\mathrm{CS}} x \mathrm{x}$ | Chip Selects |
| $\overline{\text { WE }}$ | Write Enable |
| VCC | Power |
| GND | Ground |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Milltary | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal <br> Voltage with <br> Respect to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +155 | ${ }^{\circ} \mathrm{C}$ |
| bUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2663 tbl 05

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter(1) | Conditions | Typ. | Units |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{ViN}=\mathrm{OV}$ | 130 | pF |
| COUT | Output Capacitance | $\mathrm{VouT}=\mathrm{OV}$ | 35 | pF |

NOTE:
2663 tbl 06

1. This parameter is guaranteed by design but not tested.

## RECOMMENDED DC OPERATING

CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2663 tbl 03

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7M624S |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ ${ }^{1)}$ | Max. ${ }^{(3)}$ | Max. ${ }^{(4)}$ |  |
| \|| 4 | | Input Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \mathrm{VIN}=\mathrm{GND}$ to VCC | - | - | 20 | 20 | $\mu \mathrm{A}$ |
| \|l Lo | | Output Leakage Current | $\mathrm{VCC}=5.5 \mathrm{~V}, \overline{\mathrm{CS}} \mathrm{XX}=\mathrm{V} \mathrm{H}$, VOUT $=$ GND to Vcc | - | - | 20 | 20 | $\mu \mathrm{A}$ |
| ICCX16 | Operating Current in X16 mode | $\begin{aligned} & \overline{\mathrm{CS} X X}=\mathrm{V} \text { IL, Output Open, Vcc }= \\ & 5.5 \mathrm{~V}, \mathrm{f}=\mathrm{fMAX} \end{aligned}$ | - | 960 | 1950 | 2240 | mA |
| ICCx8 | Operating Current in X8 mode | $\overline{\mathrm{CS}} \mathrm{XX}=\mathrm{V}$ it, Output Open, Min. Duty Cycle $=100 \%$ | - | 720 | 1380 | 1640 | mA |
| IccX4 | Operating Current in X4 mode | $\overline{\mathrm{CS}} \mathrm{xx}=\mathrm{V} \mathrm{L}$, Output Open, Min. Duty Cycle $=100 \%$ | - | 600 | 1100 | 1340 | mA |
| ISB | Standby Power Supply Current | $\overline{\mathrm{CS}} \mathrm{XX} \geq \mathrm{VIH}$ (TTL Level), $\mathrm{VcC}=5.5 \mathrm{~V}$. Output Open | - | 480 | 820 | 1040 | mA |
| ISB1 | Full Standby Power Supply Current | $\overline{\mathrm{CS}} \mathrm{XX} \geq \mathrm{VCc}-0.2 \mathrm{~V}$ VIN $\geq \mathrm{Vcc}-$ 0.2 V or $\leq 0.2 \mathrm{~V}$ (CMOS Level) | - | 0.32 | $320{ }^{(2)}$ | 320 | mA |
| Vol | Output Low Voltage | $1 \mathrm{LL}=10 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ | - | - | 0.5 | 0.5 | V |
|  |  | $1 \mathrm{LL}=8 \mathrm{~mA}, \mathrm{VCC}=4.5 \mathrm{~V}$ | - | - | 0.4 | 0.4 | V |
| VOH | Output High Voltage | $1 \mathrm{OH}=-4 \mathrm{~mA}, \mathrm{VcC}=4.5 \mathrm{~V}$ | 2.4 | - | - | - | V |

NOTES:

1. Typical limits are at $\mathrm{Vcc}=5.0 \mathrm{~V},+25^{\circ} \mathrm{C}$.
2. Issi max. at commercial temperature $=240 \mathrm{~mA}$.
3. $L A A=30,35,45,55,65 \mathrm{~ns}$.
4. $t A A=25 \mathrm{~ns}$.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load (for tchz, tcLz, twhz and tow)
*Including scope and jig.

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{array}{\|c\|} \hline \text { 7M624S25 } \\ \text { Com'I. Only } \end{array}$ |  | 7M624S30 |  | 7M624S35 |  | 7M624S45 |  | 7M624S55 |  | 7M624S65 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |

## Read Cycle

| IRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | 45 | - | 55 | - | 65 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 AA | Address Access Time | - | 25 | - | 30 | - | 35 | - | 45 | - | 55 | - | 65 | ns |
| $t$ ACS | Chip Select Access Time | - | 25 | - | 30 | - | 35 | - | 45 | - | 55 | - | 65 | ns |
| 1 OH | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| t CLZ | Chip Selection to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| 1 CHz | Chip Deselection to Output in High Z | - | 20 | - | 25 | - | 30 | - | 30 | - | 30 | - | 30 | ns |
| $t \mathrm{PU}$ | Chip Selection to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| t PD | Chip Selection to Power Down Time | - | 25 | - | 30 | - | 35 | - | 35 | - | 35 | - | 35 | ns |

Write Cycle

| $t$ Wc | Write Cycle Time | 25 | - | 30 | - | 35 | - | 45 | - | 55 | - | 65 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t \mathrm{CW}$ | Chip Selection to End of Write | 22 | - | 25 | - | 30 | - | 40 | - | 50 | - | 55 | - | ns |
| t AW | Address Valid to End of Write | 22 | - | 25 | - | 30 | - | 40 | - | 50 | - | 55 | - | ns |
| t AS | Address Set-up Time | 2 | - | 3 | - | 5 | - | 5 | - | 5 | - | 10 | - | ns |
| $t$ WP | Write Pulse Width | 20 | - | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| $t$ WR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $t \mathrm{DW}$ | Data Valid to End of Write | 15 | - | 20 | - | 20 | - | 25 | - | 25 | - | 30 | - | ns |
| 1 DH | Data Hold Time | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| $t$ WHz | Write Enable to Output in High Z | 0 | 20 | 0 | 25 | 0 | 30 | 0 | 30 | 0 | 30 | 0 | 35 | ns |
| tow | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

TIMING WAVEFORM OF READ CYCLE NO. $1(1,2)$


2663 drw 04
TIMING WAVEFORM OF READ CYCLE NO. $2(1,3)$


NOTES:

1. WE is high for READ cycle.
2. CSXX is low for READ cycle.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}} \mathrm{xx}$ transition low.
4. Transition is measured $\pm 200 \mathrm{mV}$ from steady state voltage with specified loading in Figure 2 . This parameter is guaranteed by design but not tested.
5. All READ cycle timings are referenced from the last valid address to the first transitioning address.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\mathrm{WE}}$ CONTROLLED TIMING) ${ }^{(12,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\mathrm{CS}}$ CONTROLLED TIMING) $)^{(12,3,5)}$


NOTES:

1. $\overline{W E}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{\mathrm{CS}}$ and a low $\overline{\mathrm{WE}}$
3. TWR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of write cycle.
4. During this period, I/O pins are in the output state and input signals must not be applied.
5. If the $\overline{C S}$ low transition occurs simultaneously with or after the $\overline{W E}$ low transition, outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION



256K x 16
IDT7M4016 CMOS STATIC RAM MODULE

## DESCRIPTION:

The IDT7M4016 is a 4 megabit high-speed CMOS static RAM module constructed on a multi-layered ceramic substrate using sixteen ( $256 \mathrm{~K} \times 1$ ) static RAMs in leadless chip carriers. The IDTM4016 is anupgrade from the IDT7M624 ( $64 \mathrm{~K} \times 16$ RAM module) offering four times the memory density in the same size package. Making four chip select lines available (one for each group of four RAMs) allows the user to configure the memory into a $256 \mathrm{~K} \times 16,512 \mathrm{~K} \times 8$ or $1024 \mathrm{~K} \times 4$ organization.

The IDT7M4016 is packaged in a 48-pin, 900 mil wide sidebrazed DIP. This enables four megabits of static RAM memory to be placed in less than 2.2 square inches of board space.

All inputs and outputs of the IDT7M4016 are TTL-compatible and operate from a single 5V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

All IDT military module semiconductor components are compliant to the latest revision of MIL-STD-883, Class B, making them ideally suited to applications demanding the highest level of performance and reliability.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1)}$



PIN NAMES

| Vcc | Power |
| :--- | :--- |
| GND | Ground |
| Ao-A17 $^{2}-$ | Addresses |
| Do-D15 | Data Input/Output |
| $\overline{\mathrm{CS} 0-3}$ | Chip Selects |
| $\overline{\text { WEL }}$ | Write Enable (Lower Byte) |
| $\overline{\text { WEU }}$ | Write Enable (Upper Byte) |

## TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | Output | Power |
| :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | High-Z | Standby |
| Read | L | H | DATAouT | Active |
| Write | L | L | High Z | Active |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2713 tol 03

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $T A=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{CIN}(\mathrm{D})$ | Input Capacitance <br> (Data) | $\mathrm{VIN}=\mathrm{OV}$ | 30 | pF |
| $\mathrm{CIN}(\mathrm{A})$ | Input Capacitance <br> (Address and Control) | $\mathrm{VIN}=\mathrm{OV}$ | 200 | pF |
| CouT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 30 | pF |

NOTE:
2713 to 04

1. This parameter is guaranteed by design, but not tested.

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |
| NOTE: |  |  |  |  |  |

1. $V_{I L}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \| 1 | | Input Leakage <br> (Address and Control) | Vcc = Max., Vin = GND to Vcc | - | 80 | $\mu \mathrm{A}$ |
| \|l|l| | Input Leakage (Data) | $V C C=M a x ., \mathrm{V}$ IN = GND to Vcc | - | 10 | $\mu \mathrm{A}$ |
| \| L O | | Output Leakage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{CS}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min}$., $1 \mathrm{OH}=-4 \mathrm{~mA}$ | 2.4 | - | V |

2713 tbl 07

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | $\frac{\text { IDT7M4016 }}{} \text { Max. }$ |  | IDT7M4016 ${ }^{(2)}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Max. |  | Max. |  |  |
|  |  |  | Com'l. | MII. | Com'l. | MII. |  |
| IcC1 | Operating Current | Vcc $=$ Max., $\mathrm{CS} \leq \mathrm{VIL}, f=0$, Outputs Open | 1760 | - | 1600 | 1760 | mA |
| Icc2 | Dynamic Operating Current | $\text { VCC }=\text { Max. }, C S \leq V I L, f=f \text { MAX }$ <br> Output Open | 2560 | - | 2400 | 2560 | mA |
| ISB | Standby Supply Current | $V C C=$ Max., $\overline{C S} \geq \mathrm{VIH}, \mathrm{f}=\mathrm{fmax}$, Ouputs Open | 560 | - | 560 | 560 | mA |
| IsB1 | Full Standby Supply Current | $\overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}, \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\leq 0.2 \mathrm{~V}$ | 480 | - | 480 | 480 | mA |

NOTES:

1. $25,30 \mathrm{~ns}$
2. $35,45,55 \mathrm{~ns}$

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |  |
| :--- | :---: | :---: |
| Input Rise/Fall Times | 5 ns |  |
| Input Timing Reference Levels | 1.5 V |  |
| Output Reference Levels | 1.5 V |  |
| Output Load | See Figures 1 and 2 |  |
| $27+3+109$ |  |  |



FIgure 1. Output Load


Figure 2. Output Load (for tclz, tchz, tow, twhz)
*Including scope and jig

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | 7M4016S25 <br> Com'I. Only |  | 7M4016S30 <br> Com'I. Only |  | 7M4016S35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | ns |
| tAA | Address Access Time | - | 25 | - | 30 | - | 35 | ns |
| tacs | Chip Select Access Time | - | 25 | - | 30 | - | 35 | ns |
| tClz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{CCHz}^{(1)}$ | Chip Deselect to Output in High Z | - | 13 | - | 17 | - | 20 | ns |
| tor | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{tPu}^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 25 | - | 30 | - | 35 | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 25 | - | 30 | - | 35 | - | ns |
| tcw | Chip Selection to End of Write | 25 | - | 30 | - | 35 | - | ns |
| taw | Address Valid to End of Write | 25 | - | 30 | - | 35 | - | ns |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 25 | - | 30 | - | 35 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| twhZ ${ }^{(1)}$ | Write Enable io Ouput in High Z | - | 13 | - | 15 | - | 20 | ns |
| tow | Data to Write Time Overlap | 12 | - | 15 | - | 15 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | ns |

NOTE:
2713 か 10

1. This parameter is guaranteed by design, but not tested.

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | 7M4016S45 |  | 7M4016S55 |  | $\begin{gathered} \text { 7M4016S70 } \\ \text { MII. Only } \\ \hline \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| tAA | Address Access Time | - | 45 | - | 55 | - | 70 | ns |
| tacs | Chip Select Access Time | - | 45 | - | 55 | - | 70 | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{tCHz}^{(1)}$ | Chip Deselect to Output in High Z | - | 25 | - | 25 | - | 30 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | 45 | - | 55 | - | 70 | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 45 | - | 55 | - | 70 | - | ns |
| tcw | Chip Selection to End of Write | 45 | - | 55 | - | 65 | - | ns |
| taw | Address Valid to End of Write | 45 | - | 55 | - | 65 | - | ns |
| tAS | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 45 | - | 55 | - | 65 | - | ns |
| twR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| ${ }^{\text {t }} \mathrm{WHZ}{ }^{(1)}$ | Write Enable to Ouput in High Z | - | 25 | - | 25 | - | 30 | ns |
| tDW | Data to Write Time Overlap | 20 | - | 30 | - | 35 | - | ns |
| tDH | Data Hold from Write Time | 0 | 二 | 0 | - | 0 | 二 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $\mathbf{2}^{(1,2)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3)}$


NOTES:

1. WE is high for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{V}$ IL.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\text { WE CONTROLLED TIMING) }}{ }^{(1,2,3)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\mathrm{CS}}$ CONTROLLED TIMING) $)^{(1,2,3,4)}$


## NOTES:

1. WE or CS must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low $\overline{W E}$.
3. TWR is measured from the earlier of CS or WE going High to the end of write cycle.
4. If the $\overline{\mathrm{CS}}$ Low transition occurs simultaneously with or after the $\overline{\mathrm{WE}}$ Low transition, the outputs remain in a high impedance state.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION



|  | $\text { 512K x } 16$ <br> CMOS STATIC RAM MODULE | IDT7MP4047 |
| :---: | :---: | :---: |

## FEATURES:

- High-speed 8 megabit CMOS static RAM module
- Fast access time: 70ns (max.)
- Low power consumption
- Active: 220mA max.

Standard version

- CMOS Standby: 16 mA max.

Very low power version (SCD4600)

- CMOS Standby: $800 \mu \mathrm{~A}$ max.
- Data retention: $400 \mu \mathrm{~A}$ max. ( $\mathrm{Vcc}=2 \mathrm{~V}$ )
- Surface mounted small outline plastic packages on a 45-pin FR-4 SIP (Single In-line Package)
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs/outputs directly TTL compatible


## DESCRIPTION:

The IDT7MP4047 is an $512 \mathrm{~K} \times 16$ CMOS static RAM module constructed on a multilayer epoxy laminate (FR-4) substrate using $8128 \mathrm{~K} \times 8$ static RAMs in small outline plastic packages and a one-of-four decoder. Availability of two Write Enables and two Output Enables provides byte access and output control flexibility. The IDT7MP4047 is available with access times as fast as 70 ns with a maximum operating current of 220 mA . For battery backup applications, a very low data retention current version is available.

The IDT7MP4047 is packaged in a 45-pin FR-4 SIP (Single In-line Package). This results is a package 4.6 inches in length and 0.3 inches in thickness.

All inputs and outputs of the IDT7MP4047 are TTL compatible and operate from a single 5 V supply. Full asynchronous circuitry requires no clocks or refresh for operation and provides equal access and cycle times for ease of use.


## PIN CONFIGURATION ${ }^{(1)}$



NOTE:

## FRONT VIEW

1. For module dimensions, please refer to drawing M41 in the packaging section.

TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :--- | :--- |
| Standby | H | X | High Z | Standby |
| Read | L | H | DATAouT | Active |
| Write | L | L | High Z | Active |

## PIN NAMES

| $\mathrm{I} / \mathrm{O}_{0}-\mathrm{I} / \mathrm{O}_{15}$ | Data Inputs/Outputs |
| :--- | :--- |
| $\mathrm{A} 0-\mathrm{A}_{18}$ | Addresses |
| $\overline{\mathrm{CS}}$ | Chip Select |
| $\overline{\mathrm{WE}} 0-1$ | Write Enables |
| $\overline{\mathrm{OE}}_{0-1}$ | Output Enables |
| Vcc | Power |
| GND | Ground |

2754 tol 01
ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Iout | DC Output Current | 50 | mA |

NOTE:
2754 कا 03

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}^{( }=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 35 | pF |
| $\mathrm{CIN}(\mathrm{C}) \cdot$ | Input Capacitance $(\overline{\mathrm{CS}})$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 8 | pF |
| COUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 35 | pF |

NOTE:
2754 tol 04

1. This parameter is guaranteed by design, but not tested.

## RECOMMENDED DC OPERATING

 CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIL}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \|lı| | Input Leakage | Vcc = Max., VIN = GND to Vcc | - | 8 | $\mu \mathrm{A}$ |
| \|liol | Output Leakage | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V O U T=G N D \text { to } V C C \end{aligned}$ | - | 8 | $\mu \mathrm{A}$ |
| VoL | Output Low Voltage | $\mathrm{Vcc}=\mathrm{Min} ., \mathrm{IOL}=2 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VcC}=$ Min., $\mathrm{IOH}=-1 \mathrm{~mA}$ | 2.4 | - | V |
| Icc | Dynamic Operating Current | $\begin{aligned} & \text { VCC = Max., } \overline{\mathrm{CS}}=\text { VIL, } \\ & \mathrm{f}=\mathrm{fMAX}, \text { Output Open } \end{aligned}$ | - | 220 | mA |
| ISB | Standby Supply Current (TTL Levels) | $\begin{aligned} & \overline{C S} \geq V_{I H}, V C C=\text { Max., } \\ & f=\text { fMAX, Ouput Open } \end{aligned}$ | - | 24 | mA |
| $1581{ }^{11}$ | Full Standby Supply Current (CMOS Levels) | $\overline{\mathrm{CS}} \geq$ VHC, VIN $\geq$ VHC or $\leq$ VLC $V C C=$ Max., Output Open | - | 16 | mA |

NOTE:

1. For low power version $\mathrm{I}_{\mathrm{s} 81}=800 \mu \mathrm{~A}$, refer to SCD4600 when ordering.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |
| $2754 \$ 108$ |  |



Figure 1. Output Load


Figure 2. Output Load
(for tclz, tolz, tchz, tohz, tow, and twhz)
*Including scope and jig

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

|  | Parameters | 7MP4047L70 |  | 7MP4047L85 |  | 7MP4047L100 |  | 7MP4047L120 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |


| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tRC | Read Cycle Time | 70 | - | 85 | - | 100 | - | 120 | - | ns |
| tAA | Address Access Time | - | 70 | - | 85 | - | 100 | - | 120 | ns |
| tacs | Chip Select Access Time | - | 70 | - | 85 | - | 100 | - | 120 | ns |
| toe | Output Enable to Output Valid | - | 45 | - | 48 | - | 50 | - | 60 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 30 | - | 33 | - | 35 | - | 40 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low $\mathbf{Z}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 40 | - | 43 | - | 45 | - | 50 | ns |
| tor | Output Hold from Address Change | 10 | - | 10 | - | 10 | - | 10 | - | ns |

## Write Cycle

| twC | Write Cycle Time | 70 | - | 85 | - | 100 | - | 120 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tWP | Write Pulse Width | 55 | - | 65 | - | 75 | - | 90 | - | ns |
| tAs | Address Set-up Time | 0 | - | 2 | - | 5 | - | 5 | - | ns |
| tAW | Address Valid to End of Write | 65 | - | 82 | - | 90 | - | 100 | - | ns |
| tCW | Chip Selection to End of Write | 65 | - | 80 | - | 85 | - | 100 | - | ns |
| tDS | Data Set-up Time | 35 | - | 38 | - | 40 | - | 45 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twhz $^{(1)}$ | Write Enable to Ouput in High Z | - | 30 | - | 33 | - | 35 | - | 40 | ns |
| tow $^{(1)}$ | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | ns |

1. This parameter is guaranteed by design, but not tested.

## DATA RETENTION CHARACTERISTICS ${ }^{(1,4)}$

( $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Condition | Min. | $\begin{gathered} \text { Max. } \\ \text { cc @ } 2.0 \mathrm{~V} \end{gathered}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VDR | Vcc for Data Retention | - | 2.0 | - | V |
| ICCDR | Data Retention Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \leq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq-0.2 \mathrm{~V} \end{aligned}$ | - | 400 | $\mu \mathrm{A}$ |
| $\operatorname{tCDR}^{(3)}$ | Chip Deselect to Data Retention Time |  | 0 | - | ns |
| $t \mathrm{R}^{(3)}$ | Operation Recovery Time |  | $\mathrm{tRC}^{(2)}$ | - | ns |

NOTES:

1. $V C C=2 V, T A=+25^{\circ} \mathrm{C}$.
2. $\quad \mathrm{tRC}=$ Read Cycle Time.
3. This parameter is guaranteed by design, but not tested.
4. This option is only offered when ordering to SCD4600.

## DATA RETENTION WAVEFORM



TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $\mathbf{2}^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


NOTES:

1. WE is high for Read Cycle.
2. Device is continuously selected, $\mathrm{CS}=\mathrm{VIL}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=V I L$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 ( $\overline{\mathrm{WE}}$ CONTROLLED TIMING) ${ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. $2(\overline{\operatorname{CS}} \text { CONTROLLED TIMING })^{(1,2,3,5)}$


NOTES:

1. WE or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (tWP) of a low CSand a low $\bar{W} E$.
3. twh is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going High to the end of write cycle.
4. During this period, I/O pins are in the output state and inputs signals must not be applied.
5. If the CS Low transition occurs simultaneously with or after the WE Low transitions, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig).. This parameter is graranteed by design, but not tested.
7. During a $\bar{W}$ controlled write cycle, write pulse ((twP) >tWHZ + tDW) to allow the $/ / O$ drivers to turn off and data to be placed on the bus for the required twD. If $O E$ is high during a $\bar{W} E$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp.

## ORDERING INFORMATION




## FEATURES:

- High density separate I/0,512K CMOS static RAM module
- Fast access time: 15ns (max.)
- Available in low profile 88 -pin sidebraze ceramic dual SIP (Dual Single In-line Package)
- Surface mounted LCC components mounted on a co-fired ceramic substrate
- High impedance outputs during write mode
- Single 5V ( $\pm 10 \%$ ) power supply
- Inputs/outputs directly TTL-compatible
- Multiple GND pins for maximum noise immunity


## DESCRIPTION:

The IDT7MC4032 is a $16 \mathrm{~K} \times 32$ static RAM module with separate I/O constructed on a co-fired ceramic substrate using eight IDT71982 16K $\times 4$ static RAMs in leadless chip carriers. Extremely fast speeds can be achieved due to the use of 64 K static RAMs Fabricated in IDT's High-performance, highreliability CEMOS ${ }^{\text {TM }}$ technology. The IDT7MC4032 is available with access time as fast as 15 ns with minimal power consumption.

The 7MC family of ceramic DSIPs offers the optimum in packing density and profile height. The IDT7MC4032 is packaged in a 88-pin ceramic dual SIP. The dual row configuration allow 88 pins to be placed on a package less than 4.5 inches long and .27 inches wide. At only 520 mils high, this low profile package is ideal for systems with minimum board spacing. Extremely high packing density can also be achieved allowing four IDT7MC4032 modules to be stacked per inch of board space.

All inputs and outputs of the IDT7MC4032 are TTLcompatible and operate from a single 5 V power supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation, and providing equal access and cycle times for ease of use.

All IDT military module semiconductor components are manufactured on compliance to the latest revision of MIL-STD-883, Class B, making them ideally suited for applications demanding the highest level of performance and reliability.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1)}$



## NOTE:

1. For module dimension, please refer to module drawing M43 in the packaging section.

## PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{13}$ | Addresses |
| :--- | :--- |
| $\mathrm{DlO}_{10} \mathrm{D}_{31}$ | Data Input |
| $\mathrm{DO}_{0}-\mathrm{DO}_{31}$ | Data Output |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\overline{\mathrm{CS}} \mathrm{I}$ | Chip Select (Lower) |
| $\overline{\mathrm{CS}} \mathrm{VCC}$ | Chip Select (Upper) |
| VCC | Power |
| GND | Ground |

2712 b1 01

## TRUTH TABLE

| Mode | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :---: | :--- | :--- |
| Standby | H | X | X | HighZ | Standby |
| Read | L | L | H | DATAouT | Active |
| Write | L | X | L | High Z | Active |
| Read | L | H | H | High Z | Active |

$2712 \pm 102$
ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -10 to +85 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| lOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2712 \#1 03

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN(D) | Input Capacitance <br> (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 15 | pF |
| CIN(A) | Input Capacitance <br> (Address and Control) | $\mathrm{VIN}=0 \mathrm{~V}$ | 80 | pF |
| COUT | Output Capacitance | $\mathrm{VOUT}=\mathrm{OV}$ | 15 | pF |

NOTE:

1. This parameter is guaranteed by design, but not tested.

RECOMMENDED DC OPERATING
CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2712 tbl 05

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
(Vcc $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \||Lu| | Input Leakage (Address and Control) | $\mathrm{Vcc}=\mathrm{Max} ., \mathrm{V}$ IN $=$ GND to Vcc | - | 80 | $\mu \mathrm{A}$ |
| \| 1 L|| | Input Leakage (Data) | $\mathrm{Vcc}=$ Max., Vin = GND to Vcc | - | 5 | $\mu \mathrm{A}$ |
| \|l니 | Output Leakage | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V \text { out }=G N D \text { to } V C C \end{aligned}$ | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |

2712 06
DC ELECTRICAL CHARACTERISTICS
(VCG $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | IDT7MC4032 <br> 15, 20ns |  | $\begin{gathered} \text { IDT7MC4032 } \\ 25 n \mathrm{~ns} \\ \hline \end{gathered}$ |  | IDT7MC4032$30,40,50 \mathrm{~ns}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Max. |  | Max. |  | Max. |  |  |
|  |  |  | Com'l. | Mil. | Com'l. | Mil. | Com'l. | MII. |  |
| ICC1 | Operating Current | $\begin{aligned} & f=0, \overline{C S} \leq V I L, V C C=\text { Max., } \\ & \text { Output Open } \end{aligned}$ | 960 | - | 960 | 1000 | 800 | 800 | mA |
| Icc2 | Dynamic Operating Current | $\begin{aligned} & \text { VCC = Max., } \overline{\mathrm{CS}} \leq \mathrm{VIL}, \\ & \mathrm{f}=\mathrm{fMAX}, \text { Output Open } \end{aligned}$ | 1200 | - | 1200 | 1200 | 1000 | 1120 | mA |
| ISB | Standby Supply Current | $\begin{aligned} & \overline{C S} \geq \text { VIIH, VCC = Max., } \\ & f=\text { fmax, Ouputs Open } \end{aligned}$ | 600 | - | 480 | 480 | 400 | 440 | mA |
| IsB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VCC}-0.2 \mathrm{~V}, \\ & \mathrm{VIN} \geq \mathrm{VcC}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | 200 | - | 160 | 160 | 120 | 160 | mA |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load (for tclz, tolz, tchz, tohz, tow, twhz)
*Including scope and jig

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{VcC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | 7MC4032S15 <br> Com'I Only |  | 7MC4032S20 Com'I Only |  | 7MC4032S25 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 15 | , - | 20 | - | 25 | - | ns |
| tAA | Address Access Time | - | \% ${ }^{\text {a }}$ | - | 20 | - | 25 | ns |
| tacs | Chip Select Access Time | - | 15 | - | 20 | - | 25 | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | § | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 10 | - | 15 | - | 15 | ns |
| tol $z^{(1)}$ | Output Enable to Output in Low Z | 5 | \$ | 5 | - | 5 | - | ns |
| tCHz ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 7 | - | 8 | - | 10 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | \%. 7 | - | 8 | - | 15 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | \% | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power Down Time | - | \% 15 | - | 20 | - | 25 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 14 | - | 17 | - | 20 | - | ns |
| tcw | Chip Selection to End of Write | 14 | , - | 17 | - | 20 | - | ns |
| taw | Address Valid to End of Write | 14. | - | 17 | - | 20 | - | ns |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 14 | - | 17 | - | 20 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 0 | - | ns |
| twhz ${ }^{(1)}$ | Write Enable to Ouput in High Z | $\cdots$ | 5 | - | 7 | - | 7 | ns |
| tDW | Data to Write Time Overlap | 8, | - | 10 | - | 13 | - | ns |
| tDH | Data Hold from Write Time | O. | - | 0 | - | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5, | - | 5 | - | 5 | - | ns |

## NOTE:

1. This parameter is guaranteed by design, but not tested.

## AC ELECTRICAL CHARACTERISTICS (Continued)

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameters | 7MC4032S30 |  | 7MC4032S40 |  | 7MC4032S50 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 30 | \% | 40 | - | 50 | - | ns |
| tAA | Address Access Time | - | \% 30 | - | 40 | - | 50 | ns |
| tACS | Chip Select Access Time | - | \% 30 | - | 40 | - | 50 | ns |
| tCLZ ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 20 | - | 22 | - | 30 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{tCHz}^{(1)}$ | Chip Deselect to Output in High Z | - | \%. 13 | - | 17 | - | 18 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | - | . 17 | - | 17 | - | 18 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - - | 0 | - | 0 | - | ns |
| $\mathrm{tPD}^{(1)}$ | Chip Deselect to Power Down Time | 二离 | \% 30 | - | 40 | - | 50 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 25 | - | 35 | - | 45 | - | ns |
| tcw | Chip Selection to End of Write | 25. | - | 28 | - | 38 | - | ns |
| taw | Address Valid to End of Write | 25 | - | 30 | - | 40 | - | ns |
| tAS | Address Set-up Time | 0 | - | 2 | - | 2 | - | ns |
| twp | Write Pulse Width | 25 | - | 28 | - | 38 | - | ns |
| tWR | Write Recovery Time | 0. | - | 0 | - | 0 | - | ns |
| tWHz ${ }^{(1)}$ | Write Enable to Ouput in High Z | - | 10 | - | 12 | - | 17 | ns |
| tDW | Data to Write Time Overlap | \% 15 | - | 17 | - | 23 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | ns |

NOTE:
2712 b 09

1. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


2712 drw 06

## NOTES:

1. WE is high for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{V}$ IL.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\mathrm{OE}=\mathrm{VIL}$
5. Transition is measured $\pm 500 \mathrm{mV}$ from steady state. This parameter is guaranteed by design but not tested.

## TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$



TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{C S}$ CONTROLLED TIMING) ${ }^{(1,6)}$


NOTES:

1. $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twp) of a low $\overline{\mathrm{CS}}$.
3. twa is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going High to the end of write cycle.
4. During this period, I/O pins are in the output state so that the input signals of opposite phase to the outputs must not be applied.
5. If the $\overline{C S}$ Low transition occurs simultaneously with or after the $\overline{W E}$ Low transitions or after the $\overline{W E}$ transition, the outputs remain in a high impedance state.
6. $\overline{\mathrm{OE}}$ is continuously low ( $\overline{\mathrm{OE}}=\mathrm{VIL})$.
7. DATAOUT is the same phase of write data of this write cycle.
8. If $\overline{\mathrm{CS}}$ is low during this period, l/O pins are in the output state. Then the data input signals of opposite phase must not be applied to them.
9. Transition is measured $\pm 500 \mathrm{mV}$ from steady state. This parameter is graranteed by design, but not tested.

## ORDERING INFORMATION



## FEATURES:

- High density 512K CMOS static RAM module
- Low profile 64 pin ZIP (zig-zag in-line vertical package)
- Fast access time: 15ns (max.)
- Surface mounted plastic components on an epoxy laminate (FR-4) substrate
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs/outputs directly TTL compatible
- Multiple GND pins for maximum noise immunity


## DESCRIPTION:

The IDT7MP4031 is a $16 \mathrm{~K} \times 32$ CMOS static RAM module constructed on an epoxy laminate (FR-4) substrate using 8 $16 \mathrm{~K} \times 4$ static RAMs in plastic SOJ packages. Availability of four chip select lines (one for each group of two RAMs) provides byte access. Extremely fast speeds can be achieved due to the use of 64 K static RAMs fabricated in IDT's high performance, high reliability CEMOS ${ }^{\text {M }}$ technology. The IDT7MP4031 is available with access time as fast as $15 n$ nswh minimal power consumption.

The IDT7MP family of ZIPs, DSIPs and SIPs offers the optimum in packing density and profile height. The IDT7MP4031 is packaged in a 64 pin (FR-4) ZIP (zig-zag inline vertical package). The dual row configuration allows 64 pins to be placed on a package 3.65 inches long and 0.35 inches wide. At only 0.50 inches high, this low profile package is ideal for systems with minimum board spacing.

All inputs and outputs of the IDT7MP4031 are TTL compatible and operate from a single 5 V supply. Full asynchronous circuitry requires no clocks or refresh for operation.

Two identification pins (PD0 and PD1) are provided for applications in which different density versions of the module are used. In this way, the target system can read the respective levels of PD0 and PD1 to determine a 16 K depth.

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION ${ }^{(1,2)}$

|  |  | 1 | GND |  |
| :---: | :---: | :---: | :---: | :---: |
| PDo | 2 | 3 | $P D_{1}$ | PDo-GND |
| $1 / \mathrm{O}$ | 4 | 5 | 1/08 | PD ${ }_{1}$-OPEN |
| $1 / O_{1}$ | 6 | 7 | $1 / 0_{9}$ |  |
| $1 / \mathrm{O}_{2}$ | 8 | 9 | I/O 10 |  |
| $1 / \mathrm{O}_{3}$ | 10 | 11 | I/O 11 |  |
| Vcc | 12 | 13 | Ao |  |
| A7 | 14 | 15 | $A_{1}$ |  |
| A8 | 16 | 17 | $\mathrm{A}_{2}$ |  |
| A9 | 18 | 19 | I/O 12 |  |
| $1 / \mathrm{O}_{4}$ | 20 | 21 | I/O 13 |  |
| $1 / \mathrm{O}_{5}$ | 22 | 23 | I/O 14 |  |
| $1 / \mathrm{O}_{6}$ | 24 | 25 | $1 / O_{15}$ |  |
| $\underline{1 / O_{7}}$ | 26 | 27 | GND |  |
| WE | 28 | 29 | NC |  |
| NC | 30 | 31 | $\overline{\mathrm{CS}}_{2}$ |  |
| $\mathrm{CS}_{1}$ | 32 |  |  |  |
| $\overline{\mathrm{CS}}_{3}$ | 34 | 33 35 | $\mathrm{CS}_{4}$ NC |  |
| NC | 36 | 37 | $\frac{\mathrm{NC}}{\mathrm{OE}}$ |  |
| GND | 38 | 39 | $1 / \mathrm{O}_{24}$ |  |
| $1 / \mathrm{O}_{16}$ | 40 | 41 | $1 / \mathrm{O}_{25}$ |  |
| I/O 17 | 42 | 43 | $1 / O_{26}$ |  |
| I/O 18 | 44 | 45 | $1 / \mathrm{O}_{27}$ |  |
| $1 / O_{19}$ A $_{10}$ | 46 | 47 | $\mathrm{A}_{3}$ |  |
| $\mathrm{A}_{10} \mathrm{~A}_{11}$ | 48 | 49 | $A_{4}$ |  |
| ${ }^{\text {A } 11}$ A 12 | 50 | 51 | A5 |  |
| $A_{12}$ | 52 | 53 | Vcc |  |
| ${ }_{\text {A }}{ }_{13}$ | 54 | 55 | $\mathrm{A}_{6}$ |  |
| $1 / \mathrm{O}_{20}$ | 56 | 57 | $1 / \mathrm{O}_{28}$ |  |
| $1 / \mathrm{O}_{21}$ | 58 | 59 | $1 / O_{29}$ |  |
| $1 / \mathrm{O}_{22}$ | 60 | 61 | $1 / O_{30}$ |  |
| $1 / \mathrm{O}_{23}$ | 62 | 63 | $1 / O_{31}$ |  |
| GND | 64 |  |  | 81 dw 02 |

## ZIP TOP <br> VIEW

NOTE:

1. For module dimensions, please refer to module drawig M46 in the packaging section.
2. Pins 2 and 3 ( $P D_{0}$ and $P D_{1}$ ) are read by the user to determine the depth of the module. If PD o reads $G N D$ and $P D_{1}$ reads Open, then the module has 16 K depth.

PIN NAMES

| $\mathrm{I} / \mathrm{OO}_{0}-31$ | Data Input/Output |
| :--- | :--- |
| $\mathrm{A}_{0}-13$ | Address Inputs |
| $\overline{\mathrm{CS}} 1-4$ | Chip Select |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| PD0-1 | Depth Identification |
| VCC | Power |
| GND | Ground |

## TRUTH TABLE

| Mode | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | High Z | Standby |
| Read | L | L | H | DATAouT | Active |
| Write | L | X | L | DATAIN | Active |
| Read | L | H | H | High-Z | Active |

2681 th 02
ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TsTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTES:
2681 \#1 03

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{F}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\operatorname{CIN}(\mathrm{D})$ | Input Capacitance <br> (Data) | $\mathrm{V}(\mathrm{N})=0 \mathrm{~V}$ | 10 | pF |
| $\mathrm{CIN}(\mathrm{A})$ | Input Capacitance <br> (Address \& Control) | $\mathrm{V}(\mathrm{IN})=0 \mathrm{~V}$ | 60 | pF |
| Cour | Output Capacitance | $\mathrm{V}(\mathrm{OUT})=0 \mathrm{~V}$ | 10 | pF |
| NOTE: |  |  |  |  |

1. This parameter is guaranteed by design, but not tested.

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $V_{\text {IL }}(\min )=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commerical | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \||LII| | Input Leakage (Address and Control) | Vcc = Max.; VIN = GND to Vcc | - | 40 | $\mu \mathrm{A}$ |
| \| $1 \mathrm{~L} \mid$ | Input Leakage (Data) | Vcc = Max.; VIN = GND to Vcc | - | 5 | $\mu \mathrm{A}$ |
| ILO | Output Leakage | $\mathrm{VcC}=$ Max.; $\overline{\mathrm{CS}}=\mathrm{VIH}, \mathrm{VOUT}=$ GND to Vcc | - | 5 | $\mu \mathrm{A}$ |
| Vol | Output Low | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High | $\mathrm{VcC}=$ Min., $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |


| Symbol | Parameter | Test Conditions | $\begin{aligned} & \text { 15ns } \\ & \text { Max. } \end{aligned}$ | $\begin{aligned} & \text { 20ns } \\ & \text { Max. } \end{aligned}$ | $\begin{aligned} & 25 \mathrm{~ns} \\ & \text { Max. } \end{aligned}$ | $\begin{aligned} & \hline \text { 35ns } \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Icc1 | Operating Current | $\begin{aligned} & f=0 ; \overline{\mathrm{CS}}=\mathrm{VIL} \\ & \mathrm{VCC}=\text { Max.; Output Open } \end{aligned}$ | 1080 | 960 | 960 | 800 | mA |
| ICC2 | Dynamic Operating Current | $\begin{aligned} & \text { VCC }=\text { Max } ; \overline{C S}=V I L ; f=\mathrm{fMAX} \\ & \text { Output Open } \end{aligned}$ | 1440 | 1200 | 1200 | 1000 | mA |
| IsB | Standby Supply Current | $\overline{\mathrm{CS}} \geq \mathrm{V}$ IH, $\mathrm{VCC}=$ Max. $\mathfrak{f}=$ fmax, Outputs Open | 600 | 480 | 480 | 400 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VCC}-0.2 \mathrm{~V} ; \mathrm{f}=0, \\ & \mathrm{VIN}>\mathrm{VCC}-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V} \end{aligned}$ | 200 | 160 | 160 | 120 | mA |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |



Figure 1. Output Load


Figure 2. Output Load (for $1 \mathrm{CHz}, \mathrm{tcIZ}, \mathrm{tOHz}$, tolz, twhz and tow)

## AC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7MP4031S15 |  | 7MP4031S20 |  | 7MP4031S25 |  | 7MP4031S35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 15 | - | 20 | - | 25 | - | 35 | - | ns |
| taA | Address Access Time | - | 15 | - | 20 | - | 25 | - | 35 | ns |
| tacs | Chip Select Access Time | - | 15 | - | 20 | - | 25 | - | 35 | ns |
| tCLZ1, ${ }^{\text {(1) }}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| TOE | Output Enable to Output Valid | - | 9 | - | 12 | - | 15 | - | 20 | ns |
| tol. ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tCHZ ${ }^{(1)}$ | Chip Deselect to Output in High Z | - | 7 | - | 8 | - | 10 | - | 15 | ns |
| tOHz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 7 | - | 8 | - | 15 | - | 15 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tPu ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{(1)}$ | Chip Deselect to Power-Down Time | - | 15 | - | 20 | - | 25 | - | 35 | ns |

Write Cycle

| twc | Write Cycle Time | 14 | - | 17 | - | 20 | - | 30 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tcW | Chip Select to End of Write | 14 | - | 17 | - | 20 | - | 25 | - | ns |
| taW | Address Valid to End of Write | 14 | - | 17 | - | 20 | - | 25 | - | ns |
| tAs | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twp | Write Pulse Width | 14 | - | 17 | - | 20 | - | 25 | - | ns |
| twr | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tWHZ |  |  |  |  |  |  |  |  |  |  |
| tow | Write Enable to Output in High Z | - | 6 | - | 7 | - | 7 | - | 10 | ns |
| tDH | Data to Write Time Overlap | Data Hold from Write Time | 10 | - | 10 | - | 13 | - | 15 | - |
| ns |  |  |  |  |  |  |  |  |  |  |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTE:

1. This parameter is guaranteed, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


2681 drw 05

TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


2681 dw 06

## NOTES:

1. $\overline{W E}$ is High for Read Cycle.
2. Device is continuously selected. $\overline{\mathrm{CS}}=\mathrm{VIL}$.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $O E=V I L$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$


2681 drw 07

TIMING WAVEFORM OF WRITE CYCLE NO. $2^{(1,6)}$


NOTES:

1. WE or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twR) of a low CS.
3. tWP is measured from the earlier of CS or WE going high to the end of the write cycle.
4. During this period, I/O pins are in the output state so that the input signals of opposite phase to the outputs must not be applied.
5. If the $\overline{C S}$ low transition occurs simultaneously with the $\overline{W E}$ low transitions or after the $\overline{W E}$ transition, outputs remain in a high impedence state.
6. $\overline{O E}$ is continuously low ( $\overline{O E}=V I L$ ).
7. Dout is the same phase of write data of this write cycle.
8. If $\overline{\mathrm{CS}}$ is low during this period, I/O pins are in the output state. Then the data input signals of opposite phase to the outputs must not be applied to them.
9. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

## ORDERING INFORMATION



SUBSYSTEMS "FLEXI-PAK" FAMILY
32K x 32
PRELIMINARY
IDT7M4003
128K x 32
IDT7M4013
CMOS STATIC RAM MODULE

## FEATURES:

- High-density 1 megabit/4 megabit CMOS static RAM modules
- Member of the Subsystems "Flexi-Pak" Family of interchangeable modules, with equivalent pin-outs, supporting a wide range of applications
- Footprint compatiblemodule upgrades to the next higher density with relative ease
- Fast access times:

7M4003-25ns (max.) commercial
7M4003-30ns (max.) military
7M4013-35ns (max.) commercial
7M4013-45ns (max.) military

- Low power CMOS operation
- Surface mounted LCC components on a multi-layered co-fired ceramic substrate
- Offered in a 66-pin "PGA-type" HIP (Hex In-line Package), occupying only 1 sq. inch of board space
- Single SV ( $\pm 10 \%$ ) power supply
- Multiple ground pins for maximum noise immunity
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT7M4003/4013 are high-speed, high-density 1 megabit/4 megabit CMOS static RAM modules constructed on a multi-layer co-fired ceramic subslrate using either 32 K x 8 or $128 \mathrm{~K} \times 8$ SRAM components in leadless chip carriers.

These modules are part of the IDT Subsytems "Flexi-Pak" Family modules. This family of SRAM/EEPROM/EPROM memory modules support applications requiring stand alone static or programmable memory requirements, or those applications needing a combination of both. All three module configurations have equivalent pin-outs, making these "plug-in compatible" (i.e. inter-changeable) modules suitable for a wide range of applications.

The IDT7M4003/4013 is available with access times as fast as $25 / 35$ ns over the commercial temperature range and $30 / 45 \mathrm{~ns}$ over the military temperature range.

This family of IDT modules are offered in a 66 -pin, ceramic HIP (Hex In-line Package). This HIP package is similar to a PGA and allows the designer to fit 1 megabit/4 megabit of memory into 1 sq . inch of board space.

All military IDT modules are assembled with semiconductor components compliant with the latest revision of MIL-STD883, Class B, making them ideally suited to applications demanding the highest level of performance and reliability.

FUNCTIONAL BLOCK DIAGRAM


2711 drw 01

## PIN CONFIGURATION ${ }^{(1,2)}$

| V/O8 | $\overline{W E}_{1}$ I/O 15 | $\bullet 1$-12 ${ }^{12}$ | $34 \bullet 45 \bullet 56 \bullet$ | 1/O24 | Vac | $\mathrm{l} / \mathrm{O}_{31}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $1 / \mathrm{O}_{9}$ | CS1 I/O 14 | -2 -13 - 24 | $35 \bullet 46 \bullet 57 \bullet$ | I/O25 | $\overline{\mathrm{CS}} 3$ | l/O30 |
| I/O 10 | GND //O 13 | - 3 -14 ${ }^{-25}$ | $36 \bullet 47 \bullet 58 \bullet$ | 1/O 26 | WE3 | $1 / \mathrm{O}_{29}$ |
| A 13 | I/O 11 I/O 12 | - 4 -15 ${ }^{26}$ | 37-48•59• | A6 | $1 / \mathrm{O}_{27}$ | 1/O28 |
| A 14 | $\mathrm{A}_{10} \overline{\mathrm{OE}}$ | $\bullet 5 \quad 16{ }^{-27}$ | $38 \bullet 49 \bullet 60 \bullet$ | A 7 | A3 | Ao |
| A 15 | $A_{11}$ GND | $\bullet 6 \quad 17$-28 | $39 \bullet 50 \bullet 61 \bullet$ | GND | $A_{4}$ | $A_{1}$ |
| A 16 | $\mathrm{A}_{12}$ WE 0 | $\bullet 7 \quad 18$ •29 | 40 - 51 - 62 - | As | A5 | $\mathrm{A}_{2}$ |
| GND | Vac 1/O 7 | - 8 - 19 - 30 | $41 * 52 \bullet 63 \bullet$ | A9 | $\overline{W E}_{2}$ | I/O 23 |
| I/Oo | CSo 1/O 6 | - 9 -20 - 31 | $42 \bullet 53 \bullet 64 *$ | I/O 16 | $\overline{\mathrm{CS}} 2$ | l/O 22 |
| $1 / \mathrm{O}$ | GND 1/O5 | - 10 - 21 - 32 | $43 \bullet 54 \bullet 65 \bullet$ | 1/O 17 | GND | l/O21 |
| // $\mathrm{O}_{2}$ | $\mathrm{I} / \mathrm{O}_{3} \mathrm{I} / \mathrm{O}_{4}$ | -11 - 22 - 33 | $44^{\bullet} 55 \bullet 66 \bullet$ | I/O 18 | I/O 19 | $\mathrm{l} / \mathrm{O}_{20}$ |
|  |  | HIP TOP VIEW |  |  |  |  |

NOTE:

1. For module dimensions, please refer to drawing M32 in the packaging section.
2. For the IDT7M4003 ( $32 \mathrm{~K} \times 32$ ) version, pins 6 and 7 are no connects.

## PIN NAMES

| Name | Descriptlon |
| :--- | :--- |
| I/O0-31 | Data Inputs/Outputs |
| $\mathrm{AO}_{\mathrm{-}} 6$ | Address Inputs |
| $\overline{W E}_{0-3}$ | Write Enables |
| $\overline{\mathrm{CS}} 0-3$ | Chip Selects |
| $\overline{\mathrm{OE}}$ | Output Enable |
| VCC | Power Supply |
| GND | Ground |

CAPACITANCE ${ }^{(1)}\left(\right.$ TA $\left.^{(1)}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN(1) | Input Capacitance <br> (DATA, $\overline{\mathrm{CS}}, \overline{\mathrm{WE}}$ ) | $\mathrm{VIN}=\mathrm{OV}$ | 50 | pF |
| $\mathrm{CIN}(2)$ | Input Capacitance <br> (ADDRESS, $\overline{\mathrm{OE}}$ ) | $\mathrm{VIN}=\mathrm{OV}$. | 12 | pF |
| COUT | Output Capacitance | Vout $=\mathrm{OV}$ | 12 | pF |

NOTE:

1. This parameter is guaranteed by design, but not tested.

TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\mathbf{O E}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :--- | :--- |
| Standby | H | X | X | High-Z | Standby |
| Read | L | L | H | DATAOUT | Active |
| Read | L | H | H | High Z | Active |
| Write | L | X | L | DATAIN | Active |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TstG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

NOTE:
2711 to 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VII}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

(VCC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C} \mathrm{TO}+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C} \mathrm{TO}+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. ${ }^{(1)}$ | Max. ${ }^{(2)}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \|니| | Input Leakage Current (Address, $\overline{\mathrm{OE} \text { ) }}$ |  | - | 5 | 10 | $\mu \mathrm{A}$ |
| \||LIL | Input Leakage Current (Data, $\overline{\mathrm{CS}}, \overline{\mathrm{WE}})$ | $\mathrm{VCC}=$ Max., VIN = GND to VCC | - | 20 | 40 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage Current | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{CS}=\mathrm{V}_{\mathrm{H}}, \mathrm{VOUT}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 5 | 10 | $\mu \mathrm{A}$ |
| Icc | Dynamic Operating Current | $\begin{aligned} & \text { Vcc = Max., } \overline{C S} \leq V I L \\ & f=f \text { max, Output Open } \end{aligned}$ | - | 800 | 880 | mA |
| ISB | Standby Supply Curent | $\begin{aligned} & V C C=\text { Max., } \overline{C S} \geq V_{I H} \\ & f=f \text { max, Output Open } \end{aligned}$ | - | 80 | 280 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VCC}-0.2 \mathrm{~V} \\ & \mathrm{VIN}>\mathrm{Vcc}-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V} \end{aligned}$ | - | 80 | 80 | mA |
| VoL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.4 | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | - | V |

## NOTE:

1. For $T A=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ versions only.
2. For $T A=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ versions only.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :---: | :---: |
| Input Rise/Fall Times | $\cdots \quad 10 \mathrm{~ns}$ |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Flgure 1. Output Load


Figure 2. Output Load (for tcLz, tolz, tchz, tohz, tow, twhz)
*Including scope and jig

## AC ELECTRICAL CHARACTERISTICS

$\left(V C C=5.0 \mathrm{~V} \pm 10 \%, T A=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameters | $\begin{gathered} \text { 7M4003S25 } \\ \text { (Com'I Only) } \\ \hline \end{gathered}$ |  | 7M4003S30 |  | $\begin{aligned} & \text { 7M4003S35 } \\ & \text { 7M4013S35 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { 7M4003S40 } \\ & 7 \mathrm{M} 4013 \mathrm{~S} 40 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { 7M4003S45 } \\ & \text { 7M4013S45 } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |

READ CYCLE

| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tAA | Address Access Time | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tacs | Chip Select Access Time | - | 25 | - | 30 | - | 35 | - | 40 | - | 45 | ns |
| tCLZ $^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toE | Output Enable to Output Valid | - | 12 | - | 13 | - | 15 | - | 20 | - | 25 | ns |
| tOLZ $^{(1)}$ | Output Enable to Output in Low Z | 2 | - | 2 | - | 2 | - | 5 | - | 5 | - | ns |
| tCHZ $^{(1)}$ | Chip Select to Output in High Z | - | 12 | - | 15 | - | 17 | - | 20 | - | 20 | ns |
| tOHZ $^{(1)}$ | Output Disable to Output in High Z | - | 12 | - | 13 | - | 15 | - | 20 | - | 20 | ns |
| toH | Output Hold from Address Change | 3 | - | 3 | - | 5 | - | 5 | - | 5 | - | ns |

## WRITE CYCLE

| tw | Write Cycle Time | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | ns |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tcW | Chip Select to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAW $:$ | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 40 | - | ns |
| tAs | Address Set-up Time | 0 | - | 0 | - | 0 | - | 2 | - | 2 | - | ns |
| tWP | Write Pulse Width | 20 | - | 23 | - | 25 | - | 30 | - | 35 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twHz $^{(1)}$ | Write Enable to Ouput in High Z | - | 12 | - | 13 | - | 17 | - | 20 | - | 20 | ns |
| tDW | Data to Write Time Overlap | 13 | - | 15 | - | 16 | - | 16 | - | 20 | - | ns |
| tDH | Data Hold from Write Time | 3 | - | 3 | - | 3 | - | 3 | - | 5 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:
2711 ы 08

1. This parameter is guaranteed by design, but not tested.

## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ and $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ）

| Symbol | Parameters | $\begin{aligned} & \text { 7M4003S50 } \\ & \text { 7M4013S50 } \end{aligned}$ |  | $\begin{gathered} \text { 7M4003S60 } \\ \text { 7M4013S60 } \\ \text { (Mii. Only) } \\ \hline \end{gathered}$ |  | $\begin{array}{\|c\|} \hline 7 \mathrm{M} 4003570 \\ \text { 7M4013S70 } \\ \text { (Mil. Only) } \\ \hline \end{array}$ |  | $\begin{aligned} & \text { 7M4003S85 } \\ & \text { 7M4013S85 } \\ & \text { (Mil. Only) } \\ & \hline \end{aligned}$ |  | $\begin{gathered} \text { 7M4003S100 } \\ \text { 7M4013S100 } \\ \text { (Mii. Only) } \\ \hline \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min． | Max． | Min． | Max． | MIn． | Max． | Min． | Max． | Min． | Max． |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| trc | Read Cycle Time | 50 | － | 60 | － | 70 | － | 85 | － | 100 | － | ns |
| tAA | Address Access Time | － | 50 | － | 60 | － | 70 | － | 85 | － | 100 | ns |
| tacs | Chip Select Access Time | － | 50 | － | 60 | － | 70 | － | 85 | － | 100 | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| toe | Output Enable to Output Valid | － | 30 | － | 30 | － | 35 | － | 40 | － | 45 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| $\mathrm{tCHz}^{(1)}$ | Chip Select to Output in High Z | － | 20 | － | 25 | － | 30 | － | 35 | － | 40 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | － | 20 | － | 25 | － | 30 | － | 35 | － | 40 | ns |
| toh | Output Hold from Address Change | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 50 | － | 60 | － | 70 | － | 85 | － | 100 | － | ns |
| tcw | Chip Select to End of Write | 45 | － | 55 | － | 65 | － | 80 | － | 90 | － | ns |
| taw | Address Valid to End of Write | 45 | － | 55 | － | 65 | － | 80 | － | 90 | － | ns |
| tAS | Address Set－up Time | 2 | － | 2 | － | 5 | － | 5 | － | 5 | － | ns |
| twp | Write Pulse Width | 40 | － | 45 | － | 45 | － | 50 | － | 55 | － | ns |
| twR | Write Recovery Time | 0 | － | 0 | 二 | 0 | － | 0 | － | 0 | 二 | ns |
| twhz ${ }^{(1)}$ | Write Enable to Ouput in High Z | － | 20 | － | 25 | － | 30 | － | 35 | － | 40 | ns |
| tow | Data to Write Time Overlap | 25 | － | 30 | － | 30 | － | 35 | － | 40 | － | ns |
| tDH | Data Hold from Write Time | 5 | － | 5 | － | 5 | － | 5 | 一 | 5 | － | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | 一 | 5 | － | 5 | － | 5 | － | 5 | － | ns |

NOTE：
1．This parameter is guaranteed by design，but not tested．

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $\mathbf{2}^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


2711 dww 06

## NOTES:

1. $\overline{W E}$ is high for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{V} I \mathrm{~L}$
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. 1 (WE CONTROLLED) ${ }^{(1,2,3,7)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 (CS CONTROLLED) ${ }^{(1,2,3,5)}$


## NOTES:

1. $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{\mathrm{C}}$ and a low $\overline{W E}$.
3. twR is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going High to the end of write cycle.
4. During this period, $I / O$ pins are in the output state, input signals must not be applied.
5. If the $\overline{C S}$ Low transition occurs simultaneously with or after the $\overline{W E}$ Low transition, the outputs remain in a high impedance state.
6. Transition is measured $\pm 200 \mathrm{mV}$ from steady state with a 5 pF load (including scope and jig). This parameter is guaranteed by design, but not tested.
7. During a $\overline{W E}$ controlled write cycle, write pulse (twp $>\mathrm{twHz}+\mathrm{tDW}$ ) to allow the $/ / O$ drivers to turn off data and to be placed on the bus for the required tow. If $\overline{O E}$ is high during an $\overline{W E}$ controlled write cycle, this requirement does not apply and the write pulse can be as short as the specified twp .

## ORDERING INFORMATION



2711 drw 10


## FEATURES:

- High-density 2 megabit CMOS static RAM module
- Fast access time
- Military: 40ns (max.)
- Commercial: 30ns (max.)
- Individual byte selects
- Upper and lower word write enables
- Available in $60-\mathrm{pin}, 600 \mathrm{mil}$ wide ceramic sidebraze DIP
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible
- Modules available with semiconductor components compliant to MIL-STD-883, Class B


## DESCRIPTION:

The IDT7M4017 is a ( $64 \mathrm{~K} \times 32$ ) high-speed CMOS static RAM module constructed on a co-fired ceramic substrate using eight $32 \mathrm{~K} \times 8$ static RAMs in leadless chip carriers. On-board decoders use A15 to select the upper or lower bank of RAMs. Four chip selects control individual byte selection. Extremely fast speeds can be achieved due to use of 256 K static RAMs and the decoder fabricated in IDT's highperformance, high-reliability CEMOS'M technology.

The IDT7M4017 is offered in a 60 -pin, 600 mil center sidebraze DIP which enables two megabits of memory to be placed in less than 1.9 square inches of board space.

The IDT7M4017 is available with fast access times over the commercial and military temperature ranges, with minimal power consumption. The circuit also offers a reduced power standby mode. When $\overline{C S}$ goes high, the circuit will automatically go to a substantially lower power mode.

All inputs and outputs of the IDT7M4017 are TTLcompatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

All IDT military module semiconductor components are manufactured in compliance with MIL-STD-883, Class B, making them ideally suited to applications demanding the highest level of performance and reliability.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1)}$



2664 drw 02

NOTE

1. For module dimensions, please refer to module drawing M16 in the packaging section.

## PIN NAMES

| A0-A15 | Addresses |
| :---: | :---: |
| I/O0.31 | Data Inputs/Outputs |
| $\overline{\mathrm{CS}} 0$ | Chip Select for I/O0-7 |
| $\overline{\mathrm{CS}} 1$ | Chip Select for I/O8-15 |
| $\overline{\mathrm{CS}} 2$ | Chip Select for I/OT6-23 |
| $\overline{\mathrm{CS}} 3$ | Chip Select for I/O24-31 |
| WE0 | Write Enable for I/O0-15 |
| WE1 | Write Enable for I/O16-31 |
| GND | Ground |
| Vcc | Power |

TRUTH TABLE

| Mode | $\overline{\text { CS }} \mathbf{~}$ | WEx | Output | Power |
| :--- | :---: | :---: | :---: | :---: |
| Standby | L | X | X | Standby |
| Read | L | H | Dout | Active |
| Write | L | L | DiN | Active |

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commerclal | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal <br> Voltage with <br> Respect to <br> GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -10 to +85 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output <br> Current | 50 | 50 | mA |

## NOTE:

2664 bl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2664 th 03

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter(1) | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{CIN}(\mathrm{D})$ | Input Capacitance <br> (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 30 | pF |
| $\mathrm{CIN}(\mathrm{A})$ | Input Capacitance <br> (Address and <br> Control) | $\mathrm{VIN}=0 \mathrm{~V}$ | 100 | pF |
| Cout | Output Capacitance | Vout $=0 \mathrm{~V}$ | 12 | pF |

NOTE:
2664 th 10

1. This parameter is guaranteed by design, but not tested.

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :--- | :---: | :---: | :---: |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

1. $V_{\text {IL }}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## DC ELECTRICAL CHARACTERISTICS

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \||LI| | Input Leakage (Address \& Control) | $\begin{aligned} & V C C=M a x . \\ & V I N=G N D \text { to } V C C \end{aligned}$ | - | 20 | $\mu \mathrm{A}$ |
| \||LI| | Input Leakage (Data) | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{VIN}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{CS}=\mathrm{VIH}, \text { Vout }=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |


| Symbol | Parameter | Test Conditions | Commerclal Max. | Military Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $1 \mathrm{Cc}{ }^{(1)}$ | Dynamic Operating Current | $\begin{aligned} & \text { VCC }=\text { Max } ; \overline{\mathrm{CS}} \leq \text { VIL; } \mathrm{f}=\mathrm{f} \mathrm{MAX} \\ & \text { Output Open } \end{aligned}$ | 750 | 790 | mA |
| IsB | Standby Supply Current (TTL Level) | $\overline{\mathrm{CS}} \geq \text { VIH, VCC = Max., }$ <br> Outputs Open | 180 | 180 | mA |
| ISB1 | Full Standby Supply Current (CMOS Levels) | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VCC}-0.2 \mathrm{~V} \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | 135 | 175 | mA |

NOTE:

1. For tAA $=30,35 \mathrm{~ns}$ versions, $I C C=900 \mathrm{~mA}$.

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


2664 dw 03
Figure 2. Output Load
(for tclz, tchz, tow, twhz)

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS

(Vcc $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7M4017S30 |  | 7M4017S35 |  | 7M4017S40 |  | 7M4017S45 |  | 7M4017S50 |  | 7M4017S60 |  | 7M4017S70 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tre | Read Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | 50 |  | 60 | - | 70 | - | ns |
| tAA | Address Access Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 50 | - | 60 | - | 70 | ns |
| tACS | Chip Select Access Time | - | 30 | - | 35 | - | 40 | - | 45 | - | 50 | - | 60 | - | 70 | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| $\mathrm{CCHz}^{(1)}$ | Chip Deselect to Output in High Z | - | 15 | - | 17 | - | 20 | - | 20 | - | 20 | - | 25 | - | 25 | ns |
| tOH | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tP( ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tPD ${ }^{11}$ | Chip Deselect to Power Down Time | - | 30 | - | 35 |  | 40 | - | 45 | - | 50 | - | 60 | - | 70 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 30 | - | 35 | - | 40 | - | 45 | - | 50 | - | 60 | - | 70 | - | ns |
| tcw | Chip Select to End of Write | 25 | - | 30 | - | 35 | - | 40 | - | 45 | - | 55 | - | 60 | - | ns |
| taw | Address Valid to End of Write | 27 | - | 30 | - | 35 | - | 40 | - | 45 | - | 55 | - | 60 | - | ns |
| tAS | Address Set-up Time | 2 | - | 5 | - | 5 | - | 5 | - | 10 | - | 10 | - | 10 | - | ns |
| twp | Write Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | 35 | - | 45 | - | 50 | - | ns |
| tWR | Write Recovery Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| twhzal | Write Enable to Output in High Z | - | 12 | - | 13 | - | 15 | - | 20 | - | 20 | - | 25 | - | 30 | ns |
| tow | Data to Write Time Overlap | 13 | - | 14 | - | 15 | - | 20 | - | 20 | - | 25 | - | 30 | - | ns |
| tDH | Data Hold from Write Time | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:
2664 th 08

1. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


## NOTES:

1. WE is High for Read Cycle.
2. Device is continuously selected, $\overline{\mathrm{CS}}=$ VIL.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{\mathrm{OE}}=\mathrm{VIL}$.
5. Transition is measured $\pm 500 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF WRITE CYCLE NO. $2^{(1,6)}$


## NOTES:

1. $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{\mathrm{CS}}$.
3. twh is measured from the earlier of $\overline{\mathrm{CS}}$ or $\overline{W E}$ going high to the end of the write cycle.
4. During this period, $1 / O$ pins are in the output state so that the input signals of opposite phase to the outputs must not be applied.
5. If the CS low transition occurs simultaneously with the WE low transition or after the $\overline{W E}$ transition, outputs remain in a high impedance state.
6. $\overline{\mathrm{OE}}$ is continuously low ( $\overline{\mathrm{OE}}=\mathrm{V}$ IL).
7. DATAOUT is the same phase of write data of this write cycle.
8. If $\overline{\mathrm{CS}}$ is low during this period, I/O pins are in the output state. Then the data input signals of opposite phase to the outputs must not be applied to them.
9. Transition is measured $\pm 500 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

## ORDERING INFORMATION



|  | $64 \mathrm{~K} \times 32$ <br> CMOS STATIC RAM MODULE | PRELIMINARY IDT7MP4036 |
| :---: | :---: | :---: |

## FEATURES:

- High density 2 Megabit CMOS static RAM module
- Low profile 64 pin ZIP (Zig-zag In-line vertical Package) or a 64-pin SIMM (Single In-line Memory Module)
- Fast access time: 20ns (max.)
- Surface mounted plastic components on an epoxy laminate (FR-4) substrate
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs/outputs directly TTL compatible
- Multiple GND pins for maximum noise immunity


## DESCRIPTION:

The IDT7MP4036 is a $64 \mathrm{~K} \times 32$ CMOS static RAM module constructed on an epoxy laminate (FR-4) substrate using 8 $64 \mathrm{~K} \times 4$ static RAMs in plastic SOJ packages. Availability of four chip select lines (one for each group of two RAMs) provides byte access. Extremely fast speeds can be achieved due to the use of 256K static RAMs fabricated in IDT's high performance, high reliability CEMOS ${ }^{\text {TM }}$ technology. The IDT7MP4036 is available with access time as fast as 20ns with minimal power consumption.

The IDT7MP family of ZIPs, DSIPs and SIPs offers the optimum in packing density and profile height. The IDT7MP4036 is packaged in a 64 pin (FR-4) ZIP (Zig-zag Inline vertical Package). The dual row configuration allows 64 pins to be placed on a package 3.65 inches long and 0.35 inches wide. At only 0.50 inches high, this low profile package is ideal for systems with minimum board spacing.

All inputs and outputs of the IDT7MP4036 are TTL compatible and operate from a single 5 V supply. Full asynchronous circuitry requires no clocks or refresh for operation.

Two identification pins (PD0 and PD1) are provided for applications in which different density versions of the module are used. In this way, the target system can read the respective levels of PD0 and PD1 to determine a 64 K depth.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1,2)}$



NOTE:

## TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | High Z | Standby |
| Read | L | L | H | DATAouT | Active |
| Write | L | X | L | DATAIN | Active |
| Read | L | H | H | High-Z | Active |

2682 02 أ

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTES:
2682 क 03

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{F}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| $\operatorname{CiN}(\mathrm{D})$ | Input Capacitance <br> (Data) | $\mathrm{V}(\mathbb{N})=\mathrm{OV}$ | 10 | pF |
| $\operatorname{CiN}(\mathrm{A})$ | Input Capacitance <br> (Address \& Control $)$ | $\mathrm{V}(\mathbb{N})=\mathrm{OV}$ | 60 | pF |
| CouT | Output Capacitance | $\mathrm{V}(\mathrm{OUT})=\mathrm{OV}$ | 10 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

## RECOMMENDED DC OPERATING

 CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2682 tol 05

1. $\mathrm{VIL}_{(\mathrm{min})}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commerical | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

## PIN NAMES

| $/ / O_{0-31}$ | Data Inputs/Outputs |
| :--- | :--- |
| $A_{0}-15$ | Addresses |
| $\overline{\mathrm{CS}} 1-4$ | Chip Selects |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| PDo-1 | Depth Identification |
| Vcc | Power |
| GND | Ground |
| NC | No Connect |

1. For module dimensions, please refer to module drawing M46 and M48 in the packaging section.
2. Pins 2 and 3 (PDo and $P D_{1}$ ) are read by the user to determine the density of the module. If PDo reads Open and PD1 read GND, then the module had a 64 K depth.

DC ELECTRICAL CHARACTERISTICS
(VCC $=5.0 \mathrm{~V} \pm 10 \%$, $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \|lı| | Input Leakage <br> (Address and Control) | Vcc = Max.; VIN = GND to Vcc | - | 80 | $\mu \mathrm{A}$ |
| \|| $\mathrm{LI} \mid$ | Input Leakage (Data) | Vcc = Max.; Vin = GND to Vcc | - | 10 | $\mu \mathrm{A}$ |
| \|lıO| | Output Leakage | $\mathrm{Vcc}=\mathrm{Max}$; $\overline{\mathrm{CS}}=\mathrm{V} \mathrm{IH}, \mathrm{VOUT}=\mathrm{GND}$ to Vcc | - | 10 | $\mu \mathrm{A}$ |
| Vol | Output Low | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VoH | Output High | $\mathrm{VCC}=$ Min., $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | V |


| Symbol | Parameter | Test Conditions | $\begin{gathered} 20,25 n s \\ \text { Max. } \end{gathered}$ | $\begin{gathered} \text { 30, 35ns } \\ \text { Max. } \end{gathered}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Icc | Dymanic Operating Current | $\begin{aligned} & f=f M A X ; \overline{C S}=V \text { VIL } \\ & V C C=\text { Max.; Output Open } \end{aligned}$ | 1280 | 1250 | mA |
| ISB | Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \text { VIH, VCC }=\text { Max. } \\ & \text { Outputs Open, } \mathrm{f}=\mathrm{fmAX} \end{aligned}$ | 280 | 280 | mA |
| ISB1. | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq V C C-0.2 V ; F=0 \\ & \mathrm{VIN}>V C C-0.2 V \text { or }<0.2 V \end{aligned}$ | 240 | 240 | mA |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |



Figure 1. Output Load


Figure 2. Output Load (for tchz, telz, tohz, tolz, twhz, and tow)
*Including scope and jig.

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{Vcc}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 7MP4036S20 |  | 7MP4036S25 |  | 7MP4036S30 |  | 7MP4036S35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tas | Address Access Time | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tacs | Chip Select Access Time | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| tCLz ${ }^{(1)}$ | Chip Select to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| toe | Output Enable to Output Valid | - | 10 | - | 12 | - | 15 | - | 25 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{tCHz}^{(1)}$ | Chip Deselect to Output in High Z | - | 15 | - | 15 | - | 20 | - | 22 | ns |
| torz ${ }^{(1)}$ | Output Disable to Output in High Z | - | 12 | - | 15 | - | 20 | - | 22 | ns |
| tor | Output Hold from Address Change | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| tpu ${ }^{(1)}$ | Chip Select to Power-Up Time | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tP0 ${ }^{(1)}$ | Chip Deselect to Power-Down Time | - | 20 | - | 25 | - | 30 | - | 35 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |
| twc | Write Cycle Time | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tcw | Chip Select to End of Write | 15 | - | 20 | - | 25 | - | 30 | - | ns |
| taw | Address Valid to End of Write | 15 | - | 20 | - | 25 | - | 32 | - | ns |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | 2 | - | ns |
| twp | Write Pulse Width | 15 | - | 20 | - | 25 | - | 30 | - | ns |
| twh | Write Recovery Time | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| twhz ${ }^{(1)}$ | Write Enable to Output in High Z | - | 12 | - | 15 | - | 15 | - | 18 | ns |
| tDw | Data to Write Time Overlap | 12 | - | 15 | - | 17 | - | 20 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | - | 0 | 二 | 0 | 二 | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTE:

1. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF READ CYCLE NO. $\mathbf{2}^{(1,2,4)}$


TIMING WAVEFORM OF READ CYCLE NO. $3^{(1,3,4)}$


2682 drw 06

## NOTES:

1. WE is High for Read Cycle.
2. Device is continuously selected. $\overline{\mathrm{CS}}=\mathrm{V}$ IL.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$


TIMING WAVEFORM OF WRITE CYCLE NO. $2^{(1,6)}$


## NOTES:

1. $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CS}}$ must be high during all address transitions
2. A write occurs during the overlap (twn) of a low $\overline{\mathrm{CS}}$.
3. twP is measured from the earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of the write cycle.
4. During this period, I/O pins are in the output state so that the input signals of opposite phase to the outputs must not be applied.
5. If the CS low transition occurs simultaneously with the $\bar{W}$ low transitions or after the $\overline{W E}$ transition, outputs remain in a high impedence state.
6. $\overline{O E}$ is continuously low $(\overline{O E}=V I L)$.
7. Dout is the same phase of write data of this write cycle.
8. If $\overline{\mathrm{CS}}$ is low during this period, $/ / \mathrm{O}$ pins are in the output state. Then the data input signals of opposite phase to the outputs must not be applied to them.
9. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

## ORDERING INFORMATION




## 256K X 32 <br> CMOS STATIC RAM MODULE

## FEATURES：

－High－density 8 megabit（ $256 \mathrm{~K} \times 32$ ）static RAM module
－Low profile 64－pin FR－4 ZIP（Zig－zag In－line Package）or 64－pin FR－4 SIMM（Single In－line Memory Module）
－Fast access time：25ns（max．）
－Surface mounted plastic components on an epoxy laminate（FR－4）substrate
－Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
－Inputs／outputs directly TTL compatible
－Multiple GND pins for maximum noise immunity

| PIN CONFIGURATION ${ }^{(1,2)}$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 1 |  | GND |  |
| PDO | 2 | 3 | $\square$ | PD1 |  |
| 1／O | 4 | 5 | $\square$ | I／O8 | PDO－GND |
| VO1 | 6 | 7 | $ص$ | $1 / \mathrm{O}_{9}$ | PD1－GND |
| $1 / \mathrm{O}_{2}$ | 8 | 9 | $ص$ | I／O10 |  |
| $1 / \mathrm{O}_{3}$ | 10 | 11 | $\square$ | l／O11 |  |
| Vcc | 12 | 13 | $\square$ | A0 |  |
| A7 | 14 | 15 | 阯 | $A_{1}$ |  |
| A8 | 16 | 17 | $\square$ | A2 |  |
| A9 | 18 | 19 | $\square$ | I／O12 |  |
| ／／O4 | 20 | 21 | $\square$ | l／O13 |  |
| l／O5 | 22 | 23 | $ص$ | l／O14 |  |
| l／O6 | 24 | 25 | $\square$ | I／O15 |  |
| V／O7 | 26 | 27 | ص | GND |  |
| WE | 28 | 29 | $ص$ | ${ }^{\text {A } 15}$ |  |
| A14 | 30 | 31 | $\square$ | $\overline{\mathrm{CS} 2}$ |  |
| $\overline{\text { CS1 }}$ | 32 |  |  |  |  |
|  |  | 33 | $ص$ | $\overline{\mathrm{CS4}}$ |  |
| $\overline{\text { CS3 }}$ | 34 | 35 | $\square$ | A17 |  |
| A16 | 36 | 37 | $\square$ | $\overline{O E}$ |  |
| GND | 38 | 39 | $ص$ | l／O24 |  |
| 1／Oı6 | 40 | 41 | $\boxminus$ | l／O25 |  |
| 1／O17 | 42 | 43 | 佰 | 1／O26 |  |
| l／O18 | 44 | 45 | $\square$ | l／O27 |  |
| 1／O19 | 46 | 47 | $\square$ | A3 |  |
| A10 | 48 | 49 | $ص$ | A4 |  |
| A11 | 50 | 51 | $\square$ | A5 |  |
| A12 | 52 | 53 | $\square$ | Vcc |  |
| A13 | 54 | 55 | $\square$ | A6 |  |
| 1／O20 | 56 | 57 | 曰 | I／O28 |  |
| 1／O21 | 58 | 59 | $\square$ | 1／O29 |  |
| 1／O22 | 60 | 61 | $\square$ | 1／O30 |  |
| ／／O23 | 62 | 63 | $\square$ | l／O31 |  |
| GND | 64 |  |  |  | 2703 dw 01 |
|  |  |  |  |  |  |

NOTES：
1．For module dimensions，please refer to drawing M47 and M49 in the packaging section．
2．Pins 2 and 3 （PDO and PD1）are read by the user to determine the depth of the module．If both read GND，then the module has a 256 K depth．

## DESCRIPTION：

The IDT7MP4045 is a 8 megabit（ $256 \mathrm{~K} \times 32$ ）static RAM module constructed on an epoxy laminate（FR－4）substrate using $8256 \mathrm{~K} \times 4$ static RAMs in plastic SOJ packages． Availability of four chip select lines（one for each group of two RAMs）provides byte access．The IDT7MP4045 is available with access time as fast as 25 ns with minimalpowerconsump－ tion．

The IDT7MP family of ZIPs，DSIPs，and SIPs offers the optimum in packaging density and profile height．The IDT7MP4045 is packaged in a 64 pin FR4ZIP（zig－zag in－line vertical package）or a 64 lead SIMM（single in－line memory module）．The dual row configuration allows 64 pins to be placed on a package 3.65 inches long and 0.35 inches wide． At only 0.575 inches high，this low profile package is ideal for systems with minimum board spacing．

All inputs and outputs of the IDT7MP4045 are TTL compat－ ible and operate from a single 5V supply．Full asynchronous circuitry requires no clocks or refresh for operation and pro－ vides equal access and cycle times for ease of use．

Two identification pins（PD0 and PD1）are provided for ap－ plications in which different density versions of the module are used．In this way，the target system can read the respective levels of PD0 and PD1 to determine a 256 K depth．

FUNCTIONAL BLOCK DIAGRAM


PIN NAMES

| I／O0－31 | Data Inputs／Outputs |
| :--- | :--- |
| A0－17 | Address |
| $\overline{\mathrm{CS} 1-4}$ | Chip Selects |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| PD0－1 | Depth Identification |
| VCc | Power |
| GND | Ground |

## ABSOLUTE MAXIMUM RATINGS

| Symbol | Rating | Comm. | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperture | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output Current | 50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC OPERATING

 CONDITIONS| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |
| NOTE: |  |  |  |  |  |

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IlLII | Input Leakage (Address \& Control) | $\begin{aligned} & \text { Vcc = Max. } \\ & V \text { IN }=G N D \text { to } V c c \end{aligned}$ | - | 20 | $\mu \mathrm{A}$ |
| IILII | Input Leakage (Data) | $\begin{aligned} & V C C=M a x . \\ & V I N=G N D \text { to } V C C \end{aligned}$ | - | 20 | $\mu \mathrm{A}$ |
| Illoi | Output Leakage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Max} . \\ & \mathrm{CS}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND} \text { to } \mathrm{VCC} \end{aligned}$ | - | 2 | $\mu \mathrm{A}$ |
| Vol | Output Low <br> Voltage | $\mathrm{VCC}=\mathrm{Min} . \quad \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=$ Min. $\quad 1 \mathrm{OH}=4 \mathrm{~mA}$ | 2.4 | - | V |
| ICC | Dynamic Operating Current | $\begin{aligned} & \overline{\mathrm{CS}}=\text { VIL, Outputs Open } \\ & \text { VCC }=\text { Max. } \mathrm{f}=0 \end{aligned}$ | - | 960 | mA |
| ISB | Standby Supply Current | $\begin{aligned} & \overline{\overline{C S}} \geq \text { VIH, } V C C=\text { Max. } \\ & \text { Outputs Open, } f=f \text { MAX } \end{aligned}$ | - | 480 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \mathrm{~V} \text { IN }>\mathrm{Vcc}-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V}, \mathrm{f}=0 \end{aligned}$ | - | 16 | mA |

2703 t 05

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |



Figure 1. Output Load

## AC ELECTRICAL CHARACTERISTICS

(VcC $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{aligned} & 7 \mathrm{MP} \\ & \mathrm{Min} . \end{aligned}$ | $\begin{gathered} 45 \mathrm{~S} 25 \\ \text { Max. } \end{gathered}$ | 7MP4 <br> Min. | $\begin{aligned} & \text { 45S30 } \\ & \text { Max. } \end{aligned}$ | 7MP404 Min. | S35 <br> Max. | 7MP4 <br> Min. | $\begin{aligned} & \text { 45S45 } \\ & \text { Max. } \end{aligned}$ | $\begin{aligned} & \text { 7MP4 } \\ & \text { Min. } \end{aligned}$ | $\begin{aligned} & \text { MS55 } \\ & \text { Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tRC | Read Cycle Time | 25 | - | 30 | - | 35 | - | 45 | - | 55 | - | ns |
| tas | Address Access Time | - | 25 | - | 30 | - | 35 | - | 45 | - | 55 | ns |
| tacs | Chip Select Access Time | - | 25 | - | 30 | - | 35 | - | 45 | - | 55 | ns |
| tClz ${ }^{(1)}$ | Chip Select to Output in Low Z | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| toe | Output Enable to Output Valid | - | 12 | - | 12 | - | 18 | - | 23 | - | 25 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{tchz}{ }^{(1)}$ | Chip Deselect to Output in High Z | - | 5 | - | 5 | - | 10 | - | 15 | - | 20 | ns |
| torz ${ }^{(1)}$ | Output Disable to Output in High 2 | - | 5 | - | 5 | - | 10 | - | 15 | - | 20 | ns |
| toh | Output Hold from Address Change | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| tPU ${ }^{(1)}$ | Chip Select to Power Up Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $t \mathrm{PD}^{(1)}$ | Chip Deselect to Power Down Time | - | 30 | - | 30 | - | 30 | - | 30 | - | 30 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| twe | Write Cycle Time | 25 | - | 30 | - | 35 | - | 45 | - | 55 | - | ns |
| tcw | Chip Selection to End of Write | 20 | - | 25 | - | 30 | - | 40 | - | 50 | - | ns |
| taw | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 40 | - | 50 | - | ns |
| tas | Address Set-up Time | 0 | - | 0 | - | 0 | - | 0 | - | 2 | - | ns |
| twp | Write Pulse Width | 20 | - | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| tWR | Write Recovery Time | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| WWHz ${ }^{(1)}$ | Write Enable to Output in High Z | 0 | 5 | 0 | 7 | 0 | 10 | 0 | 15 | 0 | 15 | ns |
| tow | Data to Write Time Overlap | 10 | - | 15 | - | 20 | - | 25 | - | 35 | - | ns |
| tDH | Data Hold from Write Time | 0 | - | 0 | 一 | 0 | - | 0 | 一 | 0 | - | ns |
| tow ${ }^{(1)}$ | Output Active from End of Write | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. This parameter is guaranteed by design but not tested.
2. Preliminary specifications only.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


2703 drw 04
TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,2,4)}$


2703 drw 05
TIMING WAVEFORM OF READ CYCLE NO. $2^{(1,3,4)}$


2703 dw 06

## NOTES:

1. WE is High for Read Cycle.
2. Device is continuously selected. $\overline{C S}=$ VIL.
3. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
4. $\overline{O E}=\mathrm{VIL}$.
5. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

## TIMING WAVEFORM OF WRITE CYCLE NO. $1^{(1)}$



TIMING WAVEFORM OF WRITE CYCLE NO. $2^{(1,6)}$


2703 drw 08

## NOTES:

1. $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CS}}$ must High during all address transitions.
2. A write occurs during the overlap (twp) of a low $\overline{C S}$ and a low $\overline{W E}$.
3. twp is measured from the earlier of $\overline{\mathrm{CS}}$ or $\overline{W E}$ going high to the end of the write cycle.
4. During this period, the I/O pins are in the input state, so the input signals of opposite phase to the outputs must not be applied.
5. If the CS low transition occurs simultaneously with the WE low transitions or after the $\overline{W E}$ transition, outputs remain in a high impedance state.
6. $\overline{O E}$ is continuously low ( $\overline{O E}=\mathrm{VIL}$ ).
7. Dour is the same phase of write data of this write cycle.
8. If $\overline{C S}$ is low during this period, I/O pins are in the output state. Then the data input signals of opposite phase to the outputs must not be applied to them.
9. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter is guaranteed by design, but not tested.

TRUTH TABLE

| Mode | $\overline{\mathbf{C S}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Standby | H | X | X | Hi-Z | Standby |
| Read | L | L | H | Dout | Active |
| Write | L | X | L | Din | Active |
| Read | L | H | H | Hi-Z | Active |

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{F}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter | Condltions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\operatorname{CiN}(\mathrm{D})$ | Input Capacitance <br> (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 20 | pF |
| $\operatorname{CiN}(\mathrm{A})$ | Input Capacitance <br> (Address and Control $)$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 70 | pF |
| CouT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 20 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested. 2703 tol 09

## ORDERING INFORMATION


$2 \times 4 \mathrm{~K} \times 60$ DATA/INSTRUCTION CACHE MODULE FOR IDT79R3000 (MULTIPROCESSOR)

## FEATURES:

- High-speed CEMOS ${ }^{\text {TM }}$ static RAM module constructed to support the IDT79R3000 CPU, in a multi-processor system, as a complete data and instruction cache
- Additional data and instruction address invalidation latches on-board to facilitate use in a multi-processor system
- Operating frequencies to support $12 \mathrm{MHz}, 16.7 \mathrm{MHz}$, $20 \mathrm{MHz}, 25 \mathrm{MHz}$ and 33 MHz IDT79R3000
- Available in a high density, low profile 132 pin QIP (Quad In-Line Package)
- Surface mounted SOs on a multilayer epoxy substrate
- Multiple ground pins for maximum noise immunity
- TTL compatible I/Os
- Single 5V ( $\pm 10 \%$ ) power supply


## PIN CONFIGURATION ${ }^{(1)}$

| GND | 1 | 67 | GND | GND | 132 | 66 | Vac |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Do | 2 | 68 | $\mathrm{D}_{1}$ | D59 | 131 | 65 | $\mathrm{D}_{58}$ |
| D2 | 3 | 69 | D3 | D57 | 130 | 64 | $\mathrm{D}_{56}$ |
| $\mathrm{D}_{4}$ | 4 | 70 | GND | D55 | 129 | 63 | $\mathrm{D}_{54}$ |
| D5 | 5 | 71 | ${ }^{\text {D }}$ W | GND | 128 | 62 | $\mathrm{D}_{53}$ |
| $\overline{O E} 1$ | 6 | 72 | $\mathrm{WE}_{1}$ | WE4 | 127 | 61 | $\mathrm{OE}_{4}$ |
| D7 | 7 | 73 | Voc | D52 | 126 | 60 | $\mathrm{D}_{51}$ |
| Vcc | - | 74 | D8 | D50 | 125 | 59 | GND |
| D9 | 9 | 75 | GND | GND | 124 | 58 | D49 |
| $\mathrm{D}_{10}$ | 10 | 76 | $\mathrm{D}_{11}$ | $\mathrm{D}_{48}$ | 123 | 57 | P2A0 |
| P1A0 | 11 | 77 | $\mathrm{P}^{1} \mathrm{~A}_{1}$ | $\mathrm{P}_{2} \mathrm{~A}_{1}$ | 122 | 56 | $\mathrm{P}_{2} \mathrm{~A}_{2}$ |
| P1A2 | 12 | 78 | GND | $\mathrm{P}_{2} \mathrm{~A}_{3}$ | 121 | 55 | $\mathrm{P} 2 \mathrm{~A}_{4}$ |
| P1A3 | 13 | 79 | $\mathrm{P}^{\text {P }} \mathrm{A}_{4}$ | GND | 120 | 54 | $\mathrm{P}_{2} \mathrm{~A}_{5}$ |
| P1A5 | 14 | 80 | $\mathrm{P}^{1} \mathrm{~A}_{6}$ | P2A6 | 119 | 53 | GND |
| P1A7 | 15 | 81 | P1A8 | P2A7 | 118 | 52 | $\mathrm{P}^{2} \mathrm{~A}_{8}$ |
| P1A9 | 16 | 82 | GND | GND | 117 | 51 | P2As |
| P1A10 | 17 | 83 | P1A11 | $\mathrm{P}^{2} \mathrm{~A}_{10}$ | 116 | 50 | P2A11 |
| P1LE1 | 18 | 84 | P1LE2 | P2OE | 115 | 49 | RESET |
| RESET ${ }_{1}$ | 19 | 85 | P10E | GND | 114 | 48 | VCC |
| $\overline{\mathrm{OE}} 2$ | 20 | 86 | Vc | P2LE | 113 | 47 | $\mathrm{OE}_{3}$ |
| WE2 | 21 | 87 | GND | D47 | 112 | 46 | WE3 |
| D12 | 22 | 88 | D 13 | GND | 111 | 45 | $\mathrm{D}_{46}$ |
| D14 | 23 | 89 | D15 | $\mathrm{D}_{44}$ | 110 | 44 | D45 |
| D16 | 24 | 90 | D17 | GND | 109 | 43 | D 43 |
| Voc | 25 | 91 | GND | $\mathrm{D}_{41}$ | 108 | 42 | D42 |
| $\mathrm{D}_{18}$ | 26 | 92 | D19 | D40 | 107 | 41 | GND |
| D20 | 27 | 93 | GND | Voc | 106 | 40 | D39 |
| D21 | 28 | 94 | $\mathrm{D}_{22}$ | D38 | 105 | 39 | $\mathrm{D}_{37}$ |
| $\mathrm{D}_{23}$ | 29 | 95 | $\mathrm{D}_{24}$ | D36 | 104 | 38 | $\mathrm{D}_{35}$ |
| D25 | 30 | 96 | GND | GND | 103 | 37 | D34 |
| D26 | 31 | 97 | $\mathrm{D}_{27}$ | D33 | 102 | 36 | D32 |
| D28 | 32 | 98 | $\mathrm{D}_{29}$ | D31 | 101 | 35 | $\mathrm{D}_{30}$ |
| Vcc | 33 | 99 | GND | GND | 100 | 34 | GND |

## NOTE:

1. For module dimensions, please refer to drawing M30 in the packaging section.

## DESCRIPTION:

The IDT7MB6064 is a 60K-byte high-speed CMOS static RAM cache module constructed on a multilayer epoxy substrate (FR-4), using 30 IDT6178 ( $4 \mathrm{~K} \times 4$ ) Resettable RAMs and 16 IDT74FCT373 latches.

The IDT7MB6064 supports use in a multi-processor(R3000 based) system by providing data address invalidation latches onboard, ensuring cache coherency among the multiple CPUs. The IDT7MB6064 is organized as two separate banks of 4 K x 60 with the IDT74FCT373s being used as address latches. The two banks of RAM with their associated address latches share a common 12-bit ADDRESS bus and a common 60 bit DATA bus. The write enable, RAM output enable and latch enable controls for the two banks are brought out separately, to support interleaving access to the two banks of RAM. Also, each bank has one set of address latches to reduce the capacitance loading on the outputs of the latches, and thereby enhance performance. $\overline{\operatorname{RESET}} 1 / \overline{\mathrm{RESET}} 2$ clears the D36-D59 portions of the data/instruction cache.

All inputs and outputs of the IDT7MB6064 are TTL-compatible and operate from a single 5V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

## PIN NAMES

| Do-D59 | Data l/Os |
| :---: | :---: |
| P1A0-P1A11 | Address Inputs |
| P2A0-P2A11 | Invalidate Address |
| P1LE1 | Data Address Latch Enable |
| P1LE2 | Instruction Address Latch Enable |
| $\overline{\text { P1OE }}$ | Data Address Enable |
| $\overline{\text { P2OE }}$ | Instruction Address Enable |
| P2LE | Invalidate Data Address Latch Enable |
| RESET ${ }_{1}$ | Data Cache Reset |
| $\overline{R E S E T}_{2}$ | Instruction Cache Reset |
| $\mathrm{WE}_{1}-\overline{\mathrm{WE}}_{4}$ | Write Enables |
| $\overline{\mathrm{OE}}_{1}-\overline{\mathrm{OE}}_{4}$ | Output Enables |
| GND | Ground |
| Vcc | Power Supply |

FUNCTIONAL BLOCK DIAGRAM


RECOMMENDEDDCOPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2666 to 04

1. $\mathrm{V}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## CAPACITANCE

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{CIN}(\mathrm{D})$ | Input Capacitance (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 20 | pF |
| $\operatorname{CIN}(\mathrm{A})$ | Input Capacitance (Address) | V IN $=0 \mathrm{~V}$ | 40 | pF |
| $\operatorname{CIN}(\mathrm{C})$ | Input Capacitance ( $\overline{\mathrm{OE}}, \overline{\mathrm{WE}})$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 50 | pF |
| $\mathrm{CIN}(\mathrm{C})$ | Input Capacitance ( $\overline{\mathrm{CS}}$ ) | $\mathrm{VIN}=0 \mathrm{~V}$ | 100 | pF |
| $\operatorname{CIN}(\mathrm{C})$ | Input Capacitance (LE, PxOE) | $\mathrm{VIN}=0 \mathrm{~V}$ | 30 | pF |
| Cout | Output Capacitance | Vout $=0 \mathrm{~V}$ | 20 | pF |

1. This parameter is guaranteed by design, but not tested.

ABSOLUTE MAXIMUM RATINGS

| Symbol | Rating ${ }^{(1)}$ | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with Respect <br> to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5 \mathrm{~V} \pm 10 \%$ |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load

Figure 2. Output Load (for tolz and totz)

* Including scope and jig.

DC ELECTRICAL CHARACTERISTICS
( $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 12MHz |  | 16.7MHz |  | 20MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| \| $\mid$ U\| | Input Leakage | Vcc = Max., VIN = GND to Vcc | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \| L O| | Output Leakage | $\begin{aligned} & \text { VCC }=\text { Max., } \overline{\mathrm{CS}}=\mathrm{VIH}, \\ & \text { Vout }=\mathrm{GND} \text { to } V C C \end{aligned}$ | - | 10 | - | 10 | - | 10 | $\mu \mathrm{A}$ |
| ICCI | Operating Current | $\begin{aligned} & f=0, \overline{C S}=\text { VIL; VcC }=\text { Max., } \\ & \text { Outputs Open } \end{aligned}$ | - | 2925 | - | 2925 | - | 2925 | mA |
| IcC2 | Dynamic Operating Current | VCC $=$ Max., $\overline{\mathrm{CS}}=\mathrm{VIL} ; f=\mathrm{fMAX}$, Outputs Open | - | 3850 | - | 3900 | - | 4150 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VCC}-0.2 \mathrm{~V}, \\ & \mathrm{VIN} \geq \mathrm{VCC}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 450 | - | 450 | - | 450 | mA |
| ISB | Standby Power Supply Current | $\begin{aligned} & \text { VcC }=\text { Max., } \overline{\mathrm{CS}} \geq \mathrm{VIH} ; f=\mathrm{fmAX}, \\ & \text { Outputs Open } \end{aligned}$ | - | 1300 | - | 1425 | - | 1575 | mA |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | 2.4 | - | V |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | - | 0.4 | V |

NOTE:

1. ICC1, ICC2 in the case for all devices selected (i.e. both instruction and data cache selected).

DC ELECTRICAL CHARACTERISTICS (Continued)
( $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 25MHz |  | 33 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \| $\mid$ L.\| | Input Leakage | Vcc = Max., Vin = GND to Vcc | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \|llol | Output Leakage | $\mathrm{Vcc}=$ Max., $\overline{\mathrm{CS}}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND}$ to Vcc | - | 10 | - | 10 | $\mu \mathrm{A}$ |
| ICC1 | Operating Current | $f=0, \overline{\mathrm{CS}}=\mathrm{VIL} ; \mathrm{VCC}=$ Max., Outputs Open | - | 3400 | - | 3700 | mA |
| IcC2 | Dynamic Operating Current | VCC $=$ Max., $\overline{\mathrm{CS}}=$ VIL; $f=$ fmax, Outputs Open | - | 4675 | - | 4900 | mA |
| ISB1 | Full Standby Supply Current | $\overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}, \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\leq 0.2 \mathrm{~V}$ | - | 600 | - | 960 | mA |
| ISB | Standby Power Supply Current | $V C C=$ Max., $\overline{C S} \geq V_{1 H} ; f=f$ MAX, Outputs Open | - | 1700 | - | 2000 | mA |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min}$., $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{loL}=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |

NOTE:

1. ICC1, ICC2 in the case for all devices selected (i.e. both instruction and data cache selected).

## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | 12MHz |  | 16.7MHz |  | 20MHz |  | 25MHz |  | 33 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tLE | Latch Enable Width | 6 | - | 6 | - | 6 | - | 6 | - | 6 | - | ns |
| tas | Address Setup Time to LE | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
| tan | Address Hold Time from LE | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | ns |
| $t_{\text {A }}{ }^{(2)}$ | Address Access Time | - | 45 | - | 35 | - | 30 | - | 25 | - | 20 | ns |
| toE ${ }^{(3)}$ | Output Enable to Output Valid | - | 22 | - | 17 | - | 11 | - | 8 | - | 5 | ns |
| tOHz ${ }^{(1)}$ | Output Disable to Output in High Z | 2 | 16 | 2 | 14 | 2 | 10 | 2 | 8 | 2 | 6 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tLE | Latch Enable Width | 6 | - | 6 | - | 6 | - | 6 | - | 6 | - | ns |
| tAS | Address Setup Time to LE | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
| tan | Address Hold Time to LE | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | ns |
| $\mathrm{taw}^{(2)}$ | Address Valid to End of Write | 40 | - | 30 | - | 25 | - | 23 | - | 20 | - | ns |
| twp | Write Pulse Width | 35 | - | 25 | - | 20 | - | 17 | - | 12 | - | ns |
| tDW | Data Valid to End of Write | 20 | - | 13 | - | 13 | - | 11 | - | 8 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | 二 | 0 | - | 0 | - | ns |
| tLoE ${ }^{(4)}$ | Latch Output Enable | - | 7 | - | 7 | - | 7 | - | 7 | - | 7 | ns |
| RESET CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tCLPW | $\overline{\text { RESET Pulse Width }}$ | 40 | - | 40 | - | 30 | - | 30 | - | 25 | - | ns |
| tCLRC | RESET High to $\overline{W E}_{4}$ Low | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |

NOTE:

1. This parameter is guaranteed by design but not tested.
2. LE already asserted.
3. For all $\overline{O E}_{1}, \overline{\mathrm{OE}} 2, \overline{\mathrm{OE}}_{3}, \overline{O E}_{4}$.
4. P1OE1 and P2OE1.

## tIMING WAVEFORM OF READ CYCLE ${ }^{(1)}$



NOTES:
2666 drw 04

1. Assume $\overline{W E}$ is active high throughout this cycle.
2. This parameter is guaranteed by design, but not tested.

## timing Waveform Of Write cycle



TIMING WAVEFORM OF $\overline{\text { RESET }}$ CYCLE


## ORDERING INFORMATION



## ADVANCE INFORMATION IDT7MB6044

## FEATURES:

- High-speed 64K-byte CMOS static RAM module constructed to support the IDT79R3000 RISC CPU as a complete data and instruction cache
- Operating frequencies to support $12 \mathrm{MHz}, 16.7 \mathrm{MHz}$, $20 \mathrm{MHz}, 25 \mathrm{MHz}$ and 33 MHz IDT79R3000
- Available in high-density, low profile 128 -pin QIP (quad in-line package)
- Surface mounted SO components on a multi-layer epoxy substrate FR-4
- Multiple ground pins for maximum noise immunity
- On-board address latches for direct interface to the IDT79R3000 CPU
-TLL compatible I/Os
- Single 5 V ( $\pm 10 \%$ ) power supply


## DESCRIPTION:

The IDT7MB6044 is a 64 K -byte high-speed CEMOS ${ }^{\text {TM }}$ static RAM cache module constructed on a multilayer epoxy substrate (FR-4) using 8 IDT71586 ( 4 K X 16) latched RAMs.

The construction and specifications of this module have been optimized to support its use as a complete 4 K deep Instruction and Data cache for the IDT79R3000 MIPs ${ }^{\text {TM }}$ microprocessor.

The IDT7MB6044 is organized as two separate banks of 4 K $x 64$ with the IDT71586s being used as address latched RAMs. The two banks of RAM with their associated address latches share a common 12-bit ADDRESS bus and a common 64 -bit DATA bus. The chip select, write enable, RAM output enable and latch enable controls for the two banks are brought out separately to support interleaving access to the two banks of RAM.

All inputs and outputs of the IDT7MB6044 are TTL-compatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

## PIN CONFIGURATION ${ }^{(2)}$



## PIN NAMES

| D0-D63 | Data 1/Os |
| :---: | :---: |
| A0-A11 | Address Inputs |
| LEi - LE4 | Latch Enables |
| $\overline{\mathrm{CS}} 1-\overline{\mathrm{CS}}_{8}$ | RAM Selects |
| $\overline{W E}_{1}-\overline{W E}_{8}$ | Write Enables |
| $\overline{\mathrm{OE}}_{1}$ - $\overline{\mathrm{OE}}_{8}$ | Output Enable |
| GND | Ground |
| Vcc | Power Supply |
| N.C. | No connection |

NOTES:

1. Each of these pins must be connected to GND or Voc through a resistor for proper operation of the IDT79R3000 applications.
2. For module dimensions, please refer to module drawing M29 in the packaging section.

## INSTRUCTION CACHE



## DATA CACHE




Integrated Device Technology, Inc.
$2 \times 8 \mathrm{~K} \times 64$ DATA/INSTRUCTION CACHE MODULE FOR IDT79R3000

## advance INFORMATION IDT7MB6043

## FEATURES:

- High-speed CEMOS ${ }^{\text {rM }}$ Static RAM Module constructed to support the IDT79R3000 RISC CPU as a complete data and instruction cache
- Operating frequencies to support $16.7 \mathrm{MHz}, 20 \mathrm{MHz}$ and 25 MHz IDT79R3000
- Available in high-density, low-profile 128-pin QIP (Quad In-line Package)
- Surface mounted SO components on a multilayer epoxy substrate
- Multiple ground pins for maximum noise immunity
- On-board address latches for direct interface to the IDT79R3000 CPU
- TTL compatible I/Os
- Single 5 V ( $\pm 10 \%$ ) power supply


## DESCRIPTION:

The IDT7MB6043 is a 128 K Byte high-speed CMOS static RAM module constructed on a multilayer epoxy substrate
(FR-4) using sixteen IDT7164 (8K $\times 8$ ) RAMs and eight IDT74FCT373 latches.

The construction and specifications of this module have been optimized to support its use as a complete 8 K deep Instruction and Data Cache for the IDT79R3000.

The IDTMB6043 is organized as two separate banks of 8 K $x 64$ with IDT74FCT373s being used as address latches. The two banks of RAM, with their associated address latches, share a common 122-bit ADDRESS bus and a common 64-bit DATA bus.

The chip select, write enable, RAM output enable and latch enable controls for the two banks are brought out separately to support interleaving acess to the two banks of RAM. Also, each bank has two sets of address latches to reduce the capacitance loading, thereby, enhancing performance.

All inputs and outputs of the IDT7MB6043 are TTLcompatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

PIN CONFIGURATION ${ }^{(1)}$


QIP
TOP VIEW

## PIN NAMES

| D0-D59 | Data Inputs/Outputs |
| :---: | :---: |
| A0-A11 | Address Inputs |
| LE $\mathrm{E}_{1}$ LE ${ }_{4}$ | Latch Enables |
| $\overline{\mathrm{CS1}} 1-\overline{\mathrm{CS1}} 8$ | RAM Selects |
| $\overline{W E}_{1}$ - WE8 | Write Enables |
| $\overline{\mathrm{OE}}_{1}-\overline{\mathrm{OE}}_{8}$ | Output Enables |
| GND | Ground |
| Vcc | Power Supply |
| N.C. | No connection |

2800 tbl 01

## NOTE:

1. These pins must be connected to GND or Vcc through a resistor for proper operation in the IDT79R3000 application.

INSTRUCTION CACHE


## DATA CACHE




Integrated Device Technology，Inc．
$2 \times 8 \mathrm{~K} \times 64$ DATA／INSTRUCTION CACHE MODULE FOR IDT79R3000 CPU （MULTIPROCESSOR）

## ADVANCE INFORMATION IDT7MB6051

## FEATURES：

－High－speed 128 K －Byte CMOS static RAM module con－ structed to support the IDT79R3000 RISC CPU in a multi－processor system as a complete data and instruc－ tion cache
－Additional data adress invalidation latches on－board to facilitate use in a multi－processor system
－Operating frequencies to support $12 \mathrm{MHz}, 16.7 \mathrm{MHz}$ ， $20 \mathrm{MHz}, 25 \mathrm{MHz}$ and 33 MHz IDT79R3000
－Available in high－density，low profile 144－pin QIP（Quad In－line Package）
－Surface mounted SO components on a multi－layer epoxy substrate FR－4
－Multiple ground pins for maximum noise immunity
－TTL compatible $/ / O s$
－Single 5V（ $\pm 10 \%$ ）power supply

## PIN CONFIGURATION ${ }^{(2)}$

| GND | 단 | 1 | 73 | GND | Vcc |  | 72 | 卫 | Vcc |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Do | － | 2 | 74 | D 1 | D62 |  |  | 曰 | $\mathrm{D}_{63}$ |
| D2 | － | 3 | 75 | D3 | D60 | 142 | 70 | $\square$ | D61 |
| D4 | － | 4 | 76 | D5 | D58 | 141 | 69 | 1 | D59 |
| D6 | 5 | 5 | 77 | D7 | D56 | 140 | 68 | マ | D57 |
| D8 | 5 | 6 | 78 | $\mathrm{D}_{9}$ | GND | 139 | 67 | 雨 | D55 |
| WE1 | 5 | 7 | 79 | OE1 | WE4 | 138 | 66 | T | $\mathrm{OE}_{4}$ |
| CS11 | 5 | 8 | 80 | GND | D54 | 137 | 65 | $\square$ | $\mathrm{CS1}_{4}$ |
| CS15 | － | 9 | 81 | D10 | D53 | 136 | 64 | $\square$ | CS18 |
| WE5 | － | 10 | 82 | $\mathrm{OE}_{5}$ | WE8 | 135 | 63 | ص | OE8 |
| D11 | ᄃ | 11 | 83 | D12 | D51 | 134 | 62 | $\square$ | Ds2 |
| D13． | － | 12 | 84 | Vcc | GND | 133 | 61 | コ | D50 |
| P2A0 | $\square$ | 13 | 85 | P2A1 | P2A12 | 132 | 60 | P | N．C． |
| P2A2 | 단 | 14 | 86 | Р2А3 | P2A10 | 131 | 59 | $\square$ | P2A11 |
| P2A4 | － | 15 | 87 | P2A5 | P2As | 130 | 58 | $\square$ | P2A9 |
| P10E | － | 16 | 88 | P2OE | P2A6 | 129 | 57 | $\square$ | P2A7 |
| A 0 | － | 17 | 89 | A1 | A12 | 128 | 56 | ص | N．C． |
| A2 | 5 | 18 | 90 | A3 | A10 | 127 | 55 | $\square$ | A11 |
| A 4 | － | 19 | 91 | As | As | 126 | 54 | T | A9 |
| D14 | － | 20 | 92 | GND | A6 | 125 | 53 | 卫 | A |
| N．C． | － | 21 | 93 | P1LE1 | N．C． | 124 | 52 | ？ | N．C． |
| N．C． | － | 22 | 94 | P1LE2 | P2LE | 123 | 51 | $\square$ | N．C． |
| D15 | － | 23 | 95 | D16 | GND | 122 | 50 | T | D49 |
| D17 | － | 24 | 96 | Vcc | D47 | 121 | 49 | $\square$ | D48 |
| D18 | － | 25 | 97 | D19 | D45 | 120 | 48 | $\square$ | D46 |
| D20 | － | 26 | 98 | D21 | D43 | 119 | 47 | P | D44 |
| WE2 | － | 27 | 99 | OE2 | WE7 | 118 | 46 | $\square$ | $\mathrm{OE}_{7}$ |
| $\overline{\mathrm{CS1}} 2$ | $\square$ | 28 | 100 | GND | GND | 117 | 45 | ص | $\stackrel{\text { CS17 }}{ }$ |
| $\mathrm{CSI}^{16}$ | $\square$ | 29 | 101 | D22 | D42 | 116 | 44 | ص | $\mathrm{CS1}_{3}$ |
| WE6 | － | 30 | 102 | $\mathrm{OE}_{6}$ | WE3 | 115 | 43 | R | OE3 |
| D23 | － | 31 | 103 | D24 | D40 | 114 | 42 |  | $\mathrm{D}_{41}$ |
| D25 | － | 32 | 104 | D26 | Vcc | 113 | 41 | ？ | D39 |
| D27 | ᄃ | 33 | 105 | D28 | D37 | 112 | 40 |  | D38 |
| D29 | － | 34 | 106 | D30 | D35 | 111 | 39 | 3 | D36 |
| D31 | $\square$ | 35 | 107 | D32 | D33 | 110 | 38 | $ص$ | D34 |
| Vcc | ［ | 36 | 108 | Vcc | GND | 109 | 37 | $\square$ | GND |
| NOTE： | TOP VIEW |  |  |  |  |  |  |  |  |

## DESCRIPTION：

The IDT7MB6051 is a 128 K －byte high－speed CMOS static RAM cache module constructed on a multilayer epoxy sub－ strate（FR－4）using 16 IDT7164（ $8 \mathrm{~K} \times 8$ ）RAMs and 8 IDT4FCT373 latches．．

The construction and specifications of this module have been optimized to support its use as a complete 8 K deep Instruction and Data cache for the IDT79R3000 MIPs ${ }^{\text {TM }}$ microprocessor．

The IDT7MB6051 supports use in a multi－processor sys－ tem by providing data invalidation latches on－board．The IDT7MB6051 is organized as two separate banks of $8 \mathrm{~K} \times 64$ with the IDT74FCT373s being used as address latches．The two banks of RAM with their associated address latches share a common 14 －bit ADDRESS bus and a common 64－bit DATA bus．The chip select，write enable，RAM output enable and latch enable controls for the two banks are brought out separately to support interleaving access to the two banks of RAM．Also，each bank has two sets of address latches to reduce the capacitance loading on the outputs of the latches and，thereby，enhance performance．

All inputs and outputs of the IDT7MB6051 are TTL－compat－ ible and operate from a single 5 V supply．Fully asynchronous circuitry is used，requiring no clocks or refreshing for opera－ tion．

## PIN NAMES

| Do－D63 | Data inputs／Outputs |
| :---: | :---: |
| A0－A13 | Address Inputs |
| P2A0－P2A13 | Invalid Address |
| P1LE1 | Data Address Latch Enable |
| P1LE2 | Instruction Address Latch Enable |
| $\overline{\text { P1OE }}$ | Data Address Enable |
| P20E | Invalidate Address Enable |
| P2LE | Invalidate Address Latch Enable |
| $\overline{\mathrm{CS} 11}-\overline{\mathrm{CS} 18}$ | RAM Selects |
| $\overline{\mathrm{CS2}} 1-\overline{\mathrm{CS} 28}$ | RAM Selects |
| $\overline{W E}_{1}$－ WEs $_{8}$ | Write Enables |
| $\overline{\mathrm{OE}}_{1}-\overline{\mathrm{OE}} 8$ | Output Enable |
| GND | Ground |
| Vcc | Power Supply |
| N．C． | No connection |

1．Each of these pins must be connected to GND or Vcc through a resistor for proper operation of the IDT79R3000 applications．
2．Dimensions for these module are currently not available，please consult the factory．

DATA CACHE


## INSTRUCTION CACHE



## $2 \times 16 \mathrm{~K} \times 60$ DATA／INSTRUCTION CACHE MODULE FOR IDT79R3000 CPU

IDT7MB6039

Integrated Device Technology，Inc．

## FEATURES：

－High－speed 240K－Byte CMOS static RAM module con－ structed to support the IDT79R3000 RISC CPU as a complete data and instruction cache
－Operating frequencies to support $12 \mathrm{MHz}, 16.7 \mathrm{MHz}$ ， $20 \mathrm{MHz}, 25 \mathrm{MHz}$ and 33 MHz IDT79R3000
－Available in high－density，low profile 128－pin QIP（Quad In－line Package）
－Surface mounted SOs on a multi－layer epoxy substrate （FR－4）
－Multiple ground pins for maximum noise immunity
－On－board address latches for direct interface to the IDT79R3000 CPU
－TTL compatible I／Os
－Single $5 \mathrm{~V}( \pm 10 \%)$ power supply

## DESCRIPTION：

The IDT7MB6039 is a 240 K －byte high－speed CMOS static RAM cache module constructed on a multilayer epoxy sub－
strate（FR－4），using 30 （16KX4）SRAMs and8 IDT74FCT373 latches．

The construction and specifications of this module have been optimized to support its use as a complete 16 K deep Instruction and Data cache for the IDT79R3000 MIPs ${ }^{\text {™ }}$ microprocessor．

The IDT7MB6039 is organized as two separate banks of $16 \mathrm{~K} \times 60$ with the IDT74FCT373s being used as address latches．The two banks of RAM with their associated address latches share a common 14－bit ADDRESS bus and a common 60 －bit DATA bus．The chip select，write enable，RAM output enable and latch enable controls for the two banks are brought out separately to support interleaving access to the two banks of RAM．Each bank of address latches reduces the capaci－ tance loading on the outputs of the latches；thereby，enhanc－ ing CPU performance．

All inputs and outputs of the IDT7MB6039 are TTL－com－ patible and operate from a single 5 V supply．Fully asynchro－ nous circuitry is used，requiring no clocks or refreshing for operation．

## PIN CONFIGURATION ${ }^{(2)}$

| GND |  | 1 | 65 | GND | Vcc |  |  | $\square$ | Vcc |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 2 | 66 | D1 | N．C． | 127 |  | － | N．C． |
| D2 | R | 3 | 67 | D3 | N．C． | $126^{(1)}$ | $1{ }^{\prime}$ | 号 | N．C． |
| D4 | $\square$ | 4 | 68 | D5 | D58 | 125 | 61 | $\sqsupset$ | D59 |
| D6 | $\square$ | 5 | 69 | D7 | D56 | 124 | 60 |  | D57 |
| Ds | － | 6 | 70 | D3 | GND | 123 | 59 | － | D55 |
| WE1 | － | 7 | 71 | $\mathrm{OE}_{1}$ | WE4 | 122 | 58 | ص | $\mathrm{OE}_{4}$ |
| $\overline{\mathrm{CST}} 1$ | － | 8 | 72 | GND | D54 | 121 | 57 | $\square$ | $\mathrm{CSI}_{4}$ |
| CS15 | － | 9 | 73 | D10 | D53 | 120 | 56 | $\square$ | CS1a |
| WE5 | － | 10 | 74 | OE5 | WE8 | 119 | 55 | D | OE8 |
| D11 | $\square$ | 11 | 75 | D12 | D51 | 118 | 54 | ح | D52 |
| D13 | $\square$ | 12 | 76 | Vcc | GND | 117 | 53 | － | D50 |
| A0 | － | 13 | 77 | A1 | A12 | 116 | 52 | ？ | $A^{\prime} 3$ |
| A2 | G | 14 | 78 | А 3 | A10 | 115 | 51 | $\square$ | A11 |
| A4 | － | 15 | 79 | A5 | A8 | 114 | 50 | $\square$ | A9 |
| D14 | － | 16 | 80 | GND | A6 | 113 | 49 | － | $A_{7}$ |
| $\overline{\mathrm{CS2}} 3$ | － | 17 | 81 | LE1 | LE2 | 112 | 48 | $\square$ | CS22 |
| CS22 | ¢ | 18 | 82 | LE3 | LE4 | 111 | 47 | $\square$ | $\mathrm{CS2}_{4}$ |
| D15 | － | 19 | 83 | D16 | GND | 110 | 46 | ， | D49 |
| D17 | 든 | 20 | 84 | Vcc | D47 | 109 | 45 | マ | D48 |
| D18 | － | 21 | 85 | D19 | D45 | 108 | 44 | $\square$ | D46 |
| D20 | － | 22 | 86 | $\mathrm{D}_{21}$ | D43 | 107 | 43 | 己 | D44 |
| $\mathrm{WE}_{2}$ | － | 23 | 87 | OE2 | WE7 | 106 | 42 | $\square$ | $\mathrm{OE}_{7}$ |
| $\overline{\mathrm{CS1}} 2$ | － | 24 | 88 | GND | GND | 105 | 41 | ， | CS17 |
| CS16 | － | 25 | 89 | D22 | D42 | 104 | 40 | $\square$ | $\mathrm{CST}_{3}$ |
| $\mathrm{WE}_{6}$ | － | 26 | 90 | $\mathrm{OE}_{6}$ | WE3 | 103 | 39 |  | $\mathrm{OE}_{3}$ |
| D23 | － | 27 | 91 | $\mathrm{D}_{24}$ | D40 | 102 | 38 | $\checkmark$ | D41 |
| D25 | ¢ | 28 | 92 | D26 | Vcc | 101 | 37 | $\square$ | D39 |
| D27 | － | 29 | 93 | D28 | D37 | 100 | 36 | 卫 | D38 |
| D29 | － | 30 | 94 | D30 | D35 | 99 | 35 | 卫 | D36 |
| D31 | ¢ | 31 | 95 | D32 | D33 | 98 | 34 | $\square$ | D34 |
| Vcc | － | 32 | 96 | Vcc | GND | 97 | 33 | $\square$ | GND |

## PIN NAMES

| Do－D59 | Data Inputs／Outputs |
| :---: | :---: |
| A0－A13 | Address Inputs |
| LE $\mathrm{L}_{1}$ LE 4 | Latch Enables |
| $\overline{\mathrm{CS} 11}-\overline{\mathrm{CS} 18}$ | RAM Selects |
|  | RAM Selects |
| $\overline{W E}_{1}-\overline{W E}_{8}$ | Write Enables |
| $\overline{\mathrm{OE}}_{1}-\overline{\mathrm{OE}}_{8}$ | Output Enables |
| GND | Ground |
| Vcc | Power Supply |
| N．C． | No connection ${ }^{(1)}$ |

2800 tbl 01

## NOTES：

1．Each of these pins must be connected to GND for proper operation of this module．
2．For module dimensions，please refer to module drawing M28 in the packaging section．

## QIP <br> TOP VIEW

INSTRUCTION CACHE


8

2800 drw 02

## DATA CACHE



## ABSOLUTE MAXIMUM RATINGS

| Symbol | Rating | Comm. | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TbIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicatedin the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## RECOMMENDED DC OPERATING

CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2800 tbl 03

1. VIL (min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 12 MHz <br> Min. Max. | 16.7 MHz <br> Min. Max. | 20 MHz <br> Min. Max. | 25 MHz <br> Min. Max. | 33 MHz <br> Min. Max. | Unlt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \|ILI| | Input Leakage Current | $\begin{aligned} & \text { Vcc = Max., } \\ & \text { Vin = GND to Vcc } \end{aligned}$ | 20 | 20 | 20 | 20 | - 20 | $\mu \mathrm{A}$ |
| \|llol | Output Leakage Current | $\begin{aligned} & \text { Vcc }=\text { Max. }, \overline{\mathrm{CS}}=\mathrm{VIH}, \\ & \text { Vout }=\mathrm{GND} \text { to } \mathrm{Vcc} \end{aligned}$ | 10 | 10 | 10 | 10 | 10 | $\mu \mathrm{A}$ |
| Icc1 | Operating Current | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{VIL}, \mathrm{VCC}=\mathrm{Max} . \\ & \text { Outputs Open, } f=0 \end{aligned}$ | 3000 | 3000 | - 3000 | - 3500 | - 3750 | mA |
| ICC2 | Dynamic Operating Current | $\begin{aligned} & \text { Vcc = Max., } \overline{C S}=V \\|, \\ & f=\mathrm{fMAX}, \text { Outputs Open } \end{aligned}$ | 3750 | 3750 | 4050 | - 4500 | - 4750 | mA |
| ISB1 | Full Standby Operating Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}, \mathrm{VIN}> \\ & \mathrm{Vcc}-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V} \end{aligned}$ | 450 | 450 | 450 | 600 | - 750 | mA |
| ISB | Standby Power Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VIH}, \mathrm{VCC}=\text { Max., } \\ & \text { Outputs Open, } \mathrm{f}=\mathrm{fMAX} \end{aligned}$ | 1500 | 1500 | 1650 | - 1800 | - 2000 | mA |
| VOH | Output High Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} ., \\ & \mathrm{lOH}=-4 \mathrm{~mA} \end{aligned}$ | 2.4 | 2.4 | 2.4 | 2.4 . | 2.4 - | V |
| Vol | Output Low Voltage | $\begin{aligned} & \mathrm{VCC}=\mathrm{Min} . \\ & \mathrm{lOL}=8 \mathrm{~mA} \end{aligned}$ | 0.4 | 0.4 | 0.4 | 0.4 | $-0.4$ | V |

2800 tbl 05

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load (for tolzt ohk
*Including scope and jig.

## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 12 MHz |  | 16.7 MHz |  | 20 MHz |  | 25 MHz |  | 33 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tus | Latch Enable Width | 8 | - | 6 | - | 6 | - | 6 | - | 6 | - | ns |
| tAS | Address Setup Time to LE | 4 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
| tah | Address Hold Time from LE | 3 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | ns |
| ta $^{(2)}$ | Address Access Time | - | 45 | - | 35 | - | 30 | - | 25 | - | 20 | ns |
| tacs | Chip Select Time . | - | 40 | - | 30 | - | 25 | - | 20 | - | 15 | ns . |
| toe | Output Enable Time | - | 22 | - | 17 | - | 11 | - | 8 | - | 5 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | 2 | 16 | 2 | 14 | 2 | 10 | 2 | 8 | 2 | 6 | ns |
| tolz ${ }^{(1)}$ | Output Disable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tue | Latch Enable Width | 8 | - | 6 | - | 6 | - | 6 | - | 6 | - | ns |
| tas | Address Setup Time to LE | 4 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
| tah | Address Hold Time from LE | 3 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | ns |
| taw ${ }^{(2)}$ | Address Valid to End of Write | 40 | - | 30 | - | 25 | - | 23 | - | 20 | - | ns |
| tcw | Chip Select to End of Write | 35 | - | 25 | - | 20 | - | 18 | - | 15 | - | ns |
| twp | Write Pulse Width | 30 | - | 25 | - | 20 | - | 17 | - | 12 | - | ns |
| tow | Data Valid to End of Write | 20 | - | 13 | - | 13 | - | 11 | - | 8 | - | ns |
| tor | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |

NOTES:

1. This parameter is guaranteed by design but not tested.
2. LE already asserted.

TIMING WAVEFORM OF READ CYCLE ${ }^{(1)}$


NOTES:

1. $\overline{W E}$ and $\overline{\mathrm{CS}}$ must be High for all address transitions.
2. This parameter is guaranteed by design but not tested.

## TIMING WAVEFORM OF WRITE CYCLE ${ }^{(1)}$



2800 drw 06

NOTE:

1. A write occurs (twP) during the overlap of a Low $\overline{\mathrm{CS}}$ and $\overline{\mathrm{WE}}$ and a High LE.

TRUTH TABLE

| Mode | $\overline{\text { CS1 }}$ | $\overline{\text { CS2 }}$ | $\overline{\mathbf{O E}}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Standby | H | X | X | X | High Z | Standby |
| Standby | X | H | X | X | High Z | Standby |
| Read | L | L | L | H | Dout | Active |
| Read | L | L | H | H | High Z | Active |
| Write | L | L | X | L | DIN | Active |

2800 tbl 07

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{F}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C} \mathbb{N}$ | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 60 | pF |
| C OUT | Output Capacitance | VouT $=0 \mathrm{~V}$ | 20 | pF |

NOTE:

1. This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION




Integrated Device Technology, Inc.
$2 \times 16 \mathrm{~K} \times 60$ DATA/INSTRUCTION CACHE MODULE FOR IDT79R3000 CPU (MULTIPROCESSOR)

## FEATURES:

- High Speed 240K-Byte CMOS Static RAM Module con structed to support the IDT79R3000 CPU in a multi processor system as a complete data and instruction cache
- Additional data and instruction address invalidation latches on-board to facilitate use in a multi-processor system
- Operating frequencies to support $12 \mathrm{MHz}, 16.7 \mathrm{MHz}$, $20 \mathrm{MHz}, 25 \mathrm{MHz}$, and 33 MHz IDT79R3000
- Available in a high density, low profile 120-pin QIP (Quad-In-Line Package)
- Surface mounted SO's on a multilayer epoxy substrate (FR-4)
- Multiple ground pins for maximum noise immunity.
- TTL compatible I/O's
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## PIN CONFIGURATION ${ }^{(1)}$



## DESCRIPTION:

The IDT7MB6049 is a 240 K -Byte high-speed CMOS Static RAM cache module constructed on a multilayer epoxy substrate (FR-4) using 28 (16K x 4) RAM's, 16 IDT74FCT373 latches, and 1 IDT74FCT244.

The IDT7MB6049 is organized as two separate banks of $16 \mathrm{~K} \times 60$ with the IDT74FCT373's being used as address latches. The two banks of RAM with their associated address latches share a common 14-bit ADDRESS bus and a common 60 -bit DATA bus. The chip select, write enable, RAM output enable, and latch enable controls for the two banks are brought out separately, to support inter-leaving access to the two banks of RAM. Also, each bank has two sets of address latches to reduce the capacitance loading on the outputs of the latches; thereby enhancing CPU performance.
The IDTMB6049 supports use in a multi-processor (IDT79R3000 based) system by providing a second address bus and an addtional set of latches for that bus. This bus is used in multi-processor applications to latch an address from a source other than the R3000. This maintains cache coherency by allowing the system to invalidate entries in the data cache. For more details on IDT7MB6049 operation, please refer to Application Note AN-76.

All inputs and outputs of the IDT7MB6049 are TTL-compatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

PIN NAMES

| D (0)-D (59) | Data Inputs/Outputs |
| :---: | :---: |
| P1A (0)-P1A (13) | Address inputs |
| P2A (0)-P2A (13) | Invalidate Address Inputs |
| P1LE1 | Data Address Latch Enable |
| P1LE2 | Instruction Address Latch Enable |
| $\overline{\mathrm{P} 1 \mathrm{OE}}{ }_{(1)}$ | Data Address Enable |
| $\overline{\mathrm{PIOE}}{ }_{(2)}$ | Instruction Address Enable |
| P2OE ${ }_{(1)}$ | Invalidate Data Address Enable |
| P2OE (2) | Invalidate Instruction Address Enable |
| P2LE1 (1) | Invalidate Data Address Latch Enable |
| P2LE2 ${ }^{(2)}$ | Invalidate Instruction Address Latch Enable |
| $\overline{\mathrm{CS}}$ (1), $\overline{\mathrm{CS}}_{(2)}$ | Data, Instruction Cache RAM Selects |
| $\overline{\mathrm{WE}}{ }_{(1)}-\overline{W E}_{(4)}$ | Write Enables |
| $\overline{\mathrm{OE}}$ (1) - $\overline{\mathrm{OE}}$ (4) | Output Enables |
| GND | Ground |
| Vcc | Power Supply |

1. For module dimensions, please refer to drawing M26 in the packaging section.

2796 tbl 01

FUNCTIONAL BLOCK DIAGRAM


## FUNCTIONAL BLOCK DIAGRAM



## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with Respect <br> to GND | -0.5 to 7.0 | V |
| TA | Operating Temperature | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

NOTE:
2796 tbl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliabilty.

RECOMMENDED DC
OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Units |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voitage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:
2796 tbl 03

1. VIL (Min.) $=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | $0 \mathrm{~V} .$. | $5.0 \mathrm{~V} \pm 10 \%$ |

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 12 MHz |  | 16.7MHz |  | 20MHz |  | 25MHz |  | 33 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| \| 4.1 | Input Leakage Current | $\mathrm{Vcc}=$ Max., VIN $=$ GND to Vcc | - | 20 | - | 20 | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \|lLo| | Output Leakage Current | $\begin{aligned} & \text { Vcc = Max., } \overline{\mathrm{CS}}=\mathrm{VIH}, \\ & \text { Vout }=\mathrm{GND} \text { to } \mathrm{Vcc} . \end{aligned}$ | - | 10 | - | 10 | - | 10 | - | 10 | - | 10 | $\mu \mathrm{A}$ |
| Icc1 | Operating Current | $\begin{aligned} & \mathrm{f}=0, \overline{\mathrm{CS}}=\mathrm{VIL}, \mathrm{VcC}=\text { Max., } \\ & \text { Output Open } \end{aligned}$ | - | 2350 | - | 2400 | - | 2500 | - | 2850 | - | 3000 | mA |
| ICC2 | Dynamic Operating Current | $\text { Vcc }=\text { Max. }, \overline{C S} \leq \text { VIL, } f=\text { fMAX, }$ <br> Output Open | - | 2850 | - | 2900 | - | 3125 | - | 3400 | - | 3600 | mA |
| Is81 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc} 0.2 \mathrm{~V}, \\ & \mathrm{VIN}>V c \mathrm{~V}-0.2 \mathrm{~V} \text { or }<0.2 \mathrm{~V} \end{aligned}$ | - | 450 | - | 450 | - | 450 | - | 600 | - | 750 | mA |
| ISB | Standby Power Supply Current | $\overline{\mathrm{CS}} \geq \mathrm{VIH}, \mathrm{VCC}=\operatorname{Max} . f=f \mathrm{MAX},$ <br> Outputs Open | - | 1300 | - | 1425 | - | 1575 | - | 1700 | - | 2000 | mA |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | 2.4 | - | 2.4 | - | 2.4 | - | V |
| VOL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | - | 0.4 | - | 0.4 | - | 0.4 | V |

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :--- |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |

2796 tbl 06


Figure 1. Output Load

Figure 2. Output Load (for tolz, torz)

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 12 MHz |  | 16.7MHz |  | 20MHz |  | 25MHz |  | 33 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tle | Latch Enable Width | 8 | - | 6 | - | 6 | - | 6 | - | 6 | - | ns |
| tAS | Address Setup Time to LE | 4 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
| tah | Address Hold Time from LE | 3 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | ns |
| $\mathrm{taA}^{(2)}$ | Address Access Time | - | 45 | - | 35 | - | 30 | - | 25 | - | 20 | ns |
| tacs | Chip Select Time | - | 40 | - | 30 | - | 25 | 一 | 20 | - | 15 | ns |
| toE ${ }^{(3)}$ | Output Enable Time | - | 22 | - | 17 | - | 11 | - | 8 | - | 5 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | 2 | 16 | 2 | 14 | 2 | 10 | 2 | 8 | 2 | 6 | ns |
| tolz ${ }^{(1)}$ | Output Disable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tLE | Latch Enable Width | 8 | - | 6 | - | 6 | - | 6 | - | 6 | - | ns |
| tas | Address Setup Time to LE | 4 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
| taH | Address Hold Time from LE | 3 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | ns |
| tAW ${ }^{(2)}$ | Address Valid to End of Write | 40 | - | 30 | - | 25 | - | 23 | - | 20 | - | ns |
| tcw | Chip Select to End of Write | 35 | - | 25 | - | 20 | - | 18 | - | 15 | - | ns |
| twp | Write Pulse Width | 30 | - | 25 | - | 20 | - | 17 | - | 12 | - | ns |
| tDW | Data Valid to End of Write | 20 | - | 13 | - | 13 | - | 11 | - | 8 | - | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| tLOE ${ }^{(4)}$ | Latch Output Enable | - | 7 | - | 7 | - | 7 | - | 7 | - | 7 | ns |

## NOTES:

1. This parameter is guaranteed by design but not tested.
2. LE already asserted.
3. For all $\overline{\mathrm{OE}}(1), \overline{\mathrm{OE}}(2), \overline{\mathrm{OE}}(3), \overline{\mathrm{OE}}_{(4)}$
4. For all $\overline{\mathrm{P}} 1 \mathrm{OE}_{1}, \overline{\mathrm{P}} 1 \mathrm{OE}_{2}, \overline{\mathrm{P} 2 O E}_{1}, \overline{\mathrm{P} 2 \mathrm{OE}} 2_{2}$

## TIMING WAVEFORM OF READ CYCLE



NOTE:

1. This parameter is guaranteed by design but not tested

## TIMING WAVEFORM OF WRITE CYCLE



## ORDERING INFORMATION




Integrated Device Technology, Inc.
$2 \times 16 \mathrm{~K} \times 64$ DATA/INSTRUCTION CACHE MODULE FOR GENERAL PURPOSE CPUs

## FEATURES:

- High-speed 256K-ByteCMOS static RAM module constructed to support general purpose CPUs as a complete data and instruction cache
- Supports operating frequencies of $12 \mathrm{MHz}, 16.7 \mathrm{MHz}$, $20 \mathrm{MHz}, 25 \mathrm{MHz}$ and 33 MHz
- Available in a high-density, low profile 128-pin QIP (quad in-line package)
- Surface mounted SO's on a multilayer epoxy substrate (FR-4)
- Multiple ground pins for maximum noise immunity
- TTL-compatible I/Os
- Single 5V ( $\pm 10 \%$ ) power supply


## PIN CONFIGURATION ${ }^{(1)}$

| GND $\square_{1}$ | 65 GND | Vcc 128 | 64 | Vcc |
| :---: | :---: | :---: | :---: | :---: |
| Do $\square^{2}$ | $66 \mathrm{D}_{1}$ | D62 127 | 63 | $\mathrm{D}_{6}$ |
| $\mathrm{D}_{2} \square^{3}$ | $67 \mathrm{D}_{3}$ | D60 126 | 62 | $\square \mathrm{D}_{61}$ |
| $\mathrm{D}_{4} \square_{4}$ | 68 Ds | D58 125 | 61 | $\mathrm{D}_{59}$ |
| $\mathrm{D}_{6} \square^{4}$ | 69 D7 | D56 124 | 60 | D $\mathrm{S}_{7}$ |
| $\mathrm{D}_{8}{ }^{6}$ | 70 Dg | GND 123 | 59 | $\square \mathrm{D}_{55}$ |
| WE, 7 | $71 \mathrm{OE}_{1}$ | WE $^{\text {W }} 122$ | 58 | $\mathrm{OE}_{4}$ |
| CS1, $\square^{8}$ | 72 GND | D54 121 | 57 | $\square \mathrm{CSI}_{4}$ |
| $\overline{\mathrm{CS1}} 5 \square^{9}$ | 73 D 10 | Ds3 120 | 56 | 曰 $\mathrm{CS1}_{8}$ |
| WE5 ${ }^{10}$ | $74 \mathrm{OE}_{5}$ | $\mathrm{WE}_{8} 119$ | 55 | $\square \mathrm{OE}_{8}$ |
| $\mathrm{D}_{11}{ }^{11}$ | 75 D 12 | D51 118 | 54 | $\mathrm{D}_{52}$ |
| $\mathrm{D}_{13} \mathrm{C}_{12}$ | 76 Vcc | GND 117 | 53 | $\mathrm{D}_{50}$ |
| A 013 | 77 At | A12 116 | 52 | $A_{13}$ |
| $\mathrm{A}_{2}-14$ | 78 A3 | A 10115 | 51 | $\square \mathrm{A}_{11}$ |
| $\mathrm{A}_{4}{ }^{15}$ | 79 As | $A_{88} 114$ | 50 | Ag |
| $\mathrm{D}_{14} \mathrm{C}_{16}$ | 80 GND | A6 113 | 49 | $A_{7}$ |
| $\overline{\mathrm{CS2}}, 17$ | 81 LE ${ }_{1}$ | LE 2112 | 48 | $\square^{\text {CS22 }}$ |
| $\mathrm{CS2}_{3}{ }^{18}$ | $82 \mathrm{LE}_{3}$ | LE4 111 | 47 | $\square \mathrm{CS2}_{4}$ |
| $\mathrm{D}_{15} 19$ | $83 \mathrm{D}_{16}$ | GND 110 | 46 | $\mathrm{D}_{49}$ |
| D17 ${ }^{20}$ | 84 Vcc | D47 109 | 45 | $\mathrm{D}_{48}$ |
| $\mathrm{D}_{18} \mathrm{C}^{21}$ | $85{ }^{19}$ | D45 108 | 44 | $\mathrm{D}_{46}$ |
| D20 22 | $86 \mathrm{D}_{21}$ | $\mathrm{D}_{43} 107$ | 43 | $\square \mathrm{D}_{44}$ |
| $\mathrm{WE}_{2} \mathrm{C}^{23}$ | $87 \mathrm{OE}_{2}$ | $\mathrm{WE}_{7} 106$ | 42 | $\square \mathrm{DE}_{7}$ |
| $\mathrm{CS1}_{2} \square^{24}$ | 88 GND | GND 105 | 41 | 口 CS17 |
| $\mathrm{CSI}_{6} \square^{25}$ | $89 \mathrm{D}_{22}$ | D42 104 | 40 | $\square \mathrm{CSI}_{3}$ |
| $\overline{W E}_{6}{ }^{26}$ | $90 \overline{O E}_{6}$ | WE3 $^{103}$ | 39 | $\square \overline{\mathrm{OE}}_{3}$ |
| $\mathrm{D}_{23}{ }^{27}$ | $91 \mathrm{D}_{24}$ | D40 102 | 38 | $\mathrm{D}_{41}$ |
| $\mathrm{D}_{25} \mathrm{~L}_{28}$ | 92 D 26 | Vcc 101 | 37 | $\mathrm{D}_{39}$ |
| $\mathrm{D}_{27} \square^{29}$ | 93 D 28 | D37 100 | 36 | $\mathrm{D}_{38}$ |
| D29 $\square^{30}$ | $94 \mathrm{D}_{30}$ | D35 99 | 35 | $\mathrm{D}_{36}$ |
| $\mathrm{D}_{31} \square^{31}$ | $95 \mathrm{D}_{32}$ | $\mathrm{D}_{33} 98$ | 34 | $\square \mathrm{D}_{34}$ |
| Vcc $\square^{32}$ | 96 Vcc | GND 97 | 33 | $\square \mathrm{GND}$ |
| QIP <br> TOP VIEW |  |  |  |  |

## DESCRIPTION:

The IDT7MB6040 is a 256K-byte high-speed CMOS static RAM cache module constructed on a multilayer epoxy substrate (FR-4), using 32 ( $16 \mathrm{~K} \times 4$ ) RAMs and 8 IDT74FCT373 latches.

The IDT7MB6040 is organized as two separate banks of $16 \mathrm{~K} \times 64$ with the IDT74FCT373s being used as address latches. The two banks of RAM with their associated address latches share a common 14-bit ADDRESS bus and common 64-bit DATA bus. The chip select, write enable, RAM output enable and latch enable controls for the two banks are brought out separately to support interleaving access to the banks of RAM. Each bank of address latches reduce the capacitance loading on the outputs of the latches; thereby, enhancing CPU performance.

All inputs and outputs of the IDT7MB6040 are TTLcompatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, requiring no clocks or refreshing for operation.

## PIN NAMES

| Do - D63 | Data Inputs/Outputs |
| :--- | :--- |
| $\mathrm{Ao}_{6}-\mathrm{A}_{13}$ | Address Inputs |
| $\mathrm{LE}_{1}-\mathrm{LE}_{4}$ | Latch Enables |
| $\overline{\mathrm{CS}} 11^{-\overline{\mathrm{CS}} 18}$ | RAM Selects |
| $\overline{\mathrm{CS}} 21^{1}-\overline{\mathrm{CS}} 24$ | RAM Selects |
| $\overline{\mathrm{WE}}_{1}-\overline{\mathrm{WE}}_{8}$ | Write Enables |
| $\overline{\mathrm{OE}}_{1}-\overline{\mathrm{OE}}_{8}$ | Output Enables |
| GND | Ground |
| VCc | Power |

2743 bl 01

NOTE:

1. For module dimensions, please refer to module drawing M28 in the packaging section.

## DATA CACHE



INSTRUCTION CACHE


2743 drw 03

ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TbiAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

2743 tbl 04
NOTE:

1. $\operatorname{VIL}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

DC ELECTRICAL CHARACTERISTICS
$\left(\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 12 MHz |  | 16.7MHz |  | 20MHz |  | 25 MHz |  | 33 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| \|ILI | Input Leakage Current | $\begin{aligned} & V C C=M a x . \\ & V \mathbb{N}=G N D \text { to } V c c \end{aligned}$ | - | 20 | - | 20 | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \|lıO| | Output Leakage Current | $\begin{aligned} & \text { Vcc = Max., } \overline{\mathrm{CS}}=\mathrm{VIH}, \\ & \text { Vout }=\mathrm{GND} \text { to Vcc } \end{aligned}$ | - | 10 | - | 10 | - | 10 | - | 10 | - | 10 | $\mu \mathrm{A}$ |
| Icc1 | Operating Current | $f=0, \overline{C S}=V \mathrm{VI}, V C C=M a x .$ <br> Outputs Open | - | 3000 | - | 3000 | - | 3000 | - | 3600 | - | 4000 | mA |
| ICC2 | Dynamic Operating Current | $\begin{aligned} & \text { Vcc }=\text { Max., } \overline{\mathrm{CS}}=\mathrm{VIL}, \mathrm{f}=\mathrm{fmax} \\ & \text { Outputs Open } \end{aligned}$ | - | 3750 | - | 3750 | - | 4050 | - | 4500 | - | 4800 | mA |
| IsB1 | Full Standby Supply Current | $\begin{aligned} & \mathrm{CS} \geq \mathrm{Vcc}-0.2 \mathrm{~V}, \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \\ & \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 450 | - | 450 | - | 450 | - | 600 | - | 960 | mA |
| IsB | Standby Power Supply Current | $\begin{aligned} & \text { VCC }=\text { Max., } \overline{\mathrm{CS}}=\mathrm{VIH}, \mathrm{f}=\mathrm{fmAx} \\ & \text { Outputs Open } \end{aligned}$ | - | 1500 | - | 1500 | - | 1650 | - | 1800 | - | 2000 | mA |
| VOH | Output High Voltage | $\mathrm{Vcc}=\mathrm{Min} ., \mathrm{loh}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | 2.4 | - | 2.4 | - | 2.4 | - | V |
| VOL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{loL}=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | - | 0.4 | - | 0.4 | - | 0.4 | V |

## AC TEST CONDITIONS

| In Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Flgure 1. Output Load


2743 drw 04
Figure 2. Output Load (for tolz, 10 HZ )

* Including scope and jig.


## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 12MHz |  | 16.6MHz |  | 20MHz |  | 25MHz |  | 33 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tLE | Latch Enable Width | 8 | - | 6 | - | 6 | - | 6 | - | 6 | - | ns |
| tAS | Address Setup Time to LE | 4 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
| tAH | Address Hold Time from LE | 3 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | ns |
| $\mathrm{taA}^{(2)}$ | Address Access Time | - | 45 | - | 35 | - | 30 | - | 25 | - | 20 | ns |
| tacs | Chip Select Time. | - | 40 | - | 30 | - | 25 | - | 20 | - | 15 | ns |
| toe | Output Enable Time | - | 22 | - | 17 | - | 11 | - | 8 | - | 5 | ns |
| tohz ${ }^{(1)}$ | Output Disable to Output in High Z | 2 | 16 | 2 | 14 | 2 | 10 | 2 | 8 | 2 | 6 | ns |
| tolz ${ }^{(1)}$ | Output Disable to Output in Low Z | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tLE | Latch Enable Width | 8 | - | 6 | - | 6 | - | 6 | - | 6 | - | ns |
| tAS | Address Setup Time to LE | 4 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
| tah | Address Hold Time from LE | 3 | - | 1.5 | - | 1.5 | 一 | 1.5 | - | 1.5 | - | ns |
| taw ${ }^{(2)}$ | Address Valid to End of Write | 40 | - | 30 | - | 25 | - | 23 | - | 20 | - | ns |
| tcw | Chip Select to End of Write | 35 | - | 25 | - | 20 | - | 18 | - | 15 | - | ns |
| twp | Write Pulse Width | 30 | - | 25 | - | 20 | - | 17 | - | 12 | - | ns |
| tow | Data Valid to End of Write | 20 | - | 13 | - | 13 | - | 11 | - | 8 | 一 | ns |
| tDH | Data Hold Time | 0 | - | 0 | - | 0 : | - | 0 | - | 0 | - | ns |

## NOTE:

1. This parameter is guaranteed by design but not tested.
2. LE already asserted.

## TIMING WAVEFORM OF READ CYCLE ${ }^{(1)}$



## NOTES:

1. $\overline{W E}$ and $\overline{C S}$ must be High for all address transitions.
2. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE ${ }^{(1)}$


2743 drw 06

## NOTE:

1. A write occurs ( $t_{\text {wp }}$ ) during the overlap of a Low $\overline{C S}$ and $\overline{W E}$ and a High LE.

## TRUTH TABLE

| Mode | $\overline{\text { CS1 }}$ | $\overline{\text { CS2 }}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { WE }}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Standby | H | X | X | X | High Z | Standby |
| Standby | X | H | X | X | High Z | Standby |
| Read | L | L | L | H | Dout | Active |
| Read | L | L | H | H | High Z | Active |
| Write | L | L | X | L | Din | Active |

CAPACITANCE ${ }^{(1)}\left(\mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Conditions | Typ. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| CIN | Input Capacitance | Vin $=0 \mathrm{~V}$ | 60 | pF |
| COUT | Output Capacitance | Vout $=0 \mathrm{~V}$ | 20 | pF |

## NOTE:

1. This parameter is guaranteed by design but not tested.

## ORDERING INFORMATION



2743 dw 7

## FEATURES:

- High-speed 240K-Byte CMOS static RAM module constructed to support the IDT79R3000 CPU, in a multiprocessor system as a complete data and instruction cache
- Additional data and instruction address invalidation latches on-board to facilitate use in a multi-processor system
- RESET pin invalidates instruction cache in one operation
- Operating frequencies to support $12 \mathrm{MHz}, 16.7 \mathrm{MHz}$, $20 \mathrm{MHz}, 25 \mathrm{MHz}$ and 33 MHz IDT79R3000
- Available in a high density, low profile 120 -pin QIP (Quad In-Line Package)
- Surface mounted SOs on a multilayer epoxy substrate
- Multiple ground pins for maximum noise immunity
- TTL compatible I/Os
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply


## PIN CONFIGURATION

| GND | 1 | 61 | GND | GND | 120 | 60 | Vcc |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Do | 2 | 62 | D1 | D58 | 119 | 59 | D59 |
| D2 | 3 | 63 | D3 | D56 | 118 | 58 | D57 |
| D4 | 4 | 64 | D5 | D54 | 117 | 57 | D55 |
| D6 | 5 | 65 | D7 | D52 | 116 | 56 | D53 |
| WE1 | 6 | 66 | $\mathrm{OE}_{1}$ | WE4 | 115 | 55 | $\mathrm{OE}_{4}$ |
| $\overline{\mathrm{CS}} 1$ | 7 | 67 | Vcc | GND | 114 | 54 | GND |
| D8 | 8 | 68 | D9 | D50 | 113 | 53 | D51 |
| D10 | 9 | 69 | D11 | D48 | 112 | 52 | D49 |
| P1A0 | 10 | 70 | P1A1 | P2A0 | 111 | 51 | P2A1 |
| P1A2 | 11 | 71 | Р1А3 | P2A2 | 110 | 50 | P2A3 |
| P1A4 | 12 | 72 | P1A5 | P2A4 | 109 | 49 | P2A5 |
| P1LE1 | 13 | 73 | P1LE2 | P2LE1 | 108 | 48 | GND |
| P1A6 | 14 | 74 | P1A7 | P2A6 | 107 | 47 | P2A7 |
| P1A8 | 15 | 75 | P1A9 | P2A8 | 106 | 46 | P2A9 |
| P1A10 | 16 | 76 | P1A11 | P2A 10 | 105 | 45 | P2A11 |
| P1A12 | 17 | 77 | P1A13 | P2A12 | 104 | 44 | P2A13 |
| P1OE1 | 18 | 78 | GND | P210E 1 | 103 | 43 | RESET |
| D12 | 19 | 79 | D 13 | D46 | 102 | 42 | D47 |
| D14 | 20 | 80 | D 15 | D44 | 101 | 41 | D45 |
| D16 | 21 | 81 | D 17 | D42 | 100 | 40 | D43 |
| D18 | 22 | 82 | D19 | D40 | 99 | 39 | D41 |
| WE2 | 23 | 83 | $\mathrm{OE}_{2}$ | WE3 | 98 | 38 | $\mathrm{OE}_{3}$ |
| GND | 24 | 84 | GND | Vcc | 97 | 37 | CS2 |
| D20 | 25 | 85 | D21 | D38 | 96 | 36 | D39 |
| D22 | 26 | 86 | D23 | D36 | 95 | 35 | D37 |
| D24 | 27 | 87 | D25 | D34 | 94 | 34 | D35 |
| D26 | 28 | 88 | D27 | D32 | 93 | 33 | D33 |
| D28 | 29 | 89 | D29 | D30 | 92 | 32 | D31 |
| Vcc | 30 | 90 | Vcc | Vcc | 91 | 31 | GND |
| QIPTOP VIEW $\quad 2755 \mathrm{dwc}$ |  |  |  |  | 2755 dw |  |  |

## DESCRIPTION

The IDT7MB6061 is a 240 K -byte high-speed CMOS static RAM cache module constructed on a multilayer epoxy substrate (FR-4). The data cache uses the IDT6198 (16K x 4) SRAMs while the instruction cache uses both the IDT6198 and the IDT6178 (4K x 4) Resettable SRAMs; both cache sharing the 60 -bit data bus.

Both cache also have a set of IDT74FCT373 latches to interface with the address bus. The data cache has an additional set of latches so each processor within the multiprocessor system has the ability to invalidate the data cache.

The instruction cache uses the IDT6178 ( $4 \mathrm{~K} \times 4$ ) Cache Tag SRAMs for D36-D59. These bits cover the Tag and Valid bit fields. Address bits A2-A13 are used for this portion of the instruction cache (i.e. there are four words per line in this cache). Asserting RESET will clear D36-D59 to zeros in a single operation.

All inputs and outputs of the IDT7MB6061 are TTL-compatible and operate from a single 5 V supply. Fully asynchronous circuitry is used, reqiring no clocks or refreshing for operation.

## PIN NAMES

| Do-D59 | Data Inputs/Outputs |
| :---: | :---: |
| P1A0-P1A11 | Address inputs |
| P2A0-P2A11 | Invalidate Address |
| P1LE1 | Data Address Latch Enable |
| P1LE2 | Instruction Address Latch Enable |
| P1OE | Data Address Enable |
| P2OE | Instruction Address Enable |
| P2LE | Invalidate Data Address Latch Enable |
| $\mathrm{RESET}_{1}$ | Data Cache Reset |
| $\overline{\text { RESET }}_{2}$ | Instruction Cache Reset |
| $\overline{W E}_{1-\overline{W E}_{4}}$ | Write Enables |
| $\overline{\mathrm{OE}}_{1} \overline{\mathrm{OE}}_{4}$ | Output Enables |
| GND | Ground |
| Vcc | Power Supply |

## NOTE:

1. For module dimensions, please refer to drawing M27 in the packaging section.

FUNCTIONAL BLOCK DIAGRAM
DATA CACHE


INSTRUCTION CACHE


## RECOMMENDED DC OPERATING

CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

1. $\mathrm{V}_{\mathrm{IL}}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## CAPACITANCE

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\operatorname{CIN}(\mathrm{D})$ | Input Capacitance (Data) | $\mathrm{VIN}=0 \mathrm{~V}$ | 20 | pF |
| $\mathrm{CIN}(\mathrm{A})$ | Input Capacitance (Address) | $\mathrm{VIN}=0 \mathrm{~V}$ | 40 | pF |
| $\mathrm{CIN}(\mathrm{C})$ | Input Capacitance ( $\overline{\mathrm{OE}}, \overline{\mathrm{WE}})$ | $\mathrm{VIN}=0 \mathrm{~V}$ | 50 | pF |
| $\mathrm{CIN}(\mathrm{C})$ | Input Capacitance ( $\overline{\mathrm{CS}}$ ) | $\mathrm{ViN}=0 \mathrm{~V}$ | 100 | pF |
| $\mathrm{CIN}(\mathrm{C})$ | Input Capacitance (LE, PxOE) | $\mathrm{VIN}=0 \mathrm{~V}$ | 30 | pF |
| Cout | Output Capacitance | Vout $=0 \mathrm{~V}$ | 20 | pF |

NOTE:

1. This parameter is guaranteed by design, but not tested.

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Value | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with Respect <br> to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -10 to +85 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output Current | 50 | mA |

NOTE:
2755 tbl 02

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

RECOMMENDED OPERATING
TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Amblent <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | OV | $5 \mathrm{~V} \pm 10 \%$ |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 10 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |

2755 to 06


FIgure 1. Output Load


FIgure 2. Output Load (for tolz and torz)

- Including scope and jig.


## DC ELECTRICAL CHARACTERISTICS

(VcC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 12MHz |  | 16.7 MHz |  | 20MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| \|lı| | Input Leakage | Vcc = Max., VIN = GND to Vcc | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage | $\begin{aligned} & V C C=\text { Max., } \overline{C S}=V_{I H}, \\ & \text { Vout }=\text { GND to } V C C \end{aligned}$ | - | 10 | - | 10 | - | 10 | $\mu \mathrm{A}$ |
| Icc1 | Operating Current | $\begin{array}{\|l} \hline f=0, \overline{C S}=V I L ; V C C=\text { Max., } \\ \text { Outputs Open } \\ \hline \end{array}$ | - | 2925 | - | 2925 | - | 2925 | mA |
| Icc2 | Dynamic Operating Current | $\begin{aligned} & \text { VCC }=\text { Max., } \overline{\mathrm{CS}}=\mathrm{V} \mathrm{VL} ; \mathrm{f}=\mathrm{fmAX}, \\ & \text { Outputs Open } \end{aligned}$ | - | 3850 | - | 3900 | - | 4150 | mA |
| ISB1 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}, \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 450 | - | 450 | - | 450 | mA |
| ISB | Standby Power Supply Current | $\begin{aligned} & \text { VCC = Max., } \overline{C S} \geq V \mathbb{V} ; f=f M A X, \\ & \text { Outputs Open } \end{aligned}$ | - | 1300 | - | 1425 | - | 1575 | mA |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | 2.4 | - | V |
| VoL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{IOL}=8 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | - | 0.4 | V |

NOTE:

1. Icci, IcC2 in the case for all devices selected (i.e. both instruction and data cache selected).

DC ELECTRICAL CHARACTERISTICS (Continued)
(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 25MHz |  | 33MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \|lu| | Input Leakage | Vcc = Max., VIN = GND to Vcc | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \|lıO| | Output Leakage | $\mathrm{VCC}=$ Max., $\overline{\mathrm{CS}}=\mathrm{VIH}, \mathrm{VOUT}=\mathrm{GND}$ to Vcc | - | 10 | - | 10 | $\mu \mathrm{A}$ |
| Icc1 | Operating Current | $f=0, \overline{C S}=$ VIL; Vcc $=$ Max., Outputs Open | - | 3400 | - | 3700 | mA |
| ICC2 | Dynamic Operating Current | $V C C=$ Max., $\overline{C S}=V_{1 L} ; f=f$ max, Outputs Open | - | 4675 | - | 4900 | mA |
| ISB1 | Full Standby Supply Current | $\overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}, \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V}$ or $\leq 0.2 \mathrm{~V}$ | - | 600 | - | 960 | mA |
| ISB | Standby Power Supply Current | VCC = Max., $\overline{\mathrm{CS}} \geq \mathrm{VIH} ; \mathrm{f}=\mathrm{fmAX}$, Outputs Open | - | 1700 | - | 2000 | mA |
| VOH | Output High Voltage | $\mathrm{VcC}=\mathrm{Min}$., $\mathrm{IOH}=-4 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |
| VoL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min} ., \mathrm{lOL}=8 \mathrm{~mA}$ | - | 0.4 | 一 | 0.4 | V |

## NOTE:

1. ${ }^{\circ} \mathrm{C} 1, \mathrm{I}_{\mathrm{C}} \mathrm{i}$ in the case for all devices selected (i.e. both instruction and data cache selected).

## AC ELECTRICAL CHARACTERISTICS

（ $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | 12MHz |  | 16.7 MHz |  | 20MHz |  | 25 MHz |  | 33MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． |  |
| READ CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tLE | Latch Enable Width | 6 | － | 6 | － | 6 | － | 6 | － | 6 | － | ns |
| tas | Address Setup Time to LE | 2 | － | 2 | － | 2 | － | 2 | － | 2 | － | ns |
| tah | Address Hold Time from LE | 1.5 | － | 1.5 | － | 1.5 | － | 1.5 | － | 1.5 | － | ns |
| tas ${ }^{(2)}$ | Address Access Time | － | 45 | － | 35 | － | 30 | － | 25 | － | 20 | ns |
| tacs | Chip Select Time | － | 40 | － | 30 | － | 25 | － | 20 | － | 15 | ns |
| tof ${ }^{(3)}$ | Output Enable to Output Valid | － | 22 | － | 17 | － | 11 | － | 8 | － | 5 | ns |
| torz ${ }^{(1)}$ | Output Disable to Output in High Z | 2 | 16 | 2 | 14 | 2 | 10 | 2 | 8 | 2 | 6 | ns |
| tolz ${ }^{(1)}$ | Output Enable to Output in Low Z | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |
| WRITE CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tLE | Latch Enable Width | 6 | － | 6 | － | 6 | － | 6 | － | 6 | － | ns |
| tas | Address Setup Time to LE | 2 | － | 2 | － | 2 | － | 2 | － | 2 | － | ns |
| tah | Address Hold Time to LE | 1.5 | － | 1.5 | － | 1.5 | － | 1.5 | － | 1.5 | － | ns |
| $\mathrm{taw}^{(2)}$ | Address Valid to End of Write | 40 | － | 30 | － | 25 | － | 23 | － | 20 | － | ns |
| tcw | Chip Select to End of Write | 35 | － | 25 | － | 20 | － | 18 | － | 15 | － | ns |
| twp | Write Pulse Width | 30 | － | 25 | － | 20 | － | 17 | － | 12 | － | ns |
| tDW | Data Valid to End of Write | 20 | － | 13 | － | 13 | － | 11 | － | 8 | － | ns |
| toh | Data Hold Time | 0 | － | 0 | － | 0 | － | 0 | － | 0 | － | ns |
| tLOE ${ }^{(4)}$ | Latch Output Enable | － | 7 | － | 7 | － | 7 | － | 7 | － | 7 | ns |
| RESET CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |
| tCLPW | RESET Pulse Width | 40 | 一 | 40 | － | 30 | 一 | 30 | － | 25 | － | ns |
| tCLRC | RESET High to WE4 Low | 5 | － | 5 | － | 5 | － | 5 | － | 5 | － | ns |

## NOTE：

1．This parameter is guaranteed by design，but not tested．
2．LE asserted．
3．$\overline{\mathrm{OE}}_{1}, \overline{\mathrm{OE}}_{2}, \overline{\mathrm{OE}}_{3}, \overline{\mathrm{OE}}_{4}$
4．P1OE1 and P2OE1．

## TIMING WAVEFORM OF READ CYCLE ${ }^{(1)}$



NOTE:

1. Assume $\overline{W E}$ is active high throughout this cycle.
2. This parameter is guaranteed by design but not tested.

TIMING WAVEFORM OF WRITE CYCLE


TIMING WAVEFORM OF RESET CYCLE


## ORDERING INFORMATION



## FEATURES:

- $16 \mathrm{~K} \times 32$ high-performance Writable Control Store (WCS)
- Serial Protocol Channel (SPCTM) -reading, writing and interrogation
- 4 byte/wide output enables
- Separate chip select, write enable and output enable memory controls
- High fanout pipeline register
- Fully width expandable
- Compact 64 -pin ceramic sidebraze DIP
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT7M6032 is a $16 \mathrm{~K} \times 32$-bit Writable Control Store (WCS) RAM and pipeline register. It features eight IDT7198 16K $\times 4$ high performance static RAMs and four IDT49FCT818 Serial Protocol Channel (SPC) registers. These devices are arranged to form the $16 \mathrm{~K} \times 32$ Writable Control Store RAM with Serial Protorol Channel for loading of the memory. The address lines, chip select, write enable and output enable of the RAMs are all bused together to form one large $16 \mathrm{~K} \times 32$ memory. Each eight Data V/Os of the RAM are connected to the D inputs of an IDT49FCT818. The device has the serial data-in and serial data-out bits connected to form a 32 -bit Serial Protocol Channel register. The module features four
separate output enables, one for each of the IDT49FCT818 registers. Thus, the $Y$ outputs from the IDT49FCT818 registers may be enabled or put into the high-impedance state on individual 8 -bit boundaries. The Command/Data (C/D), Serial Shift Clock (SCLK) and Parallel Clock (PCLK) are all bus organized across the four IDT49FCT818 registers. The thirty-two register output bits, eight from each device, are separately brought out to form a 32 -bit wide pipeline register on the Writable Control Store.

In normal operation, data from the 32-bit wide memory is loaded into the IDT49FCT818 registers on the low-io-high transition of PCLK. Reading and writing of the memory by means of the Serial Protocol Channel is performed using the IDT49FCT818. That is, the data to be loaded can be shifted in the serial data input by using the SCLK and a load command executed by shifting the proper command word in the serial data input when the $C / \bar{D}$ line is in the command mode. This command will then be executed by manipulating the $C / \bar{D}$ line and SCLK line. Data is then written into the RAM by bringing the write enable line on the RAM memory from the high state to the low state and back to the high state.

The IDT7M6032 is offered in a compact 64-pin 600 mil wide ceramic dual in-line module. It is constructed using ceramic LCC components on a multilayer co-fired ceramic substrate and occupies less than 2 square inches of board space.

The semiconductor components used on all IDT military modules are manufactured in compliance with the latest revision of MIL-STD-883, Class B, making them ideally suited to applications demanding the highest level of performance and reliability.


[^17]
## PIN CONFIGURATION ${ }^{(1)}$



NOTE:

1. For module dimensions, please refer to module drawing M17 in the packaging section.

## TRUTH TABLE

| Mode | $\overline{\mathbf{C}}$ | $\overline{\mathbf{O E}}$ | $\overline{\mathbf{W E}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Standby | H | H | X | High-Z | Standby |
| Standby | H | L | X | Dour | Standby |
| Read | L | L | H | Dour | Active |
| Read | L | H | H | High-Z | Active |
| Write | L | SPC $^{(1)}$ | L | SPC $^{(1)}$ | Active |

## NOTE:

2714 th 02

PIN NAMES

| Pin Name | I/O | Description |
| :--- | :---: | :--- |
| PCLK | I | Parallel Data Register Clock |
| Yo-31 | O | Parallel Data Register Output Pins (YO = LSB, <br> Y31 = MSB) |
| $\overline{\text { OEY }}$ | 1 | Output Enable for Y Bus (Overidden by SPC <br> Inst. 8 \&14) |
| SDI | I | Serial Data In for SPC Operation. Data and <br> command shifts in the Least Significant Bit first |
| SDO | O | Serial Data Out for SPC Operation. Data and <br> command shifts out the Least Significant Bit <br> first |
| C/D | I | Mode Control for SPC |
| SCLK | I | Serial Shift Clock for SPC Operations |
| $\overline{\mathrm{CS}}$ | I | RAM Chip Select |
| $\overline{\text { WE }}$ | I | RAM Write Enable |
| A0-13 | I | Address Bus Pins |
| $\overline{R O E}$ | I | Internal RAM Ouput Enable for D bus |

2714 bl 01

ABSOLUTE MAXIMUM RATINGS

| Symbol | Rating $^{(1)}$ | Commercial | Military | Unit |
| :--- | :--- | :---: | :---: | :---: |
| VTERM | Terminal Voltage <br> with Respect <br> to GND | -0.5 to +7.0 | -0.5 to +7.0 | V |
| TA | Operating <br> Temperature | 0 to +70 | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature <br> Under Bias | -55 to +125 | -65 to +135 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage <br> Temperature | -55 to +125 | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | 50 | 50 | mA |

NOTE:
2714 tol 03

1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

CAPACITANCE ( $\mathrm{TA}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditlons | Typ. | Unit |
| :--- | :--- | :--- | :---: | :---: |
| CIN | Input Capacitance | $\mathrm{VIN}=0 \mathrm{~V}$ | 15 | pF |
| $\mathrm{CIN}(\mathrm{C})$ | Input Capacitance <br> Address and Control | $\mathrm{VIN}=0 \mathrm{~V}$ | 60 | pF |
| CouT | Output Capacitance | Vout $=0 \mathrm{~V}$ | 10 | pF |

## NOTE:

1. This parameter is guaranteed by design, but not tested.
2. See SPC Commands for proper execution of write cycle.

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage | 4.5 | 5 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6 | V |
| VIL | Input Low Voltage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIL}=-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

DC ELECTRICAL CHARACTERISTICS
$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 25ns |  | 30ns |  | 35ns |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| \||Lإ| | Input Leakage Data Bus $\mu \mathrm{A}$ | $\mathrm{VcC}=$ Max., VIN = GND to Vcc | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \|liLo| | Output Leakage $\mu \mathrm{A}$ | $\begin{aligned} & V C C=M a x ., \overline{C S}=V I H, \\ & \text { Vout }=G N D \text { to } V c c \end{aligned}$ | - | 20 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| Icc1 | Operating Current mA | $\begin{aligned} & f=0, \overline{C S} \leq V I L, \\ & \text { Vcc }=\text { Max.; Outputs Open } \end{aligned}$ | - | 900 | - | 800 | - | 800 | mA |
| ICC2 | Dynamic Operating Current mA | $V C C=\text { Max., } \overline{\mathrm{CS}} \leq V_{I L} ; f=f M A x ;$ Outputs Open | - | 1200 | - | 1150 | - | 1050 | mA |
| ISB | Standby Supply Current mA | $\overline{\overline{C S}} \geq V_{I H}, f=f M A X,$ <br> Outputs Open | - | 450 | - | 450 | - | 450 | mA |
| ISB1 | Full Standby Supply Current mA | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VCC}-0.2 \mathrm{~V}, \\ & \mathrm{VIN} \geq \mathrm{VCC}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 125 | - | 125 | - | 125 | mA |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min}$., $\mathrm{IOH}=-15 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | 2.4 | - | V |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min}$., $\mathrm{loL}=32 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | - | 0.4 | V |

## DC ELECTRICAL CHARACTERISTICS (Continued)

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Test Conditions | 45ns |  | 55ns |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. |  |
| \| 1 LI| | Input Leakage Data Bus $\mu \mathrm{A}$ | $V C C=M a x ., V I N=$ GND to Vcc | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| \|lLO| | Output Leakage $\mu \mathrm{A}$ | $\begin{aligned} & \text { Vcc }=\text { Max. }, \overline{C S}=V I H, \\ & \text { Vout }=G N D \text { to } V c c \end{aligned}$ | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| Icct | Operating Current mA | $\begin{aligned} & f=0, \overline{C S} \leq V \mathrm{IL}, \\ & \mathrm{Vcc}=\text { Max.; Outputs Open } \end{aligned}$ | - | 800 | - | 800 | mA |
| ICC2 | Dynamic Operating Current mA | $\begin{aligned} & \text { VCC }=\text { Max., } \overline{\mathrm{CS}} \leq \text { VIL; } f=f \text { MAX; } \\ & \text { Outputs Open } \end{aligned}$ | - | 1050 | - | 1050 | mA |
| IsB | Standby Supply Current mA | $\overline{\mathrm{CS}} \geq \mathrm{VIH}^{\prime}, \mathrm{f}=\mathrm{f} \operatorname{MAX},$ <br> Outputs Open | - | 450 | - | 450 | mA |
| ISB1 | Full Standby Supply Current mA | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{Vcc}-0.2 \mathrm{~V}, \\ & \mathrm{VIN} \geq \mathrm{Vcc}-0.2 \mathrm{~V} \text { or } \leq 0.2 \mathrm{~V} \end{aligned}$ | - | 125 | - | 125 | mA |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min}$, $\mathrm{IOH}=-15 \mathrm{~mA}$ | 2.4 | - | 2.4 | - | V |
| Vol | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min}$., $\mathrm{lOL}=32 \mathrm{~mA}$ | - | 0.4 | - | 0.4 | V |

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |



Figure 1. Output Load


Figure 2. Output Load
(for tolz, tchz, tohz, twhz, and tow)

- Including scope and jig


## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol | Parameter | 25ns |  | 30ns |  | 35ns |  | 45ns |  | 55ns |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tac | Address Valid to PCLK | 25 | - | 30 | - | 35 | - | 45 | - | 55 | - | ns |
| tcs | $\overline{\text { CS Valid to PCLK }}$ | 25 | - | 30 | - | 35 | - | 45 | - | 55 | - | ns |
| toesu | $\overline{\text { ROE Valid to PCLK Set Up }}$ | 15 | - | 20 | - | 25 | - | 30 | - | 35 | - | ns |
| tPCY | $\overline{\text { PCLK }}$ to Output Valid | - | 13 | - | 13 | - | 16 | - | 16 | - | 16 | ns |
| toe | $\overline{\text { OE Valid to Output Valid }}$ | 2 | 13 | 2 | 13 | 2 | 16 | 2 | 16 | 2 | 16 | ns |
| torz ${ }^{(1)}$ | $\overline{\mathrm{OE}}$ Negated to Output in High Z | 2 | 12 | 2 | 12 | 2 | 12 | 2 | 12 | 2 | 12 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| taw | Address Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 45 | 二 | ns |
| tcw | $\overline{\mathrm{CS}}$ Valid to End of Write | 20 | - | 25 | - | 30 | - | 35 | - | 45 | - | ns |
| twp | Write Enable Pulse Width | 18 | - | 23 | - | 28 | - | 30 | - | 40 | - | ns |
| tWCD | Cont/Dat to End of Write | 22 | - | 25 | - | 28 | - | 30 | - | 35 | - | ns |
| tAS | Address Setup Time | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |

1. This parameter is guaranteed by design, but not tested.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


NOTES:
2714 drw 03

1. $\overline{W E}$ is high for Read Cycle.
2. Transition is measured $\pm 200 \mathrm{mV}$ from steady state. This parameter guaranteed by design, but not tested.
timing waveform of write cycle no. 1 ( $\overline{\text { WE CONTROLLED TIMING) })^{(1,2,4)}}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2 ( $\overline{\text { CS }}$ CONTROLLED TIMING) ${ }^{(1,2,3,4)}$


NOTES:

1. WE or $\overline{C S}$ must be high during all address transitions.
2. A write occurs during the overlap (twP) of a low $\overline{C S}$ and a low $\overline{W E}$.
3. If the $\overline{C S}$ low transition occurs simultaneously with or after the $\overline{W E}$ low transition, the outputs remain in a high impedance state.
4. $\overline{R O E}=V_{I H}$.

## AC ELECTRICAL CHARACTERISTICS (SPC TIMING)

(VCC $=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ and $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Symbol |  | Parameter | 25ns |  | 30ns |  | 35ns |  | 45ns |  | 55ns |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\begin{aligned} & \mathrm{tPLH} \\ & \mathrm{tPHL} \end{aligned}$ | T2 |  | SCLK High to SDO | - | 15 | - | 15 | - | 22 | - | 22 | - | 22 | ns |
|  | T3 | SDI to SDO (Stub Mode) | - | 45 | - | 45 | - | 45 | - | 45 | - | 45 | ns |
|  | T4 | C/D Low to Y | - | 15 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
|  | T5 | SCLK High to $Y$ | - | 15 | - | 15 | - | 25 | - | 25 | - | 25 | ns |
|  | T6 | C $\overline{\mathrm{D}}$ Low to SDO | - | 15 | - | 15 | - | 25 | - | 25 | - | 25 | ns |
| tsu | S2 | C/ $\overline{\mathrm{D}}$ to SCLK High | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | ns |
|  | S3 | SDI to SCLK High | 8 | - | 8 | - | 8 | - | 8 | - | 8 | - | ns |
|  | S4 | Y or D to C/D Low | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
|  | S5 | C $\overline{\mathrm{D}}$ to PCLK High | 12 | - | 12 | - | 12 | - | 12 | - | 12 | - | ns |
| $t \mathrm{H}$ | S6 | Y to PCLK High | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
|  | H2 | C/̄ from SCLK Low | 12 | - | 12 | - | 12 | - | 12 | - | 12 | - | ns |
|  | H3 | SDI from SCLK High | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
|  | H4 | Y or D from C/ $\bar{D}$ Low | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
|  | H5 | SCLK High from PCLK High | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
|  | H6 | $\mathrm{C} \overline{\mathrm{D}}$ from PCLK High | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
|  | H7 | Y from PCLK High | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| thz ${ }^{(1,2)}$ | 2z,4z | SCLK High to D or Y High Z | - | 15 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| tLz ${ }^{(1,2)}$ | $3 z, 5 z$ | $\mathrm{C} \overline{\mathrm{D}}$ High to D or Y High $Z$ | - | 15 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| tZHL ${ }^{(1,2)}$ | Z2,Z3 | $\mathrm{C} \overline{\mathrm{D}}$ Low to D or Y Valid 22, 23 | - | 15 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| tw | W1 | PCLK (High \& Low) | 10 | - | 10. | - | 15 | - | 15 | - | 15 | - | ns |
|  | W2 | SCLK (High \& Low) | 30 | - | 30 | - | 35 | - | 35 | - | 35 | - | ns |
|  | W3 | C $\overline{\mathrm{D}}$ High | 30 | - | 30 | - | 35 | - | 35 | - | 35 | - | ns |

## NOTE:

2714 tol 10

1. This parameter is guaranteed by design, but not tested.
2. $O E=V_{I H}$.

## GENERAL AC WAVEFORMS FOR PARALLEL INPUTS AND OUTPUTS



GENERAL AC WAVEFORMS FOR SERIAL PROTOCOL INPUTS AND OUTPUTS


## DETAILED WAVEFORMS OF SERIAL PROTOCOL OPERATIONS



PARALLEL DATA REGISTER $\rightarrow$ SPC Data (Inst.1)
SET SERIAL MODE (Inst. 11)
SET STUB MODE (Inst. 12)


2714 drw 11


SCP Data $\longrightarrow$ PARALLEL DATA REGISTER SYNCHRONOUS W/PCLK (Inst. 3)


## DETAILED FUNCTIONAL BLOCK DIAGRAM



The detailed block diagram consists of two main elements: the parallel data register and the SPC data/command registers. The main data path is from the $D$ inputs down to the data register and through to the Y outputs. This path is typically used during standard operations. For diagnostic or systems initialization, the internal SPC data path is used. This path allows access between the SPC data and command registers and the standard data path, pins and data register. The SPC data and command registers are accessed via the SDI, SDO, $C / \bar{D}$ and SCLK pins.


2714 drw 15

## SPC FUNCTIONAL DESCRIPTION

The Serial Protocol Channel (SPC) has been optimized for the minimum number of pins and the maximum flexibility. The data is passed in on a Serial Data Input pin (SDI) and out on a Serial Data Output pin (SDO). The transfer of the data is controlled by a Serial Clock (SCLK) and a Command/Data mode input (C/D). These four pins are the basic SPC pins. To the outside, the SPC appears as two serial shift registers in paralle-one for command and the other data. The serial clock shifts data and the Command/Data (C/D) line selects which register is being shifted. The command register is used
to control loading of data to and from the data register with other storage elements in the device.

With respect to executing anSPC command, there are four distinct phases: (1) data is shifted in, (2) followed by the command, (3) the command is executed, and (4) data is shifted out. During the data mode, data is simultaneously shifted into the serial data register while the data in the register is shifted out. During the command mode, opcode-type information is shifted through the serial ports. The command is executed when the last bit is shifted in and the $C / \bar{D}$ line is brought low. The execution phase is ended with the next serial clock edge.


SPC data and commands are shifted in through the SDI pin, which is a serial input pin, and out through the SDO pin, which is a serial output pin. Data and commands are shifted in Least Significant Bit first; Most Significant Bit last (Yo = LSB, $\mathrm{Y}_{15}=\mathrm{MSB}$ ). Execution of SPC commands is performed by stopping the shift clock SCLK, and lowering the C/D line from high-to-low. Later the SCLK may then be transitioned from low-to-high. SPC commands and data can be shifted anytime, without regard for operation. During the execution phase, care must be taken that there is no conflict between the SPC operation and parallel operation. This means that if the SPC operation attempts to load the parallel data register (opcode 10) while PCLK is in transition, the results are undefined. In general, it is required that the PCLK be static during SPC operations. The synchronous commands (opcode 3 and 13), however, allow the PCLK to run. In these operations, the high-to-low transition of the $C / \bar{D}$ line takes on the function of an arm signal in preparation for the next low-tohigh transition of the PCLK.

## SPC COMMANDS

There are 16 possible SPC opcodes. Fourteen of these are utilized, the other two are reserved and perform NO-OP functions. The top eight opcodes, 0 through 7 , are reserved for transferring data into the SPC data register for shifting out. The lower eight opcodes, 8 through 15, are used for transferring data from the SPC data register to other parts of the device. Two of the commands are also used for connecting the data in and out pins.

| OPCODE | SPC COMMAND |
| :---: | :--- |
| 0 | Y to SPC Data Register |
| 1 | Parallel Data Register to SPC Data Register |
| 2 | D to SPC Data Register |
| 3 | Y to SPC Data Register Synchronous w/PCLK |
| 4 | Status ( $\overline{\text { OEY, PCLK) to SPC Data Register }}$ |
| 5 | Connect Y to D |
| $6-7$ | Reserved (NO-OP) |
| 8 | SPC Data to Y ( $\overline{\text { OE }}$ is overidden) |
| 9 | SPC Data to D |
| 10 | SPC Data to Parallel Data Register |
| 11 | Select Serial Mode |
| 12 | Select Stub Mode |
| 13 | SPC Data to Parallel Data Register Synchronous <br> w/PCLK |
| 14 | Connect D to Y ( $\overline{O E}$ is overidden) |
| 15 | NO-OP |

Opcode 0 is used for transferring data from the Y output pins into the SPC data register. Opcode 1 transfers data from the output of the register, before the tri-state gate, into the SPC data register. Opcode 2 transfers data from the $D$ input pins into the SPC data register.


Opcode 3 transfers data on the Y pins to the SPC data register on the next PCLK, thus achieving a synchronous observation of the SPC data register in real time. This operation can be forced to repeat without shifting in a new command by pulsing C/D low-high-low after each PCLK. As soon as data is shifted out using SCLK, the command is terminated and must be loaded in again.
$Y \longrightarrow$ SPC Data Synchronous w/PCLK (Inst. 3)


Opcode 5 connects $Y$ to $D$. Opcodes 6 and 7 are reserved, hence designated NO-OP.


Opcode 8 is used for transferring SPC data directly to the $Y$ pins. When executing opcode 8, the state of $\overline{O E Y}$ is a "do not care"; that is, data will be output even if $\overline{\mathrm{OE}} \mathrm{Y}=\mathrm{HIGH}$. Opcode 9 is used tor transferring SPC data to the D pins. Operands 8 and 9 can be temporarily suspended by raising the $C / \bar{D}$ input and resumed by lowering the $C / \bar{D}$. As soon as SCLK completes transition, the command is terminated.


Opcode 10 is used tor transferring data from the SPC data register into the parallel data register, irrespective of the state of PCLK. However, PCLK must be static between C/D going high-to-low and SCLK going low-to-high.


Opcodes 11 and 12 are used to set Serial and Stub Mode, respectively. After executing one of these opcodes, the device remains in this mode until programmed otherwise. The Serial mode is the default mode that the IDT49FCT818 powers up in. In Serial mode, commands are shifted through the SPC command register and then to the SDO pin. This is the typical mode used when several varieties of devices that utilize the SPC access method are employed on one serial ring.

SERIAL MODE


In Stub mode, SDI is connected directly to SDO. In this way, the same diagnostic command can be loaded into multiple devices of like type. For example, in four clock cycles the same command could be loaded into 8 IDT49FCT818s (64-bit pipeline register). Dissimilar devices must be segregated into serial scan loops of similar type, as shown below. During the command phase, the serial shift clock must be slowed down to accommodate the delay from SDI to SDO through all of the devices. The slower clock is typically a small tradeoff compared to the reduced number of clock cycles.


Opcode 13 transfers data from the SPC data register to the parallel data register on the next PCLK. Opcode 14 connects the $D$ bus to the $Y$. Operation 14 can be temporarily suspended by raising the $C / \overline{\mathrm{D}}$ input and resumed by lowering the $\mathrm{C} / \overline{\mathrm{D}}$ input again. The operation is terminated by SCLK.


Connect D to Y (Inst. 14)


Opcodes 3 and 13 transfer data synchronous to the PCLK which means that the high-to-low on the $\mathrm{C} / \overline{\mathrm{D}}$ input is an arm signal. The data and command can be shifted in while the PCLK is running. The C/D line is dropped prior to the desired PCLK edge and raised before the next edge. Instruction 13 can be repeated over many times by leaving the $\mathrm{C} / \overline{\mathrm{D}}$ line low during multiple transitions of the PCLK while not clocking SCLK. PCLK cycles can even be skipped by raising the C/D input during the desired clock periods. Instruction 3 can be repeated by pulsing the $C / \bar{D}$ high after each PCLK.


The ability to continuously execute a synchronous command can provide major benefits. For example, the synchronous read (Instruction 3, Y to SPC data) instruction could be clocked into the SPC data register. Then, it could be continuously executed by pulsing the $C / \bar{D}$ line high. When the whole system is stopped (PCLK quiescent), the serial data register will contain the next to the last state of the parallel data register. That value can be shifted out and the current state of the parallel register can then be observed, allowing for the observation of two states of the parallel register (the current and the previous).

As companies like IDT continue to integrate more onto each device and put each device into smaller packages such as surface mount devices, the board level testing becomes more complex for the designer and the manufacturing divisions of companies. To help this situation, serial diagnostics was invented. This allows for observation of critical signals deep within the system. During system test when an error is observed, these signals may be modified in order to zero in on the fault in the system.

Serial diagnostics is primarily a scheme utilizing only a few pins (4) to examine and alter the internal state of a system for the purpose of monitoring and diagnosing systemfaults. It can be used at many points in the life of a product: design debug and verification, manufacturing test and field service. This document describes a serial diagnostic scheme which was developed at IDT and will be used in future VLSI logic devices designed by IDT.

## ORDERING INFORMATION



## WRITABLE CONTROL STORE STATIC RAM MODULE

## FEATURES:

- $8 \mathrm{~K} \times 112$ high-performance Writable Control Store (WCS)
- Serial Protocol Channel (SPC ${ }^{\text {TM }}$ )-reading, writing and interrogation
- High fanout pipeline register
- Width expandable
- Designed for high-speed writable control store applications
- Assembled with IDT's high-reliability vapor phase solder reflow process
- Compact quad in-line module
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The IDT7MB6042 is an $8 \mathrm{~K} \times 112$ Writable Control Store (WCS) RAM and pipeline register. It features fourteen $8 \mathrm{~K} \times 8$ IDT7164 high-performance static RAMs and fourteen IDT49FCT818 Serial ProtocolChannel (SPC) registers. These devices are arranged to form the $8 \mathrm{~K} \times 112$ Writable Serial Store RAM with Serial Protocol Channel for loading of the memory. Each eight outputs of the RAM are connected to the D inputs of an IDT49FCT818 in the normal fashion. The device has the serial data-in and serial data-output bits
connected to form a 112-bit Serial Protocol Channel register. The command/data (C/D) and Serial Shift Clock (SCLK) are all bus organized across the fourteen IDT49FCT818 registers. The 112 register output bits, 8 from each device, are separately brought out to form a 112 -bit wide pipeline register on the Writable Control Store.

In normal operation, data from the 112-bit wide memory is loaded into the IDT49FCT818 registers on the low-to-high transition of PCLK. Reading and writing of the memory by means of the Serial Protocol Channel are performed using the protocol of the IDT49FCT818. (For details of this operation, please refer to the IDT49FCT818 data sheet.) The data to be loaded can be shifted in the serial data input by using the SCLK and a load command executed by shifting the proper command word in the serial data input when the C/D line is in the command mode. This command will then be executed by manipulating the C/D line and SCLK line in the desired fashion. Data is then written into the RAM by bringing the write enable line on the RAM memory from the high state to the low state and back to the high state.

The IDT7MB6042 is offered as a compact, cost-effective FR-4 quad in-line module and occupies less than 9 squaro inches of board space.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION ${ }^{(1)}$

GND
A0

NOTE:

1. For module dimensions, please refer to drawing M31 in the packaging section.

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Symbol | Rating | Commercial | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage with <br> Respect to GND | -0.5 to +7.0 | V |
| TA | Operating Temperature | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| TBIAS | Temperature Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| TSTG | Storage Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| lout | DC Output Current | 50 | mA |

## NOTE:

1. Stresses greater than those listed under ABSOLUTE MAXIMUMRATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

## TRUTH TABLE

| Mode | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{WE}}$ | Output | Power |
| :--- | :---: | :---: | :---: | :--- | :--- |
| Standby | H | H | X | High Z | Standby |
| Standby | H | L | X | DouT | Standby |
| Read | L | L | H | Dour | Active |
| Read | L | H | H | High Z | Active |
| Write | L | SPC $^{(1)}$ | L | SPC $^{(1)}$ | Active | 2744 tbl 04

RECOMMENDED DC OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | 4.5 | 5.0 | 5.5 | V |
| GND | Ground | 0 | 0 | 0 | V |
| VIH | Input High Voltage | 2.2 | - | 6.0 | $V$ |
| VII | Input Low Voitage | $-0.5^{(1)}$ | - | 0.8 | V |

NOTE:

1. $\mathrm{VIL}(\min )=.-3.0 \mathrm{~V}$ for pulse width less than 20 ns .

## RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE

| Grade | Ambient <br> Temperature | GND | Vcc |
| :---: | :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 0 V | $5.0 \mathrm{~V} \pm 10 \%$ |

CAPACITANCE (TA $=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Typ. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| CiN(D) | Input Capacitance <br> Data | $\mathrm{VIN}=\mathrm{OV}$ | 10 | pF |
| CIN(A) | Input Capacitance <br> Address and Control | $\mathrm{ViN}=0 \mathrm{~V}$ | 120 | pF |
| Cout | Output Capacitance | VouT $=0 \mathrm{~V}$ | 10 | pF |

NOTE:

1. This parameter is sampled and not $100 \%$ tested.

## PIN DESCRIPTION

| Pin Name | VO | Description |
| :---: | :---: | :---: |
| PCLK | 1 | Parallel Data Register Clock |
| A0. 12 | 1 | Address Bus Pins ( $\mathrm{A}^{0}=\mathrm{LSB}, \mathrm{A}_{12}=\mathrm{MSB}$ ) |
| Y0-111 | 1/O | Parallel Data Register Output Pins ( $\mathrm{Y} 0=L \mathrm{LSB}, \mathrm{Y} 111=\mathrm{MSB}$ ) |
| OEY | 1 | Output Enable for Y Bus (Overidden by SPC Inst. 8 and 14) |
| SDI | 1 | Serial Data In for SPC Operation. Data and command shifts in the Least Significant Bit first |
| SDO | 0 | Serial Data Out for SPC Operation. Data and command shifts out the Least Significant Bit first |
| C/ $\bar{D}$ | 1 | Mode Control for SPC |
| SCLK | I | Serial Shift Clock for SPC Operations |
| $\overline{\mathrm{CS}}$ | 1 | Chip Select for lower order 56 bits (active low) |
| $\overline{\text { CS1 }}$ | 1 | Chip Select for upper order 56 bits (active low) |
| CS2 | 1 | Chip Select for all bits (active high) |
| WE | 1 | Internal RAM Write Enable |
| $\overline{\text { ROE }}$ | 1 | Internal RAM Output Enable |

## NOTE:

1. See SPC commands for proper execution of write cycle.

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | Test Conditions | Min． | Max． | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ｜lu｜ | Input Leakage <br> （Address and Control） | $\begin{aligned} & V C C=\text { Max. } \\ & \text { VIN = GND to VCC } \end{aligned}$ | － | 100 | $\mu \mathrm{A}$ |
| ｜｜LI｜ | Input Leakage （Data） | $\begin{aligned} & \text { VCC = Max } \\ & \text { VIN = GND to VCC } \end{aligned}$ | － | 15 | $\mu \mathrm{A}$ |
| ｜liol | Output Leakage | $\begin{aligned} & V C C=M a x . \\ & C S=V I H, V O U T=G N D \text { to } V c C \end{aligned}$ | － | 15 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathrm{VCC}=\mathrm{Min}$ ．， $\mathrm{IOL}=32 \mathrm{~mA}$ | － | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{VCC}=\mathrm{Min}$ ， $\mathrm{IOH}=-15 \mathrm{~mA}$ | 2.4 | － | V |
| ICC1 | Operating Current | $\begin{aligned} & f=0, \overline{\mathrm{CS}}=\mathrm{VII}, \mathrm{VcC}=\text { Max., } \\ & \text { Output Open } \end{aligned}$ | － | 1500 | mA |
| ICC2 | Dynamic Operating Current | $\begin{aligned} & \text { VCC }=\text { Max., } \overline{\mathrm{CS}}=\mathrm{VIL}, f=\mathrm{fmAX} \\ & \text { Output Open } \end{aligned}$ | － | 2380 | mA |
| IsB | Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq \mathrm{VIH}, \text { VCC = Max. } \\ & \mathrm{f}=\text { fmAX, Outputs Open } \end{aligned}$ | － | 560 | mA |
| Is81 | Full Standby Supply Current | $\begin{aligned} & \overline{\mathrm{CS}} \geq V C C-0.2 V, \\ & V I N>V C C-0.2 V \text { or }<0.2 V \end{aligned}$ | － | 280 | mA |

2744 tbl 07

## aC ELECTRICAL CHARACTERISTICS

（ $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ）

| Symbol | Parameter | 30ns |  | 35ns |  | 40ns |  | 50ns |  | 60ns |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． | Min． | Max． |  |
| Read Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| tac | Address Valid to PCLK Set Up | 30 | － | 35 | － | 40 | － | 50 | － | 60 | － | ns |
| tcs | $\overline{\mathrm{CS}}$ Valid to PCLK Set Up | 30 | － | 35 | － | 40 | － | 50 | － | 60 | － | ns |
| toesu | $\overline{\text { ROE }}$ Valid to PCLK Set Up | 17 | － | 20 | － | 25 | － | 30 | － | 35 | － | ns |
| tPCY | PCLK to Output Valid | － | 10 | － | 12 | － | 15 | － | 15 | － | 15 | ns |
| toe | $\overline{\text { OE Asserted to Output Valid }}$ | － | 10 | － | 12 | － | 15 | － | 15 | － | 15 | ns |
| tohz | $\overline{\mathrm{OE}}$ Negated to Output in High Z | － | 10 | － | 12 | － | 15 | － | 15 | － | 15 | ns |
| Write Cycle |  |  |  |  |  |  |  |  |  |  |  |  |
| taw | Address Valid to End of Write | 25 | － | 30 | － | 35 | － | 45 | － | 55 | － | ns |
| tcw | Address Valid to End of Write | 25 | － | 30 | 一 | 35 | 一 | 45 | － | 55 | － | ns |
| twp | Write Enable Pulse Width | 23 | 一 | 28 | － | 33 | － | 43 | － | 53 | － | ns |
| tWCD | Cont／Dat to End of Write | 23 | － | 28 | 一 | 30 | － | 35 | － | 40 | － | ns |
| tas | Address Setup Time | 0 | － | 0 | － | 2 | － | 2 | － | 2 | － | ns |

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
SPC TIMING

| Symbol |  | Parameter | 30ns |  | 35ns |  | 40ns |  | $50 \mathrm{~ns}$ |  | 60ns |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{tPLH} \\ & \mathrm{tPHL} \end{aligned}$ | T2 | SCLK High to SDO | - | 15 | - | 15 | - | 22 | - | 22 | - | 22 | ns |
|  | T3 | SDI to SDO (Stub Mode) | - | 210 | - | 210 | - | 310 | - | 310 | - | 310 | ns |
|  | T4 | $\mathrm{C} / \overline{\mathrm{D}}$ Low to Y | - | 15 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
|  | T5 | SCLK High to $Y$ | - | 15 | - | 15 | - | 22 | - | 22 | - | 22 | ns |
|  | T6 | C/D Low to SDO | - | 15 | - | 15 | - | 25 | - | 25 | - | 25 | ns |
| tsu | S2 | C/D to SCLK High | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | ns |
|  | S3 | SDI to SCLK High | 8 | - | 8 | - | 8 | - | 8 | - | 8 | - | ns |
|  | S4 | Y or D to C/D Low | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
|  | S5 | C/D to PCLK High | 12 | - | 12 | - | 12 | - | 12 | - | 12 | - | ns |
| th | S6 | $Y$ to PCLK High | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | ns |
|  | $\mathrm{H}_{2}$ | C/D from SCLK Low | 12 | - | 12 | - | 12 | - | 12 | - | 12 | - | ns |
|  | $\mathrm{H}_{3}$ | SDI from SCLK High | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
|  | $\mathrm{H}_{4}$ | Y or D to C/D Low | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
|  | H5 | SCLK High to PCLK High | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
|  | $\mathrm{H}_{6}$ | C/D from PCLK High | 2 | - | 2 | - | 2 | - | 2 | - | 2 | - | ns |
|  | H7 | Y from PCLK High | 3 | - | 3 | - | 3 | - | 3 | - | 3 | - | ns |
| thz ${ }^{(1,2)}$ | 2z, 4z | SCLK High to D or Y High Z | - | 15 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| tuz ${ }^{(1,2)}$ | 3z, 5z | C/D High to D or Y High Z | - | 15 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| tzHL ${ }^{(1,2)}$ | Z2, Z 3 | $\mathrm{C} / \overline{\mathrm{D}}$ Low to D or Y Valid | - | 15 | - | 15 | - | 20 | - | 20 | - | 20 | ns |
| tw | W1 | PCLK (High and Low) | 10 | - | 10 | - | 15 | - | 15 | - | 15 | - | ns |
|  | $\mathrm{W}_{2}$ | SCLK (High and Low) | 30 | - | 30 | - | 35 | - | 35 | - | 35 | - | ns |
|  | W3 | C/D High | 30 | - | 30 | - | 35 | - | 35 | - | 35 | - | ns |

## NOTES:

1. Guaranteed but not tested.
2. $\overline{\mathrm{OE}}=\mathrm{VIH}$.

TIMING WAVEFORM OF READ CYCLE NO. $1^{(1)}$


NOTES:

1. WE is High for Read Cycle.
2. Transition is measured $\pm 200 \mathrm{mV}$ from steady state.

TIMING WAVEFORM OF WRITE CYCLE NO. 1, ( $\overline{\mathrm{WE}}$ CONTROLLED TIMING) $)^{(1,2,3,5)}$


TIMING WAVEFORM OF WRITE CYCLE NO. 2, ( $\overline{C S}$ CONTROLLED TIMING) ${ }^{(1,2,3,4,5)}$


NOTES:

1. WE or $\overline{C S}$ must be high during all address transitions.
2. A write occurs during the overlap (tWP) of a low $\overline{C S}$ and a low $\overline{W E}$.
3. twR is measured fromt he earlier of $\overline{C S}$ or $\overline{W E}$ going high to the end of the write cycle.
4. If the $\overline{\mathrm{CS}}$ low transition occurs simultaneously with or after the $\overline{\mathrm{WE}}$ low transition, the outputs remain in the high impedance state.
5. tROE $=\mathrm{V}_{\mathrm{IH}}$.

## GENERAL AC WAVE FORM FOR PARALLEL INPUTS AND OUTPUTS



2744 drw 06

## GENERAL AC WAVE FORM FOR SERIAL PROTOCOL INPUTS AND OUTPUTS



## DETAILED AC WAVE FORM OF SERIAL PROTOCOL OPERATIONS





2744 drw 09

2744 drw 08

$\mathrm{Y} \longrightarrow$ SPC Data SYNCHRONOUS W/PCLK (Inst. 3)



2744 drw 11


2744 drw 13

## DETAILED FUNCTIONAL BLOCK DIAGRAM



The detailed block diagram consists of two main elements: the parallel data register and the SPC data/command registers. The main data path is from the D inputs down to the data register and through to the Y outputs. This path is typically used during standard operations. For diagnostic or system initialization, the internal SPC data path is used. This path allows access between the SPC data and command registers and the standard data path, pins and data register. The SPC data and command registers are accessed via the SDI, SDO, $\mathrm{C} / \overline{\mathrm{D}}$ and SCLK pins.


2744 drw 15

## SPC FUNCTION DESCRIPTION

The Serial Protocol Channel (SPC) has been optimized for the minimum number of pins and the maximum flexibility. The data is passed in on a Serial Data Input pin (SDI) and out on a Serial Data Output pin (SDO). The transfer of the data is controlled by a Serial Clock (SCLK) and a Command/Data mode input (C/D $)$. These four pins are the basic SPC pins. To the outside, the SPC appears as two serial shift registers in paralle-one for command and the other data. The serial clock shifts data and the Command/Data ( $C / \overline{\mathrm{D}}$ ) line selects
which register is being shifted. The command register is used to control loading of data to and from the data register with other storage elements in the device.

With respect to executing an SPC command, there are four distinct phases: (1) data is shifted in, (2) followed by the command, (3) the command is executed, and (4) data is shifted out. During the data mode, data is simultaneously shifted into the serial data register while the data in the register is shifted out. During the command mode, opcode-type information is shifted through the serial ports. The command is executed when the last bit is shifted in and the $C / \bar{D}$ line is broughtlow. The execution phase is ended with the next serial clock edge.


SPC data and commands are shifted in through the SDI pin, which is a serial input pin, and out through the SDO pin, which is a serial output pin. Data and commands are shifted in Least Significant Bit first; Most Significant Bit last (Yo = LSB, Y15 = MSB). Execution of the SPC commands is performed by stopping the shift clock, SCLK, and lowering the C/D line from high-to-low. Later the SCLK may then be transitioned from low-to-high. SPC commands and data canbe shifted anytime, without regard for operation. During the execution phase, care must be taken that there is no conflict between the SPC operation nad parallel operation. This means that if the SPC operation attempts to load the parallel data register (opcode 10) while PCLK is in transition, the results are undefined. In general, it is required that the PCLK be static during SPC operations. The synchronous commands (opcode 3 and 13), however, allow the PCLK to run. In these operations, the high-to-low transition of the C/D line takes on the function of an arm signal in preparation for the next low-to-high transition of the PCLK.

## SPC COMMANDS

There are 16 possible SPC opcodes. Fourteen of these are utilized, the other two are reserved and perform NO-OP functions. The top eight opcodes, 0 through 7, are reserved for transferring data into the SPC data register for shifting out. The lower eight opcodes, 8 through 15, are used for transferring data from the SPC data register to other parts of the device. Two of the commands are also used for connecting the data in and out pins.

| Opcode | SPC Command |
| :---: | :--- |
| 0 | Y to SPC Data Register |
| 1 | Parallel Data Register to SPC Data Register |
| 2 | D to SPC Data Register |
| 3 | Y to SPC Data Register Synchronous w/ PCLK |
| 4 | Status ( $\overline{\text { OEY }, ~ P C L K) ~ t o ~ S P C ~ D a t a ~ R e g i s t e r ~}$ |
| 5 | Connect Y to D |
| $6-7$ | Reserved (NO-OP) |
| 8 | SPC Data to Y $\overline{\text { OE }}$ is overidden) |
| 9 | SPC Data to D |
| 10 | SPC Data to Parallel Data Register |
| 11 | Select Serial Mode |
| 12 | Select Stub Mode |
| 13 | SPC Data to Parallel Data Register <br> Synchronous w/ PCLK |
| 14 | Connect D to Y ( $\overline{\text { OE is overidden) }}$ |
| 15 | NO-OP |

2744 th 10

Opcode 0 is used for transferring data from the Y output pins into the SPC data register. Opcode 1 transfers data from the output of the register, before the tri-state gate, into the SPC data register. Opcode 2 transfers data from the $D$ input pins into the SPC data register.


2744 drw 18


Opcode 3 transfers data on the Y pins to the SPC data register on the next PCLK, thus achieving a synchronous observation of the SPC data register in real time. This operation can be forced to repeat without shifting in a new command by pulsing C/D low-high-low after each PCLK. As soon as data is shifted out using SCLK, the command is terminated and must be loaded in again.


Opcode 4 is used for loading status into the SPC data register. The format of bits is shown below.


2744 dw 21


Opcode 5 connects $Y$ to D. Opcodes 6 and 7 are reserved, hence designated NO-OP.


2744 drw 24

Opcode 8 is used for transferring SPC data directly to the Y pins. When executing opcode 8, the state of OEY is a "do not care"; that is, data will be output even if $\overline{O E Y}=$ HIGH. Opcode 9 is used for transferring SPC data to the D pins. Operands 8 and 9 can be temporarily suspended by raising the $C / \bar{D}$ input and resumed by lowering the $C / \bar{D}$. As soon as SCLK completes transition, the command is terminated.


Opcode 10 is used for transferring data from the SPC data register into the parallel data register, irrespective of the state of PCLK. However, PCLK must be static between C/ $\overline{\mathrm{D}}$ going high-to-low and SCLK going low-to-high.


2744 drw 26

Opcode 11 and 12 are used to set Serial and Stub Mode, respectively. Atter executing one of these opcodes, the device remains in this mode until programmed otherwise. The Serial mode is the default mode that the IDT49FCT818 powers up in. In Serial mode, commands are shifted through the SPC command register and then to the SDO pin. This is the typical mode used when several varieties of devices that utilize the SPC access method are employed on one serial ring.


In Stub mode, SDI is connected directly to SDO. In this way, the same diagnostic command can be loaded into multiple devices of like type. For example, in four clock cycles the same command could be loaded into 8 IDT49FCT818s (64-bit pipeline register). Dissimilar devices must be segregated into serial scan loops of similar type, as shown below. During the command phase, the serial shift clock must be slowed down to accommodate the delay from SDI to SDO through all of the devices. The slower clock is typically a small tradeoff compared to the reduced number of clock cycles.


2744 dw 28

Opcode 13 transfers data from the SPC data register to the parallel data register on the next PCLK. Opcode 14 connects the Dbus to the $Y$. Operation 14 can be temporarily suspended by raising the $C / \bar{D}$ input and resumed by lowering the $C / \bar{D}$ input again. The operation is terminated by SCLK.


Opcode 3 and 13 transfer data synchronous to the PCLK which means that the high-to-low on the $C / \bar{D}$ input is an arm signal. The data and command can be shifted in while the PCLK is running. The C/ $\bar{D}$ line is dropped prior to the desired PCLK edge and raised before the next edge. Instruction 13 can be repeated over many times by leaving the $C / \bar{D}$ line low during multiple transitions of the PCLK while not clocking SCLK. PCLK cycles can even be skipped by raising the $C / \bar{D}$ input during the desired clock periods. Instruction 3 can be repeated by pulsing the $\mathrm{C} / \overline{\mathrm{D}}$ high after each PCLK.


The ability to continuously execute a synchronous command can provide major benefits. For example, the synchronous read (Instruction 3, Y to SPC data) instruction could be clocked into the SPC data register. Then, it could be continuously executed by pulsing the $\mathrm{C} / \overline{\mathrm{D}}$ line high. When the whole system is stopped (PCLK quiescent), the serial data register will contain the next to the last state of the parallel data register. That value can be shifted out and the current state of the parallel register can then be observed, allowing for the observation of two states of the parallel register (the current and the previous).

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | :---: |
| Input Rise/Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figures 1 and 2 |




2744 dw 32
ORDERING INFORMATION


THE SUBSYSTEM'S "FLEXI-PAK" CMOS MODULE FAMILY

## ADVANCE INFORMATION

SRAM, EPROM, \& EEPROM MODULES

## FEATURES:

- High-density modules using high-speed CMOS SRAM, EPROM, and EEPROM components.
- Inter-changeable modules, with equivalent footprints, support a wide range of applications
- Fast access times:

SRAM: 30ns (max.) - military
25ns (max.) - commercial
EEPROM: 95ns (max.) - military
75ns (max.) - commercial
EPROM: 150ns (max.) - military 120ns (max.) - commercial

- Low power CMOS operation
- Surface mounted LCC components on a co-fired ceramic substrate
- Offered in a 66-pin, ceramic "PGA-type" HIP (Hex In-line Package). occupying only 1 sq. inch of board space
- Single 5V ( $\pm 10 \%$ ) power supply
- Multiple ground pins for maximum noise immunity
- Inputs and outputs directly TTL-compatible


## DESCRIPTION:

The Flexi-Pak family of modules are high-speed, highdensity CMOS memory modules constructed on a multilayer co-fired ceramic substrate using either SRAM, EPROM, or EEPROM components in leadless chip carriers.

This family of IDT modules support applications requiring stand alone static or programmable memory, or those applications needing a combination of both. All module configurations in this family have equivalent footprints, allowing "plugin compatibility" with each other (i.e. interchangeable), ideal for a wide range of prototype and debugging applications.

The Flexi-Pak family utilizes the fastest commercial grade and MIL-STD-883, Class B military grade components, giving you the highest performance available anywhere. CMOS technology offers a low-cost, low-power alternative to bipolar and fast NMOS memories.

All versions of the Flexi-Pak module family are offered in a 66-pin, ceramic HIP (Hex In-line Package). This HIP package is similar to a PGA and allows the designer to fit into 1 sq. inch of board space.

All IDT military modules are assembled with semiconductor components compliant with the latest revision of MIL-STD883, Class B. Additional testing and burn-in when assembled into a module, make them ideally suited to applications demanding the highest level of performance and reliability.

## ORGANIZATIONS

SRAM: IDT7M4003-128K x 8, 64K x 16, 32K x 32 IDT7M4013-512K x 8, 256K x 16, 128K x 32

EEPROM: IDT7M7004-128K x 8, 64K x 16, 32K x 32 IDT7M7014-512K x 8, 256K x 16, 128K x 32

SRAM / EPROM: IDT7M7012-64K $\times 8 / 64 \mathrm{~K} \times 8$ $64 \mathrm{~K} \times 8 / 32 \mathrm{~K} \times 16$ $32 \mathrm{~K} \times 16 / 64 \mathrm{~K} \times 8$ $32 \mathrm{~K} \times 16 / 32 \mathrm{~K} \times 16$
IDT7M7002 - 64K x $8 / 256 \mathrm{~K} \times 8$ $64 \mathrm{~K} \times 8 / 128 \mathrm{~K} \times 16$ 32K x 16 / 256K x 8 $32 \mathrm{~K} \times 16 / 128 \mathrm{~K} \times 16$
IDT7M7022-256K x $8 / 256 \mathrm{~K} \times 8$ $256 \mathrm{~K} \times 8 / 128 \mathrm{~K} \times 16$ $128 \mathrm{~K} \times 16 / 256 \mathrm{~K} \times 8$ 128K x 16/128K x 6
IDT7M7032-256K x $8 / 64 \mathrm{~K} \times 8$ $256 \mathrm{~K} \times 8 / 32 \mathrm{~K} \times 16$
$128 \mathrm{~K} \times 16 / 64 \mathrm{~K} \times 8$
$128 \mathrm{~K} \times 16 / 32 \times 16$


As the largest supplier of military and commercial modules, IDT Subsystems would like to take this opportunity to discuss an exciting phase of our business: the custom module. To facilitate your understanding of our procedures, we have attached several documents which should prove helpful. These are:
I. Custom Module Flowchart
II. Specification Approval Form
III. Custom Module Terms and Conditions
IV. Mini spec example
V. Design Guidelines (refer to Application Note AN-44)
VI. Custom Module Product Proposals

The Custom Module Flowchart outlines the documentation flow while the Custom Module terms and conditions are an addendum to our standard terms and conditions found on IDT quote forms. Also included is an example of a "mini spec" which is a datasheet-like spec for custom modules. An appli-
cations note on design guidelines is included in this databook (refer to AN-44) which is useful for preliminary custom module analysis. Finally, we have included several examples of IDT generated module product proposals. These one page proposals are used to help stimulate design ideas of custom modules for various system applications, i.e. cache, DSP, or data buffering.

Additional information concerning Subsystems quality and reliability can be found in our IDT Quality Conformance Program brochure available at any of our IDT Sales Offices worldwide.

IDT has a highly trained staff of Field Sales and Application Engineers, as well as a factory design team to assist you in obtaining the optimal solution for your system requirements.

If any questions arise or further information is needed, please contact your IDT sales representative.

## I. CUSTOM MODULE FLOWCHART

The purpose of this flowchart is to show how a module evolves from an idea into a finished product.


* For several examples of IDT Subsystems Product Proposals, please refer to Section VI of this application note.


## II. SPECIFICATION APPROVAL FORM


antegrated device technology SUBSYSTEMS DIVISION

SPECIFICATION APPROVAL FORM

DATE: 05/09/89

| CUSTOMER | COMPANY XX |
| :--- | :--- |
| PART NUMBER $\quad$ IDT7MB4009S25P |  |

PLEASE FIND ATTACHED THE FOLLOWING DOCUMENTS:

1. PACKAGE DIMENSIONS - REV. 00
2. AC/DC PARAMETERS - REV. 01
3. SCHEMATIC - REV. 00
4. PIN OUT - REV. 00
5. IDT TERMS AND CONDITIONS

REVIEW THE ABOVE SPECIFICATIONS. YOUR SIGNATURE BELOW INDICATES ACCEPTANCE OF THE SPECIFICATIONS LISTED ABOVE. PLEASE RETURN THIS FORM TO YOUR IDT SALESPERSON OR REPRESENTATIVE.

SIGNATURE: $\qquad$
TITLE: $\qquad$
DATE: $\qquad$

## III. CUSTOM MODULE TERMS AND CONDITIONS

## Custom Module <br> Terms and Condlitions Addendum

These terms and conditions are addition to the standard Integrated Device Technology terms and conditions of Sale.

1. Ownership
a. Integrated Device Technology, Inc. will own all equipment and tooling manufactured in order to build the required module regardless of any NRE or set-up charges paid by Buyer unless specifically agreed to in writing.
b. Integrated Device Technology, Inc. reserves the right to market the custom module as a standard product any time unless otherwise specifically agreed to in writing.
2. Cancellations and Reschedules
a. In the event that Buyer wishes to cancel all or part of an order, or change the scope of an order, the termination or change will be accepted only with the specific approval of Integrated Device Technology in writing.
b. In the event that a cancellation or reschedule occurs prior to the shipment of prototypes, the Buyer will be liable for all or part of the tooling and set-up charges associated with producing the custom module.
c. Integrated Device Technology must be notified 90 days in advance of shipment of modules for any rescheduling or cancellations.
3. Specifications

All specifications of prototypes and subsequent shipments will be agreed to in writing by Integrated Device Technology and the Buyer by:
a. A customer specification formally reviewed and accepted by Integrated Device Technology without exception; or
b. A specification generated by Integrated Device Technology which the Buyer agrees to in writing.

## IV. MINI SPEC EXAMPLE

The following documents are examples of the items found in the IDT custom module mini-spec: pin out, electrical characteristics, package dimensions, schematic, and terms and conditions.

## PIN CONFIGURATION



2807 dw 02

2807 drw 03


DATE: 05/27/88

DC ELECTRICAL CHARACTERISTICS

| Symbol | Parameter | Test Conditlons | Min. | Max. |
| :---: | :---: | :---: | :---: | :---: |
| \|LILA| | Input Leakage (Addr \& Control) | $\begin{array}{\|l\|} \hline V C C=M A X \\ V I N=G N D \text { to } V C C \\ \hline \end{array}$ | - | 40uA |
| \|LLO| | Output Leakage (Data) | $V c c=M A X$ $\overline{\mathrm{CS}}=\mathrm{VIH}$, Vout $=$ GND to Vcc | - | 10uA |
| ICC1 | Operating Current | $\mathrm{f}=\mathrm{O} \quad \overline{\mathrm{CS}} \leq \mathrm{VIL}$ $\mathrm{VCC}=\mathrm{MAX} ;$ Output Open | - | 620 mA |
| ICC2 | Dynamic Operating Current | $\begin{aligned} & \text { VCC=MAX; } \\ & \mathrm{CS} \leq \text { VIL; f=fMAX } \\ & \text { Output Open } \end{aligned}$ | - | 760 mA |
| ISB | Standby <br> Supply Current | $\begin{aligned} & \text { VcC=MAX; } \overline{\mathrm{CS}} \geq \mathrm{VIH} \\ & \text { f=fMAX } \\ & \text { Outputs Open } \\ & \hline \end{aligned}$ | - | 440 mA |
| ISB1 | Full Standby Supply Current | $\overline{\mathrm{CS}} \geq$ Vcc-0.2V VIN>VcC-0.2 or $<0.2 \mathrm{~V}$ | - | 120 mA |
| loL | Output Low Current | Vcc=MIN VoL=0.4 | 8 mA | - |
| IOH | Output High Current | $\mathrm{VCC}=\mathrm{MIN} \mathrm{VOH}=2.4$ | - | $-4 \mathrm{~mA}$ |
| \|ILIId | Input Leakage (Data) | $\begin{aligned} & \text { VcC=MAX } \\ & \text { VIN=GND to Vcc } \end{aligned}$ | - | 10uA |

AC ELECTRICAL CHARACTERISTICS

| Read Cycle (nS) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | Min. |  |  |  | Max. |  |  |  |
| TRC | 25 | - | TWC | 20 | - |  |  |  |  |  |  |  |  |  |
| TAA | - | 25 | TCW | 20 | - |  |  |  |  |  |  |  |  |  |
| TACS | - | 25 | TAW | 21 | - |  |  |  |  |  |  |  |  |  |
| TOE | - | 15 | TAS | 1 | - |  |  |  |  |  |  |  |  |  |
| TOH | 5 | - | TWP | 20 | - |  |  |  |  |  |  |  |  |  |
| TPU | 0 | - | TWR | 0 | - |  |  |  |  |  |  |  |  |  |
| TPD | - | 20 | TDW | 13 | - |  |  |  |  |  |  |  |  |  |
|  |  |  | TDH | 0 | - |  |  |  |  |  |  |  |  |  |

TRISTATE PARAMETERS

| Min. Max. |  |  |  |  | Min. |  |  | Max. |
| :--- | :---: | :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| TCLZ | 5 | - | TOHZ | - | 15 |  |  |  |
| TCHZ | - | 12 | TWHZ | - | 7 |  |  |  |
| TOLZ | 5 | - | TOW | 5 | - |  |  |  |

COMMENTS:

2807 tbl 02
8


## V. DESIGN GUIDELINES

Please reter to Application Note AN-44 for a more detailed look at custom module design guidelines.

## VI. IDT APPLICATION SPECIFIC CONCEPTS (PRODUCT PROPOSALS)

This section includes a number of product proposals which not only demonstrate IDT's applications abilities, but also how
those abilities can be used to solve real engineering problems. The concept of translating a customer's unique memory intensive building block becomes reality by using the Subsystem Division's engineering expertise. Use this section as a guide to better understand if IDT's custom module capabilities may be appropriately utilized in your application.

## 16 BYTE INSTRUCTION/16K BYTE DATA CACHE MODULE FOR THE IDT79R3000 CPU

## PRODUCT PROPOSAL IDT7MB6074

## FEATURES:

- Family member in a group of pin compatible high speed CMOS static RAM modules to support the IDT79R3000 RISC CPU
- Organized as a 16 K byte instruction and 16 K byte data cache
- Operating frequencies to support $12 \mathrm{MHz}, 16.7 \mathrm{MHz}$, 20 MHz , and 25 MHz IDT79R3000
- Available in a high-density, low profile 160 pin PIP (Pent In-line Package)
- Surface mounted plastic components on an FR-4 substrate
- On-chip address latches for direct interface to the IDT79R3000 CPU
- Inputs/outputs directly TTL compatible
- Single 5V ( $\pm 10 \%$ ) power supply
- Multiple ground pins for maximum noise immunity


## FUNCTIONAL BLOCK DIAGRAM

instruction cache



CEMOS is a tradernark of Integrated Device Technology, Incorporated

## DESCRIPTION:

The IDT7MB6074 is a dual-banked 16 K byte instruction cache and 16K byte data cache for the IDT79R3000 CPU. The IDT7MB6074 uses 8 IDT71586 ( $4 \mathrm{~K} \times 16$ ) high speed CMOS latched static RAMs on a multilayer epoxy laminate substrate (FR-4). Extremely high speeds are achieved using IDT's high performance, high reliability CEMOS ${ }^{\text {TM }}$ technology. The construction and specifications of this module have been optimized to suport its use as a complete instruction and data cache for the MIPS R3000 (RISC CPU).

The IDT7MB6074 is organized as two separate banks of static RAM with on-chipaddress latches. The two banks share a common 12-bit address bus and a common 64 -bit data bus. The chip slect, write enable, RAM output enable and latch enable controls for the two banks are brought out separately to support interleaved access.

This module is designed to facilitate the implementation of the highest performance caches for the IDT79R3000 architecture while consuming minimum board space. As part of a family of pin compatible caches, the IDT7MB6074 provides the optimum solution for customers requiring a 16 K byte instruction cache and a 16 K byte data cache.

The pent in-line package (PIP) configuration allows 160 leads to be placed in five rows on a horizontal mount package 3.5 inches long, 1.4 inches wide and 350 mils tall. All inputs and outputs of the IDT7MB6074 are TTL compatible and operate from a single 5 V power supply.

## PIN NAMES

| Do $-\mathrm{D}_{63}$ | Data Inputs/Outputs |
| :--- | :--- |
| $\mathrm{Ao}_{1}-\mathrm{A}_{11}$ | Addresses |
| $\overline{\mathrm{CS}} 1-\overline{\mathrm{CS}} 8$ | Chip Selects |
| $\overline{W E}_{1}-\overline{\mathrm{WE}}_{8}$ | Write Enables |
| $\overline{\mathrm{OE}}_{1}-\overline{\mathrm{OE}}_{8}$ | Output Enable |
| $\mathrm{LE} 1-\mathrm{LE} 4$ | Latch Enables |
| Vcc | Power Supply |
| GND | Ground |



## 128K BYTE SECONDARY CACHE MODULE FOR THE $\mathbf{~} 486^{\text {TM }}$ MICROPROCESSOR

## PRODUCT PROPOSAL IDT7MP6086

## FEATURES:

- High density 128 K byte direct mapped secondary cache module
- Family member of pin compatible i486 cache modules
- Uses the IDT71589 32K $\times 9$ CacheRAM ${ }^{\text {TM }}$ with burst counter and self-timed write
- Matches all timing and signals of the i486 processor
- Operates with $\mathbf{i} 486$ speeds of up to 40 MHz
- 72 lead FR-4 SIMM (single in-line memory module)
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs/outputs directly TTL compatible
- Multiple ground pins for maximum noise immunity


## PIN CONFIGURATION



CacheRAM, CEMOS is a trademark of Integrated Device Technology, Incorporated i486 is a trademark of Intel Corporation

## DESCRIPTION:

The IDT7MP6086 is a 128 K byte direct mapped secondary cache module.The IDT7MB6086 uses 4 IDT71589 32K $\times 9$ CacheRAMs in plastic surface mount packages mounted on a multilayer epoxy laminate (FR-4) substrate. Extremely high speeds are achieved using IDT's high performance, high reliability CEMOS ${ }^{\text {TM }}$ technology. This module is designed to facilitate the implementation of the highest performance secondary caches for the i486 architecture while using low speed logic devices and consuming minimum board space.

The IDT7MP6086 data RAMs contain a full set of write data and address registers. These registers are combined with the internal write abort logic to allow the processor to generate a self-timed write based upon a decision which can be left until the end of the write cycle.

An internal burst address counter accepts the first cycle address from the processor and then cycles through the adjacent four locations using the i486's burst refill sequence on appropriate rising edges of the system clock.

Three program identification pins are provided so that the system can uniquely identify the IDT7MP6086.

The single in-line package configuration allows 72 leads to be placed on a package 4.0 inches long, 0.55 inches tall and 0.25 inches thick. The IDT7MP6086 is available to interface with a 40 MHz i486. All inputs and outputs of the IDT7MP6086 are TTL compatible and operate from a single 5 V power supply.

FUNCTIONAL BLOCK DIAGRAM


2807 drw 07

## PIN NAMES

| Do - D35 | Data Inputs/Outputs |  |
| :---: | :---: | :---: |
| A0-A14 | Address |  |
| $\overline{\mathrm{CS}}$ | Data RAM Chip Select |  |
| WE0- ${ }^{\text {WE }} 3$ | Data RAM Byte Write Enables |  |
| $\overline{O E}$ | Data RAM Output Enable |  |
| CLK | Processor Clock |  |
| $\overline{\text { ADS }}$ | Address Strobe |  |
| PD0 - PD2 | Program Identification |  |
| Vcc | Power |  |
| GND | Ground | 2807 tol 04 |

## PROGRAM I.D. TABLE

| PDo | Cache Size | GND $=128 \mathrm{~KB}$ |
| :--- | :--- | :--- |
|  |  | $\mathrm{NC}=$ No Cache |
| PD1 | Wait States | $\mathrm{GND}=0$ |
|  |  | $\mathrm{NC}=1$ |
| PD2 | Processor Speed | $\mathrm{GND}=33 \mathrm{MHz}$ |
|  |  | $\mathrm{NC}=40 \mathrm{MHz}$ |

NOTE:

1. NC = No Connect.


Integrated Device Technology, Inc.

128K BYTE SECONDARY CACHE MODULE FOR THE $\mathbf{~} 486^{\text {™ }}$ MICROPROCESSOR

PRODUCT
PROPOSAL IDT7MP6089

## FEATURES:

- High density 128 K byte direct mapped secondary cache module with tag and validity RAM
- Family member of pin compatible i486 cache modules
- Uses the IDT71589 32K $\times 9$ CacheRAM ${ }^{T M}$ with burst counter and self-timed write and IDT6178 4 Kx 4 cache tag RAM
- Matches all timing and signals of the i486 processor
- Operates with i486 speeds of up to 40 MHz
- 110 lead FR-4 ZIP (zig-zag in-line memory module)
- Single 5 V ( $\pm 10 \%$ ) power supply
- Inputs/outputs directly TTL compatible
- Multiple ground pins for maximum noise immunity


## FUNCTIONAL BLOCK DIAGRAM



## DESCRIPTION:

The IDT7MP6086, a 128 K byte direct mapped secondary cache module with tag and validity RAM, is a family member of pin compatible i486 cache modules. The IDT7MB6089 uses 4 IDT71589 32K x 9 CacheRAMs, 10 IDT6178 $4 \mathrm{~K} \times 4$ cache-tag/resettable RAMs, and logic in plastic surface mount packages all mounted on a multilayer epoxy laminate (FR-4) substrate. Extremely high speeds are achieved using IDT's high performance, high reliability CEMOS ${ }^{\text {TM }}$ technology. This module is designed to facilitate the implementation of the highest performance secondary caches for the i486 architecture while using low speed programmable logic devices and consuming minimum board space.

The IDT7MP6089 data RAMs contain a full set of write data and address registers. These registers are combined with the internal write abort logic to allow the processor to generate a self-timed write based upon a decision which can be left until the end of the write cycle. An internal burst address counter accepts the first cycle address from the processor and then cycles through the adjacent four locations using the i486's burst refill sequence on appropriate rising edges of the system clock.

The IDT6178s provide the system with several tag and valid controls for further flexibility in cache operation.

The zig-zag in-line package configuration allows 110 leads to be placed on a package 5.65 inches long, 0.50 inches tall and 0.35 inches thick. The IDT7MP6089 is available to interface with a 40 MHz i486. All inputs and outputs of the IDT7MP6089 are TTL compatible and operate from a single 5 V power supply.

## PIN NAMES

| Do-35 | Data Inputs/Outputs |
| :--- | :--- |
| $\frac{\mathrm{A} 2-31}{\overline{\mathrm{CS}}}$ | Address |
| $\overline{\mathrm{BWE}} 0-3$ | Data RAM Chip Select |
| $\overline{\mathrm{OE}}$ | Data RAM Byte Write Enable |
| $\overline{\mathrm{TWE}} 0-1$ | Data RAM Output Enable |
| $\overline{\mathrm{TOE}} 0-1$ | Tag RAM Write Enable |
| CLK | Tag RAM Output Enable |
| $\overline{\mathrm{MATCH}} 0-1$ | Processor Clock |
| $\overline{\mathrm{CLR}}$ | Tag RAM Match |
| $\overline{\mathrm{VD}} 0-3$ | Valid RAM Clear |
| $\overline{\mathrm{VOE}} 0-1$ | Valid Data |
| $\overline{\mathrm{VWE}} 0-1$ | Valid Output Enable |
| ADS | Valid Write Enable |
| VCC | Address Strobe |
| GND | Power |

2807 tbl 05

CacheRAM, CEMOS is a trademark of Integrated Device Technology, Incorporated 1486 is a trademark ol Intel Corporation

64K BYTE CACHE MODULE FOR THE MC68030 MICROPROCESSOR

## PRODUCT PROPOSAL IDT7MP6030

## FEATURES:

- High density 64 K byte unified cache data and tag module
- 50 MHz MC 68030 operation
- 64K bytes with 16 byte line size
$-16 \mathrm{~K} \times 32$ data cache
- $4 \mathrm{~K} \times 16 \mathrm{tag}$ RAM
$-4 \mathrm{~K} \times 4$ validity RAM
- Write through architecture
- Matches all timing and signals of the MC68030 microprocessor
- Cache coherency/shared memory supported through MC68030 local bus arbitration
- 90 lead FR-4 ZIP (zig-zag in-line package)
- Single 5 V ( $\pm 10 \%$ ) power supply
- Inputs/outputs directly TTL compatible
- Multiple ground pins for maximum noise immunity


## FUNCTIONAL BLOCK DIAGRAM



## DESCRIPTION:

The MC68030 can achieve its maximum potential through the use of a zero wait state cache memory, especially when running at speeds of at least 33MHz. The IDT7MP6030 is a fully integrated 64 K byte direct mapped unified cache with tag and validity RAM. A 16 byte line size dictates a 4 K deep cachetag. The validity RAM contains the valid/invalid state of each of the four longwords within the selected cache line.

A direct mapped cache is used because the higher cache bandwidth more than compensates for a slightly lower hit rate compared with an n-way set associative cache. Hit/miss logic is left off board in order to give the designer maximum freedom in the implementation. A detailed timing analysis for the IDT7MP6030 is provided in IDT Application Note AN-46.

The IDT7MP6030 uses 8IDT6198 16K $\times 4$ static RAMs and 5 IDT6178 4 Kx 4 cache tag RAMs in plastic SOJ packages mounted on a multilayer epoxy laminate (FR-4) substrate. Extremely high speeds are achieved using IDT's high performance, high reliability CEMOS $^{\text {TM }}$ technology.

ThE IDT7MP6030 is designed to facilitate the implementation of the highest performance secondary caches for the MC68030 architecture while consuming minimum board space. The vertical zig-zag in-line configuration allows 90 leads to be placed on a package 5.3 inches long, 0.5 inches tall and 0.35 inches thick. All inputs and outputs of the IDT7MP6030 are TTL compatible and operate from a single 5 V power supply.

## PIN NAMES

| Do-31 | Data Inputs/Outputs |  |
| :---: | :---: | :---: |
| A0-31 | Address |  |
| $\overline{\mathrm{CS}}$ | Data RAM Chip Select |  |
| WE0-3 | Data RAM Byte Write Enable |  |
| $\overline{\mathrm{OE}}$ | Data RAM Output Enable |  |
| TWE | Tag RAM Write Enable |  |
| TOE | Tag RAM Output Enable |  |
| $\overline{\text { MATCH }}$ - 3 | Tag RAM Match |  |
| $\overline{\text { CLR }}$ | Valid RAM Clear |  |
| $\overline{\mathrm{VD}} \mathrm{O}^{-3}$ | Valid Data |  |
| $\overline{\text { VOE }}$ | Valid Output Enable |  |
| VWE | Valid Write Enable |  |
| Vcc | Power |  |
| GND | Ground |  |



## FEATURES:

- High density 64 K byte cache with tag
- Low profile 90 pin ZIP (zig-zag in-line vertical package)
- Fast access time: 15ns (max.)
- Surface mounted plastic components on an epoxy laminate (FR-4) substrate
- Single $5 \mathrm{~V}( \pm 10 \%)$ power supply
- Inputs/outputs directly TTL compatible
- Multiple ground pins for maximum noise immunity


## DESCRIPTION:

The IDT7MP6059 is a 64 K byte cache module constructed on an epoxy laminate (FR-4) substrate using 8 IDT6198 16K $\times 4$ static RAMs and 5 IDT6178 4Kx4 cache tag RAMs in plastic SOJpackages. Extremely high speeds canbe achieved due to the use of static RAMs fabricated in IDT's high performance, high reliability CEMOS ${ }^{\text {TM }}$ technology. The IDTMP6059 is available with access times as fast as 15 ns with minimal power consumption.

The IDT7MP family of ZIPs, DSIPs and SIPs offers the optimum in packing density and profile height. The IDT7MP6059 is packaged in a 90 pin FR-4 ZIP (zig-zag in-line vertical package). The dual row configuration allows 90 pins to be placed on a package 4.7 inches long and 0.35 inches wide. At only 0.50 inches high, this low profile package is ideal for systems with minimum board spacing.

All inputs and outputs of the IDT7MP6059 are TTL compatible and operate from a single 5 V supply. Full asynchronous circuitry requires no clocks or refresh for operation and provides equal access and cycle times for ease of use.

FUNCTIONAL BLOCK DIAGRAM


2807 drw 10

## PIN CONFIGURATION



## PIN NAMES

| $/ / O 0-31$ | Data Inputs/Outputs |  |
| :--- | :--- | :--- |
| $\frac{A 0-13}{}$ | Address |  |
| CS | Chip Select |  |
| WE0-3 | Write Enables |  |
| $\overline{O E}$ | Output Enable |  |
| CLK | Processor Clock |  |
| TAGWE | Tag Write Enable |  |
| TAGCS | Tag Chip Select |  |
| Vcc | Power |  |
| GND | Ground | 2807 tol 07 |


| Integrated Device Technology, Inc. | 16-BIT FOUR-PORT RAM-BASED MATRIX MULTIPLICATION ENGINE MODULE | PRODUCT PROPOSAL IDT7M900V |
| :---: | :---: | :---: |

## FEATURES:

- Complete matrix multiplication engine building block
- Extremely high performance:

Commercial- 30ns clock cycle time (max.)
Military - 40ns clock cycle time (max.)

- Independerit computational operations and I/O access
- 128 pin quad in-line module package (QIP)
- Semiconductor components manufactured using IDT's high performance CEMOSTM technology
- Modules available with semiconductor components compliant to MIL-STD-883, Class B


## DESCRIPTION:

Matrix multiplication is one of the most often used operations in DSP algorithms. In addition, matrix multiplication is the basic operation at the heart of computer graphics. For example, changing the position, orientation and size of objects in a drawing requires a geometrical transformation which is generally represented by a series of matrix multiplications. In high performance systems, a matrix multiplication engine
(MME) such as the IDT7M900V is necessary to facilitate the operation.

The IDT7M900V consists of 2 IDT7052 $2 \mathrm{~K} \times 8$ four-port RAMs, one IDT7210 $16 \times 16$-bit multiplier-accumulator, and four IDT7383 16-bit ALUs surface mounted on a co-fired ceramic substrate configured as a 128 pin quad in-line module package. With the IDT7052 four-port SRAM, system designers can considerably improve the performance and simplify the implementation of an MME versus a conventional singleport RAM implementation. The IDT7210 can do either multiply or multiply-accumulate function. Operands at I/O ports are all 16-bit, but 32-bit precision is preserved at internal computation. A mode control pin allows user to select data format as two's complement or unsigned number. All the iniernal registers can be clocked to provide pipelined architecture, in which multiplication results are generated every clock cycle.

All inputs and outputs of the IDT7MP6030 are TTL compatible and operate from a single 5 V power supply. All IDT military module semiconductor components are compliant to the latest revision of MIL-STD-883, Class B, making them ideally suited for applications demanding the highest level of performance and reliability.

## PIN NAMES

| Do -15 | I/O Databus |
| :--- | :--- |
| CLK | Clock |
| AC0-47 | Address Generator Controls |
| F0-15 | Address Generator Flags |
| RCo-15 | Four-port RAM Control |
| MC0-10 | Multiplier-Accumulator Control |
| VcC | Power |
| GND | Ground |

## BLOCK DIAGRAM



2807 drw 12


## FEATURES:

- First-In/First-Out memory module
- Asynchronous and simultaneous read and write
- Configurable as $8 \mathrm{~K} \times 36$ or $16 \mathrm{~K} \times 18$ unidirectional or 8 K $\times 18$ bidirectional FIFO
- Multiple status flags: Full, Empty
- Ultra-high-speed: 40ns access time
- Fully expandable by both word depth and/or bit width
- Dual-port zero fall-through time architecture
- Available in high-density 108 -pin quad in-line FR-4 package


## DESCRIPTION:

The IDT7MB2001 is a FIFO module that consists of eight IDT72041s ( $4 \mathrm{~K} \times 9$ ). The IDT72041 is a dual-ported memory
that utilizes a special first-in/first-out algorithm that loads and empties data on a first-in/first-out basis.

The IDT7MB2001 is user-configurable in three modes:

- An 8K x unidirectional FIFO, or
- A 16K $\times 18$ unidirectional FIFO, or
- An $8 \mathrm{~K} \times 18$ bidirectional FIFO.

In all three modes, the module offers two flags, Full and Empty, to prevent data overflow and underflow. Expansion logic of the IDT72041s allows wider and/ordeeper FIFOs to be created using multiple devices without external logic.

The module also allows asynchronous and simultaneous read and write operations. The dual-port RAM array allows zero fall-through time and a ninth bit is provided for every byte to store parity.

Access time is as fast as 40 ns . The module is offered in a high-density 108 -pin quad in-line package.

## FUNCTIONAL BLOCK DIAGRAM



2807 drw 13

## FUNCTIONAL BLOCK DIAGRAM (Continued)

$8 \mathrm{~K} \times 36$

$16 \mathrm{~K} \times 18$


## $8 \mathrm{~K} \times 18$ BIFIFO



2807 drw 14


## FEATURES:

- First-In/First-Out memory module
- Asynchronous and simultaneous read and write
- 36-bit data bus on one side; 9-bit data bus on other side
- All logic required for conversion between 36- and 9-bit buses included on board
- $4 \mathrm{~K} \times 36$-bit to $16 \mathrm{~K} \times 9$-bit deep
- Selectable LSB or MSB first on 9-bit side
- Bidirectional
- Latching transceiver for LS 8 bits between the two buses
- Total cycle time 45ns


## DESCRIPTION:

This module is a FIFO that has upt to 8 IDT72041s ( $4 \mathrm{~K} \times 9$ ) on board. The module is bidirectional with $4 \mathrm{~K} \times 36$ transforming to $16 \mathrm{~K} \times 9$ on one side andback to $4 \mathrm{~K} \times 36$ on the other side. All logic necessary to control the conversion between 36 and 9 bits is included on the module.

On the 9-bit side, there is a DIRN pin which determines whether the 36 bits of data is presented to the 9 -bit side's most significant byte first or least significant byte first and, conversely, whether the 9-bit side data is being entered MSB or LSB first.

Included on-board is an 8-bit transceiver with separate latch enables for each side to allow the passing of status between the buses.

Access time is as fast as 40 ns . The module is offered in a high-density 108 -pin quad in-line package.

## FUNCTIONAL BLOCK DIAGRAM



## CENETAL MEORMATION

## TECHMOLOGY AND CAPABHLTIES

OUALITY AND RELABBLITY

## PACRAGE DACRAMOUTLINES

ECLPRODUCTS

FHO PRODLCTS

SPECALTY NEWORY PRODUCTS

SUBSYSTENSPROLUCTS

## TABLE OF CONTENTS

## PAGE

APPLICATION AND TECHNICAL NOTES
FIFO Products Application Notes
AN-01 Understanding the IDT7201/7202 FIFO ..... 9.1
AN-15 Using the IDT72103/104 Serial-Parallel FIFO ..... 9.2
AN-22 Performance Advantages with IDT's Flagged FIFOs ..... 9.3
AN-34 General Purpose ( 16 -Bit to 8 -Bit) BiFIFO Interface ..... 9.4
AN-36 The BiFIFO Parity Generation and Checking ..... 9.5
AN-39 The Programmable Flags of BiFIFOs ..... 9.6
AN-56 The BiFIFO Expansion Configuration ..... 9.7
AN-57 The BiFIFO Bypass ..... 9.8
AN-60 Designing with the IDT SyncFIFO™ - The Architecture of the Future ..... 9.9
AN-69 Depth Expansion of IDT's Synchronous FIFOs Using the Ring Counter Approach ..... 9.10
AN-71 Simplify SCSI Host Adapter Design with Bidirectional FIFO Memories ..... 9.11
AN-73 Understanding the Output Control $\overline{\mathrm{OE}}$ of the Flagged FIFOs:
IDT72021/31/41 ..... 9.12
FIFO Products Technical Notes
TN-06 Designing with FIFOs ..... 9.13
TN-08 Operating FIFOs on Full and Empty Boundary Conditions ..... 9.14
TN-09 Cascading FIFOs or FIFO Modules ..... 9.15
Specialty Memory Products Application Notes
AN-02 Dual-Port RAMs Simplify Communication in Computer Systems ..... 9.16
AN-09 Dual-Port RAMs Yield Bit-Slice Designs without Microcode ..... 9.17
AN-14 Dual-Port RAMs with Semaphore Arbitration ..... 9.18
AN-42 Using the IDT7052 FourPort ${ }^{\text {TM }}$ SRAM ..... 9.19
AN-43 IDT FourPort ${ }^{\text {™ }}$ RAM Facilitates Multiprocessor Designs ..... 9.20
AN-45 Introduction to IDT's FourPort ${ }^{\text {TM }}$ RAM ..... 9.21
AN-59 Using IDT7024 and IDT7025 Dual-Port Static RAMs to Match System Bus Widths ..... 9.22
AN-67 Using IDT71502 RAMs in a Real-Time Debugging Tool for an R3000 Microprocessor-based System ..... 9.23
AN-68 Dual-Port RAM Simplifies PC to TMS320 Interface ..... 9.24
AN-70 Dual-Port Interrupt Expansion ..... 9.25
Subsystems Products Application Notes
AN-44 Design Guidelines for Custom Module Packages ..... 9.26
AN-74 Understanding Dual-Port Shared Memory Modules ..... 9.27
AN-75 Using the IDT7M4017 in an 8-Bit and 16-Bit Wide Organization ..... 9.28
AN-76 Using the IDT7MB6049 Cache Module with the IDT79R3000 RISC Processor in Single or Multiprocessor Systems ..... 9.29

UNDERSTANDING THE IDT7201/7202 FIFO

APPLICATION
NOTE
AN-01

## INTRODUCTION

This article discusses several different types of FIFOqueues, their implementation, their performance and their use. Data, or information in computers, is processed as words or bytes in a predominantly serial fashion. There are producers and consumers of information that are connected by busses. Often there is a mismatch in the rate at which data is produced and the rate at which it can be accepted. The data is therefore buffered in serial lists until it can be used. The serial lists are stored in memory and require overhead to maintain them. These First-In-First-Out (FIFO) structures can be implemented at many levels from all software to all hardware. The software implementations are often the most flexible but yield the lowest performance. The hardware implementations, while less flexible, give the highest performance.

## QUEUES

The elements of any computer or controller can be divided into three categories in relation to information: transformation, storage and transfer. Logic gates transform and combine information, memory elements store information and wires transfer information between the other elements.

Memory can be viewed as an element which transfers information with respect to time. The simplest of memory elements are latches and registers. RAMs are dense arrays of latches. While RAMs allow for dense information storage, they require an address to access individual pieces of information in the array. Therefore, addresses (information) must be generated and stored in order to access the desired information. The addresses are stored in programs and data structures such as linked lists.

Queues are a special organization of dense arrays of latches. Queues are a linearorganization of groups of latches. Access to the linear string is restricted to either end. While RAMs allow for random access of any data in the array at any point in time, they require address inputs. Queues on the other hand, don't have an address thus avoiding the address generation and storage overhead. Queues can be divided into two categories: FIFOs and LIFOs.

Queues can be observed in the world about us. FIFO is an acronym for "First-In-First-Out". They can be observed in a bank line-up where customers enter at the end of a line, and after some wait, are serviced at the other end. The FIFO queue provides a mechanism by which customers which arrive at an erratic rate can wait until a teller can accommodate them.

LIFO is an acronymfor "Last-In-First-Out". We can observe this phenomenon in the work place. As a person is working at a desk, interrupts occur. A higher priority interrupt such as a phone callor a request from people higher in management will cause the person to drop the work on the desk and start a new
by Michael J. Miller
task. When the higher priority task is accomplished, the interrupted task on the desk is resumed. Depending on how many interrupts of sequentially higher priority tasks come in during the day, the stack of tasks on the desk grows. Another time honored example is the stacks of trays at the cafeteria. As trays are washed they are placed on a spring loaded elevator which sinks down to accommodate the new trays. When new customers enter the food line, trays are removed from the stack.

As can be seen in the above examples, queues are used to buffer between the flows of consumers and distributors of services. Groups of computing elements can be divided into consumers and producers of information with rates that must be matched. For example, a rotating Winchester disk is a source of information that must be serviced at a rate that may not be easily matched by the CPU which is consuming the information through the use of a data bus.

## SIMPLE FIFO

The implementation of FIFOs is varied and presents many trade-offs. The simplest design treats the FIFO as a fixed number of memory elements in a linear array. When data is


Figure 1. Hardware Implementation of a Fixed Length FIFO
written (pushed) in at one end, all of the rest of the elements shift their data over to their neighbor at the same time. One can visualize (Figure 1) the structure as a shift register. The same structure can be implemented in software where the program manages an array of memory locations in RAM. To push data into the queue the program must first start by moving the contents of the next to the last location into the last location. The algorithm continues from the last to the first location. When all of the data has been rippled down, the first location in the queue will be vacated. The data to be pushed into the queue is written into that vacated location.

An improvement in the software solution could be made with the introduction of a pointer. A pointer is a variable which contains an address. The pointer would identify a location from which to read the output of the FIFO. When a new piece of information is written, it would go into the location identified by the pointer after which the pointer would be incremented. The pointer now points at the new output data. When the pointer reaches the end of the array, the next increment would be replaced by setting the pointer to the beginning of the array. The obvious advantage is that the program does less work and therefore is faster. This software technique is called a circular queue with one pointer. (See Figure 2.)

## FIXED LENGTH FIFO: NO FALL-THROUGH

The FIFO described previously is called a Fixed Length FIFO and has the characteristic that it takes N cycles for a piece of information that was placed into it to emerge out of it. The number N is the number of locations in the FIFO. This implementation also has the characteristic, that when first started after power up, it will produce unknown data for N cycles until the first valid data arrives at the output. The latency is therefore $\mathrm{N} \mathrm{read/write} \mathrm{cycles}$. not allow for differences between the rate of input and output rates. This type of FIFO is used where the arrival of data at the output is delayed to match parallel paths in a pipelined system.

## VARIABLE LENGTH FIFO

The variable length FIFO solves the rate mismatch problem, but requires more overhead to implement. Where the

(a)


Figure 2. Circular Queue with One Pointer a) as it Is in memory
b) logical view
fixed length FIFO is like a steel pipe which information is fed through and has a fixed number of locations, the variable length FIFO is like a rubber hose that can stretch, holding from one to many items. The items are removed at will instead of being required to at write time. Every variable length system has a limit and therefore must signal when it is at capacity and must be serviced before bursting.

## FALL-THROUGH FIFOS

In the real world of silicon and aluminum there is no such thing as rubber. Variable length FIFOs must therefore be implemented using fixed length queues. This fact creates some limitations which translate into trade-offs. The traditional hardware implementation uses two sets of shift registers. One set is used to hold the data in much the same way as in the fixed length FIFO. Data that is placed in the top emerges at the bottom. There is a second shift register that functions in parallel. The second shift register contains flags that indicate whether the associated data element at the same chronological position in the data queue is valid data or not. When data is written into the top location of the data queue, a true flag is placed into the "valid bit" queue. The variable length quality is achieved by allowing the data and its associated valid bit to "sink down" into the next location below it if there is no valid data in that location (see Figure 3). In this way valid data "sinks" to the bottom of the queue and stacks up in much the same way as pearls being dropped into a narrow tube tilled


Figure 3. Classical FIFO Architecture
with oil. The clocking of data down through the queue is controlled by an internal self-generated clock. The maximum latency or fall-through time is a product of the number of cells in the queue and the internal clock cycle length. This approach meets the requirement that differing rates may be accommodated. The valid bit data is brought out in parallel with the queue data. The valid bit data tells the consumer when valid data is present, thus avoiding the start-up period of invalid data as in the previous implementation of the fixed length FIFO. Examples of this approach are the shorter FIFOs such as the MMI67401. Fall-through FIFOs tend to have very long undesirable fall-through times if the FIFO is deep.

The software approach could be designed to mirror the typical hardware approach by working with two arrays. One for the data and one of the valid bits. That approach uses too


Figure 4. Circular Queue with Two Pointers
a) as It is In memory
b) logical view


2813 drw 05
much memory. An alternate could use a wider array which carried the valid bit with the data. The algorithm would then start at the end of the array and pass to the front, advancing all elements which were valid to the end of the array until all valid data was collected at the end of the array. This approach would be very costly in terms of CPU cycles for what is achieved. There is a fall-through latency which is a product of the time to execute the updated software loop times the number of locations in the queue.

## TWO-POINTER FIFO

A more economical approach would utilize two pointers and one array that was as wide as the data. One pointerwould point to the location at which new data is written into. The second pointer identifies where data is to be read from for output from the queue (see Figure 4). When either pointer is used to access a location, it is incremented. When a pointer is incremented to the last location in the array, the next increment will be substituted with a reset of the pointer to the beginning of the array. The logical view of this structure is a circular queue with a read and a write pointer. This approach results in a much shorter fall-through time while still achieving the variable length feature. The fall-through time is the time that it takes to invoke the software to write the data into the queue, plus the time that it takes to invoke the software to read the data out of the queue. While this is much better than the previous approach, it still requires a reasonable amount of time to accomplish.

## TODAY'S HIGH SPEED FIFOS

The hardware approach, which is used by the IDT7201 and IDT7202 devices, utilizes the software concepts demonstrated in the previous approach but at very fast hardware speeds (50ns typical military). The block diagram in Figure 5 shows the two pointers which locate where reading and writing is to take place in the queue (RAM Array). There is added logic which provides status about the queue: empty ( $\overline{\mathrm{EF}}$ ) half full ( $\overline{\mathrm{HF}}$ ) and full ( $\overline{\mathrm{FF}}$ ) ( means an active LOW signal). Two pins, one input $(\overline{\mathrm{I}})$ and one output ( $\overline{\mathrm{XO}}$ ) provide for unlimited expansion while still maintaining the 50 ns fallthrough time. This part functions identically to the software approachutilizing the two pointers. When either pointer reaches the last location, it is reset to the first location, thus achieving a circular queue via a wraparound approach. The status flags reflect the count of how many valid pieces of data are in the queue. After the device is reset, the empty flag ( $\overline{E F}$ ) is asserted. As soon as a datum is written into the queue, the empty flag is deasserted. The empty flag is not asserted again until all pieces of data have been read from the queue. When the count of data elements reaches one-half the number of locations in the RAM array, the half full flag ( $\overline{\mathrm{FF}}$ ) is asserted. If a read is performed which reduces the count to just below the half way count, then the ( $\overline{\mathrm{HF}}$ ) is deactivated. The full flag is asserted when the count of data elements is exactly equal to the number of locations in the RAM array, thus flagging that there are no more empty locations in the queue.

Figure 5. Functional Block Dlagram of IDT7201/7202 FIFO

## WIDER FIFOS

Applications may vary widely as to the width and depth of the FIFO required. If an application's maximum requirement is 1024 locations or less and 9 bits in width or less, then the IDT7202 will fit. Wider word widths can be achieved by connecting two or more devices in parallel (control signals). The status flags can be detected from any one device because
each device is working in lock step parallel. Figure 6 shows an example of an 18 bit-word composed of two IDT7201/7202 devices. The older classical architecture would require more external circuitry to match the Input Ready and Output Ready signals to account for differences in the internal self-generated clock frequencies. RAM-based FIFOs, such as the IDT7201/7202, do not have this problem.


Figure 6. IDT7201/7202 FIFO Word-Width Expansion


Flgure 7. IDT7201/7202 FIFO Word-Depth Expansion

## DEEPER FIFOS

Some applications require deeper FIFOs. In the older architecture, deeper FIFOs mean longer fall-through times because they are connected end to end. The time increases in direct proportion to the number of devices. For example two devices yield a maximumfall-through time of twice that of one device. This can make some applications of FIFOs impractical or totally unuseable.

With the two pointer approach used in the IDT7201/7202, the data input busses are connected together and the data output busses are common. This produces a parallel architecture (see Figure 7) as opposed to the serial approach above. The parallel structure is analogous to cascading standard RAM devices to achieve deeper memories.

Since FIFOs do not have chip selects and external decoding mechanisms, the task of choosing which device is selected must be provided for internally. The control (in the IDT7201/7202) is achieved through a unique serial structure. The first (or master) FIFO is identified by grounding the $\overline{F L}$ input. All other FIFOs in the structure must have the FL input
pulled up to $\mathrm{V}_{\mathrm{cc}}$. The $\overline{\mathrm{XO}}$ output of the first FIFO is connected to the $\overline{X I}$ input on the next FIFO in the queue. The $\overline{X O}$ output of that FIFO is connected to the $\overline{X I}$ input of the next and so on until the $\overline{X O}$ output of the last FIFO is connected to the $\overline{\mathrm{XI}}$ input of the first FIFO (see Figure 7).

After reset, the active read and write pointers are in the first device. When the write pointer has progressed to the end of the first FIFO device, it outputs a pulse on $\overline{X O}$ which activates the write pointer at the beginning of the next device and simultaneously deactivates the write pointer in the first device. Thus, write enable control is passed to the second device. When the active read pointer reaches the end of the first device, it terminates and activates the read pointer in the next device with another pulse on the $\overline{X O}$ output of the first device. Figure 8 shows the progression of read and write pointers across two devices. In this ring structure, the read pointer is always chasing the write pointer. The pointer enable crosses the device boundaries via sending an $\overline{X O}$ pulse onto the next device. This continues in a circular queue fashion.


Figure 8. Example on $\overline{\mathrm{XO}} / \overline{\mathrm{XI}}$ Expansion Scheme

The IDT7201/7202 has been designed such that the read and write pointer can never cross over each other even in the cascade mode. The XO pulse is synchronous with read and write. When the last location is read or written, the $\overline{\mathrm{XO}}$ output goes low with the read or write enable input and back high with the read or write enable. To see why there is no conflict even though reads and writes are asynchronous, the usage must be examined. The case of concern is when the FIFO is empty and the read and write pointers are at the last location. It must be realized that the consumer will not read until the empty flag is deasserted. The empty flag output will go high after the write pulse has gone high again thus ensuring that the $\overline{X O}$ pulse, indicating the write pointer, has been passed on to the next device. The consumer will then read the last location causing
another pulse on $\overline{\mathrm{XO}}$ which will transfer the read pointer (see Figure 9).

There is one special case regarding read flow-through mode (discussed below). In this mode the consumer can anticipate the write, by producer, by lowering the read enable input. In this case the $\overline{\mathrm{XO}}$ input does not go low with read enable. When write enable is lowered, $\overline{\mathrm{XO}}$ goes low. $\overline{\mathrm{XO}}$ goes high with write enable. At this point the empty flag is cleared, thus signaling to the consumer to terminate the read after the appropriate period specified in the data sheet. During this period the $\overline{X O}$ output, which went high at the end of the write enable pulse, has lowered again. When the read enable is raised by the consumer, the XO output goes high. In this way two pulses on $\overline{\mathrm{XO}}$ are assured (see Figure 9).


Figure 9. Generation on $\overline{\mathrm{XO}}$ Output When the FIFO Is Empty
a) regular case
b) the read-flow through case

Two examples of the IDT7201/7202 in expanded depth configuration are available from IDT commercially. The IDT7M203/204 are Subsystems modules which incorporate onto one ceramic substrate four FIFO LCCs and the $\overline{\mathrm{EF}} \& \overline{\mathrm{FF}}$
"OR" gating to produce $2 \mathrm{Kx9}$ and $4 \mathrm{Kx9}$ FIFOs. The Subsystem module has a lead frame which pins out like the 28 -pin 0.6 inch IDT7201/7202. This allows for a plug compatible 4Kx9 FIFO in one socket.

## SPECIAL FEATURES OF IDT7201/7202

The architecture used in the IDT7201/7202 provides some features that distinguish it from FIFOs with other architectures. One outstanding feature is the dual port implementation of the RAM array. The RAM is designed in such a way that the read and write ports are separate, allowing for simultaneous asynchronous reads and writes with no hand shaking or arbitration. In the classical architecture the consumer and producer circuits must monitor ready flags for each access.

The IDT7201/7202 support a retransmit function. In the single device solution, the $\overline{F L} / \overline{\mathrm{RT}}$ input may be pulsed low signaling a retransmit.

A retransmit operation will set the internal read pointer to the first location and will not affect the write pointer. READ ENABLE $(\bar{R})$ and WRITE ENABLE $(\bar{W})$ must be in the high state during retransmit. This feature is useful when less than $512 / 1024$ writes are performed between resets. The retransmit feature is not compatible with Depth Expansion Mode and will affect HALF FULL FLAG $(\overline{\mathrm{HF}})$ depending on the relative locations of the read and write pointers. For example in a communications application, during transmission of a message the receiver may request a retransmit of the message. This can be accomplished by always starting new messages at the beginning of the queue via a pulse on the reset input. If and when the retransmit request arrives the $\overline{\mathrm{FL}} / \overline{\mathrm{RT}}$ line is pulsed. The read pointer is repositioned at the beginning of the queue. The message producer may continue to write more of the same message into the queue as the retransmit of the message continues. The retransmit can happen as many times as desired. At the start of the next complete message, the reset line ( $\overline{\mathrm{RS}}$ ) must be pulsed after the successful acknowledge by the receiver. The reset ensures that the new message will be placed in the FIFO at the start of internal queue. It should be noted that when retransmit is possible, messages cannot be bigger than the maximum size of the queue. If the message is longer than the queue, even though the read pointer has progressed far enough to accommodate the extra data, resetting the read pointer back to the beginning with retransmit will produce data from the end of message instead of the beginning.

This architecture supports flow-through modes. In the read flow-through mode, when the buffer is empty, the consumer can anticipate the write by the producer at the other end by lowering the read input. When the empty flag ( $\overline{E F}$ ) goes false the consumer circuitry can terminate the early read cycle by reading the data and deasserting the read signal. The read input must go high for a brief period in order to clock the read pointer. The read flow-through mode avoids the standard sequence of monitoring flag going high before hitting a read cycle.

The write flow-through mode is a mode that is employed when the FIFO is full. The producer can anticipate a read by the consumer by lowering the write input before the read. When the full flag ( $\overline{\mathrm{FF}}$ ) raises, the producer knows that the consumer has read a location, thus freeing up a location that can receive the new data. The producer then raises the write input which actually writes the data into the RAM array. This flow-through mode avoids the overhead of monitoring the full
flag before initiating a write cycle.
The IDT7201 is pin and functionally compatible with the Mostek MK4501 thus serving as an alternate source. The IDT7202 gives the same functionality as the IDT7201 but is twice as deep (1024×9). The IDT7202 is the largest FIFO made with the zero fall-through time architecture making it the logical choice for FIFO applications.

## SOFTWARE VERSUS HARDWARE SOLUTIONS

With every application involving a computer orprogrammed controller, the designer can trade off between performing certain functions in software or hardware. In general, the software solution is a more flexible design (easily changed) but performs the task more slowly. The hardware solution is less flexible but performs the task very fast.

To clarify these concepts, a discussion of an application and how it could be solved at the various levels from software to hardware is beneficial. A good example is a file server. The server could be connected to a Local Area Network (LAN) and, on the other side, to a Winchester disk drive. Both I/O connections demand attention at unpredictable intervals and must be serviced on demand or data is lost.

If the data rate of both interfaces is sufficiently low, a total software solution might be considered. The data rate would have to be low enough such that the software code could poll the status of either I/O port. As data arrives it could be placed into software FIFO queues. When a full record is buffered, then processing would commence. During the processing, the I/O ports must still be monitored as another user on the LAN might make a request (see Figure 10). It is doubtful that a total software solution could be designed for the server application that would have acceptable system performance.

The next approach to consider might be to include hardware interrupts. Interrupts allow for one task to be running and almost immediately switching to an I/O service routine. Interrupts are something like a hardware subroutine call. This scheme would use the interrupt mechanism to call routines to move data to and from the I/O ports and the software FIFO queues. The overhead of constantly polling the I/O port status flags would be eliminated, thus allowing for higher system performance. An asynchronous-type problem is introduced with interrupts. To use interrupts properly, the I/O service routines may be called at any instance. Therefore, the interrupt routines must be designed in such a way that they do not destroy data that the interrupted task might be using. Usually, the routines must be careful to save the state of the machine, perform their task and restore the state of the machine. The extra code to maintain the state of the machine is an overhead that is not in the polled solution. Worse yet, saving the state of the machine may be too much overhead to allow for an interrupt during a time-critical piece of code. Because interrupts may not be acceptable at certain points in the code, the programmer must insert code to disable and re-enable interrupts around the critical sections.

Where the polling scheme provides a solution which has a more easily definable sequence of execution, the interrupt solution is indefinite. The programmer must spend a lot more


Figure 10. Example Solutions for Flle Servers
time proving that all possible sequences caused by random interrupts will produce desirable results. Because interrupts may not be acceptable at certain points in the code, the programmer must insert code to disable and re-enable interrupts around the critical sections. The interrupt disable solution not only cuts performance by not accepting I/O during some
periods, but also adds more overhead with the maintenance of the interrupt enable mechanism. In some sense, interrupts can be to software what the meta-stable flip-flop problem is to hardware.

The interrupt solution can be moved out of the software and more into the hardware realm through the use of a technique
called Direct Memory Access (DMA). The DMA solution is provided by a block of circuitry which monitors the I/O ports. When the port requires attention, the DMA logic interrupts the current task at the bus transfer level and steals a memory cycle to transter the data to or from the port and the FIFO queue in memory. The task that is running on the processor misses only a few memory cycles now and again which is much less than in the interrupt scheme where a whole subroutine of many memory cycles was executed to transfer each element of data. The DMA solution is not for free. DMA controllers are complex devices which must be programmed as well as designed into the bus structure. The DMA mechanism can only serve one source at any given instance in time thus still being a bottleneck in throughput.

So far, each solution proposed has moved the mechanism that feeds data to or from FIFOs in program memory away from the software and closer to the I/O port. The memory bus still remains the bottleneck because both FIFO queues are in memory. To simplify and improve performance, hardware FIFOs such as the IDT7201/7202 can be used. The processor would interface to the FIFO through an I/O port as before, but the FIFO would now be between the I/O port and the rest of the hardware. The software could then service the data at a steady rate and be sure that data was not lost without the problems or overhead of more complicated schemes such as interrupts or DMA.

Because the queues are between the controller and the peripheral the peripheral can load or read the queue without interrupting the controller. Since the controller is not involved with maintaining both queues, there is no possibility of lost databecauseone queue was being serviced while data to the other queue arrived. For these reasons the hardware FIFO represents the highest performance solution.

If the designer uses large FIFOs like the IDT7202 there is a minimum of device count. Assuming 2 FIFOs (transmit and receive)for each I/O port gives a count of four 28 -pin devices for the FIFO solution. The DMA solution would at least be one 40 -pin device and several bus buffer/control devices. The interrupt solution would require a similar parts count to the DMA solution. Therefore the FIFO solution is not only the highest performance solution but usually has the lowest part count of the hardware solutions.

## COMMUNICATIONS-MULTIPLEXOR APPLICATION

Another example of a rate mismatch problem is shown in a CRT terminal and CPU interface. In order to not load the CPU with the burden of monitoring the UARTs of multiple CRTs and printers a communications controller is employed. The controller can serve as a communications multiplexor and data concentrator (see Figure 11).

As the controller receives characters it must buffer them such that if multiple characters are received close together from several terminals, they will not be lost as more characters come in. The natural structure to store them in is a queue of the FIFO type. The CPU will then need to respond to the characters. If the controller is inputting other characters, the CPU should not have to wait until the controller is done. Therefore, a FIFO can be employed on the transmit side as well as the receive side. To make the design simple, two sets of FIFOs could be placed between the CPU and controller. When characters are received they are placed in one end of a FIFO and read from the other end by the CPU. As the CPU prepares characters for transmission, it places them in a FIFO going the other direction. The controller then reads them from the other end of the transmit FIFO and sends them out through the UART.


2813 dow 11

Figure 11. Communications Controlier Example

Conceivably, there could be a pair of FIFOs for each.UART. That way it would be easy for both the controller and the CPU to keep straight which characters correspond with which UART. While this provides for a large total of buffer space for characters it is more than needed when using a part like the IDT7201/7202. For eight UARTs, this scheme would require a minimum of sixteen FIFO devices. A better solution would be to use one FIFO device in either direction. If an IDT7202 were used, it could provide a maximum of up to 128 characters per UART if all the UARTs input at the same time and rate. While the two FIFO techniques would most likely provide plenty of buffering at a minimal device count, it presents the problem of which character belongs to which UART The solution is to make a wider FIFO which is 18 bits wide; thus using 4 devices instead of 16 devices for 8 UARTs. This would allow for a UART number to be placed in the FIFO along side each character. The remainder of the word could be used for flag status and command information between the CPU and the controller. For example, several of the bits in the FIFO word could indicate whether the character information was a character to send or BAUD change rate information.

The empty and full flags of the IDT7201/7202 FIFO would be used as status flags. For example the transmit buffer must be monitored from both sides. As the CPU prepares a charac-
ter to transmit, it would first examine the full flag ( $\overline{\mathrm{FF}})$ to see if the FIFO is full. If the FIFO was full, it would delay outputting the character. If the buffer is not full then it would place the character in the FIFO. The empty flag (EF) would be monitored by the controller. As soon as the CPU places a character into an empty FIFO the empty flag would change to not true. At this point the controller would know there was a character in the buffer which could be transmitted. The controller would read characters from the buffer as long as the empty flag was not true (buffer contains more than one character).

## CONCLUSION

Hardware FIFOs are an economical memory organization to use when lists of data items are to be buffered. Because they do not require an address to access items in the list, there is less overhead in terms of circuitry and access time. The FIFO buffer is most often used as a "system rubber band" to stretch between the differing and fluctuating rates of different elements in a system. The IDT7201/7202 FIFO device features the newest RAM-based architecture and provides the latest in technology in terms of access time fall-through time and size, thus providing the most economical solution for today's design needs.

## By Robert Stodieck

## INTRODUCTION

FIFOs are a common hardware solution in designs where data must be transferred between two subsystems with different characteristic data generation, transfer or usage rates. A common case is the serialization and de-serialization of data. Serialization is required for a variety of applications such as communication, data storage and display. The IDT72103 and IDT72104 parallel-serial FIFOs have been designed to address these applications.

The IDT72103/4 FIFOs are a RAM-based design with self-incrementing internal read and write pointers. This design results in very low fall-through times compared to older FIFO designs that are based on ganged shift registers. The fall-through time of a FIFO is the time elapsing between the end of the first write to the FIFO and the time the first read may begin. The first byte of data written into the IDT72103/4 FIFOs is available as soon as the write is complete and the Empty Flag is consequently de-asserted.

Similarly, the serial registers are not shift registers but bit wide memory arrays with self-incrementing pointers. The serial output word and the serial input word transfer data starting from the least significant bit. If only a partial word is transferred into the serial input register, the bits will be in the correct bit location in the serial input register and not shifted right or left.

## PARALLEL OPERATING CONSIDERATIONS

Regardless of how a FIFO is designed or used, FIFO full and empty boundary conditions require special consideration from the system designer. FIFO reads and writes may occur completely asynchronously from each other unless the FIFO is completely full or empty. What happens when excess reads or writes occur after the FIFO is full or empty depends on the design of the particular device. If a FIFO is empty, then reading the FIFO again will produce data which is out of sequence or invalid. If the FIFO is full, writing data overwrites previously written data or loses the data being written.

The design of the IDT72103/4 FIFOs gates out write pulses once the FIFO is full and gates out read pulses once the FIFO is empty. Excess writes are ignored and thus do not overwrite valid data. Excess reads produce invalid data since the outputs of the FIFO are tri-stated when the Empty Flag is active, but do not read data bytes out of sequence.

The Full and Empty Flags signal the full and empty boundary conditions. An internal read cycle cannot begin until the Empty Flag is de-asserted and a write cannot begin until the Full Flag is de-asserted (Figure 1).

If the read signal is low prior to the de-assertion of the Empty Flag or the write signal is low prior to the de-assertion of the Full Flag, they cannot be allowed to transit high again until an appropriate minimum read or write pulse time has elapsed.


Figure 1. Parallel Read and Write Timing FollowIng the De-Assertion of the Full and Empty Flags

Failure to observe this boundary condition timing produces internal read and write pulses of excessively short duration and may result in erratic operation.

The IDT72103/4 provide a full complement of flags which do not interact with the read and write signals. These provide the designer with flexible FIFO status indicators. They include, Empty +1 , Full - 1, Half-Full and Almost-Empty/Full. The Almost-Empty/Full Flag is asserted when the FIFO is less than $1 / 8$ th full and again when it is greater than $7 / 8$ th full.

The IDT72103/4 FIFOs can be expanded in depth to any level by cascading multiple devices. For depth expansion, the input and output buses are connected in parallel. The expansion output (XO) pin of the first part is connected to the expansion input (XI) pin of the next device in the cascade until all the parts are connected in a loop (Figure 2). The First-Load pin of one of the parts is tied to ground to identify it as the first device to be loaded in the cascade. All other parts have the First-Load pin tied to Vcc. The retransmit feature cannot be used in the depth expansion mode.

Empty Flag and Full Flag signals for the depth expanded cascade are derived from the individual FIFO Empty and Full Flag signals by logically ORing them together. The retransmit feature and the flags other than Empty and Full cannot be used in the depth expansion mode.

The IDT72103/4 FIFOs' retransmit feature allows data written to the FIFO one time to be read any number of times. The retransmit feature resets the read pointer to begin re-reading data from the first byte that was written after a reset pulse. This is particularly useful for applications such a video frame buffers which are written once and read many times.


Figure 2. Parallel Depth Expansion to 12 Kilobytes

## SERIAL TRANSFER AND EXPANSIONFLEXISHIFT ${ }^{\text {TM }}$

The serial registers are bit wide memory arrays. Both serial width and serial depth expansion are facilitated by connecting the serial inputs and outputs in parallel. The serial output of an individual device is tri-stated when it is not active. Which serial input and serial output is active at a given moment is controlled through the expansion pins SOX (Serial Output Expansion), SIX (Serial Input

Expansion), XO (Expansion Output) and XI (Expansion Input). Whether in an expansion mode or not, serial transfers always begin from the least significant bit.

The serial word width of the IDT72103/4 FIFOs may be programmed to be from four to any number of bits by using multiple parts (Figures 3 and 4). When used in the serial mode, the unused parallel input pins, Do-D8, and the unused parallel output pins, Q0-Q8, are used to output information on the status of the serial transfer (Figure 5).


Figure 4. Serial Input Width Expansion to 24 Bits

Figure 3. Serial Output Width Expansion to 24 Bits



Figure 5. Parallel Pin Output Signals When in Serial Mode

These signals are used to trigger the reading and writing of data words to and from the FIFO registers and allow us to program the serial word width. These signals may also be used to drive related external logic. The minimum serial word width that may be programmed is 4 bits. Because $\mathrm{D}_{0}-\mathrm{D}_{8}$ and Q0-Q8 are simple outputs when the part is being used in the serial mode, they must not be bused together when in this mode.

The serial output word width is programmed by connecting the read line to the $Q$ pin numbered one less than the word width required. The serial input word width is programmed by connecting the write line to the $D$ pin numbered one less than the word width required. When multiple parts are used to expand the word width beyond 9 bits, this pattern continues over to the next part in sequence. In Figures 3 and 4, the word width has been programmed to nine plus nine plus six, or twenty-four bits.

On the serial input side, the SIX input of a FIFO that will sink higher order bits is tied to the D8 pin of the FIFO which will sink lower order bits. The SIX input of the part to receive the lowest order bits is tied to VCC. Likewise, on the serial output side, the SOX input of a FIFO that will source higher order bits is tied to the Q8pin of the FIFO which will source the lower order bits. The SOX input of the part to receive the lowest order bits is tied to VCC. The serial expansion inputs SIX and SOX should not be used by external logic.

## HARDWARE DESIGN

It is important to remember that FIFOs are state machines with internal logic being clocked by the read, write and expansion inputs. These control lines are high frequency clock lines and must be treated as such by the designer. it is important that these signals be clean, glitch free and reflection free.

With fast logic types and long traces it may be desirable to terminate the control signal lines to reduce ringing. A 20 to 50 Ohm series resistor placed close to the driving outputs may help balance the impedance of the output driver to the transmission impedance of the line and thus reduce ringing. Unused FIFO inputs must always be tied to VCC or ground. When cascading the FIFO in depth
or width, the expansion lines XI, XO, SIX and SOX should be as short as possible. If they are long, termination of these lines may also be required.

The designer must take care not to inadvertently design noise into these signals. For example, a designer may choose to strobe the read and write lines with a 74138 decoder. Since the inputs to the decoder never arrive at precisely the same time, the outputs may sequence through a number of transient states before settling. The result is a random number of very fine glitches (decoder glitches) on the outputs and, thus, the read and write signal lines. Since the logic is quite fast, the glitches may be very narrow and difficult or impossible to find with a logic analyzer.

## HIGH-SPEED SERIAL LINK USING THE IDT72103/4

To minimize the CPU time associated with excessive task switching when transferring data, the ideal communications link appears to the processor as a range of memory addresses (dualport memory) or an address that can be repeatedly read or written without corrupting data (FIFO).

If a serial link is required between two systems, a simple system using two parallel-serial FIFOs may provide a straightforward solution. If it is required, data word widths can be adjusted in the process. For example, data being transferred from a 32-bit processor can be folded to 16 -bit words when moving through the FIFO serial link for use by a 16 -bit CPU receiving the data. In this FIFO-serial link, data written to the transmitting FIFO is automatically transferred to the receiving FIFO as quickly as the hardware allows. The FIFO-serial link appears to the two systems as a virtual FIFO. The two communicating systems need only respond to the Empty or Full Flags of their respective local FIFOs.
In parallel I/O mode, the fall-through time of the IDT72103/4 is very small. The fall-through time of the FIFO-serial link is dedicated by the serial transfer rate and the serial word width. The serial data transfer rate may be limited by the characteristics of the serial channel or by the upper limit imposed by the FIFO logic.


Figure 6. Serial Link Using Two IDT72104 FIFOs

## SERIAL LINK OPERATION

For the purpose of illustration, a partial schematic of the serial handshake logic is shown in Figure 7. Operation of the serial link
requires logic to pause the clock signals when tho transmitthin FIFO is empty or when the receiving FIFO is full and to restart tho serial clock when the FIFOs are again ready for transfers.


Figure 7. Partial Clock Enable Logic

The clock signals to the FIFOs are paused when the transmitter's Empty Flag or the receiver's Full Flag is asserted. The clock signals are re-started and serial transfer begins again when the Full and Empty flags are both de-asserted. Since the Empty and Full flags are both asserted after clocking the first bit of the last word to be transferred, the logic must also allow the last word to be transferred entirely before it de-asserts the clock enable signals. This is done by delaying the disabling of the clock signals until the read signal of the transmitting FIFO goes high. This signals to the handshake logic that the last bit of the serial transfer has been completed. The clock signal is then disabled in a high state. When both
the transmitter's Empty Flag and the receiver's Full Flag are de-asserted, the serial clock signals are enabled again.

A complete schematic is shown in Figure 8. The logic is essentially the same as that in Figure 6, but includes provisions for synchronization to the serial clock and system reset. An IDT74FCT374A is used as array of clocked D-type flip-flops for synchronization of the handshake logic to the serial clock. Since the de-assertion of the Empty and Full flags is asynchronous to the serial transfer clock, logic is required to resolve metastability resulting from clock edge coincident transitions of the "HALT

CLOCK" signal. This is done by clocking the signal through stages of clocked D flip-flops.


Figure 8. Serial Handshake Logic

The serial output clock must be one clock pulse ahead of the serial input clock. This is due to the fact that the FIFO serial output does not output the first bit until after the first positive output clock edge. Until this time, the output is in a high impedance state. On the other hand, the FIFO serial input inputs the first bit on the first serial input clock edge. To accomplish the necessary one clock cycle delay, the clock enable signal is clocked through one extra D flipflop before it affects the serial input clock signal.

Reset of the serial handshake logic occurs automatically. The "HALT CLOCK" signal is asserted a few serial clock pulses after the transmitting FIFO's Empty Flag is asserted during reset. The cross coupled NAND gate flip-flop keeps the clocks disabled after reset until the transmitting FIFO de-asserts the Empty Flag and, thus, "HALT CLOCK" for the first time. This provides adequate time for the $\mathrm{Q}_{\mathrm{n}}-2$ signal to return to logic high following reset, thus completing the reset sequence.

## TIMING

The timings for the serial interface are based on the IDT72103/4 preliminary data sheet, dated April 1987, for a part with a 50 ns address access time and for the schematic in Figure 8. Timing for other versions will follow this pattern. For operation at 40 MHz , pipelining of logic delays is required for the handshake logic. The serial clock period is only 25 ns. For operation at lower speeds, somewhat less complex circuitry can be used with fewer D flipflops for pipelining.

The timings shown in Figures 9 and 10 assume the use of an IDT74FCT374A with CP-to-On delay of 6.5 ns maximum and fast 74F00 series logic with propagation delays of 6 ns. Minimum clock high time is dictated by the need to enable and disable the clock without glitching. Conservatively, this is 6 ns OR gate delay +6.5 ns CP-to-On delay. Minimum clock period is dictated, in this case, by the fastest FIFO shift logic specification of 40 MHz .

The "HALT CLOCK" signal may be de-asserted too close to the positive clock edge to avoid metastability in the D flip-flop associated with register input $D_{3}$. To assure that the metastability does not cause glitches in the clock signal, the output $\mathrm{O}_{3}$ feeds the input D4. This would give the metastable flip-flop 25 ns , the clock period
minus 2ns, the set-up time for the next D input stage to settle out before affecting the clock logic. With this logic family, this time should be adequate to provide a very low probability that the metastable condition will not propagate further. Since timing is not critical here, another flip-flop stage has been added to ensure this (D5 and O5).

At 20 ns maximum from clock high, the transmitter's read signal can be too late to safely de-assert the clock signals after one necessary gate delay (6ns) and still meet the set-up time for the IDT74FCT374A register (2ns). Instead, the output signal of a Q output tap two less than that used for the read signal is clocked in (Figure 9). The time from clock high to $Q$ high is then 20 ns maximum plus 2 ns set-up. This safely fits into the 25 ns window.

The AND gate shown in Figure 7 is present in Figure 8, but is the input to an additional OR gate not shown in Figure 7. The OR gate and a set-reset flip-flop are used to assure that the clocks are not active during reset. The flip-flop is set during system reset and cleared when the "HALT CLOCK" signal is de-asserted for the first time after reset. The flip-flop's clock-to-output time ( 6.5 ns output 5 and 6 ), plus the two gate delays ( $6.5 \mathrm{~ns}=6 \mathrm{~ns}$ ), plus the set-up time (2ns), adds up to 20.5 ns maximum and fits safely into the 25 ns window provided.


Figure 9. Serial Clock Disable Timing


Figure 10. Serial Clock Enable Timing

The clock signals are disabled in the high state. In order to enable and disable them without glitches; the enable and disable operations must take place in the 12.5 ns window provided by the clock high time. The register's clock-to-output delay is $6.5 n$ maximum; the gate delay is 6 ns maximum.

The transmitter's serial clock must be one pulse ahead of the receiver's serial clock. This is accomplished by requiring the receiver's clock enable signal to pass through one additional D flip-flop before becoming effective ( $\mathrm{D}_{7}$ and $\mathrm{O}_{7}$ ).

The reset pulse must be low for two serial clock pulses and the first write to the transmitting FIFO must not occur prior to RSQH (the time required for the FIFO Q outputs to return high after reset pulse -35 ns for the part in question). Four additional serial clock pulses are required to ensure reset of the handshake logic without false clock pulses.

## DATA WIDTH FOLDING DURING SERIAL TRANSFER

Data word widths may be multiplied or divided by integer quantities during transfer. Figure 11 shows an example where 16 -bit data words are being folded into 8 -bit words during serial transfer from a 16-bit processor to an 8 -bit system. The folding operation is transparent to the processors on either side.

The folding operation is accomplished by programming the serial word width on each side of the serial link to multiples of each other. In Figure 11, the right hand serial word width has been programmed to be 16 bits. Nine bits of transmit FIFO \#1 and 7 bits of transmit FIFO \#2 are used. This is done by tying the SOX input of FIFO \#1 to VCC and triggering the read input for both FIFOs from the Q4 output of transmit FIFO \#2.

On the left hand side, the serial word width is programmed to 8 bits by tying the SIX input to VCC and tying the write signal to the I/O pin D7.


Figure 11. Schematic Facilitating 16-Bit to 8-Bit Data Folding During Serial Transfer

## ONE-BIT VIRTUAL FIFO

In the serial-in/serial-out mode, the parallel-serial FIFO operates as a virtual 1 bit wide FIFO. The SICP input functions as a write input and the SOCP input functions as a read input. In this mode of operation the IDT72103/4 may be used to widen the word width of a parallel FIFO in 1-bit increments (Figure 12).

The 1-bit virtual FIFO has a latency of 4 to 9 bits, depending on the programmed serial word width. For example, if the FIFO is programmed for 9 -bit words, 10 bits must be written into the FIFO before the Empty Flag is de-asserted and the first 9 bits can be read.

The depth of the virtual FIFO in this mode is $9 \times 4096$ bits. If the word width is programmed to be 4 , the latency is reduced to 4 bits and the depth is reduced to $4 \times 4096$ bits.

In applications where some latency is not a problem, the serial-in/serial-out FIFO can be used to extend the width of a parallel FIFO in increments of one. In general, the serial-serial FIFO depth should exceed the depth of the parallel FIFO to avoid empty and full boundary condition conflicts.
In Figure 12, an IDT74FCT861 latch is shown to maintain tristate capability across all 10 output bits. This may not be required.


Figure 12. Serial-Serial FIFO Expanding the Width of a Parallel FIFO

## CONCLUSION

The IDT72103/4 Parallel-Serial FIFO can be used to reduce parts count and lower power consumption in numerous applications which involve FIFOs and parallel/serial data conversion. Applications include video frame buffers, communications links,
printer buffers and parallel-parallel FIFO bandwidth adjustment.
The numerous status flags, ample depth, speed and the presence of an independent output enable control make the FIFO highly flexible for use in parallel-to-parallel mode applications as well.

By Danh Le Ngoc

## INTRODUCTION

The most common application for the FIFO is an elastic data buffer between two synchronous or asynchronous systems for the purpose of passing data.

Because data is produced and accepted at different rates, it is important to monitor the boundary conditions (FULL or EMPTY) of the data buffer. Failure to act on the boundary conditions will result in data overflow or underflow. The current FIFO generation, such as IDT7201/02/03/04, signals the empty, half-full and full condition by asserting the $\overline{E F}, \overline{\mathrm{HF}}$ and $\overline{\mathrm{FF}}$, respectively. The empty and full flags are also fed back internally and inhibit further Read and Write operations until the FIFO is no longer empty or full.
The increasing use of high-speed CMOS, coupled with the introduction of the 32-bit CPU, has created the demand for a faster and smarter generation of FIFOs. New Flagged FIFOs offer
the basic features of IDT's industry standard FIFOs (IDT7201/02/03/04) while providing two new flags: ALMOST-EMPTY and ALMOST-FULL. These flags can be used as early warning flags in critical real-time applications such as data acquisition, high-speed data link and pipeline Digital Signal Processing applications. In the multi-tasking environment, the ALMOST-EMPTY and ALMOST-FULL can also be used to set the interrupt request in advance, so that the CPU has sufficient time to perform the task switch without loss of data due to the task switch latency. Other advantages of these Flagged FIFOs are an increase in memory utilization and the Three-State Control, $\overline{\mathrm{OE}}$, for the outputs (Q0-8). The use of independent Three-State Control simplifies the interface with bus and I/O channels and improves timing in read and write cycles. Figure 1 is a block diagram of the new Flagged FIFOs: IDT72021/31/41.


Figure 1. Simplified Block Diagram for Flagged FIFOs


Figure 2. Almost-Empty and Almost-Full Flags on the IDT72021/31/41

## APPLICATIONS USING THE FLAGGED FIFOS

Typical applications using the new features of the Flagged FIFOs are demonstrated below.

- almost-empty and almost-full flag as early WARNING FLAGS IN REAL-TIME DIGITAL SIGNAL PROCESSING APPLICATIONS
Figure 3 is a simplified block diagram of a real-time spectrum analyzer featuring A/D channels, input buffer, FFT processor, display processor, output buffer and CRT. In operation, the DSP engine processes on the previous frame of data at the 50 MHz
rate, while the A/D channel samples the analog signal at the comparatively slow rate of 20 MSPS . This data rate mismatch requires the use of a FIFO to act as an elastic data buffer. To prevent data overflow, the ALMOST-FULL flag is used as an early warning to the DSP controller. With this signal, the DSP engine has sufficient time to empty the input buffer (FIFO) into the buffer at its own high-speed data rate. Meanwhile, the AVD channel continues to refill the input buffer from other side at its much slow rate. At the other end of the system, a second FIFO acts as an output buffer between the high-speed display processor and slow CRT. In this case the ALMOST-EMPTY FLAG is used as an early warning so that the display processor can begin filling the buffer with the next image.


Figure 3. Simplifled Block Diagram for a Real-Time Spectrum Analyzer

- MAXIMUM UTILIZATION OF MEMORY WITH THE ALMOST-FULL AND ALMOST-EMPTY FLAGS IN HARD DISK DRIVE APPLICATIONS
Because of the high data rates used in the hard disk drive protocols, SMD, SCSI and IPI or the standard data communication protocols (Ethernet, Supernet and Fiber-optics which can go up to 100 Mbits per second), even the newer and faster microprocessors will struggle to keep up with the speed of 1/O channels. For this; reason, data buffering is always considered in any high-speed I/O transfer. The design in Figure 4 shows the data buffer for a high-speed hard disk application. In such CPU-to-I/O controller applications, FIFOs are often used to construct the data buffer. Normally two sets of FIFOs are
arranged in the back-to-back manner, where one set acts as a transmit buffer and the other as the receiver buffer. In this arrangement, the CPU dumps data in the transmit FIFO until the FIFO is $7 / 8$ full. At this point, the FIFO sets the Almost-Full Flag, initiating the data transfer to the I/O channel at its higher speed rate. In similar fashion, the high-speed I/O channel dumps data into the receiver FIFO until it is almost full. In this case, the Almost-Full Flag triggers an interrupt request to the host processor or DMA request to the DMA controller. If the request goes to the DMA controller, the DMA channel can transfer the entire block of data into the system memory in one burst. Figure 4 illustrates a host interface between a 32-bit microcomputer system based on an Intel 80386 and a Disk Drive.


Figure 4. Block Dlagram of a Disk Drive Controller

## - ASYNCHRONOUS THREE-STATE CONTROL

Another common use for FIFOs is as a data buffer between a microcomputer and high-speed I/O bus for the purpose of passing data back and forth. The figures on the next page illustrate two examples of the interface between a 32-bit processor and the I/O channel of the IBM PC AT, one using

FIFOS without three-state control and the other using FIFOs with their three-state control. As Table 1 indicates, using thenew Flagged FIFOs with their three-state control pin produces faster read and write cycles. An additional advantage is the ability to repeat a reading from the same FIFO location without advancing the read pointer.


Figure 5. IDT7202 FIFOs Without Three-State Control as a Data Buffer Between IBM AT and an Accelerator Board


Figure 6. IDT72021 FIFOs withThree-State Control as a Data Buffer Between IBM AT and an Accelerator Board

Table 1. Read and Write Cycle with IDT7202/021

| DELAYS PATHS | WITHOUT THREE-STATE <br> CONTROL | WITHOUT THREE-STATE <br> CONTROL |
| :--- | :---: | :---: |
| IDT74FCT521A: TPLH | 7.2 ns | $0.0 \mathrm{~ns}^{\star}$ |
| IDT74FCT138A: TPLH | 9.0 ns | 9.0 ns |
| IDT7402/021: TRC | 35.0 ns | 35.0 ns |
| TOTAL | 50.2 ns | 44.0 ns |

*Although this propagation delay is specified at 7.2 ns , it occurs in parallel with the slower 9.0 ns propagation delay of the IDT74FCT138A and is not additive as is the case in the "without three-state control" application.

## CONCLUSION

As the need for high-speed data computation increases, the FIFO must also become faster and smarter. The next generation of FIFO, as exemplified by the IDT72021/31/41, meets that challenge.

by Julie Lin and Danh LeNgoc

## INTRODUCTION

The IDT7251/510/52/520 are high-speed, low power bidirectional FIFO organized as 512 by 18 and 1024 by 18 respectively. The 18-to-9 bit BiFIFO contains many proprietary features, such as: Reread/Rewrite capability, parity function, programmable flags, DMA handshake circuitry, and bypass path. Some of these features require initial set up through programming of the internal configuration registers (see data sheet).

The focus of this application note is to describe the default mode of the BiFIFO after the software "Reset All" operation or the hardware reset ( $\overline{\mathrm{RS}}$ ) (on the IDT72510/520 only). The default mode provides a bidirectional data buffer for a CPU-toCPU interface. The equivalent block diagram is illustrated in Figure 1 where four flag pins are set as FLGA = "A $\rightarrow$ B empty", FLGB = "A $\rightarrow$ B full", FLGC = "B $\rightarrow$ A empty" and FLGD $=$ " $B \rightarrow$ A full", respectively.


NOTE:

1. Available in the IDT72520/510.

Figure 1. The Bus Matching BIFIFO

This configuration can be used as a bidirectional dat a buffer between a 16-bit processor and an 8-bit processor, as shown in Figure 2. The 16-bit CPU is hooked to Port A, whereas the 8 -bit CPU is connected to Port B . The interface functions of the 16-bit CPU include reading the $B \rightarrow$ A FIFO, writing the $A$ $\rightarrow$ B FIFO, monitoring the empty flag of the $B \rightarrow$ A FIFO
(FLGC) and the full flag of the $A \rightarrow B$ FIFO (FLGB). Similarly, the 8-bit CPU interiace includes reading the $A \rightarrow B$ FIFO, writing the $B \rightarrow A$ FIFO, monitoring the full flag of the $B \rightarrow A$ FIFO (FLGD) and the empty flag of the $A \rightarrow B$ FIFO (FLGA). Since the parity function is not used in the BiFIFO, the parity bits, DA17-A16 and DB8, are pulled down with 10K resistors.


2733 dmw 02
Figure 2. The Bus Matching BiFIFO Fits Into the 16-Bit CPU to 8-Bit CPU Interface

## THE BiFIFO PARITY GENERATION AND CHECKING

## APPLICATION

NOTE
AN-36

## INTRODUCTION

An occasional error may be introduced into the information while moving binary words within a digital system or in exchanging words with other systems. One erroneous bit due to noise in the system will cause an incorrect word to be transmitted. The parity generation and checking feature in the BiFIFO allows the user to detect and correct such data errors. This application note describes the function of this feature.

The parity checking and generation is available on IDT's 7251/72510/7252/72520 devices in the BiFIFO family. Figure

1 is the functional block diagram of the BiFIFO. Port A consists of 16 data bits (DA15-A0) and two parity bits (Da17-A16). Port B consists of 8 data bits (DB7-B0) and one parity bit (DB8). Depending on the direction of the data flow, the parity is generated/checked either before writing or after reading the memory on Port B side. In the bypass mode, only the 8 data bits are passed through memory, while the 9th bit (DA16 or DB8) will go through parity generation and checking. Configuration Register 7 (Table 6 of data sheet) is used to select the various parity function and is shown in Table 1.


Figure 1. Functlonal Block Dlagram

CONFIGURATION REGISTER 7

| BH' | Function |  |  |
| :---: | :---: | :---: | :---: |
| 0-7 | Unused |  |  |
| 8 | Parity Input Control | 0 | Disable Parity Generate, Enable Parity Check |
|  | $B \rightarrow A$ | 1 | Enable Parity Generate, Disable Parity Check |
| 9 | Parity Output Control | 0 | Disable Parity Generate, Enable Parity Check |
|  | $A \rightarrow B$ | 1 | Enable Parity Generate, Disable Parity Check |
| 10 | Parity Odd/Even | 0 | Odd |
|  | Control | 1 | Even |
| 11 | Assign Parity Error to | 0 | No Parity Error Output |
|  | Flag A Pin | 1 | Parity Error on Flag A Pin |
| 15-12 | Unused | Note: All default to 0. |  |

273201
Table 1. Parity Function

## PARITY GENERATION

$\mathrm{A} \rightarrow$ B FIFO Operation: A word (2 bytes) written into Port $A$ requires two reads from Port $B$ to retrieve both bytes. The data bits (DA7-DA0, DA15-DA8) and the ninth bit (DA16, DA17) are written into $A \rightarrow B$ FIFO memory at the same time as one word. The original parity bit from $A \rightarrow B$ FIFO is ignored by the parity generate/check circuitry. Parity bits are generated when reading from Port $B$. The parity generation mode is enabled by setting " 1 " on Bit 9 of Configuration Register 7. The generated parity bit flows through the path (\#1) as indicated in Figure 2a.
$A \rightarrow B$ Bypass: The 8-bit data on DA9-A0 is passed directly to Port B bus DB7-B0. The parity on DA16 is ignored in the parity generate/check circuitry. A new parity is generated and placed on DB8 as an output.
$B \rightarrow$ A FIFO Operation: Two writes to Port $B$ is stored in FIFO memory as a word. Each byte consists of 8 data bits (Db7-DBo) and a ninth bit (DB8). The ninth bit in the parity generate/check circuitry is ignored while the data is written into $B \rightarrow$ A FIFO memory. Similarly, parity generation mode is enabled by setting " 1 " on Bit 8 of Configuration Register 7. The generated parity bit flows through the path (\#3), as indicated in Figure 2b.
$\mathrm{B} \rightarrow \mathrm{A}$ Bypass: The 8-bit data on DB7-Bo is passed directly to DA7-A0. The parity bit on DB8 is ignored. A new parity is generated and placed on DA16 as an output.


Figure 2a. Parity Generate/Check for $\mathbf{A} \rightarrow \mathbf{B}$

## PARITY CHECKING

$A \rightarrow B$ FIFO Operation: This mode is similar to the parity generation mode except that the ninth bit is tested by the parity circuitry. Both the data bits and the ninth bit are written into the $\mathrm{A} \rightarrow$ B FIFO, and are then read from the FIFO memory. The ninth bit is compared to the parity bit that is generated from the parity circuitry. The Exclusive-OR of the parity check indicates "Read Parity Error" result. The ninth bit flows through the path (\#2), as indicated in Figure 2a.
$A \rightarrow B$ Bypass: The parity bit on DA16 is passed to DB8. The parity checking result is shown on "Read Parity Error" bit.
$B \rightarrow$ A FIFO Operation: This works in a similar manner to the $A \rightarrow B$, except that the data is written into $B \rightarrow A F I F O$, and the Exclusive-OR result of the ninth bit and generated parity indicates Write Parity Error result. The ninth bit passes through the path (\#4), as indicated in Figure 2 b .

The parity check mode is enabled by setting a 0 (also the default condition) either Bit $8(B \rightarrow A)$ or Bit $9(A \rightarrow B)$ of Configuration Register 7.
$B \rightarrow$ A Bypass: The parity bit on DB8 is passed to DA16. The parity checking result is shown on "Write Parity Error" bit.


Figure 2a. Parlty Generate/Check for $\mathbf{B} \rightarrow \mathbf{A}$

## ODD/EVEN PARITY

Odd or even parity can be selected through Configuration Register 7 (Bit 10). Even parity (put a 1 in Bit 10) implies all 1s from data bits and parity bit, resulting in an even number. Odd parity ( 0 in Bit 10) implies all 1s from the combined data bits and parity bit, resulting in an odd number. The parity error defaults to odd parity.

## PARITY ERROR INDICATIO'N

## Status Register

The read or write parity error from the parity function circuitry will set the read/write parity error bit of the Status Register (Table 8 of 7251/510/52/520 data sheet) to " 1 ". Bit 9 is the Write Parity Error flag. Bit 10 is for the Read Parity Error flag. The Status is accessed by the Address Control ( $\overline{\mathrm{CS}} A=0, \mathrm{~A}_{1}=1, A 0=1$ ).

## External Flag Pin

The OR of the two internal parity error flags is available as an option for output on the external Flag A pin. This is enabled by setting Bit 11 of Configuration Register 7.

## Resetting a Parity Error

The parity circuit is constructed in such a way that once a parity error is detected, the error flag is set and remains set until a clear command is executed. The parity error flag can be cleared through the command register (Table 2 of data sheet) by selecting $A(1010)$ and $B(1011)$ in the opcode.

## DEFAULT PARITY FUNCTION

Under the default condition, Configuration Register 7 enables the following functions:

1. $B \rightarrow A$ and $A \rightarrow B$ parity checking
2. Odd parity
3. External parity error not available.

# THE PROGRAMMABLE FLAGS OF BiFIFOs 

APPLICATION
NOTE
AN-39

By Julie Lin and Danh LeNgoc

This application note explores one of the key features of the IDT7251/510/52/520 BiFIFO - the software programmable flags. The functional capabilities include: (i) Programmable offset values for the "Almost" flags, (ii) External flags, and (iii) Internal flags. The programming procedures are explained and illustrated by an example. Finally, the flag assignment of the default operation mode is discussed.

The BiFiFO is composed of two FIFOs named as $\mathrm{A} \rightarrow \mathrm{B}$ FIFO and $B \rightarrow$ A FIFO, each with four internal flags. These eight internal flags are $\mathrm{A} \rightarrow \mathrm{B}$ Empty, $\mathrm{A} \rightarrow \mathrm{B}$ Almost-Empty, $A \rightarrow B$ Full, $A \rightarrow B$ Almost-Full, $B \rightarrow A$ Empty, $B \rightarrow A$ Almost-Empty, $\mathrm{B} \rightarrow \mathrm{A}$ Full and $\mathrm{B} \rightarrow \mathrm{A}$ Almost-Full. The Almost-Empty flag is defined as the condition when the read pointer is "Offset" steps behind the write pointer. Similarly, the Almost-Full flag indicates the condition when the write pointer is "Offset" steps behind the read pointer. The offset values of the four Almost flags are programmable through Configuration Registers 0-3. The programmable Almost flags can be used as early warning flags in critical real-time applications such as data acquisition, high-speed data links and pipelined digital signal processing applications. All the flags can be accessed either internally through the Status Register for CPU software polling or externally through four flag pins for interrupting the CPU.

## The Offset Values of the Almost Flags

The offset values defined by Registers 0-3 are unsigned positive numbers (see Table 1). They range from 0 to 1023 for the IDT7252/520 and from 0 to 511 (Bit 9 should be set to " 0 ") for the IDT7251/510. Specifically, Register 0 is for the $A \rightarrow B$ Almost-Empty flag; Register 1 is for the $A \rightarrow B$ Almost-Full flag; Register 2 is for the $\mathrm{B} \rightarrow$ A Almost-Empty flag; Register 3 is for the $B \rightarrow A$ Almost-Full flag.


## External Flags

Each of the four flag pins FLGA, FLGB, FLGc and FLGd can be programmedto any one of eight internal flags, together with the choice of polarity. Register 4 is used to select the flags for the external flag pins (see Table 2). This register is divided into four fields of four bits each: Bits 0-3 select FLGA; Bits 4-7 select FLGB; Bits 8-11 select FLGc; Bits 12-15 select FLGd. The selections for each external flag are listed in Table 3. The most significant bit of the four-digit selection code selects flag polarity - " 0 " for active low, " 1 " for active high. The next bit selects a particular FIFO - " 0 " for $\mathrm{A} \rightarrow \mathrm{B}$ FIFO, " 1 " for $\mathrm{B} \rightarrow \mathrm{A}$ FIFO. The remaining two bits indicate the relative position of read and write pointers - "00" for Empty. " 01 " for Almost-Empty, "10" for Full, "11" for Almost-Full.

Register 4
 2735 か 02

Table 2. Register 4 for the Selection of External Flags

| Selectlon Code | Selected Flags |
| :--- | :--- |
| 0000 | $\mathrm{~A} \rightarrow$ B Empty |
| 0001 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Almost Empty }}$ |
| 0010 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Full }}$ |
| 0011 | $\mathrm{~A} \rightarrow \mathrm{~B} \overline{\text { Almost Full }}$ |
| 0100 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Empty }}$ |
| 0101 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Almost Empty }}$ |
| 0110 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Full }}$ |
| 0111 | $\mathrm{~B} \rightarrow \mathrm{~A} \overline{\text { Almost Full }}$ |
| 1000 | $\mathrm{~A} \rightarrow$ B Empty |
| 1001 | $\mathrm{~A} \rightarrow$ B Almost Empty |
| 1010 | $\mathrm{~A} \rightarrow$ B Full |
| 1011 | $\mathrm{~A} \rightarrow$ B Almost Full |
| 1100 | $\mathrm{~B} \rightarrow$ A Empty |
| 1101 | $\mathrm{~B} \rightarrow$ A Almost Empty |
| 1110 | $\mathrm{~B} \rightarrow$ A Full |
| 1111 | $\mathrm{~B} \rightarrow$ A Almost Full |

Table 3. The Selection Table for External Flag Pins

Table 1. Reglsters 0-3 of the IDT7252/520 Defining the Offset Values of the Almost Flags

An Example to Illustrate the Selection of External Flags
The configuration registers are accessed by executing the command X1XmH ("X" stands for don't care) to point to Register " $m$ " ( $m=0,1,2,3,4$ ) and then reading or writing from address $2(A 1-0=10)$. These procedures are illustrated by the example shown in Table 4. In this example, four flag pins
are assigned as:
FLGA $=A \rightarrow B \overline{\text { Almost-Empty }}$ with offset $=7$
$\mathrm{FLGB}=\mathrm{A} \rightarrow \mathrm{B}$ Almost-Full with offset $=10$
FLGc $=B \rightarrow A$ Empty
FLGD $=\mathrm{B} \rightarrow \mathrm{A}$ Almost-Full with offset $=128$

| Function | $\overline{\text { CSA }}$ | A1 | A0 | R/ $\bar{W}_{A}$ | DA15-A12 | DA11-A8 | DA7-A4 | DA3-A0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Select Register 0 | 0 | 1 | 1 | 0 | XXXX | 0001 | XXXX | X000 |
| Write Register 0 | 0 | 1 | 0 | 0 | XXXX | XX00 | 0000 | 0111 |
| Select Register 1 | 0 | 1 | 1 | 0 | XXXX | 0001 | XXXX | X001 |
| Write Register 1 | 0 | 1 | 0 | 0 | XXXX | XX00 | 0000 | 1010 |
| Select Register 3 | 0 | 1 | 1 | 0 | XXXX | 0001 | XXXX | X011 |
| Write Register 3 | 0 | 1 | 0 | 0 | XXXX | XX00 | 1000 | 0000 |
| Select Register 4 | 0 | 1 | 1 | 0 | XXXX | 0001 | XXXX | X100 |
| Write Register 4 | 0 | 1 | 0 | 0 | 0111 | 0100 | 1011 | 0001 |

Table 4. The Port A Access Control to Program Flags

First of all, Register is programmed to the decimal number " 7 ". Note that Bit 9 of Registers $0-3$ should be programmed to 0 for the IDT7251/510. Register 1 is set to decimal " 10 ". Since $B \rightarrow$ A Almost-Empty flag is not used, Register 2 is not programmed. Register 3 is set to decimal " 128 ". Register 4 is programmed to designate each flag pin assignment.

## Internal Flags

Besides the external flag pins, the internal flag information can be accessed through reading the Status Register (see data sheet). As shown in Table 5, Format 0 provides the information for only four flags (Bit 12 to Bit 15). In Format 1,

| Bit | Format 0 |
| :--- | :--- |
| 0 |  |
| 1 |  |
| 2 | Odd Byte Register Bits 0-7 |
| 3 |  |
| 4 |  |
| 5 |  |
| 6 | Valid Bit |
| 7 | Write Parity Error |
| 8 | Read Parity Error |
| 9 | Status Format: 0 |
| 10 | A $\rightarrow$ B Full |
| 11 | A $\rightarrow$ B Full - Offset |
| 12 | B $\rightarrow$ A Empty |
| 13 | B $\rightarrow$ A Empty + Offset |
| 14 |  |

four extra bits (Bit 4 to Bit 7) complete the whole internal flag information. For all the flag bits of the Status Register, "1" indicates that the particular flag is on.

## The Default Operation of the Programmable Flags

After the "Reset All" command is executed (or Reset line is asserted at the IDT72520/510), Register 0-3 are cleared and Register 4 is set as " 0110010000100000 ", which means:

$$
\begin{aligned}
& \text { FLGA }=A \rightarrow B \text { Empty } \\
& \text { FLGB }=A \rightarrow B \text { Full } \\
& \text { FLGC }=B \rightarrow A \text { Empty } \\
& \text { FLGD }=B \rightarrow A \text { Full }
\end{aligned}
$$

| Blt | Format 1 |
| :--- | :--- |
| 0 | Reserved |
| 1 | Reserved |
| 2 | Reserved |
| 3 | DMA Direction |
| 4 | $\mathrm{~A} \rightarrow$ B Empty |
| 5 | $\mathrm{~A} \rightarrow$ B Empty + Offset |
| 6 | B $\rightarrow$ A Full |
| 7 | B $\rightarrow$ A Full - Offset |
| 8 | Valid Bit |
| 9 | Write Parity Error |
| 10 | Read Parity Error |
| 11 | Status Format: 1 |
| 12 | A $\rightarrow$ B Full |
| 13 | A $\rightarrow$ B Full - Offset |
| 14 | B $\rightarrow$ A Empty |
| 15 | B $\rightarrow$ A Empty + Offset |

Table 5. Status Register Format

## by John Chen

The BiFIFO family consists of the Bus-Matching BiFIFOs and the Parallel BiFIFOs. The BiFIFO architecture allows the user to expand the width of the Port A and Port B data bus. There are two methods of cascading multiple Bus-Matching BiFIFOs for width expansion: the stand-alone expansion
configuration and the master/slave expansion configuration. As for the Parallel BiFIFOs, only the stand-alone expansion configuration is available. Figure 1 comprises of all possible expansion configurations.

|  | Bus-Matching BIFIFO (IDT7251/72510/7252/72520) | $\begin{gathered} \text { Parallel BIFIFO } \\ \text { (IDT72511/72521) } \end{gathered}$ |
| :---: | :---: | :---: |
| Stand-alone (1 pcs) | 18-to-9 | 18-to-18 |
| Master/Slave | 36-to-9 | N/A |
| Stand-alone (2 pcs) | 36-to-18 | 36-to-36 |
| Stand-alone (3 pcs) | 54-to-27 | 54-to-54 |

Figure 1. Expansion Configuration

## BUS-MATCHING BiFIFO

The IDT7251/72510/7252/72520 are bidirectional FIFOs configured as 18-to-9 in bus width. Generally, these BiFIFOs are ideal for data buffering between two systems with different data bus widths. This could be used for CPU-to-CPU or CPU-to-Peripheral communication. The processor/peripheral mode selection in Configuration Register 5 eases these two applications. A single BiFIFO can support an 18-to-9 configuration.

## Stand-Alone Expansion

The stand-alone expansion configuration allows as many BiFIFOs to be expanded in parallel as the user requires. To use the stand-alone mode, the BiFIFOs should be programmed
as "Stand-Alone" in the Width Expansion Mode Control in Configuration Register 5. Let's define the two-byte data as a word, and the four-byte data as a double word. The byte ordering on Port A side is arranged as:

Byte 0, Byte 2 for low and high bytes of BiFIFO 1;
Byte 1, Byte 3 for low and high bytes of BiFIFO 2;
with low byte defined as DA7-DAO, high byte as DA15-DA8. The first word read from Port B bus will be Byte 0 from BiFIFO 1 and Byte 1 from BiFIFO 2. The second word will be Byte 2 and Byte 3. The previous discussion is based on the assumption that Bit 1 of Configuration Register 5 is set to " 0 ", which enables the low byte coming out of Port $B$ before the high byte. In this example, Byte 0 is before Byte 2 and Byte 1 is before Byte 3. A 36 -bit to 18 -bit bidirectional application using two BiFIFOs is shown in Figure 2.


Figure 2. Stand-alone Expansion

## Master/Slave Expansion

The Master/Slave architecture allows 2 BiFIFOs to be cascaded together in a configuration that produces a data path of 36 bits wide in the Port A side, and a data path of 9 bits wide on the Port $B$ side (if parity bits are not used, this becomes a 32-bit/8-bit configuration).

The essence of the master/slave architecture is that the read/write operations on Port $B$ of both the slave and master BiFIFOs are controlled by the master device. In general, four generations in Port $B$ are required for every one operation in

Port A. As an example in Figure 3, if a 36 bit double word is written into Port A, 4 reads are required to flush this double word out of the BiFIFO. Conversely, 4 writes into Port B of the expanded configuration are required before a double word canbe readout of Port A. The master/slave BiFIFO architecture is defined to require the master BiFIFO to command the slave to complete 2 read or write cycles first, before the master BiFIFO is allowed to execute 2 read or write cycles.

There are two Master/Slave Expansion Configurations, the Processor mode, and the Peripheral mode.


Figure 3. Master/Slave Expansion

## Peripheral Master/Slave Expansion

To implement the Peripheral Master/Slave expansion configuration, both the Master and the Slave device must be programmed in the Peripheral mode. The DMA handshake operates out of the Master device; therefore, the Slave BiFIFO must be disabled by tying both the REQ and CLK lines low and leave the $\overline{A C K}$ line floating, as shown in Figure 4.

The Master device controls the byte order of the 36 bit words going into and out of Port B according to DMA protocol,
which requires that the master device receive a REQ input before it can input or output data through Port B. Once a REQ input has been received at the master device, the master BiFIFO generates an ACK response to the peripheral device and then sent read/write control signal to the Slave and peripheral device. After 2 slave operations, the master is allowed 2 operations to complete definition of the 36 bit doubleword.


2734 drw 04
Figure 4. Peripheral Master/Siave Expansion

Byte ordering is adjustable by programming Bit 1 of Configuration Register5 in both the Master and Slave devices. As an example, the least significant byte of the 36 -bit Port A data bus in Figure 4 is defined to be Byte 0 , then there are 4 byte orderings possible, as shown in Table 1.

| Master | Slave | Byte Order |
| :---: | :---: | :---: |
| 0 | 0 | $0,1,2,3$ |
| 0 | 1 | $1,0,2,3$ |
| 1 | 0 | $0,1,3,2$ |
| 1 | 1 | $1,0,3,2$ |

2734 tol 01

## Processor Master/Slave Expansion Configuration

To implement the Processor Master/Slave expansion configuration, Port B responds to any read or write control signals input on the $\overline{\mathrm{DS}} \mathrm{B}$ and $\mathrm{R} \overline{\mathrm{W}} \mathrm{B}$ pins (in Motorola mode) or $\overline{\mathrm{R} B}$ and $\overline{\mathrm{W}} \mathrm{B}$ (in Intel mode). The Processor Master/Slave expansion configuration is the same as the Peripheral Master/ Slave expansion configuration, except Port B of the BiFIFOs is programmed in the Processormode instead of the Peripheral mode. Even though the Peripheral mode is inactive, the CLK and REQ lines must be pulled low to satisfy the hardware reset requirement for the IDT72510/IDT72520. The Processor Master/Slave expansion configuration is shown in Figure 5.

Table 1. Byte Ordering


2734 drw 05
Flgure 5. Processor Master/Slave Expansion

In this configuration, Port B of the master device waits for either a read or write strobe (or $\overline{\mathrm{DS}} \mathrm{B}, \mathrm{R} / \overline{\mathrm{W}} \mathrm{B}$ ). The Master device lets the Slave device accept the first 2 read or write strobes. After the slave has completed 2 read or write cycles, the Master accepts the next 2 read or write inputs. The read/ write control signals in the Processor mode are inputs, on the contrary, the read/write control signals inthe Master Peripheral mode are outputs.

The byte order in which bytes are written into Port B in the Processor Master/Slave expansion configuration is also adjustable by programming Bit 1 of Configuration Register 5.

## PARALLEL BiFIFO

The IDT72511/72521 are parallel bidirectional FIFOs configured as 18 -to-18 in bus width. These BiFIFOs are ideal for data transferring between two processors or a processor and a peripheral of equal bus width. A single BiFIFO can support a 18-to-18 port configuration.

## 18-to-18

This is the default configuration of the IDT72511/72521. The core memory of Port A data bus is arranged in the order as follows: Da0-Da7, Da16, Dab-Dai5, Da17. Asfor Port B: DboD87, DB16, D88-DB15, D817. The entire data bus is used under the 18-to-18 configuration. In case the processors require only 16 bit data bus, the extra data bits can be disabled by letting all of the pins - DA16, DA17, and DB16, DB17 - stay floating. An alternative is to tie a $10 \mathrm{~K} \Omega$ or greater resistor between each data bit and ground to minimize stand-by current. The data will then only be transferred between DaODA15 and D80-DB15.

## Stand-Alone Expansion

The stand-alone expansion configuration allows an infinite numbers of BiFIFOs to be expanded in parallel to increase word width. No internal software programming is necessary to configure the stand-alone mode. A 36-bit or 32-bit data bus can simply be connected with two BiFIFOs in parallel as shown in Figure 6. The order of the data written into one port will output the exact data to the other port.


Figure 6. Stand-alone Expansion

The Master/Slave expansion configutation is not available in the ParallelBiFIFOs. The Processor or Peripheral interface mode for Port B operates in parallel BiFIFOs the same as the
bus-matching BiFIFOs. This is programmed through Bit 10 of Configuration Register 5.

THE BiFIFO BYPASS

## by John Chen and Steve Eldson

A bypass path on the IDT BiFIFO family allows small blocks of data to be exchanged directly between the processor connected to Port A and a peripheral controller on Port B. The bypass path is mostusefulfor initializingperipherals and receiving messages from these peripherals. The bypass path is shown in the detailed block diagram of the BiFIFO (Figure 1).

## BYPASS FUNCTION

The bypass path is enabled by setting the address select pins to $A 1=0, A 0=1$. In the bypass mode, the data bits from Port A (Da7-DA0, DA16) are passed directly to Port B (DB7-DBo, DB8) and the data bits from Port B are passed directly to Port A. Only lower byte Da16 and Da7-Dao are passed through to D88-DBo.
For a single BiFIFO configuration, bypass can only be enabled when the Port B interface pins are set to be outputs (peripheral interface mode). Bypass will not work if the Port B interface pins are set to be inputs (processor interface mode). Bits 10 to 12 of Configuration Register 5 must be programmed to 001 to put the BiFIFO in stand-alone peripheral interface mode.

When using the bypass path for two BiFIFOs in a 36-to-9bit configuration, the Master and Slave devices must both be in peripheral interface mode. Bits 10 to 12 of the Master BiFIFO's Configuration Register 5 must be set to 111, while the Slave BiFIFO's bits must be setto 101. Since the byte data on (Da7-Dao, Da16) pins of both Master and Slave will be passed to Port B bus concurrently, these two byte data should be identical to avoid data contention.

Because port $B$ is placed in the DMA mode, the $\overline{D S} 8$ and $R /$ $\bar{W} B$ output pins reflect the action of $\overline{\mathrm{DS}} \mathrm{A}$ and $\mathrm{R} / \overline{\mathrm{W}} \mathrm{A}$ input pins. The port B interface can operate either as an Intel- or a Motorola-style processor interface by programming Bit 0 of Configuration Register 5. For example, when Port B is programmed to a Motorola-style interface, $\overline{\mathrm{DS}}$ follows the state of $\overline{D S} A$. Similarly, $R \bar{W} B$ reflects the state of $R \bar{W} A$. If Port $B$ is programmed to be an Intel-style interface, then the $\overline{D S} A$ and $\mathrm{R} / \mathrm{W}_{\mathrm{A}}$ are translated to read strobe ( $\overline{\mathrm{R} B}$ ) and write strobe ( $\overline{\text { W }}$ B). The Intel read cycle ( $\overline{\mathrm{R}} \mathrm{B}$ ) is asserted LOW when $\overline{\mathrm{DS}} \mathrm{A}$ is asserted LOW and R/W signal ( $\overline{\mathrm{W}} \mathrm{B}$ ) is asserted LOW when $\overline{\mathrm{DS}}$ A is asserted LOW and R/WA is LOW.


2736 dww 01
Figure 1. BiFIFO Functlonal Block Dlagram

## CONFIGURATION REGISTER 5 FORMAT

| Bit | Function |  |  |
| :---: | :---: | :---: | :---: |
| 0 | Select Port B Interface $\bar{R}_{B} \& \bar{W}_{B}$ or $\overline{\mathrm{DS}} \mathrm{B}$ \& $\mathrm{R} \overline{\mathrm{N}_{\mathrm{B}}}$ | 0 |  |
|  |  | 1 | Pins are $\overline{\mathrm{DS}} \mathrm{B}$ and $\mathrm{R} \overline{\mathrm{W}} \mathrm{B}$ (Motorola-style interface) |
| 1 | Byte Order of 18-bit Word | 0 | Lower byte DA7-DA0 and parity DA16 are read or written first on Port B |
|  |  | 1 | Upper byte DA15-DAB and parity DA17 are read or written first on Port B |
| 2 | Full Flag Definition | 0 | Full Flag is asserted when write pointer meats read pointer |
|  |  | 1 | Full Flag is asserted when write pointer meets reread pointer |
| 3 | Empty Flag Definition | 0 | Empty Flag is asserted when read pointer meets write pointer |
|  |  | 1 | Empty Flag is asserted when read pointer meets rewrite pointer |
| 4 | REQ Pin Polarity | 0 | REQ pin active HIGH |
|  |  | 1 | REQ pin active LOW |
| 5 | ACK Pin Polarity | 0 | ACK pin active LOW |
|  |  | 1 | ACK pin active HIGH |
| 7-6 | REQ / ACK Timing | 00 | 2 internal clocks between REQ assertion and ACK assertion |
|  |  | 01 | 3 internal clocks between REQ assertion and ACK assertion |
|  |  | 10 | 4 internal clocks between REQ assertion and ACK assertion |
|  |  | 11 | 5 internal clocks between REQ assertion and ACK assertion |
| 8 | Port B Read and WriteTiming Control for Peripheral Mode | 0 | $\overline{\mathrm{F}}_{\mathrm{B}}, \overline{\text { We}}_{\mathrm{B}}$, and $\overline{\mathrm{DS}}_{\mathrm{B}}$ are asserted for 1 internal clock |
|  |  | 1 | $\overline{\mathrm{F}} \bar{B}^{\prime}, \overline{\mathrm{W}}$ B, and $\overline{\mathrm{DS}} \mathrm{B}$ are asserted for 2 internal clocks |
| 9 | Internal Clock Frequency Control | 0 | internal clock = CLK |
|  |  | 1 | internal clock $=$ CLK divided by 2 |
| 10 | Port B Interface Mode Control | 0 | Processor interface mode (Port B controls are inputs) |
|  |  | 1 | Peripheral interface mode (Port B controls are outputs) |
| 12-11 | Width Expansion Mode Control | 00 | Stand-alone mode (18-to 9-bits, 36 - to 18 -bits) |
|  |  | 01 | Reserved |
|  |  | 10 | Slave width expansion mode (36- to 9-bits) |
|  |  | 11 | Master width expansion mode (36- to 9-bits) |
| 13 | Unused |  |  |
| 14 | Unused |  |  |
| 15 | Unused |  |  |

Table 1. Register 5 Format

| Integrated Device Technology, Inc | DESIGNING WITH THE IDT SyncFIFO ${ }^{\text {M }}$ : THE ARCHITECTURE OF THE FUTURE | APPLICATION NOTE AN-60 |
| :---: | :---: | :---: |

by J. Scolt Gardner, Field Applications EngIneer

## INTRODUCTION

The use of First-In-First-Out (FIFO) buffers to pass information between digital circuits with differing data rates has been a standard practice in interface design. The IDT synchronous FIFO is a new architecture designed to support high-speed systems.

## THE EVOLUTION OF FIFO ARCHITECTURES

The IDT SyncFIFO can be viewed as the third generation architecture in FIFO design. The initial FIFO architecture (illustrated in Figure 1) used an architecture based on a register array indexed by special control logic which sequenced a pointer within the array. Prior to the introduction of register-based FIFOs, designers used shift registers to buffer data between systems. More general than the shift register approach, the register-based FIFO architecture is also limited in depth, due to the number of transistors needed to build each flip-flop storage element.

The second-generation FIFO introduced very large buffers based on a static memory array. The RAM-based FIFO is shown in Figure 2. The internal RAM array is actually a dualported memory addressed by the use of internal pointers. These internal pointers determine which address of the RAM will provide the data during a FIFO READ or store data during a FIFO WRITE.
With the availability of large FIFOs with buffer memory as large as 4 Kbytes , the need for memory management accentuated the need for external flags. These flags allow the user to monitor the amount of data in the FIFO. Most secondgeneration FIFOs have been enhanced to provide flags indicating a variety of FIFO conditions. Newer FIFOs, including the SyncFIFO, allow flags to be programmed to a selectable depth. Figure 3 is a block diagram of the enhanced asynchronous FIFOs.


Figure 1. Register-Based FIFO Architecture-FIrst Generation


Figure 2. RAM-Based FIFO Architecture-Second Generation


Flgure 3. Enhanced Aynchronous FIFO

## THE SyncFIFO ARCHITECTURE: <br> THE ARCHITECTURE OF THE FUTURE

The SyncFIFO improves on the RAM-based FIFO architecture by adding input and output registers in the data path. These registers are controlled by independent external clocks, allowing data operations to be synchronized with the clock edges. Many system designers are designing high-speed systems using a synchronous approach, since the complexity of the control circuitry increases with speed in an asynchronous system. In a synchronous system, the amount of control logic is minimal and does not change as the system clock frequency is increased. As system clock rates approach 25 MHz , it becomes more economical to use a synchronous design. (See Figure 4.)

## ADVANTAGES OVER THE ASYNCHRONOUS FIFO

The concept of the synchronous FIFO is not new. Many synchronous designs requiring that data transfers occur on a clock edge use external registers with an asynchronous FIFO. The READ and WRITE control signals for the FIFO must be generated by special control logic, but the device accessing the FIFO through the registers sees the FIFO as a synchronous device. Figure 5 shows the asynchronous FIFO used in a synchronous application. The primary limitation of this approach is the performance degradation due to the long data set-up time needed by the FIFO. The performance loss is evident in operations requiring consecutive accesses, since the data set-up time must be taken into account when determining the maximum cycle time.

Using an asynchronous FIFO in a high-speed system can also require special design techniques for generating the FIFO control signals. As the cycle time is decreased in higher speed systems, the width of the READ or WRITE pulse becomes very small. The minimum pulse width for asynchro-
nous FIFOs has been reduced to less than 20ns on faster devices. Generating accurately timed control pulses can require additional circuitry of greater complexity. Very narrow control pulses must be generated by using pulse shaping logic based on a system clock. It is sometimes difficult to generate properly timed narrow control pulses, since the timing margins become so small.

Figure 6 illustrates the simplicity of the IDT SyncFIFO interface. Passing data through the IDT SyncFIFO is based on a clock edge with a data set-up time of only 5 ns and a data hold time of 1 ns . A FIFO of this type allows clock rates of 50 MHz . No external pulse shaping logic is required; the only control pulses required are the free-running system clock and a simple enable signal.
In systems using pipelining, the SyncFIFO can be used as a pipeline stage without external registers, as the registers that would normally be added externally for pipelining are included in the SyncFIFO. The use of pipelining can lead to even faster aggregate data rates.

## REDUCED SENSITIVITY TO GLITCHES

Another problem faced by the designer of high-speed systems using fast asynchronous FIFOs is the sensitivity to glitches. A FIFO capable of responding to fast READ or WRITE pulses may recognize noise-induced glitches as valid control pulses. The minimum pulse widths are specified as worst-case values, and a designer must be careful to consider all operating conditions. A glitch which doesn't affect system operation during lab tests may become a problem at cold temperatures or higher supply voltages. Careful board design techniques or additional circuitry may be required in fast systems to reduce glitches on the READ and WRITE lines. By comparison, the SyncFIFO only recognizes READ and WRITE accesses during the transition of the clock signals, insuring increased noise immunity in the system.


Figure 4. Increasing Clock Frequency Necessitates Synchronous Designs


Figure 5. Typical Asynchronous Design


Figure 6. Typical Synchronous Design


Figure 7. Block Diagram of the IDT SyncFIFO

## FEATURES AND OPERATION OF THE SyncFIFO

Many of the features of IDT's SyncFIFOs are similar to the features of IDT's asynchronous FIFOs. Numerous Technical Notes and Application Notes have been published by IDT to assist the designer using asynchronous FIFOs; therefore, only the new features of the SyncFIFO will be covered in depth in this document.

The functional block diagram of the IDT SyncFIFO in standalone mode is shown in Figure 7. The first devices from IDT are the IDT72215 with a $512 \times 18$ memory array and the IDT72225 with a $1024 \times 18$ memory array. These devices allow for very fast throughput with read or write cycle times as fast as 20 ns .

Many other sizes and word widths will be provided in subsequent devices. The speed of the IDT SyncFIFO is specified by the maximum clock rate. Both SyncFIFOs operate up to 50 MHz . The synchronous nature of the architecture will allow the clock rate to increase in later products.

## WIDTH EXPANSION

As in previous FIFOs, width and depth expansion are easily accomplished. Expanding the width of the FIFO is very straightforward. Basically, data passes in parallel through multiple devices. The input control signals are connected on all devices, and the status flags may be read from any device. Any word width may be attained which is a multiple of the device word size. Figure 8 shows how a 36 -bit word is implemented using two 72215 s or 72225 s.

## DEPTH EXPANSION

To expand in depth, a daisy-chain technique is used. The first FIFO in the chain is the master (designated by tying $\overline{\mathrm{FL}}$ to ground). The remaining FIFOs in the chain are slave components (designated by tying $\overline{F L}$ to Vcc).

The master device is the device which controls all the flags and must always be the first device. The flags are ignored from the other devices. In the depth expansion mode, the Half-Full Flag $(\overline{\mathrm{HF}})$ is not available, since this pin is shared with the Write Expansion Out ( $\overline{W X O}$ ) signal.

To control how data is passed from one device to the other, Expansion In $(\overline{\mathrm{XI}})$ and Expansion Out ( $\overline{\mathrm{XO}}$ ) signals are provided to control the transfer of data. In single device mode the $\overline{\mathrm{XI}}$ lines are tied to ground. For multiple devices, the $\overline{\mathrm{XI}}$ and $\overline{\mathrm{XO}}$ lines are tied together between each device. Figure 9 is an example of the SyncFIFO used in depth expansion mode.

This example shows how three devices can be chained together to provide a deeper FIFO interface. Using three 72215 s , the total depth is 1536 words of 18 -bit data. This daisy-chain technique can be used to achieve depths up to 32,768 words by adding more devices.

The total depth of the configuration is programmed into the master device using the depth register. The total number of FIFOs in the configuration is loaded into the 5 -bit register on the third Write Clock (WCLK) while the Load ( $\overline{\mathrm{DD}}$ ) pin and the Write Enable ( $\overline{\mathrm{WEN}}$ ) are held Low. Figure 10 shows all the possible values for the depth register of the 72215 and the 72225.


Figure 8. Width Expansion of the IDT SyncFIFO


Figure 9. Depth Expansion of the IDT SyncFIFO

| IDT72215 |  | IDT72225 |  |
| :---: | :---: | :---: | :---: |
| DATA LOADED IN DEPTH REGISTER | TOTAL DEPTH IN EXPANSION CONFIGURATION | DATA LOADED IN DEPTH REGISTER | TOTAL DEPTH IN EXPANSION CONFGURATION |
| 0 (DEFAULT) | 512 | 0 (DEFAULT) | 1024 |
| 1 | 512 | $i$ | 1024 |
| 2 | 1024 | 2 | 2048 |
| 3 | 1536 | 3 | 3072 |
| 4 | 2048 | 4 | 4096 |
| 5 | 2560 | 5 | 5120 |
| 8 | 3072 | 6 | 6144 |
| - | - | - | - |
| - | - | - | - |

Figure 10. Depth Register Programming

## INDEPENDENT READ AND WRITE CLOCKS

Although the SyncFIFO handles data synchronously, the clocks are independent on each side of the FIFO. These clocks could even be free-running system clocks with different frequencies. The IDT SyncFIFO handles the transfer of data between the two systems, simplifying the timing issues normally associated with a system of this type. It is, however, possible to use the same clock for both sides of the FIFO.

## USING FLAGS FROM THE IDT SyncFIFO

The flags available on the IDT72215 and IDT72225 are the Empty Flag ( $\overline{\mathrm{EF}}$ ), the Full Flag ( $\overline{\mathrm{FF}}$ ), the Half-full Flag ( $\overline{\mathrm{HF}}$ ) and two programmable flags. The Programmable Almost Empty ( $\overline{\mathrm{PAE}}$ ) and the Programmable Almost Full ( $\overline{\mathrm{PAF}}$ ) flags can be set to any location by the user.
These flags differ from the flags available on the latest asynchronous FIFOs in that they are updated on clock transitions. The $\overline{\mathrm{EF}}$ is tied to. RCLK and the $\overline{\mathrm{FF}}$ is tied to WCLK. The three other flags are updated by either clock, depending on their current state (see data sheet). The impact of this difference will be discussed in the next section.
As with the asynchronous FIFOs, the flags operate based on the value of the internal pointers. Two separate pointers are maintained, a read pointer and a write pointer. When the last word is read from the FIFO, the read pointer equals the write pointer, and $\overline{E F}$ is asserted. When the write pointer reaches the last location in the FIFO and data is written, then FF is asserted. Likewise, the half-full flag is asserted whenever the

| $\overline{L D}$ | $\overline{\text { WEN }}$ | WCLK | SELECTION |
| :---: | :---: | :---: | :--- |
| 0 | 0 | $\square$ | EMPTY OFFSET <br> FULL OFFSET <br> DEPTH REGISTER $\rightarrow$ |
| 0 | 1 | $\square$ | NO OPERATION |
| 1 | 0 |  | WRITE INTO FIFO |
| 1 | 1 |  |  |

Figure 11. Offset Registers and the Depth Register
difference between the Read pointer and Write pointer is $\geq$ half the size of the FIFO RAM array.

The programmable flags use offset values which are programmed into internal registers. For the $\overline{\text { PAE flag, the signal }}$ will be asserted when the Read pointer is $n$ locations less than the Write pointer. As an example, suppose the FIFO is being used as a 175-word frame buffer. It is necessary to notify the processor when a frame has been received, but data may continue to arrive in the buffer. The Empty Offset Register would be programmed with the value 175 . Using this value, the $\overline{\text { PAE }}$ flag would go High after 175 writes to the FIFO. The processor could receive this signal as an interrupt to read out the 175 -word data block.

The $\overline{\text { PAF }}$ flag can be used to signal the processor after (FULL - m) writes to the FIFO. For instance, a certain system might take some time to respond to a signal from the FIFO and begin clocking out data. To notify the processor 6 write clocks in advance of the FIFO becoming full, a value of 6 is written into the Full Offset Register. This allows the user to optimize his system for the depth of the FIFO.

To write a value into one of the offset registers, $\overline{\mathrm{WEN}}$ and $\overline{\mathrm{LD}}$ are set Low. The data on the input data bus is written into the Empty Offset Register on the first Low-to-High transition of WCLK. On the second Low-to-High transition of WCLK, the Full Offset Register is written with the data inputs. The third clock transition programs the depth register. Figure 11 shows the manner in which the internal registers are programmed.

## DESIGN CONSIDERATIONS

The simplicity of the interface to the SyncFIFO makes it an ideal candidate for new designs, especially when higher throughput is required. If the design is made synchronous at the outset, later speed improvements to a system do not require a redesign of the FIFO control logic.

One of the design considerations for the SyncFIFO concerns the manner in which the input and output registers interact with the internal RAM array. It is important to note that the data goes into the input register on the Low-to-High transition of the WCLK. During the first write to the FIFO, data is also stored into the internal RAM array on the same Low-toHigh transition that loads the input register. This avoids the presence of a write latency cycle on the first Write.
To determine when data can be clocked out of the FIFO, the amount of skew between the WCLK and the following RCLK will determine if sufficient time has been allowed for the new data to be stored in the RAM. Once data has been clocked in using WCLK, the data will be available in the internal RAM for access by the read port after tSKEW1 ns (see Figures 12 and 13 for read and write cycle waveforms, and Figure 14 for the skew specifications). If this skew timing is not met, an extra
cycle of latency will be required for clocking data from the FIFO.

The output register of the SyncFIFO adds a full cycle of read latency before data is available on the output pins. This latency is a result of the need to allow time for the flags to be updated. External circuitry may need extra time to respond to the flag signals. This is especially true for the $\overline{E F}$. If a single word is written into an empty FIFO, the EF will become deasserted tREF ns after the following RCLK. This assumes that the RCLK occurs more than tskew ns after the WCLK. If the skew time is not met, an additional RCLK cycle will be required before the $\overline{E F}$ can be asserted. The data will be available on the output pins ta ns after the next RCLK.
To help clarify the timing issues, consider an example of a system which uses coincident clocks by tying the RCLK and the WCLK lines together. The $\overline{W E N}$ and $\overline{R E N}$ lines are used to control the transfer of data. If a single word is written into the FIFO on the WCLK, it will take two additional RCLKs before data will appear on the output pins. The coincident RCLK obviously does not meet the skew timing requirement. The first RCLK after the coincident WCLK/RCLK will update the flags and the second RCLK will affect the data transfer to the output pins.


## NOTE:

1. tskEw is the minimum time between a rising WCLK edge and a rising RCLK edge for $E F$ to change during the current clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than tsKEW1, then EF may not change state until the next RCLK edge.

Flgure 12. Read Cycle Timing


NOTE:

1. tskew is the minimum time between a rising RCLK edge and a rising WCLK edge for FF to change during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than tsKEw, then FF may not change state until the next WCLK edge.

Figure 13. Write Cycle Timing

| SYMBOL | PARAMETER | $\begin{gathered} \text { COM'L } \\ \text { 72215/16L20 } \\ 72225 / 26 \mathrm{~L} 20 \end{gathered}$ |  | COM'L \& MIL. 72215/16L25 72225/26L25 |  | $\begin{gathered} \text { MIL. } \\ \text { 72215/16L30 } \\ \text { 72225/26L30 } \end{gathered}$ |  | COM'L \& MIL 72215/16L50 72225/26L50 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| ${ }^{\text {t }}{ }_{\text {KKEW }}$ | Skew time between Read Clock \& Write Clock for Empty Flag \& Full Flag | 14 | - | 16 | - | 18 | - | 20 | - | ns |

Figure 14. Skew Specifications

## EXAMPLES OF SyncFIFO DESIGNS

The application areas of the SyncFIFO are not different from applications of asynchronous FIFOs. Figure 15 shows an application of the SyncFIFO in a graphics system. An asynchronous FIFO could have been used for this application, but the speeds typically required by graphics systems would have made the implementation difficult. The data sent to the graphics rasterizer usually occurs as blocks of data, and repetitive writes to the FIFO require very fast cycle times.

Figure 16 shows how two SyncFIFOs can be used as a highspeed bidirectional interface between two 16 -bit microprocessors. As in the previous example, an asynchronous FIFO might be sufficient for slow systems. The steady advance in processor speeds has led to the need for the SyncFIFO and its ability to handle the fast data rates.
In a microprocessor system the speed of the processor is very important, but of equal concern is the amount of bus bandwidth available for communicating with external devices. It is important that bus operations be accomplished as efficiently as possible. In the multiprocessing example, processor A usualiy needs to pass a block of data to processor B. The sooner the block of data is written into or read from the FIFO, the sooner the processor can return to its own processing tasks. The SyncFIFO is able to accommodate a block transfer rate of 50 MHz or $100 \mathrm{Mbytes} / \mathrm{sec}$, including parity. Width expansion would allow for $400 \mathrm{Mbytes} / \mathrm{sec}$ transfer rate in a 64 -bit system. The SyncFIFO architecture will allow for the bandwidth requirements of even faster systems in the future.

## USE IN ASYNCHRONOUS SYSTEMS

A SyncFIFO can be used in an asynchronous system; however, care must be taken in observing the timing considerations. Of primary concern is the minimum setup time for the $\overline{\mathrm{REN}}$ or $\overline{\mathrm{WEN}}$ signals. This is the time before the data can be clocked in or out of the FIFO registers. For instance, if the MemWR pulse in an asynchronous system is to be used to generate the WCLK pulse, care must be taken to insure that WEN occurs at least 8 ns before the rising edge of WCLK (for a $20 n \mathrm{n}$ device). One method of generating the proper timing is to use a system clock to synchronize the control signal, thus insuring proper setup times.
In a simple asynchronous interface, the $\bar{W} E N$ pulse can be generated by the chip select pulse. The chip select pulse is generated by the FIFO address decoder. The MemWR signal can be used to drive the WCLK line. The data lines must be stable at least 5 ns before the rising edge of the $\overline{\text { MemWR }}$ pulse.

To clock data asynchronously from the FIFO, the chip select line can be used to drive the $\overline{\operatorname{REN}}$ line. The $\overline{M e m R D}$ pulse can be inverted to provide a properly timed RCLK. The $\overline{\operatorname{REN}}$ signal must meet the 8 ns setup requirements (for a 20 ns device). The extra latency cycle for reading data may be taken into account by the device reading the FIFO. The EF will go Low when the last word is stored in the output register.

It is possible to use the MemRD signal directly, but data won't be available until 12 ns after the end of the $\overline{\text { MemRD }}$ pulse (worst case). The access time for the FIFO would have to include the width of the MemRD pulse. If the MemRD is inverted using a 7.5 ns PAL, the asynchronous read is accomplished in about 20ns.


Figure 15. A Graphics System Using the SyncFiFO


Figure 16. A Multiprocessing System Using the SyncFIFO


Figure 17. Using a SyncFIFO in an Asynchronous System

Figure 17 shows an example of the SyncFIFO used in a standard asynchronous system. A system of this type can be cycled much faster than previous solutions using asynchronous FIFOs. This system could also be enhanced to accommodate burst-mode data transfers available on newer processors. A simple counter could provide the burst pulse train needed to clock the data block. Also, note that the flags are synchronized with the clocks (see the next section).

## HOW CLOCKS AFFECT FLAGS

Care must be taken in observing the flags in a SyncFIFO. For instance, upon reading the FIFO, the transfer of the last word from the memory array to the output register causes the assertion of the empty flag ( $\overline{\mathrm{EF}}$ )-not the transfer of the last word of data out of the output register. The flags also differ from previous FIFOs in that the flags change synchronously. The flags are all updated on a clock transition.
One important consideration is that since the flags are updated synchronously, they are not updated until clocked. For instance, consider a system where the inputs are synchronous and the outputs are asynchronous. A word of data is written to the FIFO. The $\overline{\mathrm{EF}}$ does not deassert until a clock
transition on RCLK. So you could fill the FIFO without $\overline{\mathrm{EF}}$ changing if no RCLKs are provided. One solution would be to tie any available fast clocks to RCLK. Another option would be to tie RCLK and WCLK together: (NOTE: $\overline{\mathrm{FF}}, \overline{\text { PAE and PAF are }}$ asynchronous to the clocks on the 72215 and 72225. See data sheet for exact timing diagrams.) So, by using the PAE instead of the EF in this case, you can signal the asynchronous side of the status of the FIFO, since this flag is updated by both clocks.

## CONCLUSION

Using the SyncFIFO greatly eases the design efforts in a high-speed system. The SyncFIFO incorporates all of the enhanced features of the newest asynchronous FIFOs. These features include programmable flags, the ability to store large amounts of data, and the ability to directly drive a 3-state data bus. It is the addition of the input and output registers that makes the SyncFIFO unique. The ability to handle very fast data rates allows the IDT SyncFIFO to keep pace with the high-speed systems being designed today and the faster systems still to come. The IDT SyncFIFO truly represents the architecture of the future.

## DEPTH EXPANSION OF IDT'S SYNCHRONOUS FIFOs USING THE RING COUNTER APPROACH

By Bhanu V. R. Nanduri

## INTRODUCTION

This application note describes a concise design approach to expand in depth IDT's synchronous FIFOs. As an example we will use the IDT72211 synchronous FIFO to demonstrate depth expansionusing the ring counter approach. The discussion in this paper is however applicable to expand in depth all synchronous FIFOs from IDT. The first part of this paper discusses how one can expand in depth two IDT72211 synchronous FIFOs with the help of two industry standard PALs the 20R8s. The second part of this note discusses how one can accomplish depth expansion using four IDT72211s using three 20R8s, that is identical in pin out to a single large four-deep IDT72211. All PALs were programmed using "Capilano Computing Systems LPLC' ${ }^{\text {TM }}$ PLD software package" and a copy of the PAL programs is presented at the end of this paper. As the density and speed of industry standard PALs increases, it should be possible to expand in depth more of these FIFOs with a fewer number of PALs and with minimal loss in performance.

Traditionally, asynchronous FIFOs have been expanded in depth with the help of the $\overline{\mathrm{X}}$ and $\overline{\mathrm{XO}}$ pins provided on these FIFOs. These FIFOs are cascaded in depth by connecting the $\overline{\mathrm{XO}}$ pin of the present FIFO to the $\overline{\mathrm{XI}}$ pin of the next FIFO in the cascade. This procedure is carried out for all the FIFOs in the cascade until the last FIFO in the cascade is reached. The $\overline{\mathrm{XO}}$ pin of the last FIFO in the chain is connected to the $\overline{X l}$ pin of the first FIFO to complete the ring. A pin called the first load pin $\overline{(F L)}$ on one of the FIFOs is grounded to indicate that the first write and read operations will begin in that FIFO. The $\overline{\mathrm{FL}}$ pins of all the other FIFOs in the cascade are however tied to Vcc. The Full flags of all the FIFOs are ORed to provide a composite Full flag, similarly the Empty flags of allthe FIFOs are ORed to provide a composite Empty flag. The user is urged to refer to IDTs technical note TN-09 "Cascading FIFOs or FIFO Modules" for further information on expanding asynchronous FIFOs.

The IDT72215 and the IDT72225 Synchronous FIFOs are provided with two pairs of $\overline{\mathrm{XI}}$ and $\overline{\mathrm{XO}}$ pins to assist the user in expanding these FIFOs using the daisy chain arrangement. One pair of $\overline{\mathrm{XI}}$ and $\overline{\mathrm{XO}}$ pins are used to synchronize write operations in the cascade and are controlled by the WCLK, while the other pair of $\overline{X I}$ and $\overline{X O}$ pins are used to synchronize read operations in the cascade and are controlled by the RCLK. Because of the $\overline{\mathrm{XI}}$ and $\overline{\mathrm{XO}}$ pins on the IDT72215 and the IDT72225 the daisy chain arrangement used in asynchronous FIFO expansion can be likewise used.

## DEPTH EXPANSION OF IDT72211 SYNCFIFOS ${ }^{\text {™ }}$

In this section we shall describe how to expand in depth the IDT72211 synchronous FIFO without any $\overline{\mathrm{XI}}$ and $\overline{\mathrm{XO}}$ pins. This discussion as stated earlier is applicable for expanding in depth all synchronous FIFOs from IDT. The expansion we will describe uses one ring counter to supervise the write operations and another ring counter to supervise the read operations. As a first step let us expand in depth two IDT72211s. Figure 1 illustrates the arrangement to carry out this two-deep depth expansion, the PAL labelled WRENCNTLR supervises the write operations whereas the PAL labelled RENCNTLR supervises the read operations. In addition to carrying out the write and the read operations these PALs also generate the Almost Full, Almost Empty, Full and Empty Flags for the expanded FIFO. Write operations in the IDT72211 are carried out when the two write enables are asserted and occur synchronously on the rising edge of the WCLK. Similarly the read operations are carried out when the two read enables are asserted and occur synchronously on the rising edge of the RCLK. The RCLK and the WCLK inputs of the FIFO can be tied together and connected to a system clock or they can be separately connected to two separate system clocks. The two system clocks can be of either the same frequency or different frequencies as long as the minimum clock period of the device is not violated. IDT synchronous FIFOs have a one deep pipelined architecture and because of this there will be a read latency of one cycle after reset.


Figure 1.

## DESCRIPTION OF THE WRITE ENABLE CONTROLLER (WRENCNTLR)

The write enable controller (WRENCNTLR) is implemented using a fast (tpd $=7.5 \mathrm{~ns}$ ) industry standard 20R8 PAL. Write operations start when the user asserts the write clock and the global write enable "WEN" input to the WRENCNTLR. Write operations are performed synchronously and occur on the rising edge of the WCLK. After reset, the first write operation starts in FIFO A, the second in FIFO B, the third in FIFO A and the fourth in FIFO B. This pattern is repeated for all subsequent write operations. WEN2 inputs of FIFOs A and B are tied to the globalwrite enable "WEN" as shown. The WRENCNTLR provides separate WEN1 strobes to each FIFO. These strobes have been labelled $\overline{W E N \_A}$ and $\overline{W E N \_B}$. A user can stop the write operations to the FIFO by deasserting the global write enable (WEN) input. This will ensure that the WRENCNTLR will stall the present WEN1 signal and not generate the next WEN1 pulse. Care has been taken to ensure that even if the user asserts the global write enable (WEN) input to the WRENCNTLR, the WRENCNTLR will not generate the next WEN1 pulse when the composite Full flag is asserted. The composite Full flag will be asserted when all the FIFOs in the cascade have their Full flags asserted. The WRENCNTLR thus remains in the same state until the composite Full flag is deasserted ensuring that the same write sequence is maintained. The WRENCNTLR will generate an Almost Full flag only when any one of the FIFOs asserts a Full flag. This gives the user a prior warning of one word that he is approaching the end of his data queue. All outputs generated by the WRENCNTLR occur synchronously and are asserted and deasserted on the rising edge of the WCLK.

The FIFOs will each assert their Full flags after 512 words have been written into them but only if no read operations had occurred during this period. A write operation that is performed while the Full flag is asserted is ignored by the FIFOs. Internal to the IDT72211 and transparent to the user is a write inhibit signal that is generated when the FIFO is full. This signal blocks out any subsequent write operations that occur, ensuring that the state of the internal write pointer is not altered and the data in the FIFO is not overwritten.

## DESCRIPTION OF THE READ ENABLE CONTROLLER (RENCNTLR)

The read enable controller (RENCNTLR) like the write enable controller is implemented using a fast industry standard PAL, the 20R8. Read operations start when the user enables the read clock (RCLK) and asserts the active low global read enable input ( $\overline{R E N}$ ) and the active low global output enable input (GOEN) to the RENCNTLR. In our design read sequences are identical to write sequences. Hence after reset the first read starts in FIFO A, the second in FIFO B, the third in FIFO A and the fourth in FIFO B. This pattern is repeated for all subsequent read operations. The $\overline{R E N} 2$ inputs of FIFOs labelled $A$ and $B$ are tied to the global read enable "REN" as shown. The RENCNTLR provides separate $\overline{\text { REN } 1}$ strobes to each FIFO, these $\overline{\text { REN1 }}$ signals have been labelled
$\overline{R E N \_A}$ and $\overline{R E N \_B}$, in addition the RENCNTLR provides separate output enables labelled OEN_A and OEN_B. OEN_A follows $\overline{\operatorname{REN}} \mathrm{A}$ and $\overline{O E N \_B}$ follows $\overline{\operatorname{REN}} \bar{B}$. Auser wishing to stop the read operations can do so by deasserting the global read enable ( $\overline{\mathrm{REN}}$ ) input to the RENCNTLR. This will ensure that the RENCNTLR will stall the present REN1 signal and not generate the next $\overline{\mathrm{REN} 1}$ pulse. Care has been taken to ensure that even if the user asserts the global read enable ( $\overline{\mathrm{REN}}$ ) to the RENCNTLR, the RENCNTLR will not generate the next REN1 pulse if the composite Empty flag is asserted. The RENCNTLR thus remains in the same state until the composite Empty flag is deasserted thus ensuring that the same read sequence is maintained. The RENCNTLR will generate an Almost Empty flag only when one of the FIFOs asserts its Empty flag. This give the user a prior warning of one word that he is approaching the end of his data queue. The RENCNTLR also generates the composite Empty flag when both the FIFOs in the cascade assert their Empty flags. All outputs generated by the RENCNTLR occur synchronously and are asserted and deasserted on the rising edge of the RCLK.

The IDT72211 synchronous FIFO is provided with a transparent output register on the read port. This register is loaded with a new word once every read cycle (provided the FIFO is not empty). This register puts its contents on the output bus only when the output enable input ( $\overline{O E}$ ) is asserted. The function of this output register is to allow the user multiple reads of the same word without incrementing the internal read pointer. A user interested in reading the same word multiple times without altering the state of the internal read pointer can do so by disabling the $\overline{\text { REN1 }}$ and $\overline{\text { REN2 }}$ inputs to the FIFO while asserting its output enable. The user can then sample the output pins of the FIFO once every read clock cycle multiple times. The user can also skip sampling certain data by deasserting the output enable ( $\overline{\mathrm{OE}}$ ) while asserting the read enables ( $\overline{\mathrm{REN} 1}$ ) and ( $\overline{\mathrm{REN} 2}$ ).

Auserwishing to read the same word in our expanded FIFO without incrementing the read pointer can do so by deasserting the global read enable ( $\overline{\mathrm{REN}}$ ) input while asserting the global output enable ( $\overline{\mathrm{GOEN}}$ ) of the RENCNTLR. This operation stalls the read operations and the data in the output register can then be sampled. The user can then sample this output once every read clock cycle for multiple read cycles. Since the IDT SyncFIFOs have a one deep pipelined architecture, depth expansion as described in this section will result in a read latency of one cycle after reset.

The FIFOs each assert their respective Empty flags after 512 words have been read from them and only if no write operations had occurred during this period. A read operation that is performed while an Empty flag is asserted is ignored by the FIFO, it will still however supply the last word read from the FIFO. Intemal to the IDT72211 and transparent to the user is a read inhibit signal that is generated when the FIFO is empty. This signal, analogous to the write inhibit signal, is used to block out any subsequent read operations that occur, ensuring that the state of the internal read pointer is not altered and data in the FIFO's RAM array is not re-read.

## TIMING REQUIREMENTS

Figure 2. and Figure 3. illustrate the timing waveforms for the write and read operations. The timing parameters for the Synchronous FIFO expansion are shown in Table 1. To operate the 15ns IDT72211 Synchronous FIFO we would need a 20R8 PAL whose maximum tco is 4 ns . As these devices are not yet available in these speed grades we have to operate our 15 ns FIFOs with a clock period of 17.5 ns minimum. The reason for this is that the RENCNTLR asserts the read and output enable signals on the rising edge of the RCLK but with a maximum delay of 6.5 ns induced by the PAL. The IDT72211 has a tOE specified at 8ns maximum, this
implies that 14.5 ns ( $\mathrm{tCO}+\mathrm{tOE}=6.5+8 \mathrm{~ns}$ ) after the rising edge of the RCLK, data will be available for sampling. Assuming the sampling side samples the output of the FIFOs also on the rising edge of the RCLK, this leaves only 0.5 ns (tCLK - tco - toe $=15-14.5 \mathrm{~ns}$ ) before the next arrival of a positive edge on the RCLK. This duration may be too short for the sampling side's set-up time requirements. Therefore if we use the RCLK period of 17.5 ns , this would give the sampling side a data setup time of 3 ns , which is a reasonable data set-up time. The user is urged to refer to the IDT72211 and the 20R8 PAL's data sheets for more information on the timing requirements.

| Parameter <br> Symbol | Parameter Description | Min. | Max. |
| :--- | :--- | :---: | :---: |
| tco | PAL's Clock to output delay | 3 ns | 6.5 ns |
| ts | PAL's Set-up time to clock | 7 ns | - |
| trss | FIFO's reset set-up time | 10 ns | - |
| tENS | FIFO's enable set-up time | 4 ns | - |
| tenH | FIFO's enable hold time | 1 ns | - |
| tDS | FIFO's data set-up time | 4 ns | - |
| tDH | FIFO's data hold time | 1 ns | - |
| toE | FIFO's output enable time | - | 8 ns |
| toHZ | FIFO's output disable time | 1 ns | 8 ns |
| tcLK | FIFO and PAL Clock period | 17.5 ns | - |

Table 1.

Figure 2. Write Cycle Timing

Figure 3. Read Cycle Timing

## FOUR DEEP DEPTH EXPANSION OF THE IDT72211 SYNCFIFOS ${ }^{\text {TM }}$

The discussion on the two deep depth expansion using the ring counter approach, described earlier is also applicable in this section for a four-deep depth expansion. Figure 4 illustrates the four-deep depth expansion. Write operations will start when the user asserts the write clock (WCLK) and the active high global write enable "WEN" input to the WRENCNTLR. Write operations are performed synchronously and occur on the rising edge of the WCLK. After reset, the first write operation starts in FIFO A, the second in FIFOB, the third in FIFO C and the fourth in FIFO D. This pattern is repeated for all subsequent write operations. WEN2 inputs of FIFOs A, $B, C$ and $D$ are tied to the global write enable "WEN" as shown. The WRENCNTLR provides separate WEN1 strobes to each FIFO. These strobes have been labelled WEN_A, WEN_B, WEN_C and WEN_D. A user can stop the write operations to the FIFO by deasserting the global write enable (WEN) input. This will ensure that the WRENCNTLR will stall the present $\overline{\text { WEN1 }}$ signal and not generate the next $\overline{\text { WEN1 }}$ pulse. Even if the user asserts the global write enable (WEN) input to the WRENCNTLR, the WRENCNTLR will not generate the next WEN1 pulse while the composite Full flag is asserted. The WRENCNTLR thus remains in the same state until the composite Full flag is deasserted ensuring that the same write sequence is maintained. The WRENCNTLR will generate an Almost Full flag only when any one of the FIFOs asserts a Full flag. This gives the user a prior warning of three words that he is approaching the end of his data queue. The WRENCNTLR will also generate a composite Full flag when all the FIFOs assert their Full flags. All outputs generated by the WRENCNTLR occur synchronously and are asserted and deasserted on the rising edge of the WCLK.

In the four-deep depth expanded FIFO design we need to generate four read enables and four output enables to perform the read operations successfully. In addition we need to generate an Almost Empty Flag and a composite Empty Flag. The 20R8 PALs that we are using have a maximum of eight outputs only, hence this implies that we need to use at least two 20R8s to periorm the read operations successfully. As the density and the functional capabilities of PALs increases it should be possible to implement the RENCNTLR using a single PAL.
Read operations start when the user enables the read clock (RCLK) and asserts the active low global read enable input ( $\overline{\operatorname{REN}}$ ) to the RENCNTLR, in addition the user will have to assert the global (GOEN) input to the OENCNTLR. The OENCNTLR generates the separate output enable inputs to

FIFOs labelled A, B, C and D. In our design read sequences are identical to write sequences. Hence after reset the first read starts in FIFO A, the second in FIFO B, the third in FIFO C and the fourth in FIFO D. This pattern is repeated for all subsequent read operations. The REN2 inputs of FIFOS labelled A, B, C and D are tied to the global read enable "REN" as shown. The RENCNTLR provides a separate $\overline{\text { REN }}$ strobe to each FIFO, these strobes have been labelled $\overline{\text { REN_A, }}$ $\overline{R E N} B \bar{B}, \overline{R E N} C$, and $\overline{R E N}$ D. A user wishing to stop the read operations can do so by deasserting the global read enable ( $\overline{\operatorname{REN}}$ ) input to the RENCNTLR. This will ensure that the RENCNTLR will stall the present $\overline{\text { REN1 }}$ signal and not generate the next $\overline{\mathrm{REN1}}$ pulse. Even if the user asserts the global read enable ( $\overline{\operatorname{REN}}$ ) to the RENCNTLR, the RENCNTLR will not generate the next $\overline{\text { REN } 1}$ pulse if the present FIFO in the cascade has its Empty flag asserted. The RENCNTLR thus remains in the same state until the composite Empty flag is deasserted thus ensuring that the same read sequence is maintained. The RENCNTLR will generate an Almost Empty flag only when one of the FIFOs asserts its Empty flag. This give the user a prior warning of three words that he is approaching the end of his data queue. The RENCNTLR also generates the composite Empty flag when all the FIFOs in the cascade assert their Empty flags. All outputs generated by the RENCNTLR occur synchronously and are asserted and deasserted on the rising edge of the RCLK. The OENCNTLR generates separate output enables to the FIFOs, these separate output enables $\overline{O E N \_A}, \overline{O E N} B, \overline{O E N \_C}$ and $\overline{O E N \_D}$ follow the read enables $\overline{R E N} \_\bar{A}, \overline{R E N}, \bar{B}, \overline{R E N}$ C and $\overline{R E N}$ D.

A user wishing to read the same word in our expanded FIFO without incrementing the read pointer can do so by deasserting the global read enable ( $\overline{\operatorname{REN}}$ ) input to the RENCNTLR and asserting the global output enable (GOEN). This operation stalls the read operation but will assert the output enable of one of the FIFOs which contains the data to be sampled. The user can then sample this output once every read clock cycle for multiple read cycles. Because of this one deep pipelined architecture there occurs a read latency of one cycle after reset in our four deep FIFO expansion.

## SUMMARY

Expanding Synchronous FIFOs in depth can be very easily accomplished as discussed in this paper with minimum external logic. As the density, functionality and speed of industry standard PAL s increases, it will be possible to expand these FIFOs to even larger depths without incurring any loss in performance.

Figure 4.


TITLE X2WENCNTLR; TYPE MMI 20R8;

INPUTS;

| \{ WCLK | NODE [PIN1]; \} | (WCLK INPUT\} |
| :---: | :---: | :---: |
| RS | NODE [PIN2]; | \{SYNCHRONOUS RESET INPUT\} |
| FFA | NODE[PIN3]; |  |
| FFB | NODE[PIN4]; |  |
| WEN | NODE[PIN5]; |  |
| CO | NODE[PIN22]; |  |
| WEN_A | NODE[PIN20]; |  |
| WEN_B | NODE[PIN19]; |  |
| FF | NODE[PIN15]; |  |
| OUTPUTS: |  |  |
| WEN_A | NODE [PIN20]; | \{WEN1 TO FIFO A\} |
| WEN_B | NODE[PIN19]; | \{WEN1 TO FIFO B\} |
| AFF | NODE[PIN16]; | \{ALMOST FULL FLAG FOR THE EXPANSION\} |
| FF . | NODE[PIN15]; | \{FULL FLAG FOR THE EXPANSION\} |
| CO | NODE[PIN22]; | \{CO IS BIT O OF THE TWO BIT COUNTER) |

TERMS;

```
CO NOT := RS AND !WEN AND !WEN_A AND FF AND CO OR
    RS AND !WEN AND !WEN B AND !FF AND !CO OR
    RS AND !WEN AND WEN_A AND WEN_B AND !FF AND !CO OR
    RS AND WEN AND !WEN_B AND !CO OR
    RS AND WEN AND WEN_A AND WEN_B AND :CO OR
    RS AND !WEN AND WEN_A AND WEN_B AND !CO;
WEN_A NOT:= RS AND !WEN AND WEN_B AND WEN_A AND CO OR
    RS AND !WEN AND !WEN_B AND FF AND !CO OR
    RS AND !WEN AND !WEN_A AND !FF AND CO;
WEN_B NOT:= RS AND !WEN AND WEN_B AND WEN_A AND !CO OR
    RS AND !WEN AND !WEN_A AND FF AND CO OR
    RS AND !WEN AND !WEN_B AND !FF AND !CO;
AFF NOT := !FFA AND FFB OR
    FFA AND !FFB OR
    !FFA AND !FFB;
FF NOT := !FFA AND !FFB;
END;
END X2WENCNTLR.
```

| \{AUTHOR: | BHANU V. R. | NANDURI |
| :---: | :---: | :---: |
| COMPANY: | INTEGRATED | DEVICE TECHNOLOGY |
| DATE: | 01/24/89 |  |
| \} |  |  |
| MODULE X | TLR; | ( THIS PAL IS USE READ OPERATIONS X9 OR X8 FIFO EX |

TITLE X2RENCNTLR;
TYPE MMI 20R8;

INPUTS;

| \{WCLK | NODE[PIN1]; \} | \{RCLK INPUT\} |
| :--- | :--- | :--- |
| RS | NODE[PIN2]; | \{SYNCHRONOUS RESET INPUT\} |
| EFA | NODE[PIN3]; |  |
| EFB | NODE[PIN4]; |  |
| REN | NODE[PIN5]; |  |
| OEN | NODE[PIN6]; |  |
| CO | NODE[PIN22]; |  |
| REN_A | NODE[PIN20]; |  |
| REN_B | NODE[PIN19]; |  |
| OEN_A | NODE[PIN18]; |  |
| OEN_B | NODE[PIN17]; |  |
| EF | NODE[PIN15]; |  |

OUTPUTS;

| REN_A | NODE [PIN20]; | \{REN1 TO FIFO A\} |
| :--- | :--- | :--- |
| REN_B | NODE[PIN19]; | \{REN1 TO FIFO B\} |
| OEN_A | NODE[PIN18]; | \{OEN1 TO FIFO A\} |
| OEN_B | NODE[PIN17]; | \{OEN1 TO FIFO B\} |
| AEF | NODE [PIN16]; | \{ALMOST EMPTY FLAG FOR THE EXPANSION\} |
| EF | NODE[PIN15]; | \{EMPTY FLAG FOR THE EXPANSION\} |
| C0 | NODE[PIN22]; | \{CO IS BIT O OF THE TWO BIT COUNTER\} |

TERMS;

```
CO NOT := RS AND !REN AND !REN_A AND EF AND CO OR
    RS AND !REN AND !REN_B AND !EF AND !CO OR
    RS AND REN AND !REN_B AND !CO OR
    RS AND REN AND REN_A AND REN_B AND !CO OR
    RS AND !REN AND REN_A AND REN_B AND !CO;
REN_A NOT := RS AND !REN AND REN_B AND REN_A AND CO OR
    RS AND !REN AND !REN_B AND EF AND !CO OR
    RS AND !REN AND !REN_A AND !EF AND CO;
REN_B NOT := RS AND !REN AND REN_B AND REN_A AND !CO OR
    RS AND !REN AND !REN_A AND EF AND CO OR
    RS AND !REN AND !REN_B AND !EF AND !CO;
OEN_A NOT := RS AND !OEN AND !OEN_A AND REN_A AND REN_B AND CO OR
    RS AND !OEN AND !OEN_B AND !REN_A AND EF AND CO OR
    RS AND !OEN AND OEN_A AND OEN_B AND REN_A AND REN_B AND CO OR
    RS AND !OEN AND OEN_A AND OEN_B AND !REN_A AND EF AND CO;
```

```
OEN_B NOT :=RS AND !OEN AND !OEN_B AND REN_A AND REN_B AND !CO OR
    RS AND !OEN AND !OEN_A AND !REN_B AND EF AND !CO OR
    RS AND !OEN AND OEN_A AND OEN_B AND REN_A AND REN_B AND !CO OR
    RS AND !OEN AND OEN_A AND OEN_B AND !REN_B AND EF AND !CO;
```

AEF NOT : $=$ !EFA AND EFB OR
EFA AND !EFB OR
!EFA AND !EFB;
EF NOT := !EFA AND !EFB;
END;
END X2RENCNTLR.

| \{AUTHOR: | BHANU V. R. NANDURI |
| :--- | :--- |
| COMPANY: | INTEGRATED DEVICE TECHNOLOGY |
| DATE: | $01 / 24 / 89$ |
| \} MODULE WENCNTLR; |  |
|  |  |
|  | \{ THIS PAL IS USED TO CONTROL THE |
|  | WRITE OPERATIONS IN A FOUR DEER |
|  | X9 OR X8 FIFO EXPANSION SCHEME \} |

TITLE WENCNTLR;
TYPE MMI 20R8;
INPUUTS:

| \{WCLK | NODE[PIN1]; | \{WCLK INPUT\} |
| :--- | :--- | :--- |
| RS | NODE[PIN2]; | \{SYNCHRONOUS RESET INPUT\} |
| FFA | NODE[PIN3]; |  |
| FFB | NODE[PIN4]; |  |
| FFC | NODE[PIN5]; |  |
| FFD | NODE[PIN6]; |  |
| WEN | NODE[PIN7]; |  |
| C0 | NODE[PIN22]; |  |
| C1 | NODE[PIN21]; |  |
| WEN_A | NODE[PIN20]; |  |
| WEN_B | NODE[PIN19]; |  |
| WEN_C | NODE[PIN18]; |  |
| WEN_D | NODE[PIN17]; |  |
| FF | NODE[PIN15]; |  |

OUTPUTS;

| WEN_A | NODE[PIN20]; | \{WEN1 TO FIFO A\} |
| :--- | :--- | :--- |
| WEN_B | NODE[PIN19]; | \{WEN1 TO FIFO B\} |
| WEN_C | NODE[PIN18]; | \{WEN1 TO FIFO C\} |
| WEN_D | NODE[PIN17]; | \{WEN1 TO FIFO D\} |
| AFF | NODE[PIN16]; | \{ALMOST FULL FLAG FOR THE EXPANSION\} |
| FF | NODE[PIN15]; | \{FULL FLAG FOR THE EXPANSION\} |
| C0 | NODE[PIN22]; | \{C0 IS BIT O OF THE TWO BIT COUNTER\} |
| C1 | NODE[PIN21]; | \{C1 IS BIT 1 OF THE TWO BIT COUNTER\} |

```
TERMS;
CO NOT := RS AND !WEN AND !WEN_A AND FF AND CO OR
    RS AND !WEN AND !WEN_C AND FF AND CO OR
    RS AND !WEN AND !WEN_B AND !FF AND !CO OR
    RS AND !WEN AND !WEN_D AND !FF AND !CO OR
    RS AND WEN AND !WEN_B AND !CO OR
    RS AND WEN AND !WEN_D AND !CO OR
    RS AND WEN AND WEN_A AND WEN_B AND WEN_C AND
    WEN_D AND !CO OR
    RS AND !WEN AND WEN_A AND WEN_B AND WEN_C AND WEN_D AND !CO;
C1 NOT := RS AND !WEN AND !WEN_B AND FF AND C1 OR
    RS AND !WEN AND !WEN_C AND FF AND !C1 OR
    RS AND !WEN AND !WEN_C AND !FF AND !Cl OR
    RS AND !WEN AND !WEN_D AND !FF AND !C1 OR
    RS AND WEN AND !WEN_C AND !C1 OR
    RS AND WEN AND !WEN_D AND !C1 OR
    RS AND WEN AND WEN_A AND WEN_B AND WEN_C AND
    WEN_D AND !C1 OR
    RS AND !WEN AND WEN_A AND WEN_B AND WEN_C AND WEN_D AND !C1;
WEN_A NOT := RS AND !WEN AND WEN_D AND WEN_C AND WEN_B AND WEN_A AND
    CO AND C1 OR
    RS AND !WEN AND !WEN_D AND FF AND !CO AND !C1 OR
    RS AND !WEN AND !WEN_A AND !FF AND CO AND C1;
WEN_B NOT := RS AND !WEN AND WEN_D AND WEN_C AND WEN_B AND WEN_A AND
    !CO AND C1 OR
    RS AND !WEN AND !WEN_A AND FF AND CO AND Cl OR
    RS AND !WEN AND !WEN_B AND !FF AND !CO AND CI;
WEN_C NOT := RS AND !WEN AND WEN_D AND WEN_C AND WEN_B AND WEN_A AND
    CO AND !C1 OR
    RS AND !WEN AND !WEN_B AND FF AND !CO AND C1 OR
    RS AND !WEN AND !WEN_C AND !FF AND CO AND !C1;
WEN_D NOT := RS AND !WEN AND WEN_D AND WEN_C AND WEN_B AND WEN_A AND
    !CO AND !C1 OR
    RS AND !WEN AND !WEN_C AND FF AND CO AND !C1 OR
    RS AND !WEN AND !WEN_D AND !FF AND !CO AND !C1;
AFF NOT := !FFA AND FFB AND FFC AND FFD OR
    FFA AND !FFB AND FFC AND FFD OR
    FFA AND FFB AND !FFC AND FFD OR
    FFA AND FFB AND FFC AND !FFD OR
    !FFA AND !FFB AND !FFC AND !FFD;
FF NOT := !FFA AND !FFB AND !FFC AND !FFD;
END;
END WENCNTLR.
```

| \{AUTHOR: | BHANU V. R. NANDURI |
| :--- | :--- |
| COMPANY: | INTEGRATED DEVICE TECHNOLOGY |
| DATE: | $01 / 24 / 89$ |
| \} |  |
| MODULE RENCNTLR; | ( THIS PAL IS USED TO CONTROL THE |
|  |  |
|  | READ OPERATIONS IN A FOUR DEEP |
|  | X9 OR X8 FIFO EXPANSION SCHEME \} |

TITLE RENCNTLR;
TYPE MMI 2OR8;

INPUTS;

| \{WCLK | NODE[PIN1]; \} | \{RCLK INPUT\} |
| :--- | :--- | :--- |
| RS | NODE[PIN2]; | \{SYNCHRONOUS RESET INPUT\} |
| EFA | NODE[PIN3]; |  |
| EFB | NODE[PIN4]; |  |
| EFC | NODE[PIN5]; |  |
| EFD | NODE[PIN6]; |  |
| REN | NODE[PIN7]; |  |
| CO | NODE[PIN22]; |  |
| C1 | NODE[PIN21]; |  |
| REN_A | NODE[PIN20]; |  |
| REN_B | NODE[PIN19]; |  |
| REN_C | NODE[PIN18]; |  |
| REN_D | NODE[PIN17]; |  |
| EF | NODE[PIN15]; |  |

OUTPUTS;
REN_A NODE[PIN20]; \{REN1 TO FIFO A\}
REN_B NODE[PIN19]; \{REN1 TO FIFO B\}
REN_C NODE[PIN18]; \{REN1 TO FIFO C \}
REN_D NODE[PIN17]; \{REN1 TO FIFO D\}
AEF NODE[PIN16]; \{ALMOST EMPTY FLAG FOR THE EXPANSION\}
EF NODE[PIN15]; \{EMPTY FLAG FOR THE EXPANSION\}
C0 NODE[PIN22]; \{CO IS BIT O OF THE TWO BIT COUNTER\}
C1 NODE[PIN21]; \{C1 IS BIT 1 OF THE TWO BIT COUNTER\}

TERMS;

```
CO NOT := RS AND !REN AND !REN_A AND EF AND CO OR
    RS AND !REN AND !REN_C AND EF AND CO OR
    RS AND !REN AND !REN_B AND !EF AND !CO OR
    RS AND !REN AND !REN D AND !EF AND !CO OR
    RS AND REN AND !REN_B AND !CO OR
    RS AND REN AND !REN_D AND !CO OR
    RS AND REN AND REN_A AND REN_B AND REN_C AND
        REN_D AND !CO OR
        RS AND !REN AND REN_A AND REN_B AND REN_C AND REN_D AND !CO;
```

```
C1 NOT := RS AND !REN AND !REN_B AND EF AND C1 OR
    RS AND !REN AND !REN_C AND EF AND !C1 OR
    RS AND !REN AND !REN_C AND !EF AND !C1 OR
    RS AND !REN AND !REN_D AND !EF AND !C1 OR
    RS AND REN AND !REN_C AND !C1 OR
    RS AND REN AND !REN_D AND !C1 OR
    RS AND REN AND REN_A AND REN_B AND REN_C AND
    REN_D AND !C1 OR
    RS AND !REN AND REN_A AND REN_B AND REN_C AND REN_D AND !C1;
REN_A NOT := RS AND !REN AND REN_D AND REN_C AND REN_B AND REN_A AND
    CO AND C1 OR
    RS AND !REN AND !REN D AND EF AND !CO AND !C1 OR
    RS AND !REN AND !REN_A AND !EF AND CO AND C1;
REN_B NOT := RS AND !REN AND REN_D AND REN_C AND REN_B AND REN_A AND
    !C0 AND C1 OR
    RS AND !REN AND !REN_A AND EF AND CO AND C1 OR
    RS AND !REN AND !REN_B AND !EF AND !CO AND C1;
REN_C NOT := RS AND !REN AND REN_D AND REN_C AND REN_B AND REN_A AND
    CO AND !C1 OR
    RS AND !REN AND !REN_B AND EF AND !CO AND C1 OR
    RS AND !REN AND !REN_C AND !EF AND CO AND !Cl;
REN_D NOT := RS AND !REN AND REN_D AND REN_C AND REN_B AND REN_A AND
    !CO AND !C1 OR
    RS AND !REN AND !REN_C AND EF AND CO AND !C1 OR
    RS AND !REN AND !REN_D AND !EF AND !CO AND !C1;
AEF NOT := !EFA AND EFB AND EFC AND EFD OR .
        EFA AND !EFB AND EFC AND EFD OR
        EFA AND EFB AND !EFC AND EFD OR
        EFA AND EFB AND EFC AND !EFD OR
        !EFA AND !EFB AND !EFC AND !EFD;
EF NOT := !EFA AND !EFB AND !EFC AND !EFD;
END;
END RENCNTLR.
```



TERMS;

```
CO NOT := RS AND !REN AND !REN_A AND EF AND CO OR
    RS AND !REN AND !REN_C AND EF AND CO OR
    RS AND !REN AND !REN_B AND !EF AND !CO OR
    RS AND !REN AND !REN_D AND !EF AND !CO OR
    RS AND REN AND !REN_B AND !CO OR
    RS AND REN AND !REN_D AND !CO OR
    RS AND REN AND REN_\overline{A}}\mathrm{ AND REN_B AND REN_C AND
    REN_D AND !CO OR
    RS AND !REN AND REN_A AND REN_B AND REN_C AND REN_D AND !CO;
C1 NOT := RS AND !REN AND !REN_B AND EF AND C1 OR
    RS AND !REN AND !REN_C AND EF AND !C1 OR
    RS AND !REN AND !REN`C AND !EF AND !C1 OR
    RS AND !REN AND !REN_D AND !EF AND !C1 OR
    RS AND REN AND !REN_C AND !C1 OR
    RS AND REN AND !REN_D AND !C1 OR
    RS AND REN AND REN_A AND REN_B AND REN_C AND
    REN_D AND !C1 OR
    RS AND !REN AND REN_A AND REN_B AND REN_C AND REN_D AND !C1;
```

```
OEN_A NOT := RS AND !GOEN AND !OEN_A AND REN_D AND REN_C AND REN_B AND REN_A AND
    CO AND C1 OR
    RS AND !GOEN AND !OEN_D AND !REN_A AND EF AND CO AND C1 OR
    RS AND !GOEN AND !OEN_D AND !EF ANND CO AND C1 OR
    RS AND !GOEN AND !OEN_A AND !EF AND CO AND C1 OR
    RS AND !GOEN AND OEN_D AND OEN_C AND OEN_B AND OEN_A AND
    !REN_A AND EF AND CO AND C1;
OEN_B NOT := RS AND !GOEN AND !OEN_B AND REN_D AND REN_C AND REN_B AND REN_A AND
            !CO AND C1 OR
    RS AND !GOEN AND !OEN_A AND !REN_B AND EF AND !CO AND C1 OR
    RS AND !GOEN AND !OEN_A AND !EF AND !CO AND C1 OR
    RS AND !GOEN AND !OEN_B AND !EF AND !CO AND C1 OR
    RS AND !GOEN AND OEN_D AND OEN_C AND OEN_B AND OEN_A AND
    !REN_B AND EF AND !CO AND C1;
OEN_C NOT := RS AND !GOEN AND !OEN_C AND REN_D AND REN_C AND REN_B AND. REN_A AND
    CO AND !C1 OR
    RS AND !GOEN AND !OEN B AND !REN C AND EF AND CO AND !C1 OR
    RS AND !GOEN AND !OEN_B AND !EF AND CO AND !C1 OR
    RS AND !GOEN AND !OEN_C AND !EF AND CO AND !C1 OR
    RS AND !GOEN AND OEN_D AND OEN_C AND OEN_B AND OEN_A AND
    !REN_C AND EF AND CO AND !C1;
OEN_D NOT := RS AND !GOEN AND !OEN_D AND REN_D AND REN_C AND REN_B AND REN_A AND
    !CO AND !C1 OR
    RS AND !GOEN AND !OEN_C AND !REN_D AND EF AND !CO AND !C1 OR
    RS AND !GOEN AND !OEN_C AND !EF AND !CO AND !C1 OR
    RS AND !GOEN AND !OEN_D AND !EF AND !CO AND !C1 OR
    RS AND !GOEN AND OEN_D AND OEN_C AND OEN_B AND OEN_A AND
    !REN_D AND EF AND !CO AND !C1;
END;
END OENCNTLR.
```

> SIMPLIFY SCSI HOST ADAPTER DESIGN WITH BIDIRECTIONAL FIFO MEMORIES
by Julle S. Lin


#### Abstract

With the dramatic change of the processing power in the microprocessor world, the bottleneck of the system performance is shifted to the I/O subsystem. An efficient I/O interface should transfer data in a high-speed burst, such that the CPU can optimize the performance by accessing the system bus without much interruption. The SCSI adapter presented inthis paper achieves this goal with a low chip-count hardware design. A pair of monolithic bidirectional FIFOs are used to buffer transferred data between the host bus and the SCSI protocol controller.


## INTRODUCTION

A SCSI host adapter links the system bus and the SCSI bus. The adapter board requires a SCSI protocol controller to monitor all of the SCSI bus activities. The host adapters can be categorized into three architectures, depending on how the data is moved from the SCSI bus to the host memory: CPU assisted, DMA slave, and bus master. The CPU assisted architecture is easy to design and requires low chip counts. Its traditional implementation for the single-task system is considered a cost-sensitive low performance approach. By reducing software overhead and speeding up the system bus interface, the performance of this architecture can be highly improved, while the design simplicity is still preserved. The on-chip state machines of some SCSI protocol controllers perform SCSI sequences automatically, thereby reducing software overhead. To speed up the interface between a 32bit system bus (which is a growing trend) and an 8-bit SCSI controller, a monolithic bidirectional FIFO chip (BiFIFO) provides an integrated solution.

In some general computing systems the system bus arbitration scheme is widely used either for DMA channel or for bus-master I/O subsystems. But for some system designs requiring high I/O throughput rate, this complicated scheme may not be necessary for the I/O interface. The CPU-assisted SCSI design proposed in this paper can eliminate the complexity of host bus arbitration and achieve high data throughput by using the system CPU.

This SCSI adapter design is for a 32-bit RISC system bus with the NCR53C90A as the protocol controller. With 5 Mbytes/sec data rate on the SCSI bus and much faster speed on the system bus, the IDT7252 BiFIFO ( 35 ns access time) provides data buffering in both directions. Two cascaded 18-to-9 BiFIFOs achieve 36 -to- 9 bus conversion with a 4K-byte deep FIFO in each direction. Besides, the on-chip DMA
handshaking logic fits directly into the MPU interface side of the SCSI controller. Little control logic is required in this design, allowing it to be put on the system board as a SCSI port. Since the programmable flags of the BiFIFO are available in the status register and external flag pins, the CPU can regulate the data transfer process by software polling for single-task applications, or by hardware interrupt to allow background tasks to continue executing.

## SCHEMATIC AND HOST BUS

The system board used to explain this design concept contains a R 3000 CPU, cache memory, SRAM main memory, EPROM monitor, two serial ports, and a parallel port. A 32-bit address bus, a 32 -bit data bus and all necessary control signals are available on the proprietary host bus for expansion. This bus is chosen because it's simple and very easy to understand.

The simplified schematic of this SCSI adapter is illustrated in Figure 1. The BiFIFO architecture will be introduced in the next section. Hardware considerations are explained in Sections 4 and 5 , which include an address decoding scheme, signal connections and timing issues. This paper also presents software algorithms for data transfers in Section 6.

For the explanations of signal connections, the host bus signals are summarized as follows:

- EA00-EA31 are the address output pins.
- ED00-ED31 are the data I/O pins.
- SYSOUT is the main system clock output used for synchronizing data transfers.
- MRES is the active-low reset output.
- $\overline{M R E Q}$ and $\overline{X A C K}$ are handshake signals for timing external data transfers.
- UINT is the user interrupt input to the R3000.
- WEN is the write enable outputs.
- MEMRD is an active-Iow memory-read output signal, normally used to enable output drivers in the expansion system for data read operations.
- UCS1A is a decoded User Chip Select output.

All data transfers between the system board and the user expansion board are controlled by the handshake signals, $\overline{M R E Q}$ and $\overline{\text { XACK. }}$ MREQ indicates the beginning of a memory request cycle. The detection of an external memory transfer must be qualified by the address present at the time of the $\overline{\text { MREQ }}$ signal. $\overline{\text { XACK }}$ is used to indicate that the data transfer initiated by the $\overline{M R E Q}$ signal has been completed:


Figure 1. Simplified Schematic of the SCSI Adapter

## THE BIDIRECTIONAL FIFO ARCHITECTURE

The 7252 BiFIFO is a compact, highly integrated solution to simplify data transfers between two processors or a processor and a peripheral of different bus bandwidth. A stand-alone BiFIFO can handle the data transfer from an 18-bit bus to a 9bit bus. Two cascaded devices can transfer data from a 36bit bus to a 9-bit bus or an 18-bit bus. It contains one 1 K by 18 bit FIFO in each direction. The 7252 also includes a data path that bypasses both FIFOs. With this direct data path, a processor can initialize a peripheral before they transfer data via FIFOs. The detailed block diagram is illustrated in Figure 2.

Besides FIFO data transfers, the 18-bit Port $A$ is also used for BiFIFO initialization and command controls. By controlling address lines A0-1 and chip select $\overline{C S A}$, users can access six resources: the A-to-B FIFO, the B-to-A FIFO, the 9-bit direct data bus, the status, command and configuration registers. The Motorola-type CPU interface with data strobe ( $\overline{\mathrm{DS}} \mathrm{A})$ is provided on Port A.

By writing commands to Port $A$, users can do many function controls which include resetting FIFOs and/or handshake circuitry, setting DMA transfer direction, selecting one of two status register formats, increasing the read or write pointer of Port B, and clearing parity error bits. The status register reflects the current status of internal operations such as FIFO flags and parity errors. It also duplicates the contents of the odd-byte register and indicates if an even number of bytes has been written into Port B (valid bit).

Each FIFO is equipped with four internal flags: Empty, Almost Empty, Full, and Almost Full. The offset values of the Almost Empty and Almost Full flags are programmable through Configuration Registers 0-3. The four external flag pins are used to reflect internal flag status with selectable signal polarities. The selection for external flags is provided by programming Register 4. Register 5 is used for general control: selecting Intel-type or Motorola-type interface for Port B, choosing byte order of an 18-bit word, enabling reread/rewrite functions, defining handshake signal polarities and timings,
and also determining interface and expansion modes. Parity functions are set by Register 7. Register 6 is reserved for future expansion.

The BiFIFO supports two parity modes at Port B: Check and Generate. In the check mode, the parity check circuitry monitors data passed through Port $B$ and sets parity error bits accordingly. An error while transferring data into Port B sets the write parity error bit in the Status. An error while transferring data out of Port B sets the read parity error bit in the Status. The OR of these two error bits is available as an option for output on the FLAGA pin. In the generate mode the generated parity bit is placed on the Port B data bus for a data-out operation. The generated parity bit is either stored in the B-to-A FIFO or bypassed to Port A for a data-in operation.

The DMA interface is associated with Port B. REQ and ACK provide a standard DMA handshake. For the 18-bit to $9-$ bit bus interface, the handshake circuitry generates read and write strobes ( $\overline{\mathrm{R}}$ B and $\overline{\mathrm{W}}$ ) at Port B of a stand-alone BiFIFO. When cascading two BiFIFOs for the 36 -bit to 9 -bit bus interface, one device is the master and the other one is the slave. The handshake circuitry generates read and write strobes on the master device. These strobes become inputs on the slave device.

The BiFIFO has aninnovative hardware Reread and Rewrite capability on Port B side. But, Reread and Rewrite functions are also programmable from Port A , where reread and rewrite locations are set through the command register.

The 18 -bit to 9 -bit BiFIFO comes in two versions. Load Reread, Load Rewrite, and Reset are accessible through Port A commands on the 725248 -pin DIP. These functions are available either through Port A commands or directly through Port B pins on the 72520 52-pin PLCC.

## ADDRESS DECODING AND SIGNALCONNECTIONS

The user chip select UCS1A from the expansion connectors is chosen for high address bit decoding. The addresses used in the SCSI adapter are all uncached and unmapped, insuring that the block read operation will never occur. The address bits A0-A3 of the SCSI controller are connected to EA02-EA05, and the address bits A0, A1 of the BiFIFOs to EA06-EA07.

Since the partial-word manipulations are not implemented for the SCSI adapter addresses, the address pins EA00 and

EA01 are not used. Chip Select $\overline{C S} A$ of the 7252 s is connected to the decoded signal UCS1A. But Chip Select $\overline{C S}$ of the $53 C 90 A$ is from the PAL 16 L 8 , where UCS1A is qualified with EA07, EA06, MEMRD, and WEN for the bypass operation.

Since the BiFIFOs provide a bypass path for the system bus to directly access the 53C90A registers, Port A of the BiFIFOs should be chip-selected together with the 53C90A. The 53C90A should not be chip-selected when we are accessing the BiFIFO internal resources. In such an arrangement, the 53C90A will not be interfered with during the BiFIFOs' internal operations. Since Port B and Port A operations are totally independent, we can poll the status from the Port A side while Port B and the SCSI controller are engaged in the data movement via DMA handshaking.

Besides address decoding, the Motorolatype interface with $\mathrm{R} / \overline{\mathrm{W}} \mathrm{A}$ (read, write control) and $\overline{\mathrm{DSA}}$ (data strobe) controls the read/write operations on Port A. To fulfill the setup and hold time requirements between $R / \bar{W} A$ and $\overline{\mathrm{DS}} \mathrm{A}, \mathrm{R} / \bar{W}_{A}$ is connected to the inverted signal of the memory read control $\overline{M E M R D}$. To optimize the performance, the assertion of the data strobe $\overline{\mathrm{SS}} \mathrm{A}$ varies for four cases : writing/reading Port A and writing/reading 53C90A registers.

The clock used to control the handshake signals of the 7252 s comes directly from SYSOUT of the systemboard. The same clock is used throughout the SCSI adapter board for clocking the 53C90A and the PAL 22V10. The 10K pull-up resistors are used for $\bar{R}_{B}$ and $\bar{W}_{B}$ to keep signals high during the initialization. The default operation mode of the BiFIFO requires that. The handshake signals are all generated or responded to by the master device of the BiFIFOs. But $\bar{R} B$ and $\bar{W} B$ should be fed into the slave device to synchronize the byte datatransfer. The reread/rewrite functions are not used in this application, therefore $\overline{R E R}$ and $\overline{R E W}$ are tied high. REQ and CLK of the slave device are grounded for noise immunity.

To simplify the interrupt logic design, the only interupt coming out of this SCSI board is from the 53C90A, whereas the FIFO flags of BiFIFOs are polled from the Status Register. The read/write signals $\overline{R D}, \overline{W R}$ of the 53C90A are from the PAL 22V10. They are derived from $\bar{R}_{B}$ and $\bar{W}_{B}$ to fit in both DMA timing and the bypass timing. The reset from the system board MRES will reset the SCSI controller and the PAL22V10.

NOTES:
(") Can be programmed either active high or active low in internal configuration registers.
(t) Available as a pin on the IDT72510/520. Accessible on all parts through internal registers.
( $t$ t) Can be programmed through an internal configuration register to be either an input or an output

## TIMING CONSIDERATIONS

In timing considerations, the SCSI adapter involves four different kinds of interface: (i) the interface of the system board to access Port A (ii) the interface of the system board to access the 53C90A registers (iii) data transfer via DMA handshaking between Port $B$ and the 53C90A (iv) the interface between the 53C90A and the SCSI bus. With on-chip 48 mA drivers and receivers, the connection between the 53C90A and the single-ended SCSI bus is straight fonward.

All the timing diagrams from Figure 3 to Figure 8 are based on a 25 MHz clock. The timing of writing Port A is in Figure 3.

The assertion of $\overline{M R E Q}$ with a qualified address starts this writing sequence, which lasts for six cycles. Since data out from the system board will be available on the Port A bus at the third clock cycle, the rising edge of $\overline{D S} A$ is put on the fifth clock cycle to write data into the BiFIFOs. The assertion of XACK causes the Port A bus to be tri-stated four clocks later, which concludes the whole writing sequence. The state machine 22 V 10 , which provides $\overline{\mathrm{XACK}}$ and $\overline{\mathrm{DS}}$, goes through the transitions as State 0 (default state), State 1, State 2, State 3, and back to State 0 again.


Figure 3. Timing: Writing Port A of the $\mathbf{7 2 5 2}$

Figure 4 depicts the timing of reading Port A. Since the system bus fetches data three cycles behind the assertion of $\overline{X A C K}, \overline{D S A}$ should be asserted two cycles ahead of data fetching to guarantee valid data appearing on the Port A bus. The transition of the state machine is State 0, State 4, State 5, State 6, State 7, and back to State 0.

When writing a register of the 53C90A, the state machine generates a write control signal WRREG internally, which is multiplexed with $\bar{W} B$ (as for the DMA handshaking) to provide the write control $\overline{\text { WR90 }}$ for the 53C90A. As shown in Figure 5, once the bypass mode of the BiFIFO is decoded, the assertion of $\overline{D S} A$ will cause Port A data to appear on the Port $B$ bus. The delayed version of the $\overline{\mathrm{DS}} A$ signal will appear on $\bar{W} B$. The assertion of XACK terminates Port A data four clocks later, whereas the deassertion of $\overline{D S A}$ terminates Port B data within
one clock cycle. The best time for the 53C90A to fetch data from the Port B bus should be on the rising edge of the 5th clock. The state machine transitions for this 6 -cycle writing sequence covers: State 0, State 8, State 9, State 10, State 11 and State 0.

Figure 6 shows the timing for the reading of a register from the 53C90A. The read register control REREG generated internally by the state machine is used to read out a register value from the 53C90A. Just like WRREG, RDREG is multiplexed with $\bar{R} B$ (as for the DMA handshaking) to provide the read control for the 53C90A MPU interface. The assertion of $\overline{\mathrm{DS}} \mathrm{A}$ and $\overline{\mathrm{RDREG}}$ right behind the address decoding cycle, ensures the data from the 53C90A to appear on the Port A bus as fast as it can. The assertion of XACK at the 2nd clock cycle positions the data fetching of the system bus at the 5 th cycle.


Figure 4. Timing: Reading Port A of the $\mathbf{7 2 5 2}$


2726 drw 05
Figure 5. Timing: Writing a Register of the 53C90A

The state machine transitions go through the sequence: State 0 , State 12, State 13, State 14, State 15, and State 0 . The state transition diagram is drawn in Figure 9 which summarizes these four sequences.

The DMA handshake timings between the 7252s and the 53C90A are shown in Figure 7 and Figure 8. DREQ from the 53C90A is responded to by the master BiFIFO with the assertion of DACK together with $\overline{\text { WB }}$ or $\bar{R} B$. The number of clock cycles betweenthe detection of DREQ and the assertion of $\overline{\text { DACK }}$ can be programmed as 2 to 5 cycles through

Configuration Register 5. $\bar{W} B$ or $\bar{R} B$ always follows the assertion of DACK, lasts for 1 or 2 cycles (programmable through Configuration Register 5), and is deasserted together with DACK. Whenever DACK goes back to a high state, the 53C90A may start another handshake cycle by asserting request signal DREQ again. For the case where the peripheral controller timing is much slower than the clock rate, the BiFIFO allows the user to slow down the clock by dividing the external clock by two (also programmable through Configuration Register 5).


Figure 6. Timing: Reading a Register of the 53C90A


Figure 7. Timing: DMA Write Between the 7252 and the 53C90A


2726 drw 08

Figure 8. Tlming: DMA Read Between the 7252 and the 53C90A


Figure 9. State Transition Dlagram of the SCSI Adapter

## SOFTWARE ALGORITHMS FOR DATA TRANSFERS

The SCSI bus protocol can be divided into the following phases: Bus Free, Arbitration, Selection, Reselection, Command, Data In, Data Out, Status, Message In, and Message Out. Command, Status, and Message phases all belong to small-block data transfers. Data In and Data Out phases will involve large-block data transfer.

## Small-Block Data Transfers

Let's assume the SCSI adapter is the single initiator in a SCSI bus. To initiate a SCSI action, the CPU has to program several registers of the 53C90A. Afterwards, the 16-byte FIFO of the 53C90A should be filled with a Command Description Block (CDB). The CPU can then issue a command to the 53C90A to start the sequence, which includes Arbitration, Selection, and Command phases. In this process, the CPU monitors all the activities directly on the 53C90A, and bypasses the BiFIFOs. If the target asserts Status phase, the CPU should bring in the Status and Message bytes. As with the previous process, the SCSI adapter handles these phases bypassing the BiFIFOs.

## Large-Block Data Transfers

Both Data In and Data Out phases require data buffering between the SCSI controller and the system bus. The SCSI driver should regulate the data flow from the system bus to Port A by monitoring A-to-B FIFO flags.

Figure 10 shows pseudo codes for the SCSI driver during the Data Out phase. The total number of bytes to be transferred is defined by data_size. Since the size of A-to-B FIFOs (including master and slave devices) is 4 K bytes, we need to divide the data into 4 K -byte blocks. The residual block has to

```
dataout_phase(data_size)
{
    no_of_4Kblks = data_size / 4096;
    residual = data_size mod 4096;
    no_of_words = residual /4;
    no_of_bytes = residual mod 4;
    Issue "Reset A-to-B FIFO" command to 7252s;
    Issue "Set A-to-B DMA direction" to 7252s;
    Program AEF offset value of A-to-B FIFOs;
    Load count registers of the 53C90A;
    Issue flush command to flush the FIFO of
    the 53C90A;
    Issue DMA transfer command to the 53C90A;
    Loop 1 to no_of_4Kblks
    {
        While (Master 7252 is almost empty)
        {
            Write 1K words into'Port A;
        }
    }
    Program AEF offset value of A-to-B FIFOs
    to "1";
```

Figure 10. SCSI Driver Pseudo Code for the Data Out Phase

For the Data In phase, the driver knows the size of the data returned from the command type and the allocation length. The procedures that a driver takes for a Data In phase is explained with the pseudo codes in Figure 11. As in the Data Out phase, we divide the whole data size into several 4 K -byte blocks and a residual block. The BiFIFO initializations include "Reset B-to-A FIFO", "Set B-to-A DMA direction", and "Program B-to-A Almost Full Flag (AFF) offset value". The driver polls the Status Registers of the BiFIFOs until it sees AFF being asserted on the master BiFIFO. At this time, the driver starts transferring 1 K words from Port A to the destination buffer. This procedure is repeated until all the 4 K -byte blocks are read in.

To handle the residual block, the AEF of the B-to-A FIFOs is set to no_of_words, which is the number of the full word. When AEF of the master BiFIFO is not set, the driver can take no_of_words words out from Port A. The last partial word is handled as follows: (i) If there is one byte left, this byte is in the Odd-byte register of the slave device, which can be read out through the Status Register. (ii) If there are two bytes left, the driver should read B-to-A FIFOs again to get these bytes from the slave device. (iii) For the three-byte case, the first two bytes stay in the B-to-A FIFO of the slave device, the last byte should be fetched from the Status Register of the master device.

```
datain_phase(data_size)
{
    no_of_4Kblks = data_size / 4096;
    residual = data_size mod 4096;
    no_of_words = residual /4;
    no_of_bytes = residual mod 4;
    Issue "Reset B-to-A FIFO" command to 7252s;
    Issue "Set B-to-A DMA direction" to 7252s;
    Program AFF offset value of B-to-A FIFOs;
    Load count registers of the 53C90A;
    Issue flush command to flush the FIFO of
    the 53C90A;
    Issue DMA transfer command to the 53C90A;
    Loop 1 to no_of_4Kblks
l
    While (Master 7252 is almost full)
        \
        Read 1K words from Port A;
        }
        }
Set AEF offset value of the B-to-A FIFOs = no_of_words;
```


## DISCUSSIONS

SCSI is recognized as an excellent approach to interconnecting small computers and intelligent peripherals. The booming SCSI market dramatically increases available SCSI peripherals. A SCSI port is becoming a must for mid-range to high-periormance computers and workstations. Traditional SCSI adapter designs occupy a backplane slot. This paper introduced a new design example with the IDT7252 BiFIFO, which may allow the whole SCSI interface to be put on the system board. With 2 K -byte FIFOs in each direction, integrated bus-conversion, and DMA handshaking logic all in one part, the BiFIFO greatly simplifies the SCSI adapter design and increases the system throughput. Only five parts are used in this design - two BiFIFOs, one SCSI controller, and two PALs.

This design example allows only one interrupt to the system board from the SCSI controller. During the Data In and Data Out phases, the system processor has to poll FIFO flags in order to regulate the data loading/unloading rate. If the system requirements need to free the processor for the multitask application, the FIFO flag pins can be used to generate hardware interrupts. Additionally, the programmable offset of the Almost Empty/Full flags allows this design to fit into different systems without the cost that is associated with changing the buffer size.

```
    While (Master 7252 is not almost empty)
        {
        Read no_of_words words from Port A;
        }
    Switch (no_of_bytes)
    {
        case 0:
            Done;
        case 1:
            Read the last byte from the Status
            Register of the Slave device;
            Done;
        case 2:
            Read B-to-A FIFOs once to get the last
            two bytes from the Slave;
            Done;
        case 3:
            Read B-to-A FIFOs once to get the
            first two bytes from the Slave;
            Read the last byte from the Status
            Register of the Master;
            Done;
    }
}
```

Figure 11. SCSI Driver Pseudo Code for the Data In Phase UNDERSTANDING THE OUTPUT CONTROL $\overline{O E}$ OF THE FLAGGED

## APPLICATION

 NOTEAN-73

## by Danh Le Ngoc

The IDT72021/31/41 are high-speed, low-power, dual-port memory devicesknown as FLAGGED FIFOs. The FLAGGED FiFOs offer the basic features of IDT's industry standard FIFOs (IDT7201/02/03/04) while providing two new flags and the output control ( $\overline{O E}$ ). The focus of this tech note is to describe how the output control $(\overline{\mathrm{OE}})$ works. Figure 1 is a simplified block diagram of the Flagged FIFOs: IDT72021/31/ 41.

As Figure 1 shows, the three-state output buffer is controlled by the internal read signal and the external output control ( $\overline{\mathrm{OE}}$ ). A read cycle is initiated on the falling edge of the

Read Enable signal $(\bar{R})$ provided the Empty flag ( $\overline{(\bar{F})}$ is not set. After the access time (TA), data appears on the Qo-8 lines when the output control $\overline{O E}$ is low. While the read signal $(\overline{\mathrm{R}})$ is low, the same data can be read repeatedly on the $\mathrm{Q}_{0-8}$ lines under control of the output control signal ( $\overline{\mathrm{OE}}$ ). This advantage enables the reading of the same FIFO location without advancing the internal read pointer. After Read Enable ( $\overline{\mathrm{R}}$ ) goes high, the data outputs ( $\mathrm{Q} 0-8$ ) will return to a high impedance condition independent of the output control ( $\overline{\mathrm{OE}}$ ).

Table 1 illustrates the state of the Q0.8 lines dependent on the empty flag, read control $(\overline{\mathrm{R}})$ and the output control.


Figure 1. Simplified Block Dlagram for Flagged FIFOs


Figure 2. Read Cycle Controlled by $\overline{\mathrm{O}}$ and R

| $\overline{\mathrm{EF}}$ | $\overline{\mathrm{R}}$ | $\overline{\mathrm{OE}}$ | Q0-8 |
| :---: | :--- | :---: | :--- |
| 0 | $X$ | $X$ | HIGH IMPEDANCE |
| 1 | 0 | 0 | NEW Q0-8 |
| 1 | 0 | 1 | HIGH IMPEDANCE |
| 1 | 1 | 0 | HIGH IMPEDANCE |
| 1 | 1 | 1 | HIGH IMPEDANCE |

2727 tol 01
Table 1. Read Truth Table


## by Suneel Rajpal and Frank Schapfel

FIFOs are First-In/First-Out buffers that act as elastic buffers between two synchronous or asynchronous systems. The IDT7201 ( $512 \times 9$ ), IDT7202 ( $1 \mathrm{~K} \times 9$ ), IDT7203 ( $2 \mathrm{~K} \times 9$ ) and IDT7204 ( $4 \mathrm{~K} \times 9$ ) are high-speed FIFOs that can operate at frequencies greater than 20 MHz . Here are a few tips on designing with these FIFOs.

A generic block diagram of the FIFOs is shown in Figure 1. After power up, the FIFO must be reset. The reset operation requires that the read and write lines be high for a time tRPW or twPW (the read or write pulse width minimums) before the rising edge of $\overline{\mathrm{RS}}$, and to be high for a time tRSR after the rising edge of $\overline{\mathrm{RS}}$. These operating conditions are shown in Figure 2. It is important to observe the stipulated requirements on $\overline{\mathrm{R}}$ and $\overline{\mathrm{W}}$ during reset because they increment the read and write pointers and both edges of the read and write also affect the empty and full counters. The Full and Empty Flag counters have to be appropriately set after a reset operation.

The read and write pointers are high-speed counters that are incremented onevery rising edge of read and write lines. These lines must be noise-free as in other high-speed counters like F161s and AS161s. This poses a common interface issue that users often encounter. Falseclocks can be caused by transmission line effects or crosstalk. Some of the symptoms of false clocking are flags asserted when they should not be, missing data or scrambled data order.

The Read or Write signals may be generated by a part that is physically placed far away from the FIFO on a PC board. This implies a propagation delay to and from the driver to the receiver that is greater than the rise and fall time of the driver. This causes reflections on the line. Also the driver that has a low impedance on the high-to-low transition causes an impedance mismatch. The mismatch is apparent with an F-type device or a Schottky-TTL device as their high-to-low impedance is fairly small (typically under 15 Ohms for F-type or FCT and under 10 Ohms for Schottky-TTL).

This translates to a signal that eventually settles near zero volts but, in the interim, has a "damping" effect; it may go through a -2.0 volt to +1.5 volt to -1.0 volt to +.7 volt to zero volts. This is shown in Figure 3. The FIFO devices can handle a negative voltage level of 1.5 V for less than 10 ns . If a positive 1.1 voltage level persists for a pulse width greater than 5 ns , the corresponding read or write pointer may increment. Data is either written or read twice, or garbage is written to or read from one or more locations. This can cause the FIFO to be "out of sync" where the read or write (or both pointers) are at wrong locations. This problem is solved by keeping the parts creating the $\bar{R}$ and $\bar{W}$ signal as close to the FIFO as possible. If FAST ${ }^{\text {rm }}$ or Schottky devices are used, and if ringing occurs, add a series resistor of 20 to 50 Ohms so the impedance of the driver in the high-to-low transition, plus the series resistor, approximately equal the line impedance.

Read $(\overline{\mathrm{R}})$ and Write $(\overline{\mathrm{W}})$ should be high if read and write operations are not occurring. Crosstalk causes noise on the read and write lines that may be 1.1 volts or greater for more than 5 ns. However, if read and write are high and noise appears on the line, the FIFO is more noise immune (as VOH is higher on the driver when a CMOS device in being driven and the VCC noise margin is greater than the ground noise margin). During a long clock low time of 150 ns , for a clock cycle of 200 ns , a spurious read or write can occur due to noise. If the system can handle it, a better recommended timing is a clock low time of 50 ns and a clock high time of 150 ns , giving better noise immunity.

Unused data inputs should be tied to ground or Vcc. In the standalone mode or width expansion mode, XI must be grounded and $\overline{F L} / \overline{R T}$ should be tied HIGH , given the retransmit feature is unused. Good board design techniques must be practiced and a ground plane or power distribution element are highly recommended. Decoupling capacitors of $0.1 \mu \mathrm{f}$ disk capacitors should be used to decouple VCC and ground.


Figure 1. FIFO Block Diagram


Figure 2. Reset Requirements


Figure 3. Reflections and Undershoot on the Read and Write lines that cause false increments on the Read and Write pointers


The IDT7201, IDT7202, IDT7203 and IDT7204 ( $512 \times 9,1 \mathrm{~K} \times 9$, $2 \mathrm{~K} \times 9$ and $4 \mathrm{~K} \times 9$ ) FIFOs have only four control lines: Read, Write, Reset, Retransmit. The focus of this tech note is the relation of the Read and Write lines to the FIFO's empty and full conditions.

These high-speed FIFOs can perform asynchronous and simultaneous read and write operations. Read and Write assert and deassert the Empty Flag and Full Flag. Therefore, special conditions exist when a full FIFO continues to be written to and a read operation takes place. Also, special timings occur when an empty FIFO continues to be read to and a write operation takes place. These operations are called the FIFO boundary conditions.

Read and Write increment the read and write pointers on their respective rising clock edges. The read and write pointers affect the Empty Flag and Full Flag counters. The Empty Flag timings are shown in Figure 1. When the FIFO has only one word in it, the falling edge of the Read causes the Empty Flag ( $\overline{E F}$ ) to be asserted. After the clock cycle is completed (Read goes high again), $\overline{E F}$ will remain asserted and the internal read counter is not affected by subsequent read cycles. $\overline{\mathrm{EF}}$ is deasserted by the next rising edge of Write, after which another read pulse can be applied to do a read operation. In asynchronous systems, read and write operations take place at any time; $\overline{\mathrm{EF}}$ is set by one signal and deasserted by another asynchronous signal.

When Read is being clocked on an empty FIFO, the outputs will be in high-impedance. If a write operation is performed during asynchronous read cycles, a possible violation of the read pulse width minimum can occur, as shown in Figure 2. $\overline{E F}$ is deasserted, but there is an insufficient read pulse minimum width. To prevent the minimum read pulse width violation, initiate a read operation only after $\overline{\mathrm{FF}}$ is high, or guarantee a long enough read pulse width minimum time. A violation of the timing causes an internal glitch on the FIFO Read which can cause the read pointer to be "out of sync." Then the data inside the FIFO may be scrambled or may be
garbage. The Empty Flag and Full Flag counters may also be upset by the internal glitch, which upsets FIFO memory usage. The only way to recover from this violation is to do a master reset.

A similar situation arises at the full FIFO boundary condition. When the FIFO is one word from being full, the falling edge of Write causes the Full Flag ( $\overline{F F}$ ) to be asserted. After the write cycle is completed (Write goes high again), $\overline{\mathrm{FF}}$ will remain asserted and the internal write counter is not affected by subsequent write cycles. The $\overline{F F}$ flag is deasserted by the next rising edge of the Read, as shown in Figure 3, after which another write pulse can be applied to do a write operation.

When the FIFO is full and Write is being clocked, data sent to the FIFO will be ignored and the write pointer will not increment. Here, as in the earlier case, if these write cycles are asynchronous during a read operation, a possible violation of the write pulse width minimum can occur, as shown in Figure 4. Here, $\overline{F F}$ is deasserted but a sufficient write pulse minimum width is not met. To prevent the problem, initiate a write operation only after $\overline{\mathrm{FF}}$ is high, or guarantee a long enough write pulse width minimum time. A violation of the timing causes an internal glitch on the FIFO write line. This can cause the write pointers to be "out of sync" where the data inside the FIFO may be scrambled or may be garbage. The Empty Flag and Full Flag counters may also be upset by the internal glitch. Again, the only way to recover from this condition is to do a master reset.

In summary, these FIFOs are designed to transfer only valid data from input to output. To ensure that valid data is written into and read from, empty and full FIFOs handshake through the flag mechanism. When there is no output data available, the reading side must wait until the end of a write. In a full FIFO, the writing side must wait for the reading side to create an "empty" location. Incomplete read and write cycles can not only invalidate data, but can cause the pointers to be out of synchronization, requiring a master reset to renew data transfer.


Figure 1. Empty Flag from Last Read to First Write


Figure 2. Violation of $\mathrm{t}_{\mathrm{RPW}}$ During Boundary Conditions

Note:

1. Pulse within the FIFO used to clock the read pointer and the Empty and Full Flag counters.
2. Ift $\mathrm{t}_{1}<\mathrm{t}_{\text {RPW }}$ (minimum read pulse width low), then the read pointer, Empty Flag and Full Flag counters may be out of sync. See Figure 15 of IDT7201/2SA data sheet.


Figure 3. Full Flag from Last Write to First Read


Figure 4. Violation of $\mathrm{t}_{\mathrm{WPW}}$ During Boundary Conditions


Note:

1. Pulse within the FIFO used to clock the write pointer and the Empty and Full Flag counters.
2. If $t_{1}<t_{\text {wPw }}$ (minimum write pulse width low), then the write pointer, Empty Flag and Full Flag counters may be out of sync. See Figure 16 of IDT7201/2SA data sheet.

## by Suneel Rajpal and Frank Schapfel

The IDT7201, IDT7202, IDT7203 and IDT7204 are high-speed $512 \times 9,1 \mathrm{~K} \times 9,2 \mathrm{~K} \times 9$ and $4 \mathrm{~K} \times 9$ FIFOs, respectively, that can be cascaded to form even deeper FIFOs. This tech note explains how these FIFOs are cascaded. The principles mentioned here also apply to the IDT7M203, IDT7M204, IDT7M205 and IDT7M206 highspeed $2 \mathrm{~K} \times 9,4 \mathrm{~K} \times 9,8 \mathrm{~K} \times 9$ and $16 \mathrm{~K} \times 9$ cascadable FIFO modules, respectively.

A cascaded FIFO configuration of $512 \times 9$ FIFOs is shown in Figure 1. The FL pin (First Load) of the first FIFO to be loaded after a reset is tied to ground. The other FIFOs have their FL pin tied to VCC. After a reset operation, the first 512 writes occur in the first FIFO. During these write operations, the $\overline{\mathrm{XO}}$ (Expansion Out) and $\overline{\mathrm{XI}}$ (Expansion In ) lines are high. On the 512 th write, a pulse is created on the $\overline{\mathrm{XO}}$ line following the $\overline{\mathrm{W}}$ line. The pulse informs the second FIFO that it is going to receive the next word. It also informs the first FIFO that its write pointer will no longer increment due to an internal evaluation of the $\overline{\mathrm{XO}}$ line. The $\overline{\mathrm{XO}}$ line of the first FIFO is connected to the $\overline{\mathrm{XI}}$ line of the second FIFO. The $\overline{\mathrm{XO}}$ of the second FIFO is connected to the $\overline{X I}$ of the third, and so on. The $\overline{X O}$ of the last FIFO is connected to the $\overline{\mathrm{XI}}$ of the first FIFO. A typical $\overline{\mathrm{XO}}$ operation of 2048 writes after a reset is shown in Figure 2.

The same procedure holds true for read operations. During the 512th read operation after a reset, another pulse will be created on the $\overline{\mathrm{XO}}$ line following the Read line. This pulse will inform the second FIFO that it will be read from on the next cycle (provided it isn't empty). Also the first FIFO's read pointer will not increment until it receives a second pulse on its $\overline{\mathrm{XI}}$ line.

Figure 3 shows the $\overline{X O}$ and $\overline{\mathrm{XI}}$ relationship to read and write. The $\overline{X O}$ pulses are transferred to the $\overline{\mathrm{XI}}$ of the next level of FIFO. The first pulse transfers write pointer control and the second transfers read pointer control. There is an important advantage to this method expansion. A word written to the FIFO after a master reset is immediately available at the FIFO output. A read cycle can be initiated as soon as EF is unasserted. This is called zero fall-through time. Earlier shift register-based FIFOs have a fall-through time in the $\mu$ sec range.

To take full advantage of this unique expansion feature, some design precautions must be observed. Since a pulse on $\overline{\mathrm{XI}}$ activates read or write operations of the FIFO, they must be relatively free from cross-talk noise. A long trace from the $\overline{\mathrm{XO}}$ of the last FIFO to the $\overline{\mathrm{XI}}$ of the first FIFO is a potential source of cross-talk noise. To
prevent noise spikes from altering the $\overline{X I}$ input on this and other $\overline{X O}$ to $\overline{X I}$ interconnects, a small capacitor in the 22 pF to 47 pF range should be inserted between the $\overline{X I}$ inputs and ground.

Another important point is how to handle flags in the expansion mode. To create the composite Full Flag, tie the four individual FIFO Full Flags to an OR gate. The composite Empty Flag is created similarly. This additional logic is shown in Figure 1.

To create intermediate flags using the individual Full and Empty flags is more tricky, but can be done. For example, an attempt to create a composite Half-Full Flag is described here. Let us define Flagf1 as when any two FIFOs are full and at least one other FIFO is not empty. Boolean Equation for f1:

$$
\begin{aligned}
& f 1=\mathrm{FF} 1 . \mathrm{FF} 2(\overline{\mathrm{EF3}}+\overline{\mathrm{EF} 4})+ \\
& \mathrm{FF} 2 . \mathrm{FF} 3(\overline{\mathrm{EF}}+\overline{\mathrm{EF} 4})+ \\
& \mathrm{FF3} \text {.FF4 }(\overline{\mathrm{EF} 1}+\mathrm{EF2})+ \\
& \mathrm{FF} 4 . \mathrm{FF} 1(\overline{\mathrm{EF} 2}+\overline{\mathrm{EF} 3}) \\
& \mathrm{FFi}=\text { Full Flag of FIFOi } \\
& \mathrm{EFi}=\text { Empty Flag of FIFOi }
\end{aligned}
$$

In one extreme case, f 1 is asserted when there is $1.5 \mathrm{~K}-1$ words in the FIFO array. The first two FIFOs are full, with 512 words in each, and the third FIFO has 511 words. Another extreme case is when two FIFOs are full and the third FIFO has only one word. Therefore, Flag f1 is only a range of words where the half-full condition exists, from $1 \mathrm{~K}+1$ to $1.5 \mathrm{~K}-1$ words in the array. It may not be used as a half-full indicator, because the FIFO array may be almost 3/4 full before Flag f1 is asserted.

As shown in Figure 4, an empty FIFO array has a word written to it and then read from it. Then, $1.5 \mathrm{~K}-1$ words are written to the FIFO array. The write pointer is on the last word of the third FIFO. Only at this time is Flag f1 asserted, while the FIFO array has $1.5 \mathrm{~K}-1$ words in it. Intermediate flags like f1, generated from Boolean Equations, can only provide a range of values when $f 1$ is to be asserted. A precise position for f 1 cannot be determined. If Boolean Equations are used to generate intermediate flags, consider all the different locations of the read and write pointers which may assert or deassert at a particular condition.


Figure 1. Four Cascaded $512 \times 9$ FIFOs
NOTE:
Read, Write and Reset controls go to all four FIFOs.


Figure 2. The $\overline{\mathrm{XO}} / \overline{\mathrm{XI}}$ Timing Pulse for 2048 Writes and Zero Reads
NOTE:
Read line is assumed to be HIGH in this example.


Figure 3. The $\overline{\mathrm{XO}}$ and $\overline{\mathrm{XI}}$ Pulse Timings

## NOTES:

1. Pulse 1 is created by the 512 th write pulse; it is a delayed write pulse.
2. Pulse 2 is created by the 512th read pulse.
3. Pulse 3 from FIFO 2 is created by the 1024th write pulse.
4. Pulse 4 is created by the 1024th read pulse.
5. $\overline{X O}$ (FIFO 3) and $\overline{X O}$ (FIFO 4) are not shown, but they follow the same pattern.
6. $\overline{X O}$ (FIFO 4) will be created by the 2048th write pulse and later by the 2048 th read pulse, thereby transferring pointer control back to FIFO 1.


Figure 4. The Behavior of the $f 1$ Flag for Different Cases

Case 1: In the cascaded FIFO arrangement, the write pointer has just written to FIFO \#3 and the flag defined by the f1 equation would be asserted at the half-full point.

Case 2: The FIFO array is half-full at arrow at Note 1, but f1 will not be asserted until the last write into FIFO \#3 or until the FIFO array is almost $3 / 4$ full or at arrow 2.

By David C. Wyland

## INTRODUCTION

Dual-port RAMs allow two independent devices to have simultaneous read and write access to the same memory. This allows the two devices to communicate with each other by passing data through the common memory. These devices might be a CPU and a disc controller or two CPUs working on different but related tasks. The dual-port memory approach is useful and popular because it
allows the same memory to be used for both working storage and communication by both devices and avoids the need for any special data communication hardware between the devices. The latest development in dual-port RAMs has been the appearance of high speed dual-port RAM chips. These chips allow high speed access by both devices with the minimum amount of interference and delay. Integrated Device Technology offers a family of these devices as shown in Table 1.

| Width | Size | Part | Support Logic |  |  |  | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Interrupt | Busy Logic |  | Semaphore |  |
|  |  |  |  | MASTER | SLAVE |  |  |
| X8 | 1K | IDT7130 | X | X |  |  |  |
|  |  | Iq̧T7140 | X |  | x |  |  |
|  | 2K | IDT7132 |  | X |  |  |  |
|  |  | IDT7142 |  |  | X |  |  |
|  |  | IDT71321 | X | X |  |  | 52-pin |
|  |  | IDT71421 | X |  | X |  | 52-pin |
|  |  | IDT71322 |  |  |  | X |  |
|  | 4K | IDT7134 |  |  |  |  |  |
|  |  | IDT71342 |  |  |  | X | 52-pin |
| X16 | 2 K | IDT7133 |  | X |  |  |  |
|  |  | IDT7143 |  |  | X |  |  |

Table 1. Dual-Port RAMs Available from Integrated Device Technology

## DUAL-PORT RAMS: SIMULTANEOUS ACCESS

A dual-port memory has two sets of address, data and read/ write control signals, each of which access the same set of memory cells. This is shown in Figure 1. Each set of memory controls can independently and simultaneously access any word in the memory including the case where both sides are accessing the same
memory location at the same time. Up to this time, there have been very few true dual-port memories available. Memories have a single set of controls for address, data and read/write logic and are single-port RAMs. If you wanted a dual-port RAM function, you had to design special logic to make the single-port RAM simulate a dual-port RAM in operation.


Figure 1. Dual-Port Memory Block Diagram

## Direct Memory Access (DMA) as a Dual-Port Memory Simulation

The concept of using a conventional memory to simulate a dualport RAM has been common in computer systems almost from the
beginning. It is known under the name Direct Memory Access, or DMA. In the DMA concept, a single memory is shared between the CPU and one or more I/O devices as shown in Figure 2.


Figure 2. DMA Memory System Block Diagram

Each device wishing to use memory submits a request to the arbitration logic. The arbitration logic responds by connecting the memory address, data and control lines to one of the requesters and tells any other requesting devices to wait by issuing a busy signal. The busy signal causes the memory access logic in the device to wait until busy has gone away before performing a memory transfer.

## DMA Limitations: Waiting for the Bus

In a computer system with DMA, the CPU must stop and wait while an I/O device is doing DMA transfers to memory. This works well in typical systems where the I/O devices are transferring data only a small percentage of the time and the impact on CPU processing time is minimal. These assumptions do not hold where you have two CPUs trying to use the same memory. In this case, one CPU must wait while the other uses the memory. As a result, the average speed of the CPUs will typically be cut in half.

There are two solutions to this problem: 1) You can provide local memory for both CPUs and limit use of the common memory to

CPU/CPU communication only, in an attempt to reduce the time impact of DMA waiting, or 2) you can provide true hardware dualport memory between the CPUs and all simultaneous high-speed access by both CPUs to the same memory without waiting. The introduction of high-speed dual-port RAM chips now makes the second option practical.

## Dual-Port RAM Chips: How They Work

A true dual-port memory allows independent and simultaneous access of the same memory cells by both devices. This means two complete and independent sets of address, data and read/write logic and memory cells that are capable of being read and written by two different sources. An example of the dual-port memory cell is shown in Figure 3. In this cell both the left and right hand select lines can independently and simultaneously select the cell for read out. In addition, either side can write data into the cell independent of the other side. The only problem would be when both sides try to write into the same cell at the same time. We will discuss this in a moment.


## DUAL-PORT RAM CONTROL LOGIC

Dual-port RAM chips include control logic to solve three common application problems: signaling between processors, timing interactions when both are using the same location and hardware support for temporary assignment (called allocation) of a block of memory to one side only.

## Interrupt Logic For Signaling

A common problem in dual-processor systems is signaling between the processors. For example, processor A needs to signal processor B to request a task to be performed, as defined by data in the common memory. When processor B has completed the task, it needs to signal processor $A$ that the task is done. Note that the signaling must occur in both directions. A common form of signaling is for one processor to cause an interrupt on the other proces-
sor. This allows the receiving processor to be informed of a communication without having to constantly check for it.

Hardware support for this signaling function is provided by interrupt logic, available on certain IDT dual-port RAM chips. A block diagram of this logic is shown in Figure 4. In these chips, the top two addresses of the memory chip also serve as interrupt generators for each of the ports. If the left side CPU writes into the even address of this pair (3FF in a 1K RAM) an interrupt latch is set and the interrupt line to the right hand port is activated. This interrupt latch is cleared when the right hand CPU reads from the even address. A similar set of logic is provided to allow the right hand CPU to interrupt the left hand one. This logic is associated with the odd address of the pair (3FE in a 1 K memory). Providing this logic on chip saves the system designer from having to design in extra logic to allow one CPU to interrupt the other.


Figure 4. IDT7130 Interrupt Logic

## Busy Logic Solves Interaction Problems

A problem can occur with dual-port memories when both ports attempt to access the same address at the same time. There are two significant cases: when one port is trying to read the same data that the other port is writing and when both ports attempt to write to the same word at the same time. If one port is reading while the other port is writing, the data on the read side will be changing during the read and a read error can be caused. If both ports attempt to write at the same time, the memory cell is being driven by both sides and the result can be a random combination of both data words rather than the data word from one side or the other. Busy logic solves this problem by detecting when both sides are using the same location at the same time and causing one side to wait until the other side is done.

Note that although one or the other processor may have to wait occasionally, the throughput loss is minimal, typically less than $0.1 \%$. This is because the probability of both processors using the same location at the same time is small. For example, if there are a thousand words in memory with a relatively uniform and random
access of these locations by either side, the probability of a given location being accessed by one side is of the order of one part of a thousand. The probability of both sides accessing the same location at the same time is, therefore, of the order of one part in a million. As a result, the average throughput of the system is reduced by only one part per million due to dual-port RAM access contention (again, assuming uniform random address access by both sides).

## Busy Logic Design

Busy logic is called hardware address arbitration logic because it consists of hardware that decides which side will receive a busy signal if the addresses are equal. It consists of common address detection logic and a cross coupled arbitration latch. A logic diagram of the type of busy logic used in the IDT dual-port RAM chips is shown in Figure 5. The purpose of this logic is to provide a busy signal for the address that arrived last, to inhibit writing to the busy port and to make a decision in favor of one side or the other when both addresses arrive at the same time. This logic consists of a pair
of address comparators, a pair of delay buffers, a cross-coupled latch and a set of busy output drivers. The address comparator output goes true when the addresses at its inputs are equal.

In the logic shown in Figure 5, the ability to detect which address arrived last is provided by the time delay buffers between address
lines and the comparators. If we assume that the $L$ address is stableand the $R$ address changes to match the $L$ address, the $R$ address comparator will go true immediately while the L address comparator will become active some time later as determined by the time delay gates.


Flgure 5. Dual-Port Busy Logic Design

The arbitration latch formed by the Land R gates reflects the address comparator output timing. This latch has three stable states, both latch outputs A and B high, A low $/ \mathrm{B}$ high and A high/ B low. Initially, both $A$ and $B$ are high because the outputs of both address comparators are low. We start with the L address stable and the $R$ address arriving later. When the R comparator becomes active its output will go high and $B$ will go low. The A output will remain high because its address comparator input will go high sometime later and the L gate input from B output will go low before this occurs. The result is that the $R$ gate $B$ output will be active inhibiting writing to the R side of the dual-port RAM and activating the busy signal to the $\mathbf{R}$ port.

The extreme case of busy logic decision making is when both addresses arrive at exactly the same time. In this case, the outputs of both address comparators go high at the same time activating both sides of the arbitration latch. The latch will settle into one of two states with either the A or the B latch output being active. The latch design ensures that a decision will be made in favor of one side or the other.
The chip enable lines come directly into the arbitration latch, although they could have been brought into the address comparators along with the other address lines. This is because if the chip enable for one side is inactive, both reading and writing for that side is automatically inhibited and/or arbitration is not needed. If the addresses are equal, the chip enable that arrives last will lose the arbitration. If both chip enables are active then arbitration will be determined by the settling of the address lines.

## Temporary Assignment of Memory to One Side

A common problem in dual-port RAM application is the need to temporarily assign a block of memory to one side. For example,
sometimes you need to update a data table as whole and you cannot allow the other processor to use the table until you are done. This is called block allocation of the memory.

Block allocation can also be used to avoid the address arbitration problem since it is a way of ensuring that both sides do not use the same address at the same time. This method is also called software arbitration because the software on both sides decides and agrees as to who has permission to use a given portion of the memory. Software allocation has the advantage of not requiring busy logic, which is useful in systems which cannot accommodate a busy signal.

The design problem with block allocation is communication of the assignments between the CPUs. A simple but time consuming method is to pass messages between the CPUs, perhaps aided by interrupt logic. In the message method, processor A requests use of a block from processor $B$. Processor $B$ agrees and sends permission back to processor $A$. When $A$ is finished it sends a release message to $B$ which responds with a release acknowledge to $A$. In this system, four messages are sent for each block assigned and released.

## Semaphore Logic Support for Memory Assignment

Although block allocation is a software technique, it can benefit from hardware support. In message passing allocation, four messages must be passed to assign and release a block of memory. Semaphore logic, available in certain IDT dual-port RAMs, can be used to eliminate this message passing and its associated overhead. Semaphore logic provides a set of flags especially designed for the block assignment function. Each flag is used as a token to indicate which CPU has permission to use a block of memory.

Each semaphore flag can be set to one side or the other but not both. This ensures that only one side has permission to use the block of memory.

The IDT semaphore logic bits are designed to be used in a set-and-test sequence. Each bit is normally in the logic one state, indicating that it is not assigned to either side. A processor, desiring to assign a bit and, therefore, its associated block of memory, attempts to write a zero into the bit. It then reads the bit to see if it was successful. If it was, the bit will read zero, and the processor has use of the block. If it reads a one, it was unsuccessful, and the block is in use by the other side. The processor must then wait until the bit becomes zero, indicating that the other side has released it.

Semaphore flags have a particular requirement: a given flag can be assigned to only one side at a time. Specifically, you must not have a situation where both sides simultaneously think they have permission to use a block. Semaphore logic is designed to resolve this problem. If both sides attempt to set a semaphore flag at exactly the same time, only one side sees it set.

Semaphore flags consist of eight individually addressable dualport latches. Each latch can be read and written by either side. They are selected by a separate chip enable, addressed by the three last significant bits of the address lines and are read and written through the $\mathrm{D}_{0}$ data bit. Except for sharing the address, data and read/write pins of the RAM, the semaphore latches are completely independent, as shown in Figure 6.


Figure 6. Dual-Port RAM Semaphore Logic

A logic diagram of a semaphore logic flag is shown in Figure 7. In this logic, both flip-flops are initially at logic one and both Grant outputs are high. If only one flip-flop is set to zero, its corresponding Grant output will go to zero. If the other flip-flop is set later, this
will have no effect. If both flip-flops are set at the same time however, the latch will settle so that only one Grant output goes low, ensuring that only one side receives permission to use the resource.


Figure 7. Semaphore Logic Design

## DUAL-PORT RAM CHIP TIMING

The dual-port RAM has a simple static RAM interface and timing requirements. There are some special requirements associated with Busy, however. A timing diagram, shown in Figure 8, shows the relationships between address, data, read/write, chip select
and busy signals for a dual-port RAM chip and busy logic. In this diagram, the chip select is used to enable the chip for a read or write operation after the addresses have settled. An arbitration is performed at the leading edge of the chip select.


Figure 8. Dual-Port RAM Timing Diagram

## Busy Logic Timing

In the case of address contention, the busy signal from the losing RAM port stabilizes some time after the leading edge of its chip select (or after its address settles, whichever comes last). If the busy signal is going to become active, it will become active during this time or not at all. If the busy signal is generated, the CPU must wait for busy to go away before completing the read or write cycle. Once the busy signal has gone high the memory read or write cycle can proceed to completion.

Note that during the arbitration time following the chip select the busy signal may be changing. Since it is possible to have a glich on the busy line during this indeterminate period, the busy line should be sensed as a level rather than as an edge.

Busy arbitration will be somewhat slower in the extreme case where both addresses arrive at exactly the same time. This is because both gates of the arbitrator latch are initially inactive and must settle into a state where only one of them is active. There will be a period of time when both gates are in transition. This is called the metastable condition and is a classic and unavoidable problem in latch and flip-flop design. As a result, the busy settling time is somewhat longer in the low probability worst case than in the commonly observed typical case. The maximum arbitration times, $t_{B A A}$ and $t_{B A C}$, on the data sheet give the worst case values, including metastability setting, for these times.

## Read/Write Timing with Busy

The read and write timing for either port of the dual-port RAM chip is the same as a simple static RAM in the absence of address contention. All the standard timing measures apply: read data address access time is $t_{A A}$, etc.

Dual-port RAMs have additional timing specifications for the case of address contention where one port is busy and waiting for
access. For the most general and conservative case, the read or write cycle for the waiting side should begin after the busy signal goes away. The actual timing can be somewhat shorter than this in most cases.

For the case where the waiting side is waiting to write, the write timing requirement is that the write pulse width be measured from busy going away. For the case where both sides are reading, the data will be available at the outputs one access time after the address/chip select lines settle even though the busy line is active. In the most common case, the trailing edge of busy will occur more than one access time after the address and data for the busy side have settled. As a result, the read access time as measured from the trailing edge of busy, for this case $\mathrm{t}_{\mathrm{BDD}}$, is effectively zero.

The write/read case, waiting to read while the other side is writing to the same location, has some additional timing specifications. Since writing to a location by the $L$ side, for example, will involve changing the data the cell being read by the $R$ side, there is a write-to-read propagation delay time. This time is tWDD for the delay for constant write data from the leading of the write pulse to the read data, and tDDD for the delay for changing write data from a change of the write data to the read data.

If the writing side is running at minimum values for the write pulse or write data set-up times, the read access time, $t_{B D D}$, will no longer be zero. The actual $t_{B D D}$ will be equal to tWDD minus the actual write pulse width or tDDD minus the actual write data set-up time, which ever is larger (and greater than zero). Note: t $\mathrm{t}_{\mathrm{BDD}}$ is always less than $t_{A A}$ for the worst case of minimum write values. This is why the read or write cycle is begun from the trailing edge of busy for the most conservative case recommended above.


## DUAL-PORT MEMORY EXPANSION: MAKING BIG ONES OUT OF LITTLE ONES

Dual-port RAM chips can be combined to form large dual-port
memories. Expansion in memory depth with dual-port RAMs is similar to expansion in depth for conventional RAMs. An example of this kind of expansion is shown in Figure 9 where and $8 \mathrm{~K} \times 8$ dual-port RAM has been made out of $2 K \times 8$ dual-port RAM chips.


Figure 9. Depth Expansion of Dual-Port RAMs

## Width Expansion: The Busy Lock-up Problem

Dual-port RAMs can also be expanded in width. However, in this case, we have a subtle problem. Expansion in width implies that several dual-port RAM chips will be active at the same time. This is a problem if several hardware arbitrators are active at the same time. If we examine the case of a 16-bit RAM made out of two 8-bit RAMs, we can better understand the problem. If the addresses for
both ports arrive simultaneously at both RAMs, it is possible for one RAM arbitrator to activate its L busy signal and the other RAM to activate its R busy signal. If both busy signals are used on each side, we now have a situation where both sides are simultaneously busy. The system is now locked up since both sides will be busy and both CPUs will wait indefinitely for their port to become free.

## The Busy Lock-up Solution: Use Only One Aibitrator

The solution to this busy lock-up problem is to use the arbitration logic in only one RAM and to force the other RAM to follow it. In this case, one RAM is dedicated as the arbitration MASTER and additional RAM are designated as SLAVES. Two solutions to this
problem are shown in Figure 10. One solution is to add external logic to the chip-enables of additional dual-port RAM chips. The logic gates shown cause the SLAVE RAM chip select to be disabled if the MASTER RAM is busy. Since only one set of arbitration logic is controlling the system the problem of SLAVE lock-up is avoided.


Width Expansion with SLAVE Logic (Not Recommended)


Width Expansion with SLAVE Chips (Recommended)

Figure 10. Width Expansion of Dual-Port RAMs

The second, more desirable solution, is to use specially designed dual-port RAM SLAVE chips which are part of IDT's product line. These SLAVE chips incorporate the SLAVE disable logic internally so that no additional logic is required to make a MASTER/ SLAVE combination. In the SLAVE chip, the busy pin serves as an input rather than an output. If the MASTER chip activates busy, the

SLAVE chip will sense this busy state and internally disable its write enable. SLAVE chips provide a speed advantage over systems which use external logic to implement the SLAVE function. Since the SLAVE logic is built into the SLAVE RAM chip, it can be designed so that there is no speed penalty when using SLAVE chips to expand the dual-port RAM width.

## Width Expansion: Write Timing

When expanding dual-port RAMs in width, the writing of the SLAVE RAMs must be delayed until after the busy input at the SLAVE has settled. Otherwise, the SLAVE chip may begin writing while the busy signal is settling. This is true for systems using SLAVE chips and for systems using conventional dual-port RAMs
with SLAVE logic. This delay can be accomplished by delaying the write enable to the SLAVE by the arbitration time of the MASTER. This is shown in Figure 11.


Figure 11. MASTER/SLAVE Write Timing

Note that the write delay is required only in width expanded systems which use SLAVE RAMs, not in single chip or depth expanded systems where only one chip is active at a time. This is because the individual chips have a built-in delay between the chip select and write enable inputs and the internal write enable to the

RAM. Separate timing must be supplied in the SLAVE case because this internal delay time can be balanced to the arbitration time only within a chip and can vary from chip to chip. If the delay time for the SLAVE is less than the arbitration time of the MASTER, writing could begin before busy became active, as above.

Width and Depth Expansion: An Example
These techniques for expanding dual-port memories in width and depth are combined in the example shown in Figure 12. In this
example, an $8 \mathrm{~K} \times 16$ dual-port memory is made from $2 \mathrm{~K} \times 8$ chips in MASTER/SLAVE combination.


Figure 12. Width and Depth Expansion of Dual-Port RAMs

## USING THEM: DUAL-PORT RAM APPLICATION EXAMPLES

Examples of dual-port RAMs used for CPU-to-CPU communjcation are shown in Figures 13, 14 and 15. In Figure 11, a pair of 8 -bit processors communicate using a single $2 \mathrm{~K} \times 8$ dual-port RAM chip. In Figure 12, there is a similar system where a pair of 16 -bit processors communicate using a pair of dual-port RAM chips and a MASTER/SLAVE configuration. Finally, in Figure 13, we have an

8 -bit processor communicating with a 16 -bit processor through two $2 \mathrm{~K} \times 8$ dual-port RAMs.

In Figure 13, two Z80 microprocessors communicate using a single IDT7132 dual-port RAM chip. The IDT7132 is controlled by the chip enable. The write enable is set up in advance by the WR signal from the Z80 and the chip enable is used to write data into the RAM or to gate the read data onto the Z80 bus. The output enable (not shown) is tied to ground (continuous enable). The write enable is used to disable the output drivers.


Figure 13. 8-bit to 8-bit CPU Communication

In Figure 14, two 68000 microprocessors communicate through a pair of dual-port RAMs. A IDT7132/7142 MASTER/SLAVE pair is used to avoid the busy lock-up problem. Note that the Address Strobe (AS) from each 68000 is used with an address decoder to
enable the dual-port RAM chips. This is to maintain the address for read-modify-write cycles so that arbitration is not lost between the read and the write. This is important for test and set instructions, for example.


Figure 14. 16-bit to 16 -bit CPU Communication

In Figure 15, a Z80 and a 68000 communicate using a pair of IDT7132 dual-port RAMs. No SLAVE logic is required because the Z80 side chip enable decode ensures that only one RAM chip will
be enabled at a time. Otherwise, this figure is a combination of the logic from Figures 13 and 14.

DATA BITS ${ }_{8-15}$


Figure 15. 8-bit to 16 -bit CPU Communication

## SUMMARY AND CONCLUSION

The development of true dual-port memories in integrated circuit form provides the designer with the ability to set up communication between components of a computer system while avoiding many of the problems of prior systems. While the concept of dualport memory has been with us from the early days of computing in
the form of DMA, the new dual-port ICs can provide this function at very high speeds and without the delays associated with earlier designs. Because of the utility of the dual-port memory concept these chips should come into wide spread use and become one of the standard components used by the computer designer.

> DUAL-PORT RAMs YIELD BIT SLICE DESIGNS WITHOUT MICROCODE

## APPLICATION NOTE <br> AN-09

By DAVID C. WYLAND

## ABSTRACT

High-performance controller designs use bit-slice components for their speed and design flexibility. Speeds of 10-20 million instructions per second (MIPS) are common and the designer can use bit-slice design flexibility to perform speed-critical operations in one instruction. Bit-slice designs have the drawback, however, of requiring microcode design for their implementation, often with a long development cycle. The problem is that the microcode resides in a separate, stand-alone control memory which prevents use of the kind of interactive prototyping and debugging tools associated with conventional microprocessors. The problem can be eliminated by using a dual-port RAM for the control memory, making it part of the data memory address space, and converting the controller to a CPU by borrowing some techniques from Reduced Instruction Set Computer (RISC) designs. The result is a RISC controller where the microinstructions of the bit-slice approach become the instructions of a computer. The design approach provides all the speed and architectural flexibility of microcoded bitslice designs, while allowing the use of interactive debugging methods associated with microprocssors.

## BIT-SLICE VERSUS RISC ARCHITECTURES

An example of a typical bit-slice controller design is shown in Figure 1. It consists of a control flow section and a data flow section. The control flow section has a microinstruction counter and the
control memory. The data flow section has a register and ALU ele-ment-the bit-slice-plus a data memory and I/O registers on a data bus. Note that the control and data memories are separate. The use of separate data and instruction memories is called the Harvard architecture. The separate control memory provides some of the speed associated with bit-slice designs because it operates in parallel with the data memory. This allows the next microinstruction to be fetched from the control memory, while data for the current instruction may be read from the data memory. This contrasts with conventional microprocessors which alternately get instructions and data from the same memory. This use of a single memory for instructions and data is called the Von Neumann architecture.

There is a remarkable similarity between the block diagram in Figure 1 and the block diagrams of RISC computers, as can be noted by comparing the block diagram in Figure 1 with the block diagram of a RISCCPU shown in Figure 2. The difference is that the control memory and the data memory of the controller have been replaced by an instruction cache memory and a data cache memory in the RISC CPU. The instruction and data cache memories work the same as their microcode counterparts except that they both contain copies of data in the common main memory. The programmer sees a single memory-the main memory-while the hardware works as if it has two independent memories. In this manner, the RISC computer has the speed advantage of the Harvard architecture and the single memory for programs and data of the Von Neumann architecture.


FIgure 1. Bit-Slice Controller Block Diagram


Flgure 2. RISC CPU Block Diagram

The instruction and data caches of the RISC architecture are equivalent to having two ports on one memory. We can apply this concept to bit-slice controllers by using a high-speed dual-port memory in place of the cache memories, as shown in Figure 3. The dual-port RAM allows the instruction and data ports to be active simultaneously and independently, while providing both sides access to a common set of RAM cells. Since both ports are working from the same memory, the data flow section can load and move both data and instructions in the same manner as a conventional microprocessor. As a result, this design functions as a conventional CPU with a long instruction word. This allows conventional interactive software tools, such as interpreters and monitors, to be used in system development and debugging.

## DESIGN OF A RISC CONTROLLER

The design of a RISC controller using a dual-port control memory is similar to a conventional bit-slice design except for inclusion of a minimum set of operations for a CPU. This allows use as a conventional computer for software coding and debugging. In ordinary bit-slice controller designs, the minimal CPU operation set already exists as a subset of the data flow and control operations already present.

A minimal set of CPU operations, suitable for bit-slice designs, can be derived from the instruction set of a RISC-like computer such as the Data General Nova minicomputer. It is a useful example because it is a 16 -bit general register design having approximately 20 instructions and three addressing modes, yet is fully functional as a computer. From its instruction set, the list of 21 operations shown in Table 1 can be derived as a representative minimum
working set. If the design includes these operations, it will function as a CPU.
Table 1. Minimal CPU Instruction Set

1. Load register from memory at immediate address (address in instruction).
2. Load register from memory at address in a register.
3. Store register to memory at immediate address (address in instruction).
4. Store register to memory at address in a register.

5-11. Move/combine registers: move, negate, invert, add, subtract, AND, OR.
12-13. Shift: rotate left through sign, rotate right through sign.
14. Read status register.
15. Write status register.
16. Jump absolute: load program counter with immediate address.
17. Jump register: load program counter with register contents.
18-20. Jump absolute conditional: if zero result, if sign, if carry.
21. Jump and save return (Program Counter) in a register.

This instruction set assumes a set of general purpose registers (typically 16 or more in bit-slice designs), a memory which contains hoth instructions and data and a status register which records the result of register-to-register operations. I/O registers are assumed to be mapped into the memory space so that separate instructions for them are not required.


Figure 3. Bit-Slice Controller With Dual-Port Control Store

Some of the above operations are automatically included in bitslice controllers as a result of staightforward design. The register combination operations are provided by the bit-slice RALUs and the jump operations are commonly required as part of the control flow design. All that is required to complete the set is the ability to transfer registers to and from memory, to save and restore the status register and to save the Program Counter in a register in Jump and Save Return instructions.

Figure 4 shows a block diagram of a general purpose bit-slice controller design, based on the RISC controller architecture in Figure 3, and capable of implementing the minimal instruction set. This is a 16-bit controller design using an IDT49C402 16-bit RALU and a 64 -bit instruction word. The control flow section is fully pipelined for maximum speed and uses a simple counter as the Program Counter ( PC ). As a result, branch execution is delayed by one instruction: the instruction following the branch is executed before the branch takes effect. This method allows maximum speed in the control flow section and is commonly used in RISC designs. A path is provided from the PC to the data inputs of the IDT49C402 for saving the PC in a register during Jump and Save Return operations. Also shown in the block diagram is an initial-load EPROM. This EPROM holds the non-volatile copy of the program to be loaded at power up. A power up flip-flop and some sequencing logic cause the contents of this EPROM to be loaded into the RAM at power up.


Figure 4. Dual-Port Bit-Slice RISC Controller Design Block Diagram

In the design in Figure 4, the instructions and data share the same memory. The mapping for instructions and the mapping for data are different, however, as is shown in Figure 5. The eight dualport RAM chips are mapped as 2 K words of 64 bits/word on the instruction port and as 8 K words of 16 bits/word on the data port. Each 64-bit instruction word corresponds to four sequential 16-bit data words. The instruction at address 0000 on the instruction port corresponds to locations $0000,0001,0002$ and 0003 on the data port. On the instruction port, all eight chips are enabled, resulting in 64 bits of instruction output. Only the upper 14 bits of the PC are used to address the RAM so that the address in the PC is consistent with the addressing on the data side. On the data port, the least significant two bits of the address in MAR select the appropriate 16-bit word by selecting the chip enable for the appropriate one of four pairs of chips.

## RISC CONTROLLER INSTRUCTION FORMAT

The 64-bit instruction word is shown in Figure 6. Fifty of the 64 bits are used to control the basic data and control flow of the controller and 14 bits are available as additional control bits for the specific controller application. Each 64 -bit instruction word from the control port of the RAM is mapped as four 16-bit words on the data memory port. A larger instruction word can be used in the same manner as in microcoded designs. It is convenient if the word width is a power of two, such as 64 or 128 bits, so that there are no gaps in the memory space as seen from the data flow side.

The IDT49C402 is controlled by the A and B fields , 10-9, CN , Stat Enable field and the Shift Gating field. The $A$ and $B$ fields provide the 6-bit addresses for the $A$ and $B$ register inputs on the IDT49C402. The I0-9, $\mathrm{C}_{\mathrm{N}}$ and Stat $\mathrm{E}_{\mathrm{N}}$ field provide the 10 control bits to the IDT49C402, the carry-in bit and a status register load enable, respectively, and the Shift Gating field controls the shift-in/ shift-out gating for shift operations. The data source for the DIN pins of the IDT49C402 is selected by the Din field. This field can choose the data bus, the immediate data field or the PC as the data source.

The data bus is controlled by the A and B fields as well, which provide 6-bit select codes for bus read and write operations, respectively, and by the bus read/write, memory write and load MAR bits. The default operation is to gate the data from the IDT49C402 onto the data bus. The load MAR and memory write bits allow writ-
ing this data into the memory and/or MAR from the bus. The bus read bit disables the IDT49C402 outputs and gates an I/O register onto the bus as determined by the 6 -bit A field. The bus write bit causes bus data to be written into an I/O register selected by the B field.

Branch operations are controlled by the Jump and A fields. The Jump field enables loading of the PC from the bus, which is the branch operation. The A field provides the 6-bit condition select code for conditional branch operations.

The Misc Control field provides 14 bits for direct control of additional devices. This field would typically be used for gates and strobes to additional devices such as parallel multipliers, FIFOs, disk controller chips and other devices which communicate with, and are controlled by, the RISC controller.

## IMPLEMENTING THE MINIMAL INSTRUCTION SET

The RISC controller design must now be checked to ensure that it implements each instruction in the minimal instruction set.

## Load and Store

Load and Store register operations are done in two instructions: load MAR and load or store register. The load MAR instruction places register data from the IDT49C402 or data from the immediate data field on the bus and enables MAR load. The load register instruction gates memory data into the data inputs of the IDT49C402. The store register instruction gates register data onto the bus and writes it into memory.

## Move, Combine and Shift Register

Register-to-register and shift operations are performed directly by the IDT49C402 bit-slice.

## Status Register Read/Write

Read and Write Status register operations select the Status Register and bus read and write, respectively.

## Jump and Conditional Jump

Jump operations are done by enabling the PC to be loaded from the bus using either immediate or register data for the jump address. Conditional Jump is done by enabling a conditions select multiplexer to conditionally enable the PC load.


Figure 5. Dual-Port Controller Memory Map


| FIELD | FUNCTION |
| :--- | :--- |
| A | 402 reg address, bus read <br> select, or jump condition select |
| B | 402 reg address or bus write select |
| I $0-9$ | $49 C 402$ instructions + carry-in |
| Stat EN | Enable Status reg load |
| DIN | 402 D Bus: Memory, PC, Bus, I field |
| Bus R/W | Gate Bus read @ A, write @ B |
| MW, MAR | Memory write enable, Id MAR enable |
| Jump | Enable PCload, enable condition test |
| Shift | 402 shift/rotate gating |
| Imm Data | Immediate Data - addresses, etc. |
| Misc Control | Misc bits for controller functions |

Figure 6. Dual-Port Controller Instruction Format

## Jump and Save Return

The Jump and Save Return operation is performed by using the immediate data field to provide the jump address and simultaneously storing the PC in a register selected by the B field. The immediate data field is gated to the bus, the PC is gated to the IDT49C402 data inputs and the IDT49C402 is instructed to perform a D-input-to-register-load operation.

## RISC CONTROLLER TIMING

The design in Figure 4 is capable of a 55ns cycle time. A timing diagram for a $55 n$ s cycle time, assuming the $35 n$ s dual-port RAMs, is shown in Figure 7. The critical timing path, in this case, is the data path from the Memory Address Register (MAR) through the data port of the memory into the IDT49C402. If the dual-port RAMs are slower than 35 ns , the cycle is extended proportionately.


Figure 7. RISC Controller Timing Diagram

Table 2. Critical Path Timing

| CONTROL PATH | DATA PATH |  |  |
| :--- | :---: | :--- | :---: |
| PC settle: FCT161A | 6.5 ns | MAR settle: FCT161A | 6.5 ns |
| RAM Access | 35.0 | RAM Access | 35.0 |
| I reg set-up: FCT374A | 2.5 | IDT49C402A, Din Sert-up | 10.0 |
| Total | 44.0 ns | Total | 51.5 ns |

## RISC CONTROLLER APPLICATION

The utility of the RISC controller design approach is that it allows interactive system development, debugging and diagnostic testing. It also provides the potential for high-level language support of the bit-slice design. Powerful interactive access to the RISC controller can be provided by an RS-232 interface and a FORTH language interpreter program. This allows interactive coding and testing of the system, speeding up the test-and-analyze debug cycles. This RS-232 interface can exist on a separate board external to the RISC controller, connected to the bus by a connector on the controller board. No additional hardware is required for access by the designer to the system and this accesş can allow direct activation and sensing of controller hardware, setting up timing loops for oscilloscope checks and on-line development of routines. If a floppy disk controller is included in the external I/O board, the RISC controller can function as a stand-alone development system in the same fashion as other stand-alone FORTH systems.

The RISC controller's ability to load programs also means that diagnostics can be loaded from the initial load EPROM. The initial load EPROM can hold both the normal control program and various test programs. The controller can load diagnostic programs from the EPROM for board and system test without requiring permanent space for them in the control memory. This allows self-diagnostics at the hardware level with minimum cost impact on the hardware.

## SUMMARY

The RISC controller uses high-speed dual-port RAMs to blend the features of a bit-slice controller with the capabilities of a RISC computer, allowing the microinstructions of the bit-slice approach to become the instructions of a computer. This design approach provides all the speed and architectural flexibility of microcoded bit-slice designs, while allowing the use of interactive debugging methods associated with microprocessors to shorten development time.

by Michael J. Miller

## INTRODUCTION

Due to their high bandwidth and message access flexibility, dual-port RAMs are used to link multiple high-performance processors and systems. Integrated Device Technology makes dualport RAMs of many configurations, all of which consist of one RAM with two sets of address, data and control signals. This allows two processors to share the same block of physical memory in their respective address spaces. The two processors can access data in two memory locations simultaneously and asynchronously. This approach clearly outperforms a discrete parts design where two processors must synchronize through arbitration for access to a bus which is used to access one location at a time in a standard single-port RAM.


Figure 1. Dual-Port RAMs Link High-Performance Processors

IDT's dual-access approach removes synchronization requirements at the memory's bus access level. Nevertheless, synchronization must be performed at other levels to ensure data integrity and proper system operation. This application note addresses several approaches to solving the mutual exclusion problem and gives a detailed discussion of the semaphore capability provided by the IDT71322 and IDT71342.

## Arbitration

Consider a multiple-processor system where each processor has access to the same data. Arbitration schemes are necessary to resolve the situation when multiple processors want the same piece of data at the same time. Different approaches to the arbitration issue have different tradeoffs and are best-suited for different applications. These solutions vary from no arbitration, hardware solutions, and software solutions, to combinations thereof.

Seemingly, the simplest solution is to employ no arbitration at all. This approach works if the application guarantees that two processors will not access the same location simultaneously or, if they do, then the indeterminate results are acceptable. Sometimes handshaking can be employed through I/O ports or interrupt mechanisms. This approach provides a high-performance, lowoverhead design but is restricted to certain applications. If arbitration is not required, the IDT7134 can be used. It is a $4 \mathrm{~K} \times 8$ dual-port RAM with no arbitration. This part can also be used in large dualport designs where one hardware arbiter is used for a whole array composed of many IDT7134s. The interrupt handshake mechanism can be achieved by using the IDT7130/7140.

Most applications cannot sacrifice data integrity and utilize the dual-port memory as a collection of individual memory locations which require a finite access time. In this case, arbitration at memory location resolution is required. The IDT7130/7132 use an address comparison mechanism which provides a BUSY signal at both sides. When the two processors try to access the very same location, the arbitration asserts the $\overline{B U S Y}$ signal to the processor which attempted access last. When access attempts are within 5 ns of each other, a side is chosen arbitrarily. The BUSY outputs are suitable for attachment to the READY inputs of most microprocessors. This approach is very straightforward and flexible and has the benefit that a processor cannot be locked out of the RAM longer than the access period of the other processor.

The features of the IDT7130/7 132 that make them a superb solution in many designs may create problems in other applications. The fact that BUSY lines are used and that arbitration resolution is at the level of individual locations can be a major limitation in some instances. Many significant controllers, such as the 8031 and 8051 , are not equipped with READY input pins. Of those that are equipped, a penalty is often paid in the higher performance versions if they require "seeing" the BUSY signal faster than the IDT7130/7132 can supply it ( 16 MHz 68020 requires $25 \mathrm{~ns} \overline{\mathrm{AS}}$ to $\overline{\text { DSACK }) . ~ I n ~ t h e s e ~ c a s e s, ~ w a s t e f u l ~ w a i t ~ c y c l e s ~ a r e ~ r e q u i r e d . ~ I n ~ o t h e r ~}$ applications, software constraints may require mutual exclusion at the software data structure level rather than at the memory cell location level. For this reason, Integrated Device Technology developed the IDT71342 and IDT71322.

Instead of comparing addresses on every cycle, and occasionally asserting $\overline{B U S Y}$ status, the IDT71342 and IDT71322 employ circuitry to support a software mechanism called semaphores. Here, every memory cycle is equally as short as the next and arbitration is handled at the software level.

The semaphore concept was pioneered by E.N. Dijkstra in 1968. He developed a test and set approach for single processor multi-tasking systems. The task tests a memory location (a semaphore) for a particular value and, on the next cycle, the task sets the same location a unique value. If the semaphore was already set, then the current task knows that another task has access. If the value was not present, then the task knows that it has permissionto proceed and all other tasks are blocked because the semaphore is not set. Only one task at a time has permission via the semaphore. Semaphores are used like locks to resources such as disk buffers, message queues, critical code sections, shared access to communication controllers, etc.

Because the test and set operation requires that the two memory accesses are indivisible in time, the IDT7130/7132 will not support semaphores for many processors and systems. This occurs because one processor may test the semaphore and, before it can set it, the other processor might test it, too. In this case, both processors "believe" they have the semaphore. The IDT71342/71322 employs a twist by using set and test. The "set" corresponds to a request and the "test" checks to see if the request was granted. The indivisible double access requirement is avoided because, as soon as a request is made by one processor on one side, the grant
is blocked on the other side. Some processors support test and set operations through a read/modify/write operation, but the memory bus design must support the processor in such a way that the address and the chip select remain constant. When the test and set instruction is used, arbitration must take place. As will be seen, semaphore operation without hardware busy arbitration has many advantages.

The IDT semaphore scheme employs a software/hardware approach which provides a secure method of resource allocation with the flexibility of software configuration and control and the resolution of hardware. Since there is no hardware relationship between semaphores and dual-port memory locations, the block sizes, locations and semaphore association are defined by the software. The semaphores can also be used to allocate other resources such as I/O devices. This offers the system designer considerable flexibility.

As an example, dual-port RAM might be shared by a disk controller processor and a host processor. When the controller is accessing a buffer in memory (e.g. when writing a sector in a track), the main processor cannot be allowed to interrupt or delay the controller. By setting the semaphore, the controller has exclusive access to the disk buffer. When done,it releases the semaphore and therefore provides access to the disk buffer by the processor on the other side.

Because the processors must test and set a semaphore with multiple bus cycles, the semaphore arbitration scheme has a longer arbitration latency than the address comparison scheme. Since arbitration is most often used for access to multiple locations in memory the overhead can be amortized across multiple accesses. In systems that require mutual exclusion of access to data structures over a period longer than one memory cycle, this tradeoff is irrelevant.

## Functional Description of the IDT71342/71322

The IDT71342 is a fast dual-port $4 \mathrm{~K} \times 8$ CMOS static RAM with semaphore logic, packaged in a $52-\mathrm{pin}$ PLCC and LCC. The IDT71322 is a $2 \mathrm{~K} \times 8$ dual-port packaged in a 48-pin DIP and a $52-$ pin PLCC/LCC. The semaphore logic can be used to allocate portions of the dual-port RAM to one side or the other and is used in place of the address arbitration logic used in other dual-port designs. Semaphores are software-controlled. Therefore, this approach provides several advantages including allocation of multiple blocks of arbitrary size and no processor WAIT states or $\overline{B U S Y}$ logic.


Figure 2. Functional Block Diagram of Dual-Port RAM with Semaphores

Like other IDT dual-port RAMs, the IDT71342/71322 allow access to a common set of RAM cells from two independent ports. Each port is functionally identical to that of a conventional static

RAM. Both ports are completely independent and asynchronous in operation. Reading or writing on one port does not affect the operation or timing of read/write operations on the other port. Unlike the IDT7130/7132, the IDT71342/71322 do not employ hardware arbitration which blocks write access. If one port is writing to a location while the other port is reading that same location, the data will change during the read. If both ports attempt to write to the same location at the same time, the result will be some combination of the two data words being written. If both ports are reading, however, there is no interaction because the data does not change.

## How the Semaphore Flags Work

The semaphore logic is provided by a set of eight latches. These latches can be used to pass a flag, or token, from one port to the other to indicate that a block of RAM is in use. The internal circuitry prevents the flag from being passed in both directions at the same time. The semaphores provide a hardware assist for a use-assignment method called "token passing allocation". In this method, the state of the semaphore latch is used as a token indicating that a block of RAM is in use. If the processor on the L port wants to use a block of RAM, it attempts to set the latch, requesting the token. The processor then checks the latch to see if it was successful in setting the semaphore. If it was, the processor proceeds to read and/or write in the block. If the processor was not successful in setting the latch, it means that the R port had set if first, has the token and is using the block. The L port then continues to test until it is successful, indicating that the R port has released the token and is no longer using the block.

The semaphore logic is independent of the dual-port RAM. These eight latches can be accessed from either port by enabling the semaphore chip enable ( $\overline{\text { SEM }}=$ LOW), which is separate from the RAM chip enable. When the semaphore logic is enabled on a port, one of the eight latches can be read or written from that port. The latch is selected by the three least significant address pins for the port and the data for reading and writing uses the $D_{0}$ data pin.

A semaphore latch is read or written in the same manner as a RAM cell. The latch is written to a " 1 " or " 0 " by activating the semaphore logic enable, selecting the latch with the three least significant address bits, activating the write enable and putting a " 1 " or " 0 ", respectively, on the Do data pin. The latch may be read by activating the semaphore enable, selecting the latch, holding the write enable high and reading the data on Do. For the user's convenience, all eight of the data lines are set to the same value as Do during read. In other words, the data lines will contain all " 1 "s or all " 0 " $s$ when Do is a " 1 " or a " 0 ", respectively. In this way, branch zero testing can be employed.

The semaphore read logic latches the readout state of the semaphore flag during the read. This prevents the value seen by the reading port from changing during the read, even though the state of the latch may be changing internally due to write activity on the other port. The latch goes into the hold mode when both semaphore enable and output enable are active. In order to see the latch change, either the semaphore enable or output enable must be disabled, and then enabled. This means that read operations must be cyclic; it is not possible to enable the semaphore and outputenable continuously and wait for the latch value being read to change.

The semaphore logic is active low. An access token is requested by writing a " 0 " to the semaphore latch and is released by writing a " 1 ". To request a token, an attempt to write a " 0 " to the semaphore is made and the semaphore is read to determine if the " 0 " was successfully written. If a " 0 " is read, the token request was granted. If a " 1 ". is read, the request was denied and the other port has the token.

The critical case of semaphore timing occurs when both ports request the token by writing a " 0 " at the same time. The semaphore logic is specially designed to resolve this problem - if requests are made simultaneously, the logic guarantees that only one side receives the token. In this case, the token assignment will be made arbitrarily to one port or the other.

Figure 2 shows the internal logic circuitry for one semaphore "latch" cell. It is composed of multiple latches and cross-coupled AND gates which serve as an arbiter to guarantee that only one side at a time receives a grant signal. A typical sequence of semaphore operations is listed in Table 1. The Docolumns represent the logic value that would be read on that side. The "Request F/F"s are the internal flip-flops which store the state of requests.


Flgure 3. Simplified Diagram of One Semaphore Cell

| Function | Left |  | Right |  | Status |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | DO | Request F/F | Reguest F/F | DO |  |
| No action | 1 | 1 | 1 | 1 | Semaphore free |
| $L$ port writes 0 | 0 | 0 | 1 | 1 | L port has token |
| R port writes 0 | 0 | 0 | 0 | 1 | No change; L port keeps token |
| L port writes 1 | 1 | 1 | 0 | 0 | Semaphore freed: R port gets it |
| R port writes 1 | 1 | 1 | 1 | 1 | Semaphore free |
| $L$ port writes 0 | 0 | 0 | 1 | 1 | $L$ port has token |
| L port writes 1 | 1 | 1 | 1 | 1 | Semaphore free |

Table 1. Semaphore Function Table

## Use of Semaphores

Semaphores provide useful solutions for various problems at both the hardware and software levels. The following selections highlight a few of the semaphore benefits which range from increasing performance to providing functionality not available with other designs.

## High-Performance Dual-Port Design

To gain a deeper understanding of the trade-offs between semaphore and non-semaphore dual-port RAM designs, the following example compares both approaches. Dual-port memory system design requires a key awareness of the microprocessor's memory
access time requirements. Figure 3 is a read cycle timing diagram of a 20 MHz 68020 . Two timings are critical: A 45 ns address to data size acknowledge ( $\overline{\text { DSACK }}$ ) to guarantee no wait states and a 95ns address to data. It is also important to examine a typical design. Figure 4 shows the interface between a single processor and one side of the dual-port. For simplification, the other port interface was omitted from the drawing. This example shows the address bus which is decoded by a comparator (IDT74FCT521A) and an address decoder (IDT74FCT138A). The address interface chooses which dual-port RAM to enable. After the chip select is enabled, chip select address arbitration (only on the IDT7130/7132) and data access can begin.


Figure 4. Read Cycle Timing for 20Mhz 68020


Figure 5. Memory Interface to One Port of a Dual-Port RAM System

In a tightly-coupled system (i.e., the 68020 processor and dualport are on the same board), chip select can be generated from address in 13 ns . In the best case, the data acknowledge is tied to the 68020 through a NAND gate (to include other acknowledges). The NAND gate will introduce another 5 ns delay. This leaves $26.9 n$ to generate the acknowledge (DSACK) and meet the 5 ns setup time to guarantee that a wait state will not be inserted. In a less rigorous design where the dual-port and CPU are on separate boards, 10 ns or more may be required for on/off board buffers and bus delay, etc. This leaves 16 ns or less to generate acknowledge.

Considering the timing constraints, the designer can choose from several options. In applications which require arbitration resolution to the memory cell level, 26.9 ns is not enough time to generate $\overline{\text { DSACK }}$ from $\overline{C S}$ using the IDT7130L55. One solution involves
adding logic to the $\overline{\text { BUSY/DSACK path so that a wait state is always }}$ inserted until the dual-port can respond with BUSY. This will slow down the system whenever the dual-port is accessed. If block arbitration or higher memory cycle performance are required, the designer should utilize the IDT71342/71322. This configuration would only be constrained to the 95 ns address to data access time, minus any address and data buffer time. The IDT71342/71322 provides high enough performance for use with the 25 MHz 68020. Some software overhead is required for semaphore access but, given the fact that the semaphore arbitration is for a block of locations, the arbitration latency can be amortized across multiple higher speed accesses. Consequently, the semaphore approach provides a higher performance solution if block arbitration is desirable or acceptable.

## A Software View of Semaphores

The dictionary defines semaphore as "signaling by flags." A semaphore is implemented as a specialized type of memory location which can be accessed by either processor in a dual-port design. Two different operations are performed on the semaphore: the request operation which attempts to gain access and the release operation which signals the termination of access. Theseoperations are used to guarantee mutual exclusion, meaning that only one processor is accessing a resource at any given time. This occurs from the time a request is granted until the time that the semaphore is released.


Flow Chart 1. Sequence of Operations on Semaphore to Guarantee Mutual Exclusion

A semaphore is chosen which both processors associate with one resource. First the processor requests the semaphore by attempting to write a " 0 " to the semaphore location. Then it reads the location. If it receives a non-zero value (i.e. a "1"), it loops back and reads the semaphore location again. It will continue to read the location until it receives a " 0 ". The software may be written in such a way that useful work may be performed while waiting. When a " 0 " is read, the processor can access the resource for as long, and as many times, as desired. The processor must release the semaphore when it is finished with the resource. This is achieved by writing a " 1 " to the semaphore location.

## Using Semaphores at the Software Level

One example of where semaphores might be applied involves two processors working together to generate a video display for animated images. The "MASTER" processor generates a picture layout in the form of a display list. The "SLAVE" processor reads
the display list, interprets it and generates an image in a display buffer. As the image is displayed, the video buffer is cleared. The displayed list is re-interpreted and displayed. If the display list is changed, the image appears as though it has moved, giving the illusion of animation.


Figure 5. Software Block Diagram of Video Display System for Anlmation

A dual-port RAM is used to store the display list. The SLAVE interprets one display list repeatedly to generate the display buffer image, while the MASTER generates and updates another display list. The SLAVE processor continuously updates the video display buffer since the buffer is wiped clean when its contents are dumped to the video screen.

In this particular application, the dual-port RAM is broken up into three areas. The first area contains common information concerning which display list is being accessed and which one is being updated. It is locked with the semaphore SEMO. Two buffers comprise the other areas and are locked by semaphores SEM1 and SEM2. At any given time one buffer is used for the display list currently being interpreted and the other is used for the list being built. The common area stores the pointer which indicates which buffer is being updated.

The key to the effectiveness of this approach lies at the software level. The flow chart for the master processor begins with a buffer request via a semaphore. Once granted, it builds a display list. Then it releases the buffer through the semaphore mechanism. Next it calls a routine to inform the SLAVE processor to switch over to the new buffer. It then loops back to request access to the other buffer.

The SLAVE processor functions by first fetching the current buffer/number. Then it requests the buffer via the semaphore mechanism (involving SEM1 or SEM2). Once the SLAVE gains access to the buffer, it builds the display from the list. After releasing the buffer, it goes back to fetching the current buffer/number. This is necessary because the MASTER processor may have switched buffers. Fetching the current buffer/number requires access to the common area which is achieved by obtaining the semaphore SEMO. After accessing the data, the SLAVE releases SEMO which allows the MASTER to come in and update the common area.


Flow Chart 2. Sequence of Operations for Master Processor


## Flow Chart 3. Sequence of Operations fo̧ Slave Processor

The software code for the MASTER and SLAVE processors is listed on the following pages. It is in the form of a pseudo- "C" lan-guage-type program. The request for a semaphore is made by the WHILE statements accessing a variable called SEM. The semaphore is released by writing a " 1 " to that variable.

## Semaphores and Caches

In high-performance dual-port systems, semaphores can be used with caches to achieve valid data synchronization. The use of caches is an established method of speeding up access between a processor and main memory. Main memory may be slower due to the use of lower cost, higher density DRAMs or system bus latency. The cache operates by monitoring data transfer between the processor and memory. When write operations are performed, the cache remembers the data and location. When a read is performed it compares the address of the request with a list of locations it has data for. If the address matches, the cache supplies the data and aborts the main memory access. If no match occurs, the cache allows the main memory access to proceed and notes the data and location.


Flow Chart 7. Dual-Port RAM In a Cached Memory Environment

One might first assume that the dual-port RAM can always be used with cached memory accesses. However, extra considerations must be made. When data is written to a memory location in dual-port RAM, the cache stores the acquired value and its associated location. The next time that location is read, the cache will register a "match" and bypass reading from the location in dual-port RAM. This might result in an error if a processor on the other port has written new data to the location.

One way to remedy the situation is to put the dual-port RAM into non-cached I/O address space and block data transfer between the dual-port RAM and cached address space where standard RAM exists. To make this approach work, semaphores must be employed to lock a buffer in the dual-port RAM while the data is in the cached RAM. In this way a "check out" procedure can be implemented to ensure data integrity. The semaphore latches must be addressed through non-cached I/O space in order for the request and release mechanism to function correctly.

## CONCLUSION

There are a number of ways to handle dual-port RAM arbitration. Choice of the most efficient technique concerns what granularity of address arbitration is required, whether a processor must be locked out of a block of memory for multiple accesses from the other processor and what constraints are imposed by the memory access cycle timing. Semaphores provide an alternative which can result in higher performance systems and provide functions which are not otherwise achievable. The following is a quick summary. No Busy Logic-Some applications guarantee by definition that the two processors will not access the same locations simultaneously or, if they do, it doesn't matter. The IDT7134 is also ideal for use in large dual-port designs where one arbiter is used for an array of dual-port devices.
Interrupt Logic - Interrupt logic provides a signaling method from one processor to the other to provide a mechanism for handshaking.
Hardware Busy Logic - Hardware busy logic provides the lowest latency overhead when accessing multiple individual unrelated memory locations. The MASTER/SLAVE concept was introduced over two years ago by IDT to provide a single arbiter-thus avoiding deadlocks encountered with multiple arbiters-when using more than one dual-port in wide bus applications.
Semaphore Logic-Semaphore logic provides the best overhead tradeoff when accessing a block of data comprised of multiple related locations. This facility may also be required in highperformance applications where one of the processors does not have a ready/busy input or the overhead of wait states cannot be tolerated.

Semaphores provide a mechanism for one processor to bar the other processor from seeing an incomplete update of a block of data. This is achieved through a software mechanism supported by on-chip circuitry which provides a test and set facility that arbitrates between simultaneous requests.

## CODE FOR MASTER PROCESSOR

```
MAIN ( )
    FOREVER {
        SEM (CUR_BUF):= 0
        UNTIL (SEM (CUR_BUF) = 0);
        BUILD DISPLAY (CUR_BUFF);
        SEM (\overline{CUR_BUFF):= 1}
        SWITCH_BUFF (CUR_BUFF);
        IF (CUR -= BUFF = 1)
            CUR_BUFF:= 2;
            else CUR_BUFF:= 1;
            }
    }
SWITCH_BUFF (NBUFF) {
    SEMO:= O
    UNTIL (SEMO = 0); /*request*/
    BUFF:= NBUFF;
    CMD:= NEW;
    SEM:= 1; /*release*/
    RETURN ( )
    }
```


## CODE FOR SLAVE PROCESSOR

```
MAIN ( ) { { \
            CUR_BUFF:= FETCH_BUFF ( );
            PROCESS (CUR_BUFF
            }
    }
FETCH_BUFF ( ) {
    SEM 0:= 0;
    UNTIL (SEMO = 0); /*request*/
    A BUFF:= BUFF;
    CMD:= OLD;
    RETURN (ABUFF);
    SEMO:= 1; /*release*/
    }
PROCESS (BUFF) {
    SEM (BUFF):= 0;
    UNTIL (SEM (BUFF) = 0); /*request*/
    . REFRESH (BUFF): /*code to refresh display*/
    SEM (BUFF):= 1;
    }
```

By Tao Lin, Julle LIn, and Yupling Chung

## INTRODUCTION

Most digital signal processing (DSP) algorithms have inherent parallelism and may be pipelined. Usually, these algorithms are computation intensive. In real-time applications, multiprocessor or parallel distributed processor systems are commonly used to implement these DSP algorithms. In these types of systems it is necessary for different processors to randomly and independently access different locations at the same time in the same memory space. The IDT7050 (1Kx8) and IDT7052 (2Kx8) FourPort SRAMs are powerful devices to efficiently and compactly implement the memory space in these applications. Moreover, the IDT7050 and IDT7052 can increase the speed of these types of systems since the FourPort SRAMs are fast as conventional 1-port SRAMs and eliminate the complex glue logic which introduces extra delay in these systems. In this application note, we will demonstrate some examples of using the IDT7052 to implement a high performance FFT processor and a matrix multiplication englne.

## USING THE IDT7052 IN AN FFT PROCESSOR

The IDT7052 FourPort SRAM can dramatically simplify the design of a high-speed pipelined FFT processor. The basic operation of any FFT algorithm is the butterfly computation:

$$
\begin{align*}
& G=C+e^{j \Omega} \cdot D \\
& H=C-e^{j \Omega} \cdot D \tag{1-1}
\end{align*}
$$

where $\mathrm{C}, \mathrm{D}, \mathrm{G}$, and H are complex numbers. Figure 1 shows the signal flow graph of the butterily with one complex multiplication and two complex additions. Given $\mathrm{N}=$ 2 L input data samples $\mathrm{x}(0), \mathrm{x}(1) \ldots . ., \mathrm{x}(\mathrm{N}-1)$, the FFT algorithm performs the Discrete Fourier Transform on the input data to obtain the output data $X(0), X(1) \ldots . ., X(N-1)$ in $L$ stages of computation. Each stage consists of N/2 butterlly operations. There are two basic versions of the FFT algorithm: decimation-in-time (DIT) and decimation-in-frequency (DIF). Each version of the algorithm can be implemented using two schemes: not-in-place computation and in-place computation. A detailed discussion of the FFT algorithm and its implementations is given in (1).


Figure 1. The signal flow graph of the butterfly
Figure 2 shows the signal flow graph of the not-in-place computation of the DIT FFT algorithm for $\mathrm{N}=8(\mathrm{~L}=3)$. A close look at Figure 2 will reveal the major strength of the not-in-place scheme. The signal paths from the initial inputs to the first intermediary step are repeated between the first and second intermediary steps, and again between the second and third. This means that three stages have identical data access sequence. Therefore, the address generator can be very easily implemented using the IDT7381/ 83, as compared with the in-place scheme where more complex logic is required to generate the addresses. On the other hand, from Figure 2 it is obvious that in each stage of computation the output data is not in the same order as the input data. For example, in the first stage the first and second inputs $x(0)$ and $x(1)$ will go to the first and fifth locations after the butterly operation. Therefore, two separate buffers are needed to temporarily store the input and output data in each stage computation.

A conventional implementation of the input and output buffers uses two sets of dual-port SRAMs as illustrated in Figure 3. Suppose the input data is already loaded into Buffer 1. Then, in the first stage of computation the butterfly unit takes data from Buffer 1 and then loads the results into Buffer 2. In the second stage of computation the butterfly unit takes data from Buffer 2 and then loads the results into Buffer 1, and so on. To switch between these two buffers, glue logic such as multiplexers and tri-state buffers are necessary as shown in Figure 3. These devices not only occupy board space but also introduce extra delay in the data path thus, decreasing the system performance. It must be noted that $C, D, G, H$, and $\mathrm{e}^{\mathrm{j} \Omega}$ in Figure 3 are all complex numbers. Therefore, physically two groups of memories and buses are needed to store and transmit the real part and the imaginary part separately.

The IDT7052 FourPort SRAM provides a much simpler and more efficient way to implement the input and output buffers as shown in Figure 4. In this implementation, the input buffer and output buffer are merged into a single memory space. Since each of the four ports can access the whole memory
space, two of them can be dedicated to sending the data $C$ and D to the butterily unit and the other two can be dedicated to receiving the results $G$ and $H$ from the butterly unit. In this way, all glue logic can be eliminated and the system performance is greatly improved.


Flgure 2. Signal Flow Graph of Not-In-Place Decimation-In-Time FFT for $\mathrm{N}=8$


Figure 2. I/O Buffers Implemented by Two Sets of Dual-Port SRAM


Figure 4. I/O Buffer Implemented By The IDT7052 FourPort SRAM

## USING THE IDT7052 IN A MATRIX MULTIPLICATION ENGINE FOR GRAPHICS AND DSP

Matrix multiplication is one of the most often used operations in DSP algorithms. In addition, matrix multiplication is the basic operation at the heart of computer graphics. For example, changing the position, orientation, and size of objects in a drawing requires a geometrical transformation M which is generally represented by a series of matrix multiplications.

$$
\begin{equation*}
M=M_{1} \cdot M_{2} \cdot M_{3} \cdot \ldots . . . \cdot M n \tag{2-1}
\end{equation*}
$$

where $\mathrm{M}_{1}$ is a scaling, translation, or rotation matrix.
In high performance systems, a matrix multiplication engine (MME) is necessary to facilitate the operation. A typical pipelined MME has the architecture shown in Figure 5 [2]. Since the MME operates in a pipelined manner, three sets of 1-port memory (IDT6116 2Kx8 SRAMs) are needed to store the multiplicand matrix $\mathbf{A}$, multiplier matrix $\mathbf{B}$, and the product matrix $\mathbf{C}=\mathbf{A} \cdot \mathbf{B}$. The matrices $\mathbf{A}$ and $\mathbf{B}$ are preloaded into the two 1-port SRAMs from the main memory or a peripheral. The MME then performs the matrix multiplication and loads the product matrix $\mathbf{C}$ into the third 1-port SRAM. Finally, the multiplication result is sent back to the main memory or the peripheral. This implementation has two drawbacks:

1. Three separate sets of SRAMs are needed. This results in a high chip count and a complicated interface to the system bus.
2. The arithmetic unit (IDT7210) of the MME is sitting idle when the data is transferred between the memory buffers and the system main memory. This dramatically decreases the system performance especially when the MME executes a series of matrix multiplications as given in (2-1).

Now, with the advent of the IDT7052, system designers can considerably improve the performance of the MME by using the FourPort single-chip SRAM instead of the 1-port SRAM. As shown in Figure 6, the new implementation reduces the chip count and simplifies the interface between the MME and the other part of the system. Moreover, when executing a series of matrix multiplications as given in $(2-1)$, the MME is able to perform the arithmetic operation and the data transfer in parallel, as illustrated in Figure 7. First, the matrices $\mathrm{M}_{1}$ and $\mathrm{M}_{2}$ are loaded into the FourPort SRAM. Then, while the arithmetic unit performs the operation $\mathbf{M} 1 \cdot \mathrm{M} \rightarrow \mathrm{M}$, a new matrix M 3 can be loaded into an unused area of the FourPort SRAM through the 4-th 1/O port. Then, the MME will perform the multiplication $\mathrm{M} \cdot \mathrm{M}_{3}$ and the result will be stored in the location originally occupied by M1. At the same time a new matrix M4 can be loaded into the FourPort SRAM to replace M2 and so on. The operation sequence of the two implementations is shown in Figure 8, where th is the time to load a matrix into the IDT7052, tE is the time for the arithmetic unit to perform a matrix multiplication, and tM is the maximum of IL and tE . It can be readily seen from Figure 8, where the total time to execute the operation given in (2-1) is $\mathrm{tL}+(\mathrm{n}-1) \cdot(\mathrm{tL}+\mathrm{tE})$ when conventional 1-port SRAMs are used. On the other hand, the total time is $2 \mathrm{t} \mathrm{L}+(\mathrm{n}-1) \cdot \mathrm{tM}$ when the IDT7052 FourPort SRAM is used. If we make $t L$ and $t E$ almost equal to each other then we can almost double the system performance.


Figure 5. Implementation of Matrix Multiplication Engine Using 1-Port SRAMs


Figure 6. New Implementation of Matrix Multiplication Engine Using The IDT7052 FourPort SRAM


Figure 7. Using FourPort SRAMs, the MME Can Perform Arithmetic Operation and Data Transfer in Parallel

(a) Using 1-port SRAMs, the arithmetic operation and the data transfer are executed alternately.

(b) Using FourPort SRAMs, the arithmetic operation and the data transfer are executed in parallel.

Figure 8. MME Operation Sequence of the Two Implementations

## CONCLUSIONS

In this application note we have demonstrated some fundamental architectures using the IDT7052 to implement DSP and matrix algorithms. Since DSP algorithms cover a wide range of applications, there are many more architectures in which the IDT7052 FourPort SRAM can be used. The 2 Kx 8 FourPort SRAM and other members in the FourPort SRAM family give system designers greater opportunity and flexibility to improve system performance. The hardware designs that result tend to be far less specialized and lend themselves to new tasks with fewer hardware changes.

## REFERENCES

(1) Julie Lin and Danh Le Ngoc, "High-performance fixedpoint Fast Fourier Transform processor," IDT application note AN-23.
(2) Yuping Chung, "Address generator in matrix unit operation engine," IDT application note AN-35.


Integrated Device Technology, Inc.

THE IDT FourPort™ RAM FACILITATES MULTIPROCESSOR DESIGNS

APPLICATION NOTE AN-43

By Robert Stodieck

## THE IDT FourPort RAM

Serving as both a complex four bus interconnect network and fast "parallel" memory, the IDT FourPort RAM can greatly facilitate the creation of multiprocessor and multi-ALU systems to accelerate DSP, graphics, control and other tasks that involve large vector processing tasks.
Memory architectures based on single-port RAM allow only one device to access a memory array at one time. Hardware designed to accelerate computing processes by utilizing parallelism, or pipelining with single-port memory tend to require architectures that are either complex, specialized, or both. The advent of a fast FourPort single chip RAM greatly simplifies the task of creating generalized small multiprocessor or multi-ALU systems to accelerate a variety of vector algorithms.
Potential applications include dedicated real-time multiprocessor systems for control, graphics, and DSP systems, as well as general purpose vector co-processors to assist general purpose computers. Vector processing means any computing operation with a large number of operations that may be executed in parallel by multiple processors. In these applications the FourPort RAM serves both as a fast static RAM and as the interconnect network between processors working on a common data set.
Imagine a static RAM that allows four processors to randomly and asynchronously read or write four locations at a time in the same RAM array. For processes that can be executed in parallel, four processors can be programmed to operate simultaneously on different parts of a data set stored in the FourPort RAM. If data is being generated at different rates than it is being used, software controlled buffers can be created at will, temporarily storing data passing from one processor to the next. The buffering minimizes


Figure 1. The IDT7052 FourPort RAM allows four simultaneous memory accesses to independent addresses a 2 K or $1 \mathrm{~K} \times 8$-bit memory array. It serves both as a interconnect network and as fast static RAM
the time lost in handshaking between processors. Four way fully random accessibility avoids hardware imposed algorithmic constraints.
The IDT FourPort RAM has precisely these characteristics. There are only two constraints on the access patterns allowed in the FourPort. Two devices cannot write to the same address location in the RAM at the same time, since simultaneous multiple writes to any one multiport memory location may corrupt the data in that RAM location. Also, a device cannot read an address location that is being written, to avoid having the read occur when the output data is changing. There are no other restrictions on access patterns.
As it turns out address collisions are usually prohibited by the logical sequencing requirements of software, and the time lost in avoiding address collisions is often minimal. Most of the time all processors have essentially free read and write access to the memory.

## FourPort RAM BASED MULTIPROCESSOR ARRAYS FOR VECTOR OPERATIONS

The FourPort RAM is both a storage and communications media. As a communications media it has little, and in some cases zero handshaking or arbitration overhead. A processing device may be able to store results in a multiport memory and spend little or no time signaling the next device to receive the results. As a communications media it also has very high bandwidth. These characteristics make the IDT7050 and the IDT7052 a ideal memory for connecting multi-element and multiprocessor computer architectures (see Figure 2).
A multiprocessor system can be created using almost any existing microprocessor system. Since the hardware interface of the FourPort RAM to the processors is that of a simple static RAM, it can be connected transparently to almost any existing system. Control signals as well as data can be handled via the RAM. Thus, microprocessor boards that were designed for entirely different applications can be used in a multiprocessor array.

[^18]

Figure 2. FourPort RAM Interconnection advantages over DualPort RAM. The processors in both figures are inter connected with a latency of one memory access. This efficiency requires 6 separate Dual-Port RAMs but only 1 FourPort RAM

## AN OVERVIEW OF THE OPERATION OF A MULTIPORT RAM BASED MULTLPROCESSOR WITH A MULTIPORT RAM BASED CONTROL SYSTEM

Processors sharing multiport memory must avoid writing into memory locations that are simultaneously being read or written from another port. This is usually accomplished by address range segregation. That is, at any one moment processor " $A$ " is prevented from writing to multiport memory locations that processor " $B$ " is accessing from another port. Hardware interrupts, hardware semaphores and stalling processors with hardware busy logic are hardware based methods of controlling the accesses of processors to multiport RAM. It is also possible to control the processors in a multiprocessor array via the common RAM interface. This results in an essentially software-only control system. The control algorithms for a multiport RAM based multiprocessor array are different than those for a multiprocessor array based on single port RAM. This section describes an example of a control protocol for a multiport RAM based multiprocessor array.
Access coordination in multiport RAM based multiprocessors, overlaps with the more familiar task of process coordination in a multiprocessor and uses the same control schemes. In a single master system, the master determines the address ranges being used by all processors. This avoids the problems of arbitrating for resources. In small embedded systems, running algorithms of limited complexity, the software can be tuned so that software-only control approaches have little or no detrimental effect on overall performance. Such systems are more easily debugged if a simple single master control arrangement is used. In this section of this application note we will discuss a single master example.

In a master/slave array, the master controls all the actions of the slaves. The slaves must either have local program store in RAM or ROM or be operating out of the FourPort RAM. Each processor must have a unique ID code to be able to identify the unique command location where it is to receive its commands from the master. This can be achieved, for example, by supplying a unique firmware ID code via individual PROMs, PALs or readable DIP switches for each processor. A number of other approaches are possible.
Each slave command has a corresponding op-code. The slaves poll their command locations looking for new command opcodes. For example finding a " 0 " in a command location may imply no operation is requested from the slave etc. The commands can be anything that the slave processors have been programmed to do. Appropriate commands might be, multiply data values at locations 000 H to 7 FFH with the corresponding coefficients at locations 800 H to FFFH , or multiply data values at locations 000 H to 7 FFH with the value at location 800 H , etc. Thus, with a few memory accesses, the master processor can trigger and control lengthy slave processor operations.

## MASTER/SLAVE CONTROL PROTOCOL FOR A MULTIPORT RAM BASED PROCESSOR ARRAY

A command protocol is the set of rules for passing commands from the master to the slaves. In a software-only control system, all processors must be aware that writes to certain command locations are forbidden, or forbidden without "permission" from the current owner (see Figure 4). In general, aprocess is given a variable address range to operate in. The command protocol, on the other hand, uses fixed address locations.
The master of an array of processors can tell slave processor \#1 to execute a command " $n$ ", by writing the command opcode corresponding to command " $n$ " to the slave processor's command location. Parameters for the process, such as constants, or the assigned address range, are placed in reserved locations prior to starting the process that will use them.
There are four problems that a multiport RAM based command protocol must solve:

1. Write-write conflicts must be avoided in the control locations.
2. Read-write synchronization problems must be avoided in the control locations.
3. The master must not issue a new command out of sequence, i.e. the slave has to acknowledge readiness to execute a new command.
4. A slave must execute each command only one time.

Figure 3 shows flow charts for a protocol that allows a master to control slaves and slaves to receive commands without risk of violating these four rules.
All slaves have unique command locations in RAM. If the reads and writes to the command locations are asynchronous, command locations must always be read at least twice. The two read results are then compared and discarded if they do not match. In this way, command data that may have been changing during the read operation, and therefore may have been read incorrectly, is discarded.
Before issuing any command, the master first reads a slave's "command" location. If the value read indicates that the slave is ready, the master places the slave's command op-code in that same command location. The slave must signal readiness for new commands by placing a "no-op/ready" value in the command location. The "no-op/ready" flag value is interpreted as a "ready-for new-command" flag by the master, and a "no-operation" command by the slave.


Figure 3. Flow charts for a master-slave software-only command protocol for a multiport RAM based multiprocessor. In unsynchronized systems (see shaded boxes) all commands must be read at least twice with the same result before the command keyword can be assumed to be valid


Figure 4. Write Access Allocations

Having to wait for a "ready" signal from the slave prevents the master from issuing new commands out of sequence. Conversely, by signaling "ready" in this way, the slave is also clearing the old commands from the command location. This prevents the slave from later accidently re-reading and re-executing an old command. The command locations are written alternately by the master and the designated slave, but the protocol prevents simultaneous writes that might destroy the data in the RAM location. By using the same location for both the master's command and the slave's ready indication, synchronization problems caused by differences in the memory cycle rates of different processors can also be avoided.
All slaves should also have unique slave status locations in RAM where the master looks for slave status information. The status locations are writable by the slave only. Copious use of reserved slave status locations is essential for the benefit of the programmer trying to debug untested software.
The slave may also signal "done" by writing a "done" flag to a slave status location. The meaning of "done" is that the results of
the last operation are ready for use. Keep in mind that "done" is a different signal than "ready". "Ready" implies that the master can post the next command and return to executing other tasks. Depending on the overall algorithm the master is controlling, the master may write a new command as soon as "ready" is signaled, or it may need to wait until "done"' is signaled also. He cannot merely check for a "done" signal before issuing a new command. To do so would make it possible to issue new commands out of sequence, based on stale "done" signals.

## INITIALIZATION

Since multiport RAM is the control interface, the RAM command locations must be initialized prior to starting the execution of the slaves. One way this can be handled is by delaying the reset pulses to the slaves while the master initializes RAM. Alternatively, after reset, the master can issue a known sequence of commands that frees the slaves from a special start up routine.


Real $X(A)=$ Real $x(a)+($ Real $x(b) \cdot \cos \theta$-Imag $x(b) \bullet \sin \theta)$ Real $X(B)=$ Real $x(a)-($ Real $x(b) \cdot \cos \theta-\operatorname{Imag} x(b) \bullet \sin \theta)$ Imag $X(A)=I \operatorname{mag} x(a)+(\operatorname{Imag} x(b) \cdot \cos \theta+$ Real $x(b) \cdot \sin \theta)$ $\operatorname{Imag} X(B)=\operatorname{Imag} x(a)-(\operatorname{Imag} x(b) \bullet \cos \theta+$ Real $x(b) \bullet \sin \theta)$

Figure 5. Flow Diagram for Calculating One FFT Butterfly. Each ' $X$ ' pattern shown In Figure 6 represents one such "Butterfly". Each end point in Figure 6 represents a complex pair of numbers input or output to or from a "Butterfly". The sine and cosine factors are sometimes called "Twiddie Factors". The angles used for calculating the Twiddle Factors for each Butterfly are shown In Figure 6


Flgure 6. Overview of the "Butterfly" calculations for an 8 Point FFT. To complete this 8 Point FFT requires 3 stages of Butterfiles $\left(2^{3}=8\right)$. A 1K FFT has 10 stages or levels ( $2^{10}=1 K$ ). The indexes of $x(n)$, the input sequence, are shown out of sequence for graphical clarity. Each stage in this figure has 4 Butterflies

## OUTLINE OF A DIGITAL SIGNAL PROCESSING EXAMPLE

Basic DSP algorithms such as the FFT can utilize high degrees of parallelism and provide good examples of vector algorithms. The access patterns of the processor doing such an algorithm are complex and the data sets are usually small enough to fit comfortably in a multiport RAM array. Analyzing how the FFT will be processed provides a good example of the advantages of a multiport RAM based multiprocessing environment.
The objective of our example task is to translate a time series of data values into their frequency domain representation: i.e. execute a fast Fourier transform, as quickly as possible. This is a common process step in a number of systems for interpreting data from things as diverse as military radar to medical CAT scans. It is also a relatively well known algorithm among many contemporary electrical engineers, and so makes a good example for our system.
Our objective algorithm could be run on a single processor. The object of the FourPort RAM based multiprocessor arrangement is to multiply the speed of our computational process without resorting to a specialized and more expensive architecture.
The generality of this architecture implies that it can be applied to a variety of computationally involved tasks. The generality of this architecture also means that there are often a number of ways a programmer can attack a specific problem. The intent of this example is merely to illustrate one approach, not to fully optimize an algorithm.

## LOAD BALANCING

The FFT calculations can be flow graphed. When they are, they appear as a repetitive array of calculations (Figure 6) of a particular set of four equations. This set of four equations is called a 'butterfly' for the appearance of its flow graph (Figure 5 ). The inputs and outputs are series of complex numbers.
A common bench mark of processor performance is a 1 KFFT . A quick glance at the equations to be calculated shows why multiple processors are desirable for such a task. If we assume that 1024 real and 1024 imaginary data values have been loaded in the four port memory, there are now 2048 multiplications to be done as a first step. All these multiplications could be done simultaneously. Next there are 1024 additions followed by another 2048 additions to complete the first stage of FFT butterflies. Again, all of operations at any one of these three steps could be done simultaneously. For a 1K FFT there are 10 stages of butterflies.
Processing on one stage of the FFT must be completed before processing on the next stage can begin. Each processor is given an address range of FFT butterly input data to process for each stage of FFT butterlies. A sine table is required for calculation of the FFT "twiddle" factors. This can be stored in the four port memory and, therefore, will always be available to all processors. Calculation of the "twiddle" factors is a matter of calculating the addresses used in the sine look up table. (See Figure 6 for the angle calculations).
For efficiency, the computational load between processors must be balanced. Since there are hundreds or thousands of operations that may be done in parallel at each stage of the FFT, task partitioning is a matter of assigning each processor an appropriate number of "butterlies" to work on to achieve an equity of loading.
Since the minimal FFT tasks are easily divided between the processors, and the FourPort RAM all but prevents inter-processor data transfer conflicts, the four processors in this example can be kept busy most of time.
Since there are so many tasks that can be done in parallel, other types of tasks can be included without seriously upsetting the balance. For example, if one processor is being used to handle I/O and input conditioning tasks, then it can be assigned to do fewer
butterfly calculations than the other processors. If the work load of all the processors can be balanced, the net speed advantage of this four processor array, can then in fact be close to 4 times that of a single processor.

## A TMS320C2x HARDWARE INTERFACE EXAMPLE

Tl's TMS320 single chip DSP processors are particularly well suited for embedded numerical processing. An example interface is shown in Figure 7. The internal RAM and ROM of the TMS320 can be used for temporary data storage and program memory, making the FourPort RAM the only external RAM required in a processor array. The FourPort RAM also cascades in depth and width as easily as a standard single port RAM. The interface shown in Figure 7 would typically require 30ns RAMs for a 20 Mhz TMS320C2x type processor.
The TMS320C20 and TMS320C25 also include a "sync" pin that facilitates synchronizing the internal clock phases of multiple processors at reset. In synchronous TMS320C2x arrays, this guarantees that memory accesses are in phase with each other and there
are no partial clock phase memory access collisions. This form of processor synchronization is accommodated entirely in hardware.

## SUMMARY

The FourPort RAM combines features of fast static memory and a complex multiple bus interconnect network. The FourPort RAM all but eliminates stalls when transferring data between processors or to memory. This prevents bus conflicts from being a bottleneck in multiprocessor systems.
The flexibility of the FourPort RAM allows multiprocessor designs to remain generalized while achieving high speeds on critical vector processes. The fact that the RAM itself is also the interconnect network between processors eliminates the complexity of a conventional multiprocessor bus system. The straightforward static RAM interface of the FourPort RAM, allows almost any processor to be used in an array for embedded systems. These factors conspire to make practical a variety of new vector processing architectures centered around the world's first "large" truly four ported single-chip RAM.


Figure 7. A 16 -bit TMS 320 C 2 X to IDT7052 Interface Example


## By John R. Mick

## INTRODUCTION

Integrated Device Technology is continuing to pioneer higher speed and higher density static RAMs. As IDT has improved its CEMOS ${ }^{\text {m }}$ technology, new RAM architectures and additional features have become feasible. The end result is that design engineers now have powerful new integrated circuits available for demanding applications. One such circuit is the IDT7052 FourPort RAM. This device is a Four-port 2 K by 8 -bit Static RAM built using a 12-transistor four ported static RAM cell. Each of the four ports is independent in terms of the byte that it can read or write.
This new IDT7052 FourPort RAM provides the system architect with better ways to look at computer system design. For example, the IDT7052 can be used in a multiprocessor environment to pro-
vide a common memory among several processors. An example of such an architecture is shown in Figure 1. Here we see each of the four RAM ports connected to a high performance microprocessor. These processors could also be intelligent controllers, DSP engines, or a combination of the two. The FourPort RAM can be used in such computer architectures as hypercubes and parallel processing machines for storage and movement of data. It offers unheard of opportunities in digital signal processing (DSP) where new architectures for Fast-Fourier-Transforms (FFTs), recursive and non-recursive digital filters, windowing functions, and special purpose algorithms can take advantage of multiple ports into a shared memory. The IDT7052 FourPort RAM can increase system performance and reduce parts count by providing simultaneous access to the data by more than one processor at a time.


Flgure 1. Four-Port RAM Providing Common Memory to Four CPUs

## UNDERSTANDING THE FourPort RAM

In order to effectively design with the IDT7052 FourPort RAM, it is important for the design engineer to understand its construction and architectural features. This is most easily accomplished by starting with a simple single port RAM cell and evolving its architecture into the FourPort structure. Figure 2 shows a typical single port static RAM buitt using a four-transistor cell. This architecture is commonly used by most static RAM manufacturers to build static RAMs because it offers high density, good speed and low power.
In its simplest description, the device consists of two N -channel transistors (Q1) and two resistors (R1) that are connected so as to form two simple cross-coupled inverters. This gives a regenerative action such that one N -channel transistor is ON and the other N -channel transistor is OFF. Thereby, a single bit of memory is formed. In order to interface to this cross-coupled pair of inverters, two additional N -channel transistors (Q2) are connected between the inverter outputs and the bit-lines. The gates of these two N -


Flgure 2. Typlcal Four-Transistor SRAM Cell
channel transistors are connected to a line called the row select. These Q2 transistors connected between the cell and the bit lines are usually called transmission gates. The result is that when a particular row of cells in the RAM is addressed, these two transistors are turned on and one bit-line will reflect a HIGH and the other bit-line will reflect a LOW as determined by the current state of the static RAM cell.
An expanded example of this RAM architecture is shown in Figure 3. Here we see a 16-bit RAM, organized four-rows by fourcolumns internally, in a more complete form. The bit-lines of the cells are connected to the inputs of a sense amplifier by means of N -channel switches. These switches are controlled by the column address decoder. The sense amplifier will detect whether the state of the bit is a logic one or a logic zero depending on the relative polarity of the two bit-lines going into the differential sense amplifier. We usually call the transistors connected between the sense amplifier and bit-lines a data multiplexer or data selector.


Figure 3. An Example Four-Transistor Cell for a 16-bit SRAM

When we wish to write the simple RAM as shown in Figure 3, a row address line is selected by the row address decoder and the N -channel pass transistors (Q2 of Figure 2) connected to the bit lines are turned on by pulling their gates high. Now however, the write amplifier driven by the Data-In line (Figure 3) is turned on by the write enable signal via the control logic. The write amplifier will drive one bit-line HIGH and the other bit-line LOW as determined by the logic state of the data input. The output of the write amplifier is more poweriul than the inverter transistors (Q1 in Figure 2) in the

RAM cell and it easily overpowers these inverter transistors if it is necessary to flip the static RAM bit. In its simplest form, this is all there is to the circuitry of a static RAM. Functions such as chip enable are used to simply enable or disable the entire operation of the RAM. Output enable on a static RAM is used to turn "on" the outputs during a read cycle and turn "off" the outputs during write cycles. It can be used to solve timing problems in high speed applications.


Figure 5. An Example 16-bit Dual-Port RAM

A variation on the standard four-transistor static RAM cell is the six-transistor static RAM cell as shown in Figure 4. In this Figure we see that the two pull-up resistors (R1 of Figure 2) have been replaced by two P -channel transistors. The operation of such a six-transistor cell is identical to the four-transistor cell previously described. The difference between the two approaches is that the physical size of the cell with the P -channel transistors is larger than the cell with the resistors. The standby power can be lower for the six-transistor cell because there is no power being dissipated. In a four-transistor cell, one of the the pull-up resistors is always dissipating power since one transistor of the cell is always ON. The six-transistor cell can have higher radiation hardened characteristics than the four-transistor cell because the voltage swings in the cell are larger. This is because the internal node in the cell that is high is pulled to the +5 V rail by the P -channel transistor. In addition, the six-transistor cell provides higher internal noise margins in the circuit for this same reason. Most manufacturers of static RAMs use the four-transistor cell because it allows static RAMs of higher density to be fabricated with smaller die sizes.
Next, let's look at a typical dual-port RAM such as the IDT7134, a 4 K by 8 -bit device. An example schematic diagram showing a six-teen-bit two-port RAM is shown in Figure 5. Here we see our standard cross-coupled inverter pairs using two N -channel transistors with resistor pull-ups (Q1 and R1 of Figure 2) to form the sixteen
memory bits. Notice however, now there are two pairs of N -channel transmission gates connected to each RAM cell's true and compliment outputs and two pairs of bit-lines associated with each cell. Each pair of bit-lines is a read/write port into the dual-port RAM. Each pair of transmission gates has its own row address control so that Port A can select any memory cell in the RAM and Port B can select any memory cell in the RAM. This is the technique used in IDT dual-port RAMs to provide total independent access to individual bytes. Each pair of bit-lines is connected to a sense amplifier and a write buffer via a data multiplexer so that each port on the 2 -port RAM can read or write data at its selected address.
Now for the FourPort RAM operation. Figure 6 shows a minimal schematic diagram for the IDT7052 12-transistor FourPort RAM cell. The two inverters making up the basic memory cell are fabricated using two N -channel pulldown transistors and two P -channel pullup transistors. They are connected in the normal crosscoupled inverter fashion to make a single memory cell. Four individual memory ports are achieved by using four pairs of N -channel pass transistors to connect to four pairs of bit-lines. Four individual row addresses are used to select each pair of transmission gates connected between the RAM cell outputs and the bit-line pairs. Four sense-amplifier/write-buffers are used to provide individual read/write paths from each port to all the cells in the RAM.


Figure 6. A Simple Example of a Twelve Transistor FourPort RAM Configuration

From this discussion, the design engineer should understand the mechanism used to implement a FourPort RAM. As described, we can see how we can make each port of the FourPort RAM totally independent from the other ports. Do not confuse this statement to mean that independent reads and writes can always be performed without data corruption. If two ports write to the same byte at the same time, one or both values may be lost. Likewise if one port writes to a byte at the same time another port is reading the byte, the read may be corrupted even though the byte write is completed correctly. This application note does not discuss issues of data integrity in the case of multiple accesses to the same location, when one of the asynchronous accesses is a write cycle. These problems are discussed in detail in Application Note 2 and will not be further discussed here. Suffice it to say that the IDT7050 and IDT7052 FourPort RAMs have a BUSY input to allow external hardware or software arbitration schemes to be implemented to meet the specific needs of the designer's system. The $\overline{B U S Y}$ input serves only to block write cycles from the port to which this signal is applied. It has no effect on a read cycle. Note that in the following applications we are not using the BUSY input of the FourPort RAM so it should be tied HIGH. We probably will not always mention
this, so do not forget it or you will not be able to write into the FourPort RAM.
Once the rules are understood however, only engineering creativity is needed to visualize new architectural opportunities for FourPort RAMs. This powerful new memory technology will provide increased performance in future electronic processing systems.

## CASCADING THE FourPort RAM

Perhaps the most easily understood techniques in designing with static RAMs are width and depth expansion. Width expansion of any port of the FourPort RAM is straightforward. No additional parts are needed to build 16, 24 or 32 bit wide or wider memories. Any port of the FourPort RAM can be viewed the same as a simple single port static RAM. All the same rules apply and they can be applied individually to each port of the FourPort RAM.


Figure 7. A $4 K \times 16$-bit FourPort CE Controlled RAM

Depth expansion of the FourPort RAM is also quite simple. If one port is viewed as a static RAM, it is expanded similar to a single port device. Lower addresses are connected between devices and upper addresses are decoded by means of a standard decoder such as an IDT74FCT138 or IDT74FCT139. The outputs of the decoders can be used either to control the chip selects or control the write-enable and output-enable individually. Simple examples of expansion of one port of a FourPort RAM to a 4 K -word by 16 -bit configuration are shown in Figure 7 and Figure 8. Figure 7 shows
the Chip Enable expansion method while Figure 8 shows writeenable, output-enable expansion. The two schemes are similar, but, sometimes one can have a timing advantage over the other. This is usually a function of the actual timing signals that are available or have already been generated.
Once the depth expansion is understood, we can view the CPU interconnect schemes by simply looking at a one deep FourPort RAM. We recognize that deeper versions can be realized as just described.


Figure 8. A 4K×16-bit FourPort $\overline{O E}$ and $R / W$ Controlled RAM

## CONNECTING THE FourPort RAM TO CPUs

## A Z80A Example

Probably the easiest interface of the IDT7052 FourPort RAM is to a Z80A. This processor still provides a great price-performance tradeoff! By using four Z80As with the IDT7052 FourPort RAM, significant performance advantages can result. For example, no time need be lost due to DMA channels. The data placed in memory by one Z80A on one port is instantly available to another Z80A on another port. In a similar fashion, parallel processing can be performed by multiple processors working on the data in shared memory.
The typical connection scheme for the IDT7052 (or IDT7050 $1 \mathrm{Kx8}$ FourPort RAM) to a Z80A is shown in Figure 9. Here we see the eleven address lines, $A_{10}-A_{0}$, of the FourPort RAM are connected to the $A_{10}-A_{0}$ lines of the Z80A. This places the FourPort RAM in a contiguous 2 K address space of the $\mathrm{Z80A}$. The 2 K byte segment actually used is determined by upper address decode circuit. A PAL or an IDT74FCT521 could be used to perform this function. The data lines are connected between the processor and the RAM. The Z80A has a $\overline{\mathrm{RD}}$ line that can be connected to the FourPort $\overline{O E}$ and a $\overline{W R}$ line that can be connected to the FourPort $\mathrm{R} / \bar{W}$ input. This works along the lines of the a Chip Enable expansion method just described. When the Z80A addresses the FourPort RAM, either a read or write will be performed depending on the instruction being executed. If $\overline{R D}$ goes LOW, the FourPort RAM will output data from the addressed byte. If WR goes LOW, the FourPort RAM will write data into the addressed byte.


Flgure 9. Interfacing the Z80A to One Port of the FourPort RAM


Figure 10. A 16-bit FourPort RAM with the 68000 CPU

## A 68000 CONNECTION EXAMPLE

If we wish to build a 16-bit microprocessor interface to one port of the IDT7052 FourPort RAM, a typically interface might be as shown in Figure 10. Here we see two IDT7052s used in a 16-bit configuration. One FourPort RAM is connected to the lower eight data bits ( $\mathrm{D}_{7}-\mathrm{D}_{0}$ ) and the other FourPort RAM is connected to the upper eight data bits ( $\mathrm{D}_{15}-\mathrm{D}_{8}$ ). This completes a 16-bit data bus. Address lines $A_{10}-A_{0}$ of the FourPort RAM are connected between RAMs and also connected to address lines $A_{11}-A_{1}$ respec-
tively of the 68000. Remember, the 68000 does not have an $A_{0}$ address line but uses Upper-Data-Strobe (UDS) and Lower-Data-Strobe ( $\overline{\mathrm{LDS}}$ ) to control the upper and lower byte selection. These two signals in conjunction with the $\mathrm{R} \bar{W}$ signal are decoded in a PAL to generate the individual FourPort RAM R $\bar{W}$ and $\overline{O E}$ control signals. Figure 11 shows the truth table needed for the PAL. It has been my experience when working with the 68000 , that once these signals are generated, they are useful throughout the design to control other peripherals, etc. Basically, however, in this exam-
ple we simply have a lower byte FourPort RAM and an upper byte FourPort RAM.

| $\mathbb{N P U T S}$ |  |  | QUTPUTS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $R \bar{W}$ | $\overline{U D S}$ | $\overline{L D S}$ | $\overline{U R W}$ | $\overline{L R W}$ | $\overline{U O E}$ | $\overline{\mathrm{LOE}}$ |
| $X$ | 1 | 1 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 | 1 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| 1 | 0 | 1 | 1 | 1 | 0 | 1 |
| 0 | 0 | 1 | 0 | 1 | 1 | 1 |

The upper address lines of the $68000, \mathrm{~A}_{23}-\mathrm{A}_{12}$ in this case, are used to position the 2 K bytes of FourPort RAM in continuous address space of the 68000 . The actual location can be anywhere from $0 \times 000000$ to $0 \times F F F F F F$ as long as the overall range is on 2 K byte boundaries. Usually we include address strobe ( $\overline{\mathrm{AS}}$ ) in the decoding as it can solve some timing problems. A timing review will show if it is needed. An output of the decode circuit can be used to generate the data acknowledge (DTACK) if it is needed. Usually design engineers have an overall plan for generating the memory $\overline{\text { CEs }}$ and DTACK, so what is shown here is only to remind you of solving the overall problem.

Figure 11. 68000 16-bit Control PAL Truth Table

Address of Bytes in a Big-Endian 32-bit Word

| Bits 31-24 | Bits 23-16 | Bits 15-8 | Bits 7-0 |
| :---: | :---: | :---: | :---: |
| $0 \times 0024$ | - etc- | - etc- | - etc- |
| $0 \times 0020$ | $0 \times 0021$ | $0 \times 0022$ | $0 \times 0023$ |
| $0 \times 001 \mathrm{C}$ | $0 \times 001 \mathrm{D}$ | $0 \times 001 \mathrm{E}$ | $0 \times 001 \mathrm{~F}$ |
| $0 \times 0018$ | $0 \times 0019$ | $0 \times 001 \mathrm{~A}$ | $0 \times 001 \mathrm{~B}$ |
| $0 \times 0014$ | $0 \times 0015$ | $0 \times 0016$ | $0 \times 0017$ |
| $0 \times 0010$ | $0 \times 0011$ | $0 \times 0012$ | $0 \times 0013$ |
| $0 \times 000 \mathrm{C}$ | $0 \times 000 \mathrm{D}$ | $0 \times 000 \mathrm{E}$ | $0 \times 000 \mathrm{~F}$ |
| $0 \times 0008$ | $0 \times 0009$ | $0 \times 000 \mathrm{~A}$ | $0 \times 000 \mathrm{~B}$ |
| $0 \times 0004$ | $0 \times 0005$ | $0 \times 0006$ | $0 \times 0007$ |
| $0 \times 0000$ | $0 \times 0001$ | $0 \times 0002$ | $0 \times 0003$ |

Address of Bytes in a Big-Endian 16-bit Word


| Bits $15-8$ | Bits 7-0 |
| :---: | :---: |
| $0 \times 0014$ | - etc- |
| $0 \times 0012$ | $0 \times 0013$ |
| $0 \times 0010$ | $0 \times 0011$ |
| $0 \times 000 \mathrm{E}$ | $0 \times 000 \mathrm{~F}$ |
| $0 \times 000 \mathrm{C}$ | $0 \times 000 \mathrm{D}$ |
| $0 \times 000 \mathrm{~A}$ | $0 \times 000 \mathrm{~B}$ |
| $0 \times 0008$ | $0 \times 0009$ |
| $0 \times 0006$ | $0 \times 0007$ |
| $0 \times 0004$ | $0 \times 0005$ |
| $0 \times 0002$ | $0 \times 0003$ |
| $0 \times 0000$ | $0 \times 0001$ |

Address of Bytes in an 8-bit Word

| Word Address |
| :--- |
| -etc- |
| $0 \times 0010$ |
| $0 \times 000 \mathrm{~F}$ |
| $0 \times 000 \mathrm{E}$ |
| $0 \times 000 \mathrm{D}$ |
| $0 \times 000 \mathrm{C}$ |
| $0 \times 000 \mathrm{~B}$ |
| $0 \times 000 \mathrm{~A}$ |
| $0 \times 0009$ |
| $0 \times 0008$ |
| $0 \times 0007$ |
| $0 \times 0006$ |
| $0 \times 0005$ |
| $0 \times 0004$ |
| $0 \times 0003$ |
| $0 \times 0002$ |
| $0 \times 0001$ |
| $0 \times 0000$ |

Figure 12. Memory Map for 8, 16, and 32-bit Byte Ordering

## HOW ABOUT 8-BITS, 16-BITS AND 32-BITS IN THE SAME SYSTEM!!!

This is perhaps the most interesting example to talk about. We will use an 8-bit Z80A, a 16-bit 68000 and a 32-bit R3000 RISC microprocessor to discuss the design techniques. We have chosen the three processors because they are typical, they are fun to work with and they have had broad acceptance in the microprocessor world. First, let's look at Figure 12 to understand memory addressing and "memory space". All three of our selected micropro-
cessors are "byte" addressable machines. That means they can address bytes as well as words in the case of the 68000 and R3000. The 68000 is a Big-Endian machine and the R3000 will be operated in Big-Endian mode to keep things simple. (DEC and Intel fans can make the appropriate transformation. In fact, the FourPort RAM might make a really exciting byte-ordering problem solver between machines by connecting one port as Big-Endian and another port as Little-Endian to the same microprocessor and similarily for the second processor.)


Figure 13. Using a 32-bit Wide FourPort Memory with the R3000

Since we are talking about byte addressable machines, Figure 12 shows the byte addresses of an 8-bit machine, the byte addresses of a 16-bit machine and the byte addresses of a 32-bit machine. Likewise word addresses of 16-bit and 32-bit machines are shown. What is intended here is to point out that we want the consecutive byte ordering of all of the machines to remain constant. By doing this, we keep the ability to do indexing into an array of bytes from any of the processors as a simple task. For example, a 40 byte index from any byte address is the same in all processors talking to each other through the FourPort RAM. We can look at Figure 12 as representing the Z80A, 68000 and R3000 respectively.
Next, let's look at the interface needed for each of our three processors. We will build on our previous examples in this application note but there are differences needed to allow proper addressing. Let's begin by looking at the R3000. The reader should refer to IDT's wealth of information on the IDT79R3000 RISC microprocessor if you are not familiar with the standard CPU, FPA, Cache and I/O interface. We will use four of the IDT7052 FourPort RAMs to give a 32-bit wide memory for this example. We assume the first port is connected to the R3000, the second port is connected to the 68000 and the third port is connected to the Z80A. The fourth port could be connected to a second one of any of these processors or a wide selection of other things.

A typical R3000 interface is shown in Figure 13. The key element here is to understand that we are interfacing to a 32-bit data bus, 32-bit address bus with byte encoded control signals and to an R3000 interface. We are able to implement the required byte control per Figure 12 by using the "BYTE PAL" shown in Figure 13. The truth table for this PAL is shown in Figure 14. Using this decoding, we are able to do all of the required operations. This includes 32-bit word operations, 24-bit three-byte operations, 16-bit half-word operations and 8-bit byte operations. The signals available are $A_{0}, A_{1}$, AccessType0, and AccessType1, all from the R3000 address register, and we assume a R/W input from the "Control PAL" shown in Figure 13. There may be other options here, but this $R \bar{W}$ signal must be realized in some fashion. The upper address bits from the R3000 are decoded in the fashion previously discussed to locate the total 8K bytes of FourPort RAM in the R3000 address space.
Working out the timing of the R3000 interface is most of the work. Remember that at this interface point there are several flexibilities in the final timing. With an R3000 running at 16 MHz , a data transfer cycle is in multiples of 67 nanoseconds, 20 MHz gives 50 nanoseconds, and 25 MHz allows 40 nanoseconds. Thus depending on the processor speed and the FourPort RAM speed selected, block refill may or may not be desired. In any case, we
should be able to run with zero, one or two stall cycles. As mentioned before, the design engineer usually has a plan for address decoding and control handshake which is more closely tied to the
overall system design. From this standpoint, interfacing to one port of the FourPort RAM is no different than interfacing to an EPROM, DRAM, SRAM, or peripheral.

| INPUTS |  |  |  |  | QUTPUTS |  |  |  |  |  |  |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R $\bar{W}$ | ACCT1 | ACCTO | A1 | AO | W3 | W2 | W1 | W0 | R3 | R2 | R1 | R0 |  |
| 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | Word Bead |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1. | 1 | Word Write |
| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | Tri-Byte Read |
| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | Tri-Byte Read |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | Tri-Byte Write |
| 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1. | 1 | 1 | Tri-Byte Write |
| 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1. | 1 | Half-Word Bead |
| 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1. | 1 | 0 | 0 | Half-Word Read |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | Hali-Word Write |
| 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | Half-Word Write |
| 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | Read Byte 0 |
| 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | Read Byte 1 |
| 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | Read Byte 2 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | Read Brte 3 |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Write Brte 0 |
| 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | Writo Byto 1 |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | Writn Bytn? |
| 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1. | Write Byto 3 |

Figure 14. 32-bit R3000 Control PAL Truth Table (Blg-Endlan)


Figure 15. A 32-blt FourPort RAM with the 68000 CPU

| INPUTS |  |  |  | OUTPUTS |  |  |  |  |  |  |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RMW | A1 | $\overline{\overline{L D}}$ | $\overline{\text { UDS }}$ | W3 | W2 | W1 | W0 | R3 | R2 | R1 | R0 |  |
| 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | , | Word Read |
| 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | Word Read |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | Word Write |
| 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | Word Write |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | Read Byte 0 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | Read Byte 1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | Read Byte 2 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | Read Byte 3 |
| 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Write Byte 0 |
| 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | Write Byte 1 |
| 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | Write Byte 2 |
| 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | Write Byte 3 |

Figure 16. 32-Bit 68000 Configuration Control PAL Truth Table

Next, let's look at the 16-bit 68000 interface in a 32-bit memory system. A detailed block diagram is shown in Figure 15. The key thing to notice here is that four of the IDT7052 FourPort RAMs are used. Notice that two of the devices are connected to the $D_{7}-D_{0}$ data bus and two of the devices are connected to the $D_{15}-D_{8}$ data bus on the 68000. Address line $A_{1}$ will be used to select which pair of FourPort RAMs that the processor will read or write.
For example, when $A_{1}$ is LOW, control signals W3, W2, R3 and R2 will be enabled. When $A_{1}$ is HIGH, control signals W1, W0, R1 and $R 0$ will be enabled. This is shown in complete detail in the truth table of Figure 16. It we study this truth table, we see how we accomplish both 16 -bit word (half-word) reads and writes as well as 8 -bit byte reads and writes. All of this is consistent with the memory map shown in Figure 12. The technique here is actually to use $A_{1}$ to select either the lower half-word or the upper half-word in a

32-bit FourPort RAM memory system. Every thing else about the design is the same as the previous 68000 example.

Lastly, let's look at the 8-bit interface to the Z80A microprocessor. It also should be viewed as being hooked into a 32-bit memory system. A detailed block diagram is shown in Figure 17. Notice that all four of the IDT7052 FourPort RAMs are connected to the $D_{7}-D_{0}$ data bus. Address lines $A_{1}$ and $A_{0}$ will be used to select the device to which the Z80A processor will talk. In fact, $A_{1}, A_{0}, \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are inputs to the control PAL decode. The truth table to be implemented is detailed in Figure 18. This processor is only capable of performing byte reads or writes so the decoding is straightforward. $A_{1}$ and $A_{0}$ are used to do byte selection. Thus, the FourPort RAM $A_{10}-A_{0}$ address inputs are connect to the $A_{12}-A_{2}$ address lines of the Z80A. This keeps the byte addressing as desired in the memory map of Figure 12. Again the remaining part of the design is as shown in the previous Z80A example.


Flgure 17. A 32-bit FourPort RAM with the Z80A CPU

| INPUTS |  |  |  | OUTPUTS |  |  |  |  |  |  |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { WR }}$ | $\overline{R D}$ | A1 | AO | W3 | W2 | W1 | W0 | R3 | B2 | B1 | R0 |  |
| 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | Read Byte 0 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | Read Byte 1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | Read Byte 2 |
| 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | Read Byte 3 |
| 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Write Byte 0 |
| 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | Write Byte 1 |
| 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | Write Byte 2 |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | Write Byte 3 |

Figure 18. 32-bit Z80A Control PAL Truth Table

The key in all of this discussion is to keep track of the data bus width being used in the design. Similarly, the decoding and processor address connections must take this into account. This is one point that the design engineer usually does not have to deal with when working with single port memories.
The purpose of this three processor example is to show a few interconnect schemes to typical microprocessors. From this discussion, the design engineer should be able to extend the concepts presented here to other 8-bit, 16-bit and 32-bit microprocessors. Just keep the techniques in mind and work out the desired memory mapping and timing.

## SYSTEM DESIGN IDEAS

Now that we have discussed how the the FourPort RAM is built and we have a good idea of how to connect it to many processors, let's look at some system level uses for this type of FourPort RAM.

## DIGITAL SIGNAL PROCESSING (DSP)

Digital signal processing applications have been expanding as new developments in semiconductor technology provide increased packing density and new architectures in integrated circuits. The IDT7052 FourPort RAM is another in the continuing growth of integrated circuits that allow design engineers to realize new system designs.


Figure 19. A Simple DSP Engine Using a FourPort RAM

One of the simplest DSP algorithms that can be implemented is the finite-impulse-response (FIR) filter. In this type of algorithm, the impulse response of the filter has nonzero values only for a finite duration. These types of filters are easily implemented using only multiplication and summation. Figure 19 shows a block diagram of a DSP machine that takes advantage of the FourPort RAM to interface to a multiplier-accumulator (MAC) such as the IDT7210. In this example, two of the four ports of the FourPort RAM are used to feed data to the MAC inputs and a third port of FourPort RAM is used to receive completed results from the MAC output. The fourth port of the FourPort RAM is connected to a local data-address bus to interface to the remainder of the system.

In the actual operation of such a processor as shown in Figure 19, data is loaded into the FourPort RAM via Port 4. The algorithm usually needs coefficients and these are also loaded into the FourPort RAM using Port 4. An address sequencer has the responsibility of providing the correct sequence of addresses to Ports 1, 2 and 3. This unit operates in conjunction with the timing generator to execute the algorithm. Let's look at an example. Suppose our algorithm is:

$$
y(n)=A_{0}{ }^{*} x(n)+A_{1} * x(n-1)+A_{2}{ }^{*} x(n-2)+A_{3}{ }^{*} x(n-3)
$$

We could read this as the current processed value is equal to the current sample times $A_{0}$, plus the first past sample times $A_{1}$, plus the second past sample times $A_{2}$, plus the third past sample times $A_{3}$. This already shows its potential as a FourPort RAM application.
Now, we initialize our system at power-up by putting the values $A_{0}, A_{1}, A_{2}$, and $A_{3}$ into the FourPort RAM. We would most likely clear the four locations for the data. Then we start taking data. Each time we receive a data value, we can overwrite the fourth past sample. For each new sample, we will compute a new y(n) and put it into the FourPort RAM. At some point we will extract the sequence of values for $y(n)$ that we have computed. As can be seen, we can have several operations happening on the same clock cycle. RAM ports 1 and 2 could be outputting data, RAM port 3 could be inputting data, and RAM port 4 could be inputting or outputting data, all simultaneously. The speed implications are obvious. Needless to say, this is a simple example for the purpose of demonstration. But if we wanted to work on 1024 samples with 128 coefficients and a more complex algorithm, all we have to do is follow the same methodology. See IDT application note 42 for a more detailed example of how to use this method to implement a matrix multiplication.

## CPU to CPU to CPU to CPU

Referring to Figure 1 where we started this application note, we see that we have a FourPort RAM connected between four CPUs. How do we efficiently communicate each processor's status to the other processors? You will need to work an acceptable software semaphore scheme or do hardware handshaking using external circuitry. The most obvious software scheme is token passing. After each processor has determined its order in the token passing scheme, the token passing protocol boils down to each processor taking its turn. This can be achieved by reading one memory location to see who is master. Usually multiple reads and compares are performed to avoid any data corruption problems. A good example of this mechanism is detailed in IDT application note 43.
Let's take an example. The byte at address zero contains the token. The current value is one. CPU 1 is master of the FourPort

RAM and can read or write data. When finished, it writes a two at address zero. Every so often CPU 2 checks address zero and when it sees a two, it knows it is master. It performs any needed data reads or writes. When it is finished, it writes a three at address zero. CPU 3 writes a four and CPU 4 writes a one. Thus, a simple token passing scheme. "Fail safe" mechanisms can be implemented to keep the token moving if there is any failure.
Another obvious scheme is to set up a simple software semaphore path between each pair of processors. This technique can be used to pass data between processor pairs. The semaphore for each processor can use a different byte (or word) address for each semaphore in each direction. By using this method, many different software handshake techniques can be implemented. Rather than use a test and set instruction for semaphores in this application, another interlocking mechanism, like separate locations dedicated to the status of each processor, should be used to guarantee clean communications between tasks.
In addition, several hardware approaches are usually available in most multiprocessor environments. These include individual interrupts between processors as well as broadcast interrupt approaches. In either case, after the data has been set up in a private buffer, processor A can interrupt processor B to notify it of the pending message. The data structures used in such an environment can include pointer passing and linkage conventions consistent with modern day software techniques.

## SUMMARY

The FourPort RAM is a truly new innovative integrated circuit memory that offers new communications methods for computing machines. It provides exceptional speeds because of its opportunity for parallelism. The IDT7052 2 Kx 8 -bit FourPort RAM and the IDT7050 $1 \mathrm{~K} \times 8$-bit FourPort RAM are the first in a series of memories that will pioneer these new architectural frontiers. At speeds as fast as some of the fastest standard static RAMs, they bring new performance dimensions to parallel communication between tasks of a computing machine. These devices utilize the latest in IDT's CEMOS technology to provide the design engineer with an economical high performance, low power, small size and highly reliable "Speciality Memory" for todays performance-driven designs.

## USING IDT7024 AND IDT7025 DUAL-PORT STATIC RAMs TO MATCH SYSTEM BUS WIDTHS

## APPLICATION NOTE <br> AN-59

By Bhanu V. R. Nanduri

## INTRODUCTION

This application note describes three design approaches to accomplish bus width matching using the IDT7024 and the IDT7025 dual-port static RAMs. Interfacing 32-bit buses to 16 -bit buses, 32 -bit buses to 8 -bit buses and 16 -bit buses to 8 -bit buses is described in detail. In general, any bus that is a multiple of 8 bits can be efficiently interfaced to any otherbus that is also a multiple of 8 bits using these dual-port RAMs.

The IDT7024 ( $4 \mathrm{~K} \times 16$ ) and the IDT7025 ( $8 \mathrm{~K} \times 16$ ) dual-port static RAMs are identical to each other in every respect except depth. For simplicity, only the IDT7024 will be discussed in detail. The IDT7024 and the IDT7025 dual-port static RAMs are provided with left and right upper byte enable ( $\overline{U B L}$ and $\overline{U B R}$ ) and the left and right lower byte enable ( $\overline{\mathrm{LB}} \mathrm{L}$ and $\overline{\mathrm{LB}} \mathrm{R}$ ) inputs. These byte enables allow interfacing in any bus width matching scheme without the need for external tri-state buffers or transceivers.

Bus matching schemes require that the byte ordering of information be maintained. This byte ordering can be either "big-endian" or "Ilttle-endlan". If data is configured in a bigendian format, byte 0 is always the leftmost byte. Big-endian is predominant in machines such as the MC 68000 and the IBM 370. If data is configured in a little-endian format, byte 0 is always the least significant, rightmost byte. Little-endian is used in machines such as the Intel x86, NS 32000 and the DECVAX. The MIPS R3000 microprocessorand the Intergraph CLIPPER support both data formats, however both these machines must be informed at "power on reset" which data format will be used. The big-endian and the little-endian byte ordering format is pertinent to 16-bit, 32-bit and 64-bit machines and is not applicable to 8 -bit machines. Figures 1 a to 1 d illustrate the possible big-endian and the little-endian data conversions.


2671 drw 01
Figure 1a. Little-endlan and Big-endian Byte Mapping Between 32-bit and 16-blt Buses - B0, B1, B2 and 83 are Bytes Within the 32-bit and 16-blt Words


2671 dmw 02
Figure 1b. Little-endian and Big-endian Byte Mapping Between 32-blt and 8-bit Buses - B0, B1, B2 and B3 are Bytes Within the 32-bit and 8-bit Words


2671 dww 03
Figure 1c. L/tt/e-endlan and B/g-endlan Byte Mapping Between 16-blt and 8-blt Buses - B0, B1, B2 and B3 are Bytes Within the 16-bit and 8-bit Words


2671 dww 04
Figure 1d. Little-endlan and Blg-endlan Byte Mapping Between 16-blt Buses - B0, B1, B2 and B3 are Bytes Within the $\mathbf{1 6 - b l t ~ W o r d s ~}$

This discussion on interfacing buses takes into account the byte-ordering of data using either the big-endian or the littleendian data format and even shows how to share data between a big-endian and a little-endian system. This is
included to serve as a guide only and is in no way exhaustive. The user is urged to investigate further the data organization to be used in his or her design before attempting to interface buses using dual-port RAMs.


Figure 2. An Interface to Connect 8- and 16-Blt Buses

Figure 2 shows a 16 -bit bus to an 8 -bit bus interface where the 16 -bit side is assumed to be using the little-endian data format. On the 8 -bit side of the interface, high order data lines D15-D8 on the RAM are connected to low order data lines D7 - D0 of the RAM (D15 to D7, D14 to D6, etc.) and processor address line A0 is used to select the lower or higher order byte. When AO is " 0 ", RAM byte 0 is selected and when A0 is " 1 ", RAM byte 1 is selected. Address lines A12-A1 of the 8-bit processor are connected to the twelve address lines of the IDT7024, as shown. These address lines are used to select the 4 K words of the IDT7024. If the 16 -bit bus side uses the big-endian data format instead of the little-endian data format then, on the 8 -bit side, $A 0$ must be a " 1 " to select byte 0 and AO must be a " 0 " to select byte 1 to guarantee correct byte ordering on the 8 -bit side. An alternate approach to ensure correct byte ordering on the 8 -bit side is to place the inverter shown in Figure 2 on the $\overline{\mathrm{LB}}$ line instead of the $\overline{U B}$ Lline. This
change will ensure that when the 8 -bit side's AO line is " 0 ", RAM byte 1 will be selected and, when the A0 line is " 1 ", RAM byte 0 will be selected.

Figure 3 is an interface that connects a 32-bit bus to a 16bit bus. In Figure 3 both the 32 -bit side and the 16 -bit side are assumed to be little-endian. The upper chip in the diagram holds the two lower order bytes of the 32-bit word and the lower chip in the diagram holds the two higher order bytes. In this interface, processor address bit AO on the 16-bit side is used to select a 16 -bit RAM word. When AO is " 0 " the RAM's lower order sixteen bits are selected and, when AO is " 1 ", the higher order sixteen bits are selected. Selection of the upper byte or the lower byte of either of the two RAMs is determined by the upper byte enable (UBE) and the lower byte enable ( $\overline{\mathrm{LBE}}$ ) inputs. If a big-endian byte ordering is assumed on both the 32 - and the 16 -bit sides, the $\overline{U B E}$ and the $\overline{\mathrm{LBE}}$ inputs to the IDT74FCT139 must be interchanged on the 16-bit side.


2671 drw 06
Figure 3. An Interface to Connect a 32-Bit Bus to a 16-Bit Bus


2671 dw 07
Figure 4. An Interface to Connect a 32-Bit Bus to an 8-Bit Bus

Figure 4 is an interface that connects a 32-bit bus to a 8-bit bus. In Figure 4, the 32-bit side is assumed to be little-endian byte ordered. The upper chip in the diagram holds the two lower order bytes and the lower chip in the diagram holds the two higher order bytes. In this interface, address bits AO and A1 on the 8 -bit side are used to select an 8 -bit word. Table 1 illustrates the bytes selected for each combination of A0 and A1 for a little-endian byte-ordered data format on the 32-bit side. If a big-endian byte-ordering is assumed on the 32-bit side, the upperchip will hold the two higher orderbytes and the lower chip holds the two lower order bytes. Address bits AO and A1 on the 8-bit side are used to select one of four bytes as illustrated in Table 2. The mapping scheme to accomplish other bus interfaces is left to the user.

| 8-bit Side |  | 32-bit Side |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A0 | A1 | BE3 | BE2 | BE1 | BE0 |
| 0 | 0 | $X$ | $X$ | $X$ | 0 |
| 0 | 1 | $X$ | $X$ | 0 | X |
| 1 | 0 | $X$ | 0 | $X$ | X |
| 1 | 1 | 0 | $X$ | $X$ | $X$ |

Table 1. Byte Selection Equivalency Assuming the 32-Blt Side Uses the Little-Endlan Byte Ordering of Data

| 8-bit Side |  | 32-bit Side |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A0 | A1 | BE0 | BE1 | BE2 | BE3 |
| 0 | 0 | $X$ | X | X | 0 |
| 0 | 1 | $X$ | X | 0 | X |
| 1 | 0 | $X$ | 0 | X | X |
| 1 | 1 | 0 | X | X | X |
|  |  |  |  |  |  |

Table 2. Byte Selection Equivalency Assuming the 32-BIt Side Uses the Big-Endlan Byte Ordering of Data

## BUSY ARBITRATION LOGIC

Busy arbitration is performed only when there is an address match and the chip enables are active. The IDT7024 and the IDT7025 dual-port RAMs are provided with a master/slave (M/ $\overline{\text { S }}$ ) pin through which the user can configure the busy logic on these devices to operate as masters or slaves. Busy arbitration is performed only by the master, which generates the busy signal. The master outputs a logic " 0 " on the busy line of the port that loses arbitration, at the same time it generates an internal write inhibit signal to block any write operation on the losing port. When configured to operate as slaves, these devices use the busy line as an input. The slave takes the busy line as an input and generates an internal write inhibit on the same port that received the busy. The upper and lower byte enable inputs do not affect the operation of busy logic in these devices. If busy logic and width expansion are being used, it is important that the $\overline{\mathrm{CE}}$ of the master and the associated slave always be active at the same time. If the decoding logic allows the slave to be selected without the master, the busy logic will not operate correctly. Care has
beentaken inboth Figures 3 and 4 to assure correct busy logic operation. It should be kept in mind, however, that busy logic is often not an essential part of a dual-port RAM-based system. The user is urged to read Application Note AN-02 for more information on busy logic arbitration.

## INTERRUPT LOGIC

' The IDT7024/IDT7025 dual-port RAM chips have interrupt generation capability that can be very effectively used to interrupt processors connected to either side of the dual-ports. A processor connected to the left port can generate an interrup to the processor connected on the right port by writing to the topmost location in the memory array. In the case of the IDT7024, this location is FFF (Hex). The processor on the right port clears the interrupt by reading from this location, i.e. FFF (Hex). Similarly, the processor on the right port can interrupt the processor on the left port by writing to the topmost minus one location, i.e. FFE (Hex), for the IDT7024. The processor on the left port clears the interrupt by reading from location FFE (Hex).

| Side | Set Address (HEX) <br> (Write) (Interrupts the <br> Other Side) | Clear Address (HEX) <br> (Read) (Clears the <br> Interrupt on Thls SIde) |
| :--- | :--- | :--- |
| Using left port | FFF | FFE |
| Using right port | FFE | FFF |

267103
Table 3. Interrupt Set and Clear Addresses for the IDT7024 Dual-Port RAMs

| Side | Set Address (HEX) <br> (Write) | Clear Address (HEX) <br> (Read) |
| :--- | :--- | :--- |
| 32-Bit side (Using left ports) | FFF | FFE |
| 16-Bit side (Using right ports) | 1FFC | 1FFE |


| 32-Bit side (Using right ports) | FFE | FFF |
| :--- | :--- | :--- |
| 16-Bit side (Using left ports) | 1FFE | 1FFC |

2671 tol 04
Table 4. Interrupt Set and Clear Addresses for the 32-bit to 16-bit Interface Shown in Figure 3

| Side | Set Address (HEX) <br> (Write) | Clear Address (HEX) <br> (Read) |
| :--- | :--- | :--- |
| 32-Bit side (Using left ports) | FFF | FFE |
| 8-Bit side (Using right ports) | 7FFA or 7FFB | 7FFC or 7FFD |


| 32-Bit side (Using right ports) : | FFE | FFF |
| :--- | :--- | :--- |
| 8-Bit side (Using left ports) | 7FFC or 7FFD | 7FFA or 7FFB |

Table 5. Interrupt Set and Clear Addresses for the 32-bit to 8-blt Interface Shown In Figure 4

Table 3 summarizes the interrupt set and clear addresses for the IDT7024 dual-port RAMs, while Tables 4 and 5 summarize the interrupt set and clear addresses for the interface shown in Figures 3 and 4. In the interface schemes illustrated in Figures 3 and 4 , we have two dual-ports that have been used to expand the memory in width. This means that we can have two interrupt lines going active one for each chip. The schemes illustrated in Figures 3 and 4 show only interrupts from the master chip being used by either side, while the interrupts from the slave chip are not used.

## SEMAPHORE ARBITRATION

The IDT7024 and IDT7025 are provided with semaphore logic in the form of eight dual-port semaphore fiags that are independent of the memory array. These eight cells can be used to supervise the accesses to a maximum of eight blocks of memory. There is no hardware interaction between the semaphores and the RAM. Address bits $A(m) R, A(m-1) R$ and $\mathrm{A}(\mathrm{m}-2) \mathrm{R}$ in Figure 3 are inputs to an IDT74FCT138 which decodes the dual-port RAM space and the semaphore space on the 16 -bit side. Address bits $A(m) R$ and $A(m-1) R$ in Figure 4 are inputs to an IDT74FCT139 which decodes the dual-port RAM space and the semaphore space on the 8 -bit side. Similarly, address bits $A(n) L, A(n-1) L$ and $A(n-2) L$ are inputs to another IDT74FCT138 which decodes the various address spaces on the 32-bit side. It is necessary to keep the dual-port memory space and the semaphore address space separate.

| Semaphore Address |  | Selected Semaphore Cell |  |
| :---: | :---: | :---: | :---: |
| A2 | A1 | A0 |  |
| 0 | 0 | 0 | Sem Flag 0 |
| 0 | 0 | 1 | Sem Flag 1 |
| 0 | 1 | 0 | Sem Flag 2 |
| 0 | 1 | 1 | Sem Flag 3 |
| 1 | 0 | 0 | Sem Flag 4 |
| 1 | 0 | 1 | Sem Flag 5 |
| 1 | 1 | 0 | Sem Flag 6 |
| 1 | 1 | 1 | Sem Flag 7 |

2671 か 06
Table 6. Semaphore Address Map for the 32-bit Side In Figures 3 and 4

Operating on the two spaces is a mutually exclusive operation and, therefore, chip enable ( $\overline{\mathrm{CE}}$ ) and the semaphore enable (SEM) inputs must never be active at the same time. The semaphore cells are intended to assist software-based protocols intended to prevent address collisions.

The IDT semaphore cells are designed to be used in a clear-and-test sequence. Each cell is normally in the " 1 "state, indicating that neither side has been assigned the associated block of memory ("No grant"). To access a particular block of memory, one must perform the clear-and-test sequence necessary to geta "grant" from the semaphore cell representing the block. To get a "grant", one must select the semaphore cell representing the associated block of memory, write a " 0 " (request) to the semaphore cell and then read (test) the semaphore cell to see if a " 0 " was put out by the cell.

A semaphore cell is selected by asserting the semaphore enable line ( $\overline{\mathrm{SEM}}$ ) and by selecting one of the eight semaphore cells with the help of the three lower most address lines A2AO. In the read operation, if the semaphore cell is a " 0 ", that particular block of memory is "available" for use by the side requesting access. If the semaphore cell is a " 1 ", the side requesting access has a "no grant" and that particular block of memory is in use by the other side. In the IDT7024 and IDT7025, the semaphore cells broadcast the "grant" or "no grant" condition on the entire sixteenbits of the data pins. The status of the upper and lower byte enables has no effect on the semaphore request operation.

| Semaphore Address |  |  |  | Selected Semaphore Cell |
| :---: | :---: | :---: | :---: | :---: |
| A3 | A2 | A1 | A0 |  |
| 0 | 0 | 0 | X | Sem Flag 0 |
| 0 | 0 | 1 | X | Sem Flag 1 |
| 0 | 1 | 0 | X | Sem Flag 2 |
| 0 | 1 | 1 | X | Sem Flag 3 |
| 1 | 0 | 0 | X | Sem Flag 4 |
| 1 | 0 | 1 | X | Sem Flag 5 |
| 1 | 1 | 0 | X | Sem Flag 6 |
| 1 | 1 | 1 | $X$ | Sem Flag 7 |

Table 7. Semaphore Address Map for the 16-bit Side in Figures 3

| Semaphore Address |  |  |  | Selected Semaphore Cell |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A4 | A3 | A2 | A1 | A0 |  |
| 0 | 0 | 0 | $X$ | X | Sem Flag 0 |
| 0 | 0 | 1 | $X$ | X | Sem Flag 1 |
| 0 | 1 | 0 | $X$ | X | Sem Flag 2 |
| 0 | 1 | 1 | $X$ | X | Sem Flag 3 |
| 1 | 0 | 0 | $X$ | $X$ | Sem Flag 4 |
| 1 | 0 | 1 | $X$ | $X$ | Sem Flag 5 |
| 1 | 1 | 0 | $X$ | $X$ | Sem Flag 6 |
| 1 | 1 | 1 | $X$ | $X$ | Sem Flag 7 |

Table 8. Semaphore Address Map for the 8-bit Side in Figures 4

Consistent with the rest of our discussion on busy logic and interrupts, we will consider the semaphore flags inthe IDT7024 containing the lower order sixteen bits of data (master). When the 32-bit side in Figures 3 and 4 reads the semaphores, the processor on the 32-bit side will look at the lower sixteen bits only to check for a "grant" or a "no grant" condition. The 16bit and 8-bit sides access the semaphore space in Figures 3 and 4 and must read the master IDT7024 containing only the lower sixteen bits to check for a "grant" or a "no grant" condition. (Refer to Tables 6, 7 and 8.)

## SUMMARY

Interfacing various buses with the he!p of dual-ports can be implemented very easily and with a minimum of components. Byte reordering can also be accommodated easily. IDT7024 and IDT7025 dual-port static RAMs have built-in arbitration schemes, upper and lower byte enables, and pin selectable master/slave functions. These features have been designed to aid system designers in their quest for compact, simple and more reliable designs.

# USING IDT71502 RAMs IN A REAL-TIME DEBUGGING TOOL FOR A R3000 MICROPROCESSOR BASED SYSTEM 

by Bhanu V. R. Nandurl

## INTRODUCTION

The proliferation of high-speed RISC and CISC microprocessors has created a demand for real-time debugging tools. This application note shows how a real-time logic tracing tool can be created using IDT71502 multifunction RAMs. The IDT71502 can be used as a stand-alone logic analyzer or as part of an embedded fault monitor and analysis system. Details of how to apply this system to an R3000 RISC microprocessor-based system are given. The discussion in this paper is also equally valid for use in high-speed CISC processor-based designs.

The IDT71502 can be used to function either as a logic tracing device or as a test pattern generator. As a logic tracing device the IDT71502 can record bus activity continuously and then be stopped on a predetermined event such as a bus error. This allows the activity leading up to the "event" to be recorded for analysis. Since the trace function is accommodated in a single device, embedded tracing is more likely to be practical.

## DESCRIPTION OF IDT71502 MULTIFUNCTION RAM

IDT71502 is a $4 \mathrm{~K} \times 16$ multifunction RAM with an address set-up time of 25 ns . It has a breakpoint comparator, 16 -bit
pipeline register and an address counter. In addition, there is a 16 -bit set-up register used to set the chip operating mode and to read back chip operating status conditions. It includes a serial control interface called the serial protocol channel (SPC ${ }^{\text {M }}$ ) which is available in a variety of other products from IDT as well. The SPC logic, as implemented in the IDT71502, has one 8 -bit command shift register, a command decode register and a 16-bit data shift register. The serial data shift register can be configured to operate in a diagnostic mode. In the diagnostic mode of operation, the shift register can read all status conditions on the chip such as the RAM output, pipeline register output, data output pin state and RAM load/read counter value.

The serial protocol channel consists of a four-pin interface bus through which the user can access the internal registers of the IDT71502. The four pins are:
(a) Serial data input pin (SDI) for sending data and commands to the device.
(b) Serial data output pin (SDO) for extracting data from the device.
(c) Serial clock pin (SCLK) for clocking data and commands.
(d) Command/Data mode pin (C/D) to provide command or data identification to the device.


2676 drw 01
Figure 1.

This four-bit bus can be very conveniently connected to an RS-232C line for direct serial communication with a computer and Figure 1 illustrates one scheme to achieve this. The user is urged to refer to the "IDT71502 FUNCTIONALITY DEMONSTRATION BOARD USER MANUAL" for more information on interfacing the IDT71502 to the RS-232C serial communication line. The SPC's eight bit command is divided into a four-bit command field and a four-bit register field. The four-bit command field is used to determine whether a read or a write operation will be executed. The four-bit register field of the command register is used to select the various internal registers and the external pins on which the read or write will take place. Thus, the four-bit command field and the four-bit register field can effectively access any internal register for a read or a write operation and monitor the state of the external pins.

Table 1 summarizes the SPC commands, and Register codes and the set-up register format. When the command/ data line is high, commands are serially clocked through the SCLK into the internal command register via the serial data input pin (SDI). When the command/data line is low, data is serially clocked by the SCLK into the internal data register via the serial data input pin (SDI). The SPC commands are executed whenever the C/D line transitions from a command mode (logic 1) to a data mode (logic 0). This device, when configured to operate in the trace mode, serves as a real-time debugging tool analogous to a logic analyzer.

| SET-UP/STATUS REGISTER CODE |
| :--- |
| Bit Name Operation Performed <br> 15 CE Read Only <br> 14 $\overline{\text { SOE FF }}$ Read Only <br> 13 $\overline{\text { SOE Pin }}$ Read Only <br> 12 $\overline{\text { OE Pin }}$ Read Only <br> 11 $\overline{\text { WE }}$ Pin Read Only <br> 10 $\overline{\text { INIT Pin }}$ Read Only <br> 9 BP Compare Read Only <br> 8 BP Pin Read Only <br> 7 $\overline{\text { CS1 }}$ ReadWrite <br> 6 $\overline{\text { CSO }}$ ReadWrite <br> 5 Non-Reg High ReadWrite <br> 4 Non-Reg Low - <br> 3 -  <br> 2 BC-ADDRS Read/Write <br> 1 BC Pipelined Read/Write <br> 0 Trace Mode Read/Write |

2676 tol 01

SPC REGISTER CODES

| Register Code <br> (Hexadecimal) | Read/Write <br> Function | Register |
| :---: | :--- | :--- |
| 0 | Read/Write | RAM Counter |
| 1 | Read/Write | RAM Output/Input |
| 2 | Read/Write | Pipeline Register |
| 3 | Read/Write | Break Mask Register |
| 4 | Read/Write | Break Data Register |
| 5 | Read/Write | Setup and Status Register |
| 6 | Read Only | V/O15 - I/O0 (Data Pins) |
| 7 | Read Only | RAM Address Pins |
| $8-F$ | Reserved | Reserved (Unused) |

2676 th 03

Table 1.

## AN R3000-BASED SYSTEM

A block diagram of a R3000-based system's CPU and its memory interface is shown in Figure 2. It consists of the CPU and FPU, data and instruction caches and the read and write buffers connected to the CPU and the system bus. This is a typical configuration found in embedded or general purposetype systems which use the R3000. To reduce the burden of
the systemdesigner who is interestedinusing the IDT79R3000, the CPU and FPU, as well as the instruction and data caches with the read and write buffers, are now available in a compact module (IDT7RS101) which can be connected to the user's system bus. This approach to system design vastly reduces the design cycle time by shifting the design emphasis to main memory and I/O interfaces.


2676 drw 02
Figure 2. A Generic R3000 Microprocessor Based System

When debugging a system board based on the IDT7RS101 orits equivalent, the majority of debugging is done by monitoring the cache to main memory interface on the main memory side of this interface. An embedded trace function may operate in the same way. This keeps the capacitance of the trace RAM pins out of the speed critical cache buses. If desired, the R3000 canbe operated in the uncached mode. This forces all accesses to main memory and allows every memory access of the processor to be monitored from the cache to main memory interface. The userwishing to operate inthe uncached mode can do so by setting bit 11 of the TLB entry register to 1 , indicating uncached mode, oroperate the software in virtual address space kseg1. Kseg1 is kernal-mode virtual addressing space which is uncached and is 512 Mbytes long starting at virtual address $0 \times 2000 \_0000$. With this approach, the user must define instruction space and data space in the main
memory and must provide an address decoded input to the IDT71502 tracing the control bus. This input will be used to determine whether an instruction or data related transaction occurred during that clock period.

Another approach is to tie the address valid bit on the TAG bus to ground via a 300 Ohm resistor. This is necessary to prevent a direct short from occurring when the CPU is driving the TAG bus. Tying the address valid bit on the TAG bus to ground will result in invalidating the cache TAGs and cache misses will occur, resulting in the processor accessing main memory to get that information. Whenever the main memory is accessed to get information after a cache miss, the processor puts out information on the Access Type pins, indicating the size of the word to be transferred and that it was a cached reference. AccTyp(2) pin output indicates a cached reference when 1 and an uncached reference when 0 . $\operatorname{AccTyp}(0)$
indicates a Data reference when 0 and an instruction reference when 1. The AccTyp signals are latched using our control trace RAM and will determine whether an instruction or data transaction occurred during that clock period.

A user wishing to implement his own cache can use the IDT71502 in the trace mode to monitor the cache. However,
it should be pointed out that the timing for this part of his system is more stringent. The user may have to register trace data before clocking it into the IDT71502s to meet the IDT71502s set-up and hold time restrictions.


Figure 3. Block Diagram to Trace Instructions, Data, Instruction Addresses and Data Addresses on the System Bus of an R3000-based System

## DESCRIPTION OF THE MONITOR CIRCUIT

Figure 3 shows the block diagram of an implementation of the monitor circuit. It is placed on the system bus between main memory and the write buffer of the R3000. The R3000 uses the write through cache update policy to ensure data coherency. The function of the write buffer is to capture data and addresses output by the CPU and ensure that data is passed on to main memory. The read buffer is used for temporary storage of data during datatransfers between main memory and the CPU. Depending on the block refill size, the read buffer can be $1,4,8,16$ or 32 words deep. The block refill size of the system is fixed during the system reset operation. The R3000's CpCond0 input can be set to a 0 to indicate a single word transfer or can be set to a 1 to indicate a block
transter by the external memory controller. The PAL state machine is used to generate the appropriate IDT71502 strobes to capture instructions, data, instruction addresses and data addresses.

The IDT71502s labeled " 1 " in Figure 3 is used for capturing data and instruction addresses; IDT71502s labeled " 2 " is used for capturing data and instructions. The IDT71502 labeled " 3 " is used to trace the controlbus signals. In this application note, we assume a single word deep read buffer. If a system is designed for all possible types of data transfers (i.e bytes, half words, tribytes, words and block refills), our PAL equations will also have to change to generate the strobes necessary to trace these data transfers.


Figure 4. Main Memory Read Cycle (Single Word Read)


Figure 5. Main Memory Write Cycle (Single Word Write)

## TIMING ANALYSIS

Figure 4 is the timing waveform for a single word read and Figure 5 is the timing waveform for a single word write. Since the system bus timing parameters are dependent on an externalmemory controller, Table 2 summarizes the important handshaking signals needed to satisfy the protocol necessary to trace system bus signals.

AddrOutEn is an input to the read buffer from the main memory controller. When asserted, this input will enable the address that is registered in the read buffer to the system bus. $\overline{\mathrm{McRd}}$ is a read strobe that is generated by the main memory controller in response to a MemRd pulse from the R3000. $\overline{\text { RBDEn }}$ is a main memory controller input to the read buffer
that registers the data available on the system data bus into the read buffer.

WrAck is an input to the write buffer from the main memory controller. It indicates that it has written the word presented to it to main memory. $\overline{\text { RdAck }}$ is also a main memory controller output that is used to generate the $\overline{\text { RdBusy }}$ signal to the R3000. TWE is an input to the IDT71502s that latches data addresses, instruction addresses, data, and instructions; it is also an output from our PAL state machine. TCLK is the clock input to the IDT71502s tracing data addresses, instruction addresses, data, and instructions. The signals TWE and TCLK are also used as inputs to the IDT71502s in order to trace the control bus signals.

| Signal |  |
| :--- | :--- |
| $\overline{\text { BMemRd }}$ | Function |
| $\overline{\text { BMemWr }}$ | The buffered memory read signal from the R3000 |
| $\overline{\text { AddrOutEn }}$ | The buffered memory write signal from the R3000 |
| $\overline{\text { McRd }}$ | Read buffer address output enable signal from the memory controller |
| $\overline{\text { RBDEn }}$ | Main memory read strobe from the memory controller |
| $\overline{\text { WrAck }}$ | Read buffer data enable strobe from memory controller |
| $\overline{\text { RdAck }}$ | Write acknowledge to write buffer from memory controller |
| $\overline{\text { TWE }}$ | Read acknowledge to read buffer from memory controller |
| TCLK | Write enable input to IDT71502 from PAL state machine |
|  | Clock input to IDT71502 from PAL state machine |

2676 t 04
Table 2.

## TIMING SPECIFICATIONS FOR THE

## IDT71502s

tTWDS is the IDT71502 specification defined as "Trace Write Data Set-up Time". The user must satisfy the following condition:

$$
\text { tTWDS } \geq 8 \mathrm{~ns}
$$

tTWDH is the IDT71502 specification defined as "Trace Write Data Hold Time". The user must satisfy the following condition:

$$
1 T W D H \geq 2 n s
$$

tTWs is the IDT71502 specification defined as "Trace Write Enable Set-up Time." The user must satisfy the following condition:
tTWs $\geq 8 \mathrm{~ns}$
tTWH is the IDT71502 specification defined as "Trace Write Enable Hold Time." The user must satisfy the following condition:
tTWH $\geq 2 n s$

## CONCLUSION

The IDT71502 is a multifunction RAM that is fast enough to be used to trace the operation on most high-speed microprocessors including the IDT79R3000 RISC microprocessor. The 25 ns speed grade can be used to trace full speed the operation of this processor up to 25 MHz . The discussion in this paper focused on providing the pertinent information needed to construct a monitor circuit based on IDT71502 multifunction RAMs to trace the system bus of an R3000-based system. This discussion is also valid for users interested in using the IDT71502 RAMs in a trace mode to monitor system buses based on other high-speed processors.

Microprocessor based systems are usually provided with software routines that are used as diagnostic tools to test system primary and secondary memory for failures. These programs also test $1 / O$ devices before the user receives a prompt, telling him the system as a whole is ready for service. This procedure is usually carried out after system reset, but occasionally during normal operation the system "crashes" in the middle of some critical task and the user has no clue as to what happened prior to the "crash". The IDT71502 multifunction RAMs, whenoperated intrace mode and mounted permanently on critical system paths, can serve as "black boxes" to give the user this very important information. This information can then be very conveniently retrieved via the four bit serial protocol channel connected to the RS-232 connector and the reason for the crash can be determined.

The IDT71502 is a multifunction RAM that has the capability to serve as a valuable logic monitoring tool. It contains the Serial Protocol Channel and a breakpoint comparator, has a $4 \mathrm{~K} \times 16$ memory space and is available with an access speed of 25 ns . Thus, it is well-suited for use as a single chip logic analyzer in high-speed, high-density environs.


# DUAL-PORT RAM SIMPLIFIES PC TO TMS320 INTERFACE 

by Jim Handy \& Barry Seldner Integrated Device Technology, Inc. Jon BradleyTexas Instruments, Inc.

This application note describes a "no hassels" interface between the IBM PC-style backplane and a TMS320C30 DSP chip via an IDT dual-port static RAM. The interface provides an extremely simple means of downloading cross-compiled DSP code as well as sample data sets for debugging a high speed TMS320 based system in real time.

This example also shows how easily interprocessor communications hardware can be implemented via the simple insertion of a dual-port RAM between a DSP chip and a general purpose processor in a standard DSP system. A system like this one would typically use a standard CPU for data input/output and ordering, and would pass complete data sets to the DSP chip for intense calculation. Similar architectures are often used ingraphics and image processing, where an entire image is manipulated as a single data set, in transform calculations (i.e. FFTs) for sonar and radar processing. Certain systems even use this scheme several times with numerous DSP chips in order to get processing speeds proportional to the number of DSP chips in the system.

## SYSTEM OBJECTIVE

The design presented here is the TMS320C30 Software Development Board. This board is one portion of a system which helps the TMS320C30 programmer to download and debug code from an IBM PC or similar computer. In order to support the special hardware needs of the TMS320C30 programmer, an expansion connector allows memory to be added to the DSP chip's primary bus, while a target connector provides a fully buffered version of the chip's expansion bus to allow its connection to special purpose hardware. Most of the TMS320C30's status signals are also routed to the expansion bus to make them available to the hardware being debugged.

The majority of the control software is PC-resident, and is provided on magnetic media. This includes such tools as the assembler, compilers, and download and debug routines. A $2 \mathrm{~K} \times 32$ EPROM array on the primary bus of the TMS320 provides the host processor with a set of commands to allow it to load the software development board's RAMs, to set and clear breakpoints, to examine and preset internal status, and to load or store values in individual memory locations. All of these are controlled by the host's sending a command to the TMS320, which interprets that command and takes appropriate action.

A high speed $16 \mathrm{~K} \times 32$ static RAM is attached to each of the DSP chip's two buses: the expansion bus, and the primary bus. The expansion bus' RAM would typically be used to store a data set to be operated upon, and the primary bus' RAM
would be used to store code which would be debugged using this board. Both of these RAMs are zero wait-state (25ns access times at 33 MHz ) to allow real-time debugging and benchmarks to be performed. Since the TMS320's expansion bus only supports addressing of up to 8 K locations, a bank select signal is used to switch between the upper and lower halves of this port's $16 \mathrm{~K} \times 32$ memory. This signal is softwarecontrolled from the processor's expansion bus.

One design goal for this system was to move data into and out of the DSP's dedicated memory without taking an inordinate amount of time or hardware. If standard memory were to be shared between the host and the DSP chip, multiplexing logic would need to be inserted between each processor and the RAM's address, data, and control lines. This logic would find itself right in the critical timing path of the memories on the primary and expansion buses, and would make zero waitstate operation nearly unachievable. An additional headache would have been finding room on the board for the large amount of multiplexing logic required. Should the design have used a simpler method of passing data back and forth between processors either via a UART or a single byte-wide I/O buffer, the developer would have had to endured long delays during download and other communication functions as the software on either side of the port performed massive amounts of handshaking to pass even the smallest of data sets.

It became obvious early in the design cycle that the simplest method of performing fast host to DSP communication would be to use a large high-speed true dual-port static RAM to perform interprocessor communications. A dual-port RAM would allow both the host and the DSP chip to transfer data in packets, rather than as individual bits or bytes, thus accelerating downloading. The selected dual-port device would have to be one which provided some means of signalling that data packets were ready to be handed back and forth between processors.

An IDT71342 was chosen because of its speed, its depth ( 4 K bytes), the simplicity of its interface, and its ability to performinterprocessor communications through its eight internal semaphore flags (see Appendix: "Dual-Port Semaphores"). By using an IDT71342, the designers could use a single chip to implement 4 K byte high speed block transfers between the host and the TMS320, and to signal the completion of a transfer without additional hardware. Although the 45ns access time dual-port used in this system does not support zero-wait data transfers at maximum CPU speeds, data transfers are not in the critical path of the sort of software this system is used to debug. Still, a true zero-wait state system


Figure 1. TMS320C30 Software Development Board Block Diagram
could have been realized had the designers used a 25 ns dualport.

Figure 1 shows a block diagram of the complete system. The full schematic of the system is shown in Figure 6.

## INTERFACING TO THE DUAL-PORT RAM

The IDT71342 dual-port RAM uses an interface which is similar to any standard single-port byte wide static RAM. Each of the two ports (Left and Right) uses a separate set of control, address, and I/O pins. Address inputs are not multiplexed with data $I / O$. The control interface consists of three pins on either side: read write ( $\mathrm{R} / \overline{\mathrm{W}}$ ), output enable ( $\overline{\mathrm{OE}}$ ), and chip enable/ power down ( $\overline{\mathrm{CE}}$ ). The $\mathrm{R} / \overline{\mathrm{W}}$ and $\overline{\mathrm{OE}}$ pins also operate in conjunction with the semaphore select pin (SEM), which imitates the functionality of the chip enable pin, but rather than allowing reads and writes of the memory array, this pin routes the read and write control to the eight on-chip semaphore flags.

Write cycles are controlled by the simultaneous application of a logic low on both the CE and R/W inputs for one side of the RAM, and either signal can be used to control the timing of a write cycle. If the CE signal is held low and the timing is set by a low pulse on the R/ $\bar{W}$ pin, it is called a "R $/ \bar{W}$ controlled write cycle" (figure 2). Write cycles where R/W stays low while $\overline{\mathrm{CE}}$ is pulsed low are called " $\overline{\mathrm{CE}}$ controlled write cycles" (figure 3). By offering both methods of communication, IDT's dualport RAMs can be easily connected between systems with greatly differing bus interface specifications. An interesting point about this design is that while the PC or host side of the dual-port uses a R/W controlled write cycle, the DSP writes to its side of the dual-port by using a $\overline{\mathrm{CE}}$ controlled write cycle.

## THE PC BUS INTERFACE

In this design, the PC bus' control signals are routed nearly directly from the backplane to the IDT71342's R/W and $\overline{\mathrm{OE}}$ pins. The signal functions and timing of the backplane are an ideal match with those of the dual-port RAM. However, a decision was made to map the memory array into a 4 K space in the PC's memory space, while the semaphores were to be mapped into the PC's I/O space, which forced the $\overline{I O W}$ and $\overline{M E M W}$ signals to be ORed before driving them into the IDT71342's R/W input. Likewise $\overline{I O R}$ and $\overline{M E M R}$ signals are ORed before driving them into the IDT71342's $\overline{\mathrm{OE}}$ input.

The dual-port's chip enable ( $\overline{\mathrm{CE}}$ ) pin is driven indirectly by an address decoder consisting of an eight bit comparator 74ALS521 which compares the output of a 74LS377 register with addresses A12-A19. The 74LS377 is an I/O mapped register that allows the dual-port RAM to be mapped into any 4 K -byte region in the PC's main memory space. A PAL resident control register bit on the board allows the dual-port memory to be disabled, which is its state at power-up or reset.

The semaphore enable pin (SEM) is driven by a 20 L 8 PAL which decodes addresses from the PC Bus. This decoder determines whether the host is accessing memory or I/O space via the $\overline{M E M R}, \overline{M E M W}, \overline{I O R}$, and $\overline{I O W}$ signals, and enables the semaphores during an $1 / O$ access if the proper address (A0-A9) is applied to the inputs of the PAL. The PAL also uses the $\overline{I O W}$ and $\overline{M E M W}$ signals to generate a $R / \bar{W}$ controlled write cycle, while using decoded addresses to drive the $\overline{\mathrm{CE}}$ and $\overline{\mathrm{SEM}}$ inputs.

All data and address pins of the IDT71342 are isolated from the backplane with TTL buffers. A detail of the PC to dual-port interface is shown in Figure 4.

The reader should note that several considerations increased the complexity of this interface. If this design had
involved a dedicated host processor rather than a general purpose PC, the need for buffering would probably have been drastically reduced. Had both the 4 K byte RAM and the semaphores been mapped into the memory space of the host, no ORing would have been required on the MEMW, $\overline{M E M R}$, $\overline{\mathrm{OW}}$, and $\overline{\mathrm{OR}}$ signals. Finally, a very complex address
decoder was implemented in this system to allow the IDT71342's RAM to be mapped anywhere within the PC's memory space. By using a more straightforward fixedaddress scheme, logic complexity could be significantly reduced. It is conceivable that the entire interface including address decoding could have been handled with a single IC.


Figure 2. Timing Waveform of R/WControlled Write Cycle


2721 drw 09

Figure 3. Timing Waveform of CE Controlled Write Cycle.


Figure 4. PC Bus to IDT71342 Dual-Port Interfacew (Left-Hand Side of Dual-Port).


Figure 5. TMS320C30 to IDT71342 Dual-Port Interface (Right-Hand Side of Dual-Port).

## THE TMS320C30 INTERFACE

The TMS320 interfaces to the dual-port RAM through the I/O strobe on the expansion bus. The same bus is used to interface to a $16 \mathrm{~K} \times 32$ static RAM via its memory strobe signal. These two strobes signify two different ranges on the DSP chip's internal address map. A detailed diagram of the TMS320 to IDT71342 interface is shown in Figure 5.

As in the PC bus interface, the address lines are buffered between the processor and the dual-port RAM, however the light loading on the data bus removes the need for data buffering on this side. The only devices connected to the data pins are: the dual-port RAM, the DSP chip, a static RAM, a status latch, and a transceiver. The address bus needed buffering since all eight $16 \mathrm{~K} \times 4$ RAM chips, as well as the dualport, a PAL, and an address buffer are attached to these pins.

The TMS320's expansion bus uses a strobe to activate an I/O cycle, and a level to distinguish read cycles from write cycles. In this design, the expansion read/write (XR $\bar{W}$ ) output of the TMS320 is connected directly to the IDT71342 dual-port to drive the read/write ( $\mathrm{R} \overline{\mathrm{M}}$ ) input, and is simply inverted to drive the output enable ( $\overline{\mathrm{OE}}$ ) input. This inverter is not truly necessary, since the dual-port places its data outputs into a high-impedence state automatically upon the application of a write (low) level on the $\mathrm{R} / \bar{W}$ input. The $\overline{O E}$ pin on this side could have been permanently tied active (grounded).

A20L8 PAL is used to control the chip enable ( $\overline{\mathrm{CE}}$ ) input for this side of the dual-port RAM. This signal is a decoding of the DSP's expansion bus address bits XA0-XA12. The PAL used in this interface had too few product terms to allow the combination of the l/O strobe with the decoded address, so the buffered I/O strobe (BIOSTRB) has been externally ANDed with the decoded address output from the PAL before being fed into the dual-port. The semaphore select is handled the same way, but a different address decoding is used from the same PAL, and the I/O strobe is ANDed through a different gate into the semaphore ( $\overline{\mathrm{SEM}}$ ) input of the dual-port. Both of these signals can be disabled by writing to the control register.

The TMS320C30 writes to the dual-port RAM by implementing a $\overline{\mathrm{CE}}$ controlled write cycle. The $\overline{\mathrm{CE}}$ and $\overline{\text { SEM }}$ inputs are driven by two-input OR gates. One of the inputs of each of these gates represents a decoded address output from a 20 L 8 PAL, while the second input is driven by a buffered version of the I/O strobe. The only other qualifying input is the read/write ( $\mathrm{R} \overline{\mathrm{M}}$ ) input, which is directly driven by the expan-
sion read/write (XR/ $\overline{\mathrm{M}}$ ) signal on the TMS320. When the DSP chip writes to the dual-port, the address and read/write signals are output first, followed by the I/O strobe. Since IOSTRB is used to gate the $\overline{\mathrm{CE}}$ or $\overline{\mathrm{SEM}}$ signal, the timing meets the criteria for a $\overline{C E}$ controlled write cycle.

The expansion ready (XRDY) input to the TMS320, which tells it that the expansion bus cycle is complete, is a combination of the decoded address range from the PAL and a clock delay from the TMS320's H1 (clock/2) output. This signal is required for systems using slower dual-port RAMs; but is not necessary in systems where faster dual-ports are used. If the system designer choses a 25 ns or faster part for use in a 33 MHz TMS320C30 system, the XRDY input can be generated immediately upon accessing the dual-port RAM.

The gating used here generates a single wait-state on any I/O strobe within the address range of the IDT71342. This logic could be removed if a faster IDT71342 were used. On an $\overline{\text { OSTRB }}$ output from the TMS320, if the PAL decodes a dual-ported address, the strobe and decoded address are combined in the second of the two AND gates in fig. 5. This AND gate's output is fed into the XRDY OR gate to extend the expansion bus cycle. On the next rising edge of H 1 , the IOSTRB is clocked into the flip flop. This flip flop's output is connected to the first AND gate and disables the IOSTRB from reaching the second AND gate. This in turn allows the XRDY input to the TMS320 to go active, and allows the cycle to end. A single wait-state more than compensates for the 45 ns address access time of the dual-port used in this application. Other signals called target I/O ready (TIORDY) from the target connector, and the MSTRB signal from the DSP chip itself can also signal an expansion bus ready state. Since the MSTRB signal is used only to control accesses to the expansion bus' $16 \mathrm{~K} \times 32$ zero wait-state RAM, it is ORed directly back to the XRDY input through the 74AS11 gate as shown.

## CONCLUSION

The TMS320C30 Software Development Board shows the simplicity of designing an interface between a TMS320 DSP chip and the IBM PC bus using an IDT71342 dual-port RAM. The dual-port RAM serves to reduce component count, increase interprocessor communications throughput, and simplify design. Designers should be able to follow the example given here to profitably use dual-port RAMs to handle communications in any similar dual processor system.



## 








Figure 6. Complete Schematic of TMS320C30 Software Development System (section 8 of 9 )

## APPENDIX

## DUAL-PORT SEMAPHORES

Eight extra address locations in the IDT71342 4K $\times 8$ dualport RAM are dedicated to binary semaphore flags. These flags allow either the TMS320 or the host processor to claim a privilege over the other processor for functions defined by the programmer's software. As an example, the semaphore can be used by the PC to inhibit the TMS320C30 from accessing a portion of the dual-port RAM, or some other shared resource.

The dual-port RAM features a fast access time, and both ports are completely independent of each other. This means that the activity on the left port in no way slows the access time of the right port. Both ports are identical infunction to standard static RAMs and can be read from, or written to, at the same time with the only possible conflict arising from the simultaneous writing of, or a simultaneous READ/WRITE of, a nonsemaphore location. Semaphores are protected against such ambiguous situations and may be used by the system program to avoid any conflicts in the non-semaphore portion of the dual-port RAM.

Multiple processor sytems like the TMS320C30 Software Development Board can benefit from a performance increase by using these semaphores, which provide a lockout mechanism without requiring complex programming.

Software handshaking between processors offers the maximum in system flexibility by permitting shared resources to be allocated in varying configurations. The IDT71342 does not use its semaphore flags to control any resources through hardware, thus allowing the programmer to determine each flag's meaning.

## HOW THE SEMAPHORE FLAGS WORK

The semaphore logic is a set of eight latches which are independent of the dual-port RAM. These latches canbe used to pass a flag, or token, from one processor to the other to indicate that a shared resource is in use. The semaphores provide a hardware assist for a use assignment called "Token Passing Allocation." In this method, the state of a semaphore latch is used as a token indicating that a shared resource is in use. If the TMS320 wants to use this resource, it requests the token by writing a zero into the latch. The TMS320 then verifies its success in writing the latch by reading it. If it was successful, it proceeds to assume control over the shared resource. If it was not successful in writing a zero into the latch, it determines that the PC had set the latch first, is in posession of the token, and is using the shared resource. The

TMS320 can then either repeatedly inquire the status of the semaphore it requested, or it can remove its request for that semaphore by writing a one into its location. The TMS320 can then perform another task and occasionally attempt to gain control of the token via the set and test sequence. Once the PC has relinquished the token, the TMS320 can succeed in gaining control of the shared resource.

The semaphore flags are active low. A token is requested by writing a zero into a semaphore location, and is released when the same processor writes a one into that location.

The eight semaphore flags reside within the IDT71342 in a seperate memory space from the dual-port RAM. This address space is accessed by placing a low input on the $\overline{\text { SEM }}$ pin (which is used as a chip select for the semaphore flags), and using the other control pins (Address, $\overline{O E}$, and $R / \bar{W}$ ) as they would be used in accessing a standard static RAM. Each of the flags has a unique address which can be accessed by either side through address pins A0-A2. When accessing the semaphores, none of the other address pins has any effect.

When writing to a semaphore, only data pin D0 is used. If a low level is written into an unused semaphore location, that flag will be set to a zero on that side and a one on the other (see Table I). That location can now only be modified by the side showing the zero. When a one is written into the same location from the same side, the flag will be set to a one for both sides (unless a semaphore request from the other side is pending) and then can be written to by both sides. The fact that the side which is able to write a zero into a semaphore subsequently locks out writes from the other side is what makes semaphore flags useful in interprocessor communications. A zero written into the same location from the other side will be stored in the semaphore request latch for that side until the semaphore is freed by the first side.

When a semaphore flag is read, its value is spread into all data bits, so that a "set" flag reads as a one in all data bits and a flag containing a zero reads as all zeros. The read value is latched into one side's output register when that side's semaphore select ( $\overline{\mathrm{SEM}}$ ) and output enable ( $\overline{\mathrm{OE})}$ signals go active. This serves to disallow the semaphore from changing state in the middle of a read cycle due to a write cycle from the other side. Because of this latch, a repeated read of a semaphore in a test loop must cause either signal ( $\overline{\mathrm{SEM}}$ or $\overline{\mathrm{OE}}$ ) to go inactive, or the output will never change. This is not a concern in the TMS320C30 Software Development Board, since either bus' accesses to other memory locations between semaphore accesses inactivate both of these signals for a relatively long period no matter how tight of a loop is used to interrogate the device.

| FUNCTION | PC BUS DO-D7 LEFT | $\begin{gathered} \text { TMS320 } \\ \text { DO-D7 RIGHT } \end{gathered}$ | STATUS |
| :---: | :---: | :---: | :---: |
| No action | 1 | 1 | Semaphore free |
| PC writes "0" to semaphore | 0 | 1 | PC has semaphore token |
| TMS320 writes "0" to semaphore | 0 | 1 | No change. TMS320 has no write access to semaphore |
| PC writes "1" to semaphore | 1 | 0 | TMS320 obtains semaphore token |
| PC writes "0" to semaphore | 1 | 0 | No change. PC has no write access to semaphore |
| TMS320 writes " 1 " to semaphore | 0 | 1 | PC obtains semaphore token |
| PC writes "1" to semaphore | 1 | 1 | Semaphore free |
| TMS320 writes "0" to semaphore | 1 | 0 | TMS320 has semaphore token |
| TMS320 writes " 1 " to semaphore | 1 | 1 | Semaphore free |
| PC writes "0" to semaphore | 0 | 1 | PC has semaphore token |
| PC writes "1" to semaphore | 1 | 1 | Semaphore free |

Table 1. Example Semaphore Procurement Sequence

A sequence of WRITE/READ must be used to acquire a semaphore in order to guarantee that no system level contention will occur. A processor requests access to shared resources by attempting to write a zero into a semaphore location. If the semaphore is already in use, the semaphore request latch will contain a zero, yet the semaphore flag will appear as a one, a fact which the processor will verify by the subsequent read (see Table I). As an example, assume the PC writes a zero to the left port at a free semaphore location. On a subsequent read, the PC will verify that it has written successfully to that location and will assume control over the resource in question. Meanwhile, if the TMS320 attempts to write a zero to the same semaphore flag, it will fail, as will be verified by the fact that it will read a one from that semaphore during a subsequent read cycle. Had a sequence of READ/ WRITE been used instead, contention problems could have occurred during the gap between the read and write cycles.

It is important to note that a failed semaphore request must be followed either by repeated reads, or by writing a one into the same location to remove the semaphore request. The reason for this is easily understood by looking at the simple logic diagram of a semaphore flag shown in Figure 7. Two semaphore request latches feed into a semaphore flag. Whichever latch is the first to present a zero to the semaphore flag will force its side of the semaphore flag low, and the other side high. This condition will continue until a one is written into
the same semaphore request latch. Should the other side's semaphore request latch have been written to a zero in the meantime, the semaphore flag willflip over to the other side as soon as a one is written into the first side's request latch. The second side's flag will now stay low until its semaphore request latch is written with a one. From this it is easy to understand that, if a semaphore is requested and the processor which requested it no longer needs the resource, the entire system could hang up until a one is written into that semaphore request latch.

The critical case of semaphore timing is when both sides request a single token by attempting to write a zero into it at the same time. The semaphore logic is specially designed to resolve this problem. If simultaneous requests are made, the logic guarantees that only one side receives the token. If one side is earlier than the other in making the request, the first side to make the request will receive the token. If both requests happen at the same time, the assignment will be arbitrarily made to one side or the other.

One caution that should be noted when using semaphores is that semaphores alone do not guarantee that access to a resource is secure. As with any powerful programming technique, if semaphores are misused or misinterpreted a software error can easily happen. Code integrity is of the utmost importance when semaphores are used instead of hardware handshaking.


2694 drw 07
Figure 7. IDT71342 Semaphore Logic

Initialization of the semaphores is not automatic and must be handled via the initialization program at power-up. Since any semaphore which is written to a zero must be reset to a one, both the TMS320 and the PC must write a one into all semaphore locations at initialization to assure that the semaphores will be free when needed.

## USING SEMAPHORES - Some Examples

Perhaps the simplest application of semaphores is their application as resource markers for the IDT71342's dual-port RAM. Say the $4 \mathrm{~K} \times 8$ RAM was to be divided into two $2 \mathrm{~K} \times 8$ blocks, which were to be dedicated at any one time to servicing either the PC or the TMS320. Semaphore 0 could be used to indicate the side which would control the lower section of memory, and Semaphore 1 could be defined as the indicator for the upper section of memory.

To take aresource, in this example the lower 2 K of dual-port RAM, the PC could write then read a zero into Semaphore 0. If this task were successfully completed (a zero was read back, rather than a one), the PC would assume control of the lower 2K. Meanwhile, the TMS320 might attempt to perform the same function. Since the TMS320 was attempting to gain control of the resource after the PC, it would read back a one in response to the zero it had attempted to write into Semaphore 0 . At this point, the TMS320's software could choose to try and gain control of the second 2 K section by writing, then reading a zero into Semaphore 1. If it succeeded in gaining control, it would lock out the PC.

Once the PC was finished with its task, it would write a one to Semaphore 0, then may try to gain access to Semaphore 1. If Semaphore 1 was still occupied by the TMS320, the PC could remove its semaphore request and perform other tasks until it was able to write, then read a zero into Semaphore 1.

If the TMS320 performs a similar task with Semaphore 0, this protocol would allow the two processors to swap 2 K blocks of dual-port RAM with each other.

The blocks do not have to be any particular size and could even be of variable length, depending upon the complexity of the software using the semaphore flags. All eight semaphores could be used to divide the dual-port RAM or other shared resources into eight parts.

Semaphores are a useful form of arbitration in real-time DSP applications, when the PC must be locked out of a section of memory during a transfer, and the TMS320 cannot tolerate any wait states. With the use of semaphores, once the two processors had determined which memory area was "off limits" to the PC, both the PC and the TMS320 could access their assigned portions of memory continuously without any wait states. Both processors can access their assigned RAM segments at full speed.

Another application of semaphores is in the area of complex data structures. In this case, block arbitration is very important to the maintenence of data integrity. For this application one processor may be responsible for building and updating a data structure, which the other processor then reads and interprets. If the interpreting processor reads an incomplete data structure, a major error condition may exist. Therefore, some sort of arbitration must be used between the TMS320 and the PC. Software semaphores are a perfect fit. The building processoruses the semaphore to arbitrate for the block and to lock it once that processor is able to acquire the semaphore flag. This processor then is able to go in and update the data structure. When the update is completed, the semaphore and the corresponding data structure block are released. The interpreting processor then acquires the semaphore which allows it to come back and read the complete data structure, thereby guaranteeing consistency.

by John C. Mein, Field Applications Engineering

Synopsis: This tech note describes a simple technique to obtain additional interrupts from each side of a dual-port when expanding in width.

Many of today's dual- ports offer the capability of allowing one side to have an interrupt generated to the other side. This allows the signaling of messages such as data ready, data overflow, etc. This is a handy feature used quite often. IDT'S dual-ports offer two interrupts per part - one to each side when operated in standalone mode. When expanding in depth or width additional interrupts can be obtained-exactly how many more depends on how the expansion is accomplished.

A feature available in many dual-ports is depth expansion capability. One simply uses external address decoding to
select one of multiple dual-ports (usually all masters). An example of this scheme is offered by the IDT 70058 kx 8 dualport and shown in Figure 1.

This depth expansion results in two interrupts being available on either side. For side A to generate an interrupt to side $B$, side $A$ must write anything to location 1FFF (8191 decimal). This generates the interrupt to side $B$ which is cleared only by side $B$ reading the same location 1FFF. Side B can likewise generate an interrupt to side A-the only difference is the memory location is now 1FFE ( 8190 decimal). Another set of interrupts also resides at locations 3FFF (16383 decimal) and 3FFE (16382 decimal).


Figure 1. Depth Expansion of the IDT7005 8k x 8 Dual-Port

Figure 2 shows a typical system consisting of two $8 \mathrm{kx8}$ dual-ports expanded in width. Here one must be careful to have address arbitration done by only one chip (the master) and having the other chips (the slaves) follow the master. This is easily accomplished using separate master and slave chips (such as the IDT7130 and IDT7140) or on the newer chips such as the IDT7005/6 and IDT7024/25 by connecting the M/S pin appropriately. All address lines are tied in parallel and only one interrupt for each side (since the address mapping is the same for both chips) is used. The other interrupts are not connected.

However, when expanding in width, one can have extra interrupt lines (one per chip) generated by simply inverting any address line between the two (or more) dual-ports. As shown in Figure 3 we have inverted address line A12. The only item one needs to be careful about is to insure you correctly calculate the new address location for the additional interrupts. For this example, instead of the interrupts being at only 1FFF and 1FFE they are now also at FFF (4095 decimal) and FFE (4094 decimal). It would also be possible to map the interrupts to be contiguous in the address map (i.e. map them to be at FFE, FFF, 1000, and 1001).


2725 drw 02

Figure 2. Normal Width Expansion of the IDT7005 8k x 8 Dual-Port

Another way to accomplish this would be to separate the chip enables for each dual-port. Then, to enable an interrupt, just enable and write to the appropriate dual-port. The advantage of this technique is that no additional address decoding delay is inserted.

The same methodology can be applied to multiple width expansions. For instance, using a 7006 16kx8 dual-port for a 32
bit system (resulting in a 16kx32 memory) would result in four interrupts for each side for a total of 8 (compared with only two by the normal expansion method).

This tech note showed a simple way of obtaining more interrupts then normal when expanding in width. This is easily accomplished by inverting one or more of the address lines between the dual-ports.


2725 drw 03

Figure 3. Width Expansion with More Interrupts

# DESIGN GUIDELINES FOR CUSTOM MODULE PACKAGES 

## INTRODUCTION

IDT packaging technology includes the utilization of modules, in order to integrate several chip-level components into a single subsystem. The resulting packing density offers several user benefits:

1. Overall system space requirements may be substantially reduced.
2. Noise effects may be greatly reduced by the close prximity of components on a module.
3. High-speed circuit operation may be more readily achieved by the reduction of interconnect capacitance and distance.
4. Trouble-shooting and field service may be improved by the system partitioning into readily replaceable functions.
5. System enhancements may be offered as plug-in options with a minimum of board space allocation required.
The IDT Subsystems portfolio include numerous standard module products. However, it may be quite advantageous to consider the use of a custom module for a given application. In this case, the user should be familiar with IDT Subsystem design guidelines and limitations in order to determine if the resulting custom module design will meet their needs and if it can be properly manufactured.

## MODULE/COMPONENT MATERIAL CONSIDERATIONS

There are two different module materials available for use:

## FR-4 LAMINATE SUBSTRATES

It is a industry standard epoxy-glass multi-layer printed circuit board material. It is intended for commercial/industrial applications which do not have high temperature operating requirements. Plastic packaged components must be used on FR-4 modules, since the temperature coefficient of expansion of ceramic components do not match that of FR-4 material.

## CERAMIC SUBSTRATES

This substrate is a industry standard multi-layer co-fired ceramic material. This material is required for military grade products and for high-temperature applications. Ceramic is desirable for designs requiring the highest density since the packing density of components onto the substrate material is much higher with ceramic than with FR-4. It is possible to mount plastic components on ceramic modules, but this is generally not economically sensible.

## MODULE PACKAGE TYPES

IDT modules are available in a variety of standard module packages, in addition to other non-standard package. Custom packages or pin requirements are available upon request.

1. Dual In-line (DIP) - Figure 1.

Ceramic modules utilize sidebrazed pins, which do not extend onto the surfaces of the module substrate. As a result, both top and bottom surfaces of the module are available for component replacement. FR-4 material, on the other hand, requires the pins to wrap over the top and bottom surfaces for mechanical support. This reduces the available surface area (on both the top and bottom) for placement of components.
2. Quad In-line (QIP) - Figure 2.

These modules have two parallel rows of pins on each side of the module (i.e. 4 total rows), extending perpendicular to the plane of the module, like DIPs. Ceramic substrates uses sidebrazed pins for the outer row of pins and bottom brazing for the inner row (L-shaped pins permit this). FR-4 substrates requires pins to be attached through the plane of the module.
3. Hex In-line (HIP) - Figure 3.

These modules have 3 parallel rows of pins on each side of the module (i.e. 6 total rows), extending perpendicular to the plane of the module, similar to DIPs. Ceramic material uses bottom brazed pins while FR-4 requires the pins to be attached through the plane of the module.
4. Single In-line (SIP) - Figure 4.

These modules have a single line of pins which extend out in parallel to the plane of the substrate, rather than perpendicular. Ceramic substrate SIP pins are attached to the one surface only, and hence, do not impact usable surface area on the other side. FR-4 substrates, however, requires pin attachment on both surfaces and this reduces available area.
5. Dual SIP (DSIP) - Figure 5.

These modules have two parallel rows of pins which extend out in parallel to the plane of the substrate, similar to SIPs. Both ceramic and FR-4 substrates require the use of some surface area on both sides for pin attachment to the module.
6. Zig-zag In-line (ZIP) - Figure 6.

These modules have two parallel rows of pins which extend out in parallel to the plane of the substrate, similar to DSIPs. However, each side is offset relative to the other side. For the case of standard 0.100 " pinto pin spacing (on one side), the opposite side will be offset by 0.050 " but still maintain $0.100^{\prime \prime}$ pin to pin spacing on its own side.
7. Single In-line Memory Module (SIMM) - Figure 7.

These modules use industry standard edge connectortype pins to be used with card edge sockets. These substrates are made exclusively with FR-4.
8. Pin Grid Array (PGA) - Figure 8.

These modules use industry standard through hole grid array formats necessary for high pin count designs. PGAs are made exclusively with ceramic substrates.


Figure 1(a). Ceramic DIP


Figure 1(b). FR-4 DIP


Figure 2(a). Ceramic QIP

TOP VIEW


Figure 2(b). FR-4 CIP


Figure 3(b). FR-4 HIP


Figure 4(a). Ceramic SIP


Figure 4(b). FR-4 SIP

FRONT/BACK VIEW


END VIEW


Two rows of pins

Figure 5(a). Ceramic Dual-SIP

## FRONT/BACK VIEW



Figure 5(a). FR-4 Dual-SIP


Figure 6. FR-4 ZIP


Pin 1


BACK VIEW

Figure 7. FR-4 SIMM


Figure 8. Ceramic PGA


Figure 9. Illustration of Minimum Spacing Distances


Flgure 10. Illustration of Decoupling Capacitors on Module

## SURFACE ARE LIMITATIONS FOR PIN ATTACHMENT

The module sustrate type determines the method of pin attachment, as outlined in the previous section. The method of pin attachment, therefore, may impact the amount of available surface space for components on the top and bottom surfaces.

Ceramic DIPs do not have any usable surface area restrictions, since the side-brazed pins do not extend onto the module surface area. FR-4 DIPs require that $0.100^{\prime \prime}$ from the edge of the module be unavailable for components (on both sides of the module). This results because the module pins extend through both sides of the module and therefore take away some surface area.

Ceramic SIPs, due to the side-brazed pins, require the same 0.100" margin on the surface of the module to which the pins are attached. The other side has no such constraint. FR4 SIPs require $0.100^{\prime \prime}$ margin on both sides, since the pins are attached on both sides.

Dual SIPs, ZIPs, and SIMMs require 0.100" margins on both sides to accomodate the pins. This holds for both ceramic and FR-4 modules.

Ceramic QIPs have no top side restrictions for pin attachment, but have a constraint on the bottom side of $0.100^{\prime \prime}$. FR4 QIPS use pins which go through the module material and this imposes constraints on both sides. The restriction inhibits any component from being located within 0.225 " of the edge of the module on which the pins are located.

Ceramic HIPs have no top side restrictions but require $0.250^{\prime \prime}$ of margin on the bottom. FR-4 HIPs require $0.350^{\prime \prime}$ margin on both the top and bottom of the module.

PGAs have not top side restrictions; however, the bottom side is used exclusively for pin attachment. In certain cases, there may be a small bottom area available for component placement but this area is usually only large enough for logic or passive type component packages.

## COMPONENT SPACING LIMITATIONS

The space required between components on a module is the same forboth ceramic and FR-4 substrates. The minimum space between any two components on a module is $0.050^{\prime \prime}$. Figure 9 illustrates this as dimension D1. Note that if pins extend out from the body of a component package (as shown for the components of Figure 9), then the spacing required is the space starting from the ends of those pins. On the other hand, if the component pins are under the component package, then the space is merely the space between the component package bodies.

Each component on a module, regardless of the substrate type, must be at least $0.025^{\prime \prime}$ from the edge of the module, as shown by dimension D2 in Figure 9.

## DECOUPLING CAPACITORS

The inclusion of decouping capacitors is dependent upon the expected current surges on the module, as well as the general speed of the devices (higher speed devices generally
need more decoupling). It is recommended that decoupling capacitors be liberally used. Typical applications usually employ 1 decoupling capacitor for each memory component and 1 for ever 1.5 logic components on the module.

Each decoupling capacitor may be treated as any other component, in terms of its requirement for spacing from other components or module edges. The physical size of standard decoupling capacitors is $0.080^{\prime \prime}$ by $0.200^{\prime \prime}$ and the typical value is $0.068 \mu \mathrm{~F}$. Figure 10 illustrates module dimensions with capacitors included.

## OVERALL MODULE DIMENSIONS

Module length is constrained by the number of pins on the sides of the module or by component package area requirements, which ever is greater. The pin pitch (center-to-center spacing) is normally standardized at $0.100^{\prime \prime}$, but may be customized to any user-specific value. To a first-order approximation, the number of pins and their pitch determine the module length.

Module width, although variable, is best kept to standard dimensions. This eases the requirements placed upon sockets for testing, bum-in and even for final systemuse. Standard widths for high pin count modules are those widths which are multiples of $0.300^{\prime \prime}$. Common usage has been found for widths of $0.3,0.6,0.9,1.2$, and 1.5 inches.

Let us illustrate how to approximate a custom modules' dimensions with a short example.

A customer wants a custom static RAM module meeting these specifications:
a) $256 \mathrm{~K} \times 8$ memory configuration
b) using $32 \mathrm{~K} \times 8$ LCC components
c) ceramic SIP package type
d) standard $0.100^{\prime \prime}$ pin pitch

The number of necessary pins for this module would be 33 ( 18 address inputs, 8 data $/ / \mathrm{O}, 2 \mathrm{Vcc}, 2$ GND, 1 output enable, 1 chips select, and 1 write enable).

## CASE 1 - Assumption: Components Single Sided Surface

 Mounted.Shown below are calculations which will show that the area required for component placement on one side of the module are greater than (\# of required pins) $\times$ (pin pitch). Therefore, the overall dimensions of the module are determined by the area requirements of the components. Rough dimensions of the module in this case would be (also reference Figure 11):

$$
\begin{aligned}
\text { Length }= & 2\left(0.025^{\prime \prime}\right)+8\left(0.460^{\prime \prime}\right)+\left(0.360^{\prime \prime}\right)+4\left(0.080^{\prime \prime}\right)+ \\
& 12\left(0.050^{\prime \prime}\right) \\
= & 5.01 \text { inches } \\
\text { Height }= & \left(0.100^{\prime \prime}\right)+\left(0.560^{\prime \prime}\right)+\left(0.025^{\prime \prime}\right) \\
= & 0.685 \text { inches }
\end{aligned}
$$

CASE 2 - Assumption: Components Double Sided Surface Mounted.

Shown below are calculations which will show that the area required for component placement on both sides of the module are greater than (\# of required pins) $\times$ (pin pitch). Therefore, the overall dimensions of the module are determined by the area requirements of the pins. Rough dimensions of the module in this case would be (also reference Figure 12):
(Length determined by components)
Length $=2\left(0.025^{\prime \prime}\right)+4\left(0.460^{\prime \prime}\right)+\left(0.360^{\prime \prime}\right)+6\left(0.050^{\prime \prime}\right)+2\left(0.080^{\prime \prime}\right)$ $=2.71$ inches
Height $=\left(0.100^{\prime \prime}\right)+\left(0.560^{\prime \prime}\right)+\left(0.025^{\prime \prime}\right)$

$$
=0.685 \text { inches }
$$

(Length determined by the pins)
Length $=(33$ pins $) \times(0.100 " / p i n)+2\left(0.025^{\prime \prime}\right)$
$=3.350$ inches
Height $=\left(0.100^{\prime \prime}\right)+\left(0.560^{\prime \prime}\right)+\left(0.025^{\prime \prime}\right)$ $=0.685$ inches


FRONT VIEW

Figure 11. Single Sided Surface Mounted SIP Module


BACK VIEW

Figure 12. Double Sided Surface Mounted SIP Module

## SUMMARY

The guidelines outlined in this document are intended to assist in the preliminary feasibility design of custom modules. The dimensions for inter-component and pin-component spacing are based on IDT Subsystem's standard design rules. For applications requiring smaller module spacing, tighter de-
sign rules can be considered, although we recommend staying with our extensively characterized standard design rules. Contact your IDT Sales Representative for additional detailed information regarding IDT custom modules.

> OPERATION MODES OF THE DUAL-PORT RAM (SHARED MEMORY MODULE)

APPLICATION
NOTE
AN-74

## INTRODUCTION

It is becoming increasingly common for systems to incorporate two or more processors in a system, and for those processors to share a block of memory. Shared memory is oftenused for interprocessor communications, data buffering, or to reduce the memory requirements when both processors share data or code. Another application is processor/peripheral interfaces.

A common implementation of shared memory is with true dual-portedstatic RAMs. Another is to place standard dynamic or static RAM on a bus and have the processors arbitrate for access to that memory. Dual-port RAMs have the advantage over shared single-port memory of higher data transfer rates because dual-port RAMs allow simultaneous access to the two ports, and handle arbitration much more efficiently than through bus protocols. Each processor accesses the dual port as a conventional static RAM, with no knowledge of accesses on the other port except in certain cases when the two processors access the same address simultaneously. Disadvantages of dual-port RAMs are reduced density and higher cost relative to standard SRAMs. But if a system designer uses standard RAMs, he must either arbitrate for a bus, or design his own arbitration logic.

As an extension to our dual-port RAM and memory module product lines, we have developed a family of dual-ported modules, based on standard SRAMs, that we call Shiared Memory Modules (SMM). The SRAMs are combined on the module with custom circuits which implement the arbitration and multiplexing functions. Because of this combination, the SMM provides the same simple asynchronous interface as conventional dual-port RAMs, while achieving high densities at low cost.

To demonstrate its functionality and performance, we will examine in detail one of IDT's Shared Memory Modules, the IDT7MB6036.

The IDT7MB6036 is a $128 \mathrm{~K} \times 16$ Dual-Port RAM Shared Memory Module. It has three possible modes of operation: Stand Alone, Width/Depth Expansion, or Dedicated Slave Modes.

## STAND ALONE OPERATION

The SMM is a natural in cases of multiprocessor communication in the absense of a traditional arbitrated bus, and where a large amount of shared memory must fit into a limited area. To implement the same arbitration and multiplexing logic discretely would consume considerable board space and a large number of devices, as well as design time.

Although only one of the two ports can access a SMM at a given time, any processor that is unable to obtain access is notified by a $\overline{B U S Y}$ signal which is used to generate wait states until the memory becomes available. This is functionally the same as with true dual-port RAMs. The only difference is that it may occur more frequently in the SMM. But even this may not result in a performace penalty since the most common use of shared memory is for block exchanges. In this case, one side does not attempt to read the memory until the other side has finished writing a block of data into it, and simultaneous accesses of the shared memory are rarely attempted. Furthermore, if very large blocks are being transfered, improved performance may be possible with the SMM because space and cost constraints permit a larger memory than with dualport RAMs, and hence more efficient block moves.

The arbitration permits access to the memory on only one of the two ports at a time, and is based on chip select ( $\overline{\mathrm{CS}}$ ) input signals. Although data strobes ( $\overline{\mathrm{DS}})$ on the wider modules function as byte-wide chip selects, they are not included in the arbitration. The first side to assert its $\overline{\mathrm{CS}}$ is granted access. When $\overline{C S}$ is asserted on the other side, $\overline{B U S Y}$ is asserted on that side, and access is not granted. When the first side deasserts chip select, the second side is then granted access and $\overline{B U S Y}$ is deasserted. If both processors attempt access at the same time, the arbitration logic will permit access to only one side, although it not possible to predict which port that will be. Figure 1 shows the fundamental connections of a SMM to two processors in a Stand Alone Mode.

Apart from $\overline{B U S Y}$, this arbitration circuitry introduces only two special timing parameter. At the start of a write cycle, the assertion of $\overline{D S}$ (or $R \bar{W}$, whichever is asserted later) must not occur until a maximum time (tCDS) after $\overline{\mathrm{CS}}$ is asserted. This allows time for the arbitration to be performed and the address multiplexer to stabilize before the write pulse to the SRAMs is generated. Address multiplexer switching time is also required when access switches from one port to the other as indicated by $\overline{B U S Y}$ going inactive on a port that has been waiting to write. By waiting tBDS after $\overline{B U S Y}$ goes inactive before initiating the write with $\overline{\mathrm{DS}}$ (or $\mathrm{R} / \overline{\mathrm{W}}$ ), the address is allowed time to settle.

The preceding description of arbitration logic assumes that the SMM is operating in Master mode, as determined by the Master/Slave pin(M/S). This is the standard mode of operation when a single module is being used, or when multiple modules are expanded in depth. The SMM may also be configured in a Slave mode, which is similar but not identical to dual-port RAM slave operation. The slave mode is useful for width expansion of the modules, and for forcing priority to one port or the other.


2737 drw 01
Figure 1. Stand Alone Configuration

## WIDTH/DEPTH EXPANSION

When inSlave mode, the SMM does not perform arbitration, but instead depends on inputs from an external source. In width expansion (see Figure 2), a single master module is teamed with the necessary number of slave modules to achieve the desired system data width. The master performs the arbitration and transmits the results to the slave(s). This
prevents "Busy Lock-out" which could result if multiple masters disagreed on which port to grant access.

In addition to the left and right $\overline{B U S Y}$ output signals, the master also drives SEL_OUT and $1 / \bar{R}$ _OUT signals. SEL_OUT indicates that a port is actively being accessed, and L/ $\bar{R}$ _OUT indicates which port it is. On the Slave configured device, the $\overline{B U S Y}$ pins become inputs with different names. L_BUSY on


2737 drw 02
Figure 2. Width Expansion Conflguration
the slave becomes $L \overline{\mathrm{R}} \quad \mathbb{N}$ and is connected to $L \overline{\mathrm{R}}$ - $\odot U T$ on the master, while R_BUSY on the slave becomes SEL_IN and is connected to SEL_OUT on the master. Since these pins determine which port is granted access, the chip select pins on slave devices are ignored.

Master/slave combinations also mandate additional timing considerations. The read delay from the assertion of $\overline{C S}$ is increased by $\operatorname{LLR}$ ( $=\mathrm{tSEL}$ ). During writes, tCDS and tBDS must also be increased by tLR.

Depth expansion of the SMM is no different from SRAMs. Every module is configured as a master, and the additional address bits are decoded to drive the $\overline{C S}$ of each. $L \bar{R}$ OUT and SEL_OUT are left unconnected. All remaining signals, including BUSY are tied together between all modules.

## DEDICATED SLAVE OPERATION

Another important use of the Slave mode is to temporarily grant memory access to one processor exclusively. While the SMM is normally be operated in a mode that gives equal priority to either side, it may also be necessary for one processor to perform a burst read or write without interruption by the other processor. This may be achieved by switching the shared port module from master to slave mode, and asserting SEL_IN and $\overline{\operatorname{R}}$ _IN so as to permit access by only this one side. Upon completion of these accesses, the SMM is set back to Master mode and normal (equal priority) operation is resumed. This mode of operation is shown in Figure 3.

Now that we are more familiar with the functional operation of the SMM, we can discuss some of the design and performance trade-offs associated with IDT's SMM.


2737 dw 03
Figure 3. Dedicated Slave Configuration

## PERFORMANCE/TIMING COMPARISONS

Let's analyze the performance trade-offs of shared memory functionality by comparing timing differences between two possible solutions, dual-port modules and Shared Memory modules.

For this example we will examine the 70 ns versions of the IDT7M135 ( $16 \mathrm{~K} \times 8$ ) Dual-Port Module (DPM) and the IDT7MB6036 (128K x 16) Dual-Port Shared Memory Module (SMM) for various read, write and busy situations.

## SITUATION \#1: Non-contention Read Cycle

This is a condition when both ports do not simultaneously access the same memory cell for the DPM or when both ports simultaneously access any memory cell for the SMM.

|  | IDT7M135 | IDT7MB6036 |
| :--- | :--- | :--- |
| thC | 70ns (min.) | 70ns (min.) |
| tAA | 70ns (max.) | 70ns (max.) |
| taCs | 70ns (max.) | 70ns (max.) |
| toE | 40ns (max.) | 37ns (max.) |
| toH | 5ns (min.) | 5ns (min.) |
| tcLz | 10ns (min.) | N.A. |
| tCHz | 35ns (max.) | N.A. |
| toHz | 30ns (max.) | 7.5ns (max.) |
| tolz | 5 ns (min.) | 8 ns (min.) |
| tPU | 5ns (min.) | N.A. |
| tPD | 5ns (max.) | N.A. |

Both modules have almost the same timing parameters for a non-contention read cycle except for the output parameters $t C L Z, t C H z$, and tOHz or the power on/off parameters tPu and tPD. tCLZ, tCHZ, tPU and tPD parameters are not specified for the SMM because it is not applicable to its operation. However, toHz-the time in which the output drivers hold onto the data outputs is different between the modules due to the fact that the SMM data outputs come via a logic component, the on-board Data Mux, while the DPM data outputs come via a memory cell. This turns out to be a relatively minor difference unless there is concern with the impedance state of the data bus after the read cycle has already occurred.

## SITUATION \#2: Non-contention Write Cycle

This is a condition when both ports do not simultaneously access the same memory cell for the DPM or when both ports simultaneously access any memory cell for the SMM.

|  | IDT7M135 | IDT7MB6036 |
| :---: | :---: | :---: |
| twc | 70ns (min.) | 70ns (min.) |
| tcw | 60ns (min.) | 60ns (min.) |
| taw | 60ns (min.) | 60ns (min.) |
| tAS | Ons (min.) | Ons (min.) |
| twp | 45ns (min.) | tDS 35ns (min.) |
| twR | 5 ns (min.) | $5 \mathrm{~ns} \mathrm{(min)}$. |
| - tDW | 30ns (min.) | 30ns (min.) |
| tDH | 10ns (min.) | 5 ns (min.) |
| tohz | 35ns (max.) | N.A. |
| tWHZ | 35ns (max.) | N.A. |
| tow | Ons (min.) | N.A. |

Again, both modules have almost the same timing parameters for this situation. The few exceptions are the output parameters $\mathrm{tOHZ}, \mathrm{tWHz}$, and tow which are not specified on the SMM at all. Just like the Read Cycle, this omission turns out to be relatively minor unless there is concern with the impedance state of the data bus after the write cycle has already occurred.

## SITUATION \#3: Contention Read/Write Cycle

This is the condtion where both ports simultaneously access the memory cell or array.

|  | IDT7M135 | IDT7MB6036 |  |
| :--- | :--- | :--- | :--- |
| tBAA | 45ns (max.) | tCB | 15ns (max.) |
| tBDA | 45ns (max.) | tCB | 15ns (max.) |
| tBAC | 40ns (max.) | tCB | 15ns (max.) |
| tBDC | 35ns (max.) | tCB | 15ns (max.) |
| tBDD | 50ns (max.) | tCB | 70ns (max.) |
| twDD | 90ns (max.) | tBD | 70ns (max.) |
| tDDD | 70ns (max.) | tBD | 70ns (max.) |
| tAPS | 10ns (min.) |  | N.A. |

It is during contention situations where the major differences between the DPM and the SMM occur.

Both the DPM and the SMM modules will arbitrate between ports based on either $\overline{\mathrm{CS}}$ or address signals matching. Next, both will select the losing port by asserting its' corresponding $\overline{B U S Y}$ flag. The first difference occurs during this operation. The SMM uses much less time (tCB) than the DPM (tBAA or tBAC) for the arbitration logic to decide which port "lost" and then to assert the respective $\overline{B U S Y}$ flag. The SMM has a $30-$ $35 n s$ advantage over the DPM during this operation.

Another difference between the DPM and the SMM is the time it takes the "losing" port to complete a Read or Write Cycle after the matching $\overline{\mathrm{CS}}$ or address situation becomes False. For the SMM Read/Write Cycle it takes:
$\mathrm{tcB}+\mathrm{tBD}=15 \mathrm{~ns}+70 \mathrm{~ns}=85 \mathrm{~ns}$ (READ DATA OUTPUTVALID) $\mathrm{tcB}+\mathrm{tBDS}=15 \mathrm{~ns}+10 \mathrm{~ns}=25 \mathrm{~ns}$ (WRITE CYCLE INITIATED).
For the DPM Read/Write Cycle it takes:
tBDA + tBDD $=45 \mathrm{~ns}+50 \mathrm{~ns}=95 \mathrm{~ns}($ READ DATA OUTPUT VALID) or
tBDC + tBDD $=35 \mathrm{~ns}+50 \mathrm{~ns}=85 \mathrm{~ns}($ READ DATA OUTPUT VALID)
$\mathrm{tBDA}+\mathrm{twH}=45 \mathrm{~ns}+20 \mathrm{~ns}=65 \mathrm{~ns}$ (WRITE CYCLE INITIATED) or
$\mathrm{tBDC}+\mathrm{twH}=35 \mathrm{~ns}+20 \mathrm{~ns}=55 \mathrm{~ns}$ (WRITE CYCLE INITIATED).
Again we see the SMM has a $0-10 \mathrm{~ns}$ advantage over the DPM when reading valid data after a BUSY condition and a $30-40 \mathrm{~ns}$ advantage for the Write Cycle to be initiated after a BUSY condition.

The performance/timing advantages above show the SMM is faster than the DPM during BUSY arbitration situations and for read/write cycles after contention. However, keep in mind statistically $\overline{B U S Y}$ arbitration situations may arise an equal amount of times for the DPM as for the SMM but contention situations will not occur an equal amount of times. Because the DPM is truly dual-ported, contention will only occur when both ports access the same exact memory cellout of the entire memory array at the same time. The probability of this situation is small. On the other hand, the SMM has contention when one port controls the entire memory array and the opposite port accesses any location in the memory array (and thus will receive a $\overline{B U S Y}$ flag). The probability of this situation occuring is quite large by nature of the SMM's basic internal logic structure. This is especially true for applications where both ports are operating at relatively high speeds. So, although the SMM executes contention situations faster than the DPM, it is the greater number of times in which contention situation occurs which may put it at a disadvantage relative to the DPM.

This disadvantage, however, may be inconsequential when we look at the next performance trade-off, the much greater memory densities one can realize using SMM than by using DPM. The SMM is available in greater memory sizes because it uses standard high density SRAMs and logic while the DPM must use smaller density dual-port components. Another performance trade-off to think about is the associated
cost of implementing SMM vs. DPM solutions, dual-port components being harder to build and thus relatively more expensive than SRAMs.

Taking into account these various trade-offs associated with Dual-Port Modules and Shared Memory Modules, a natural division as to which module is the best solution for a specific application does become apparent. For those applications where;
a) high-speed operation of one or both ports is required, or
b) contention situations occur frequently but speed here is not a major factor, or
c) price/memory density are not major factors, then the Dual-Port Module is the product of choice. For those applications where;
a) medium/slow speed operation of one or both ports is required, or
b) contention situations occur infrequently (either statistically or via external software/hardware controls), or
c) price/memory density are major factors, then the Shared Memory Module is the product of choice.

For the sake of completeness, we would like to mention there are other ways to implement shared memory function-ality-ASICs, PALs, interleaving RAMs, and DRAMs + DRAM controllers to name a few. But for those high-performance applications which would like to take advantage of high speed, low power CMOS products IDT's Dual-Port and Shared Memory Modules do fit well into a wide range of hardware applications.

USING THE IDT7M4017 MODULE IN 8-BIT AND 16-BIT WIDE ORGANIZATIONS

APPLICATION NOTE
AN-75

## INTRODUCTION

The IDT7M4017 is a 2 megabit high-speed static RAM module constructed on a co-fired ceramic substrate using eight $32 \mathrm{~K} \times 8$ static RAM components in leadless chip carriers. The module is offered as a 60-pin sidebraze DIP allowing it to be used as a $64 \mathrm{~K} \times 32$ memory block (see IDT7M4017 datasheet). However, because the module is internally organized into fourblocks with separate chip selects, it is more versatile and can easily be configured as a $256 \mathrm{~K} \times 8$ or 128 K $x 16$ by simply decoding the four chip selects.

## 256K x 8 ORGANIZATION

Using the IDT7M4017 along with an IDT54/74FCT139 decoder device allows the user to choose to configure the module as a $256 \mathrm{~K} \times 8$ memory block (see Figure 1). The two upper order address bits A16 and A17 are used as inputs to the decoder to select one of the four outputs that will drive the module chip selects. The data lines are connected together as shown in the diagram to create a single 8-bit data bus. The two write enables on the module are connected together to allow write access to all banks with one signal.

## 128K x 16 ORGANIZATION

In similar fashion, the IDT7M4017 can be configured as a $128 \mathrm{~K} \times 16$ memory block (see Figure 2). The upper order address bit, A16, is used as an input to the decoder to select one of two outputs that each drive two of the four module chip selects. In this case, the data lines are connected together as shown in the diagram to create two separate 8-bit data buses that are read simultaneously. The write enables can be kept separate to allow byte-access capability on the 16-bit bus. Note that the user's chip select should be connected to the enable on the decoder.

## CONCLUSION

The IDT7M4017 module offers a variety of advantages to the circuit designer. One module can be used for multiple word-width applications (8-bit, 16-bit, 32-bit) with many memory depths from 64 K to 1 M . In addition, it incorporates the high density advantage of surface mount technology in a throughhole package. It guarantees a higher performance 2 M -bit memory block by integrating critical components and interconnects on a small substrate. Finally, the module solution saves on overall system cost by providing designers with a tested functional block with the added advantages of manufacturing ease, reduced troubleshooting, and faster time-to-market.

## FUTURE ORGANIZATIONS

The two no-connects on the IDT7M4017 (pins 36 and 37) are actually upper order address bits that are internally routed to provide an upgrade path for users who will require more memory in their system. The module can be populated with eight IDT71024 128K $\times 8$ static RAM components in leadless chip carriers to yield $256 \mathrm{~K} \times 32,512 \mathrm{~K} \times 16$ and $1 \mathrm{M} \times 8$ module organizations.


2701 drw 01

Figure 1. $256 \mathrm{~K} \times 8$ Organization


Figure 2. 128K $\times 16$ Organization

Integrated Device Technology, Inc.

USING THE IDT7MB6049 CACHE MODULE WITH THE IDT79R3000 RISC PROCESSOR IN SINGLE OR MULTIPROCESSOR SYSTEMS

APPLICATION NOTE
AN-76

## by Kelly Mass

The IDT7MB6049 is a complete cache module for the IDT79R3000 RISC processor and is designed for both singleand multi-processor systems. It has two banks of SRAMs, each configured as $16 \mathrm{~K} \times 60$, and each with address latches. One bank is used to cache instructions, the other to cache data. They share a data bus, allowing one bank to be accessed at a time.

Use in multi-processor systems, is facilitated by a second address bus and an additional set of latches for that bus. This bus is used in multi-processor applications to latch an address from a source other than the R3000. This allows the system to invalidate entries in the data cache in conjunction with the R3000. This is done in order to maintain cache coherency. The set of address latches for the instruction cache is included in the module for symmetry, although normally no invalidations are done to the instruction cache. Instruction cache invalidation would require cache swapping, but only datacache invalidation is described below.

When the system wants to invalidate an entry in the data cactie, it forces the R3000 into an MP Stall by asserting CpCond(3). During the one clock cycle that it takes for the processor to enter the MP Stall, it is the responsibility of the system to disable the output of the latch which supplies the processor's address to the data cache, and enable the output of the latch which supplies the invalidate address. The module pins $\overline{\mathrm{P} 10 \mathrm{E}}(1)$ and $\overline{\mathrm{P} 2 \mathrm{OE}}(1)$ are used for this purpose. It is important that they should never be activated simultaneously since the outputs of the latches are tied together. The same applies to $\overline{\mathrm{P} 10 \mathrm{E}}(2)$ and $\overline{\mathrm{P} 2 \mathrm{OE}}(2)$ for the instruction cache. Both address latches for the data cache are normally clocked by the same DCIk signal from the R3000 through the P1LE(1) and P2LE(1) pins of the 7MB6049.
Once the processor is in MP Stall, it strobes $\overline{\text { DRd }}$ while CpCond(2) is unasserted, allowing the system to read the contents of the cache. The actual invalidation of the data cache entries begins when the system asserts $\mathrm{CpCond}(2)$ and provides the appropriate invalidate address. $\mathrm{CpCond}(2)$ causes the R3000 to output an invalid bit and strobe DWr. Multiple invalidations are performed by keeping $\mathrm{CpCond}(2)$ and (3) asserted, and changing the invalidate address. Note that the invalidate address timing must be consistent with the processor timing. One suggestion is that the invalidate address input of the module be driven by a register that is clocked by SysOut.

The IDT7MB6049 has two chip select ( $\overline{\mathrm{CS}}$ ) signals. Both
of these should be grounded if the cache is not depth expanded. The four output enable ( $\overline{\mathrm{OE}}$ ) and four write enable (WE) signals are split evenly between the data and instruction cache: (1-2) control the data cache, and (3-4) control the instruction cache.
$\overline{\mathrm{OE}}(1-2)$ of the 7 MB6049 connect to the $\overline{\mathrm{DRd1}}$ and $\overline{\mathrm{DRd}}$ on the R3000. DRd1 and DRd2 are identical, and the load should be distributed evenly between them. Likewise, $\overline{\mathrm{OE}}(3-4)$ connect to $\overline{\overline{\mathrm{RD}} 1}$ and $\overline{\mathrm{IRd} 2, ~ \overline{W E}(1-2) ~ c o n n e c t ~ t o ~} \overline{\mathrm{DWr}}$ and $\overline{D W r 2}$, and $\overline{W E}(3-4)$ connect to DWr1 and DWr2.

The convention of the pin naming of the 7MB6049 is that P1 refers to the address from the R3000, and that P2 refers to the (invalidate) address from the system. Likewise, (1) refers to the data cache and (2) refers to the instruction cache. As shown in Figure 2, $\overline{\mathrm{P} 1 \mathrm{LE}}$ (1) and $\overline{\mathrm{P} 2 L E}(1)$ are typically connected together to DCIk since they latch addresses into the two data cache latches. $\overline{\text { P1LE }}(2)$ and $\overline{\text { P2LE }}(2)$ likewise are connected together to ICIk. P2LE(2) is not used if instruction cache invalidation is not performed.

Similarly, $\overline{\mathrm{P} 10 \mathrm{E}}$ (1) and $\overline{\mathrm{P} 10 \mathrm{E}}(2)$ are typically connected together so that the outputs of the two R3000 address latches are enabled anddisabledtogether, while $\overline{\mathrm{P} 2 \mathrm{OE}}(1)$ and $\overline{\mathrm{P} 2 \mathrm{OE}}(2)$ can together control the output of the invalidate address latches. $\overline{\mathrm{P} 2 \mathrm{OE}}(2)$ may be pulled continuously high if the instruction invalidate address latch is unused.

The 60 data I/O pins of the module are labeled $D(0)$ to $D(59)$. Although the ordering of the data and address pins of a RAM is normally arbitrary and can be ignored, that is not the case with the 7MB6049. Because of steps takento reduce the chip count and power consumption of the module, Tag(12)Tag(15) of the R3000 must connect to $D(36)-D(39)$ on the 7MB6049, and AdrLo(12)-AdrLo(15) of the R3000 must connect to $\mathrm{P} 1 \mathrm{~A}(10)-\mathrm{P} 1 \mathrm{~A}(13)$ on the $7 \mathrm{MB6049}$. The order in which the other I/O pins are connected is not critical. Table 1 shows recommended I/O pin connections betweenthe R3000 and 7MB6049.

| R3000 Signals |  | IDT7MB6049 Signals |
| :--- | :--- | :---: |
| Data | Data(0) - Data(31) | $D(0)-D(31)$ |
| Data Parity | DataP(0) - DataP(3) | $D(32)-D(35)$ |
| Tag | Tag(12) - Tag(31) | $D(36)-D(55)$ |
| Tag Parity | TAgP(0) $-\operatorname{TagP(2)}$ | $D(56)-D(58)$ |
| Tag Valid | TagV | $D(59)$ |

Table 1. Connection of Data and Tag Buses


2730 drw 01
Figure 1. Block Dlagram of the IDT7MB6049


2730 drw 02
Figure 2. Pin Connections of the IDT7MB6049

## DOMESTIC SALES

| ALABAMA | CANADA (EASTERN) | GEORGIA |
| :---: | :---: | :---: |
| IDT |  |  |
| 4930 Corporate Dr., Ste. 1 | Canadian Mktg. Tech. Inc. | IDT |
| Huntsville, AL 35805 | Mississauga, ONT | (SE Regional Office) |
| (205) 721-0211 | (416) 612-0900 | 1413 S. Patrick Dr., Ste. 10 Indian Harbor Beach, FL |
|  | Canadian Mktg. Tech. Inc. | 32937 |
| ALASKA | Pointe Claire, QUE (514) 694-6088 |  |
| Westerberg \& Associates |  |  |
| Bellevue, WA (206) 453-8881 | CANADA | HAWAll |
|  | (WESTERN) |  |
|  |  | IDT |
| ARIZONA |  | (Western Headquarters) |
|  | Bellevue, WA | 2972 Stender Way Santa Clara, CA 95054 |
| Western High Tech Mktg. Scottsdale, AZ (602) 860-2702 |  | (408) 492-8350 |
|  | COLORADO | N) |
| ARKANSAS | IDT |  |
|  | (NW Regional Office) | Westerberg \& Associates Bellevue, WA |
|  | $161617 \mathrm{th} \mathrm{St.}, \mathrm{Ste}$.370 Denver, CO 80202 | (206) 453-8881 |
| (S. Central Regional Office) 14285 Midway Rd., Ste. 100 | (303) 628-5494 |  |
|  |  |  |
| Dallas, TX 75244 (214) 490-6167 | Thorson Rocky Mountain | IDAHO (SOUTHERN) |
|  | Englewood, CO (303) 799-3435 | Westerberg \& Associates |
| CALIFORNIA |  | Portland, OR (503) 620-1931 |
|  | CONNECTICUT |  |
| IDT |  |  |
| (Corporate Headquarters)3236 Scott Blvd. | Lindso Associates | ILLINOIS |
|  | Woodbury, CT |  |
| P.O. Box 58015 | (203) 266-0728 | IDT |
| Santa Clara, CA |  | (Central Headquarters) |
| $\begin{aligned} & 95052-8015 \\ & \text { (408) 727-6116 } \end{aligned}$ |  | 1375 E. Woodfield Rd., |
|  | DELAWARE | Ste. 380 |
|  |  | Schaumburg, IL 60173 |
|  | IDT | (708) 517-1262 |
| (Western Headquarters) | (NE Regional Office) | Synmark Sales |
| Santa Clara, CA 95054 (408) 492-8350 | 428 Fourth St., Ste. 6 <br> Annapolis, MD 21403 | Park Ridge, IL (708) 390-9696 |
| IDT |  |  |
|  |  | INDIANA |
| 6 Jenner Dr., Ste. 100 Invine, CA 92718 | FLORIDA |  |
|  |  | Arete Sales |
| (714) 727-4438 | IDT <br> (SE Regional Office) | Ft. Wayne, IN (219) 423-1478 |
| IDT <br> (SW Regional Office) 16130 Ventura Blvd., Ste. 370 <br> Encino, CA 91436 <br> (818) 981-4438 | 1413 S. Patrick Dr., Ste. 10 |  |
|  | Indian Harbor Beach, FL | Arete Sales |
|  | 32937 (407) 773-3412 |  |
|  | (407) 773-3412 | (317) 882-4407 |
|  | IDT |  |
|  | (SE Regional Office) | W |
| Quest-Rep San Diego, CA (619) 565-8797 | 601 Cleveland St., Ste. 400 | IOWA |
|  | Clearwater, FL 34615 <br> (813) 447-2884 | Rep Associates Cedar Rapids, IA (319) 373-0152 |
|  | IDT |  |
|  | (SE Regional Office) |  |
|  | 1500 N.W. 49th St, |  |
|  | Ste. 500 |  |
|  | Ft. Lauderdale, FL 33309 |  |
|  | (305) 776-5431 |  |


| KANSAS | MISSISSIPPI |
| :---: | :---: |
| Rush \& West Associates | IDT |
| Olathe, KS | (SE Regional Office) |
| (913) 764-2700 | 1413 S. Patrick Dr., Ste. 10 |
|  | Indian Harbor Beach, FL |
|  | 32937 |
| KENTUCKY | (407) 773-3412 |
| Norm Case Associates |  |
| Rocky River, OH | MISSOURI |
|  | Rush \& West Associates |
|  | St. Louis, MO |
| LOUISIANA | (314) 965-3322 |
| IDT |  |
| (S. Central Regional Office) | MONTANA |
| 14285 Midway Rd., Ste. 100 |  |
| Dallas, TX 75244 | Thorson Rocky Mountain |
| (214) 490-6167 | $\begin{aligned} & \text { Englewood, CO } \\ & \text { (303) } 799-3435 \end{aligned}$ |
| MAINE |  |
|  | NEBRASKA |
| IDT |  |
| (Eastern Headquarters) | IDT |
| \#2 Westboro Business Park | (Central Headquarters) |
| 200 Friberg Pkwy., | 1375 E. Woodfield Rd., |
| Ste. 4002 | Ste. 380 |
| Westboro, MA 01581 (508) 898-9266 | Schaumburg, IL 60173 (708) 517-1262 |
| MARYLAND | NEVADA <br> (NORTHERN) |
| IDT |  |
| (NE Regional Office) | IDT |
| 428 Fourth St., Ste. 6 | (Western Headquarters) |
| Annapolis, MD 21403 (301) $058-5423$ | 2972 Stender Way |
| (301) 858-5423 | Santa Clara, CA 95054 (408) 492-8350 |
| MASSACHUSETTS |  |
|  | NEVADA |
| (Eastern Headquarters) | (SOUTHERN) |
| \#2 Westboro Business Park | Western High Tech Mktg. |
| 200 Friberg Pkwy., <br> Ste. 4002 | (Clark County, NV) |
| Westboro, MA 01581 <br> (508) 898-9266 | $\begin{aligned} & \text { Scottsdale, AZ } \\ & \text { (602) } 860-2702 \end{aligned}$ |
| MICHIGAN | NEW HAMPSHIRE |
|  | IDT |
| Farmington Hills, MI | (Eastern Headquarters) \#2 Westboro Business Park |
| (313) 553-3370 | 200 Friberg Pkwy., <br> Ste. 4002 |
| MINNESOTA | Westboro, MA 01581 (508) 898-9266 |

MISSISSIPPI
(SE Regional Office) 1413 S. Patrick Dr., Ste. 10 ndian Harbor Beach, FL 32937
(407) 773-3412

## MISSOURI

\& West Associates
St. Louis, MO
(314) 965-3322

## MONTANA

Thorson Rocky Mountain
Englewod, $\mathbf{1}$

## NEBRASKA

DT 1375 E Woodtiold Rd Ste. 380
Schaumburg, IL 60173
(708) 517-1262

NEVADA (NORTHERN)
(Western Headquarters) Stencer Way
Santa Clara, CA 95054
(408) 492-8350

## NEVADA

(SOUTHERN)
Western High Tech Mktg.
Clark County, NV
Scottsdale, AZ

## NEW HAMPSHIRE

(Eastern Headquarters)
\#2 Westboro Business Park
200 Friberg Pkwy.
Ste. 4002
(508) 898-9266

Edina, MI
(612) 932-2920


## IDT TECHNICAL CENTERS

Integrated Device Technology
(South Central Regional Office)
14285 Midway Road, Suite 100
Dallas, TX 75244
(214) 490-6167

Integrated Device Technology
(Eastern Headquarters)
\#2 Westboro Business Park 200 Friberg Parkway, Suite 4002
Westboro, MA 01581
(508) 898-9266

INTEGRATED DEVICE TECHNOLOGY, INC.
(European Headquarters/Northern Europe
Regional Office)
21 The Crescent
Leatherhead
Surrey, UK KT228DY
Tel.: 44-372-377375

AUTHORIZED DISTRIBUTORS
HALL-MARK
ELECTRONICS
HAMILTON/AVNET
INSIGHT
VANTAGE
ZENTRONICS
COMPONENTS

## INTERNATIONAL SALES



## SWEDEN

Svensk Teleindustri AB
Spanga, Sweden
Tel.: 46-8-761-7300

## SWITZERLAND

W. Stolz AG

Baden-Daettwil, Switzer-
land
Tel.: 41-56-849000
W. Stolz AG

Lausanne, Switzerland
Tel.: 41-21-274838

## TAIWAN

Johnson Trading Company
Taipei, Taiwan
Tel.: 886-273-31211
General Industries Inc.
Taipei, Taiwan
Tel.: 886-2764-5126

## UNITED KINGDOM

IDT
(European Headquarters/
Northern Europe Regional Office)
21 The Crescent
Leatherhead
Surrey, UK KT228DY
Tel.: 44-372-363339
Micro Call, Ltd.
Thame Oxon, England
Tel.: 44-84-261-939


[^0]:    1. Typical parameters are specified at $\mathrm{VEE}=-5.2 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and maximum loading.
[^1]:    BICEMOS is a trademark of Integrated Device Technology, Inc.

[^2]:    * "A" to be included for 7201 ordering part number only.

[^3]:    *Indudes jig and scope capabilities.

[^4]:    1. BiFIFO flags must be assigned to external flag pins to be observed. $D=$ FIFO depth (IDT72511 $=512$, IDT72521 = 1024), $n=$ Almost-Empty flag offset, $m=$ Almost-Full flag offset.
[^5]:    * Including scope and jig

[^6]:    NOTE:

    1. $\overline{\mathrm{CE}} \mathrm{L}=\overline{\mathrm{CE}}_{\mathrm{R}}=\mathrm{V}_{\mathrm{IL}}$
[^7]:    * Including scope and jig.

[^8]:    1. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only.
    2. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range only.
    3. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With BUSY (For Master IDT7132 only)".
    4. To ensure that the earlier of the two ports wins.
    5. teDD is a calculated parameter and is the greater of 0 , twDD-twP (actual) or tDDD-tDw (actual)
    6. To ensure that the write cycle is inhibited during contention.
    7. To ensure that a write cycle is completed after contention.
    8. " $x$ " in part numbers indicates power rating (SA or LA).
    9. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With Port-to-Port Delay (For Slave IDT7142 Only)".
    10. Not available in DIP packages - see $7032 / 7042$ data sheet.
    11. DIP packages for $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range only - see $7032 / 7042$ data sheet.
[^9]:    * Including scope and jig.

[^10]:    NOTES:

    1. $R \bar{W}$ is high for Read Cycles.
    2. Device is continuously enabled, $\overline{\mathrm{CE}}=\mathrm{VIL}$.
    3. Addresses valid prior to coincident with $\overline{\mathrm{CE}}$ transition low.
    4. $\overline{O E}=V I L$.
[^11]:    NOTES:

    1. Port-to-port delay through RAM cells from writing port to reading port; refer to "Timing Waveform of Read With $\overline{B U S Y}(M / \bar{S}=H)$ ".
    2. To ensure that the earlier of the two ports wins.
    3. tBDD is a calculated parameter and is the greater of 0 , tWDD - tWP (actual) or tDDD - tDW (actual).
    4. To ensure that the write cycle is inhibited during contention.
    5. To ensure that a write cycle is completed after contention.
    6. " $x$ " is part numbers indicates power rating ( S or L ).
    7. Port-to-port delay through RAM cells from writing port to reading port, refer to "Timing Waveform of Read With $\overline{\mathrm{BUSY}}(\mathrm{M} / \overline{\mathrm{S}}=\mathrm{L})$ ".
[^12]:    1. No arbitration in IDT7M144/IDT7M145 (SLAVE): $\overline{\text { BUSY }}$ in inhibits write in IDT7M144/IDT7M145.
[^13]:    CEMOS is a trademark of Integrated Device Technology, Inc.

[^14]:    1． $\operatorname{tRSC}=\mathrm{tRS}+\mathrm{tRSR}$
    2． $\bar{W}$ and $\overline{\mathrm{R}}=\mathrm{V} I H$ during RESET．

[^15]:    PIN CONFIGURATION ${ }^{(1)}$
    FUNCTIONAL BLOCK DIAGRAM

    | NC - | 1 | 32 | $\square \mathrm{Voc}$ |
    | :---: | :---: | :---: | :---: |
    | A16 | 2 | 31 | ص A15 |
    | A14 | 3 | 30 | $\square \mathrm{NC}$ |
    | A12 | 4 | 29 | ص WE |
    | A 7 | 5 | 28 | [ $\mathrm{Al}_{13}$ |
    | A6 | 6 | 27 | $\square \mathrm{As}$ |
    | A5 | 7 | 26 | - A9 |
    | $\mathrm{A}_{4}$ | 8 | 25 | ص $\mathrm{A}_{11}$ |
    | А 3 | 9 | 24 | $\square \mathrm{OE}$ |
    | A2 | 10 | 23 | A10 |
    | $\mathrm{A}_{1}$ | 11 | 22 | $\square$ CS |
    | Ao $\square$ | 12 | 21 | $\square 1 / \mathrm{O}$ |
    | l/O1 | 13 | 20 |  |
    | $1 / \mathrm{O} 2$ - | 14 | 19 | 1/06 |
    | l/O3 | 15 | 18 | $\square \mathrm{I} / \mathrm{O}_{5}$ |
    | GND - | 16 | 17 | $\square \mathrm{I} / \mathrm{O}_{4}$ |
    | DIP  <br> TOP VIEW $\left.\begin{array}{r}2656 \mathrm{drw} 01 \\ 2656 \mathrm{drw}\end{array}\right)$ |  |  |  |

    ## NOTE:

    1. For module dimensions, please refer to module drawing $M 6$ and $M 7$ in the packaging section.
    

    PIN NAMES

    | $\mathrm{AO}-16$ | Addresses |
    | :--- | :--- |
    | $\mathrm{I} / \mathrm{O}_{1-8}$ | Data Input/Output |
    | $\overline{\mathrm{CS}}$ | Chip Select |
    | VCC | Power |
    | $\overline{\mathrm{WE}}$ | Write Enable |
    | $\overline{\mathrm{OE}}$ | Output Enable |
    | GND | Ground |

    2656 tol 01

[^16]:    2706 Drw 01
    NOTE:

    1. For module dimensions, please refer to module drawing M42 in the packaging section.
[^17]:    CEMOS and SPC are trademarks of Integrated Device Technology Inc.

[^18]:    FourPort is a trademark of Integrated Device Technology, Inc.

