## Lattice

## Lattice Data Book <br> 1994



Electronics Group
Claude Michael Group
FAX

## 嫊Lattice- <br> 

## pLSI and ispLSI Product Index

| PART\# | Pins | Density (PLD Gates) | Tpd (ns) | Fmax ( MHz ) | $\begin{gathered} \text { Icc } \\ (\mathrm{mA}) \end{gathered}$ | Description | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| pLSI / ispLSI 1016 | 44 | 2000 | 10, 12, 15, 20 | 110, 90, 80, 60 | 150 | 64 Macrocell High-Density PLD | 2-61 |
| pLSI / ispLSI 1024 | 68 | 4000 | 12, 15, 20 | 90, 80, 60 | 190 | 96 Macrocell High-Density PLD | 2-81 |
| pLSI / ispLSI 1032 | 84 | 6000 | 12, 15, 20 | 90, 80, 60 | 195 | 128 Macrocell High-Density PLD | 2-97 |
| pLSI / ispLSI 1048 | 120 | 8000 | 15, 18, 24 | 80, 70, 50 | 235 | 192 Macrocell High-Density PLD | 2-117 |
| pLSI / ispLSI 1048C | 128 | 8000 | 18, 24 | 70,50 | 235 | 192 Macrocell High-Density PLD | 2-133 |
| pLSI / ispLSI 2032 | 44 | 1000 | 7.5,10,15 | 135, 110, 80 | - | 32 Macrocell High-Density PLD | 2-151 |
| pLSI / ispLSI 3256 | 160 | 11000 | 15, 17, 23 | 80, 70, 50 | - | 256 Macrocell High-Density PLD | 2-169 |

## GAL Product Index

| PART \# | Pins | Tpd (ns) | Fmax (MHz) | $\begin{gathered} \text { Icc } \\ (\mathrm{mA}) \end{gathered}$ | $\begin{aligned} & \text { Isb } \\ & (\mu \mathrm{A}) \end{aligned}$ | Description | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| GAL16V8 | 20 | 5, 7.5, 10, 15, 25 | 166, 100, 62.5, 41.6 | 55, 90, 115 | - | Universal 20-Pin PLD | 3-5 |
| GAL16V8Z/ZD | 20 | 12, 15 | 83.3, 62.5 | 55 | 100 | Zero-Power 20-Pin PLD | 3-29 |
| GAL16VP8 | 20 | 15, 25 | 80, 50 | 115 | - | 64mA High Output Drive 16V8 | 3-49 |
| GAL18V10 | 20 | 15,20 | 62.5 | 115 | - | 22V10 Subset | 3-67 |
| GAL20RA10 | 24 | 10, 15, 20, 30 | 71.4, 50, 41.7, 25 | 100 | - | Asynchronous - 10 Prog. Clocks | 3-79 |
| GAL20V8 | 24 | 5, 7.5, 10, 15, 25 | 166, 100, 62.5, 41.6 | 55, 90, 115 | - | Universal 24-Pin PLD | 3-97 |
| GAL20V8Z/ZD | 24 | 12, 15 | 83.3, 62.5 | 55 | 100 | Zero-Power 24-Pin PLD | 3-121 |
| GAL20VP8 | 24 | 15, 25 | 80,50 | 115 | - | 64mA High Output Drive 20V8 | 3-141 |
| GAL20XV10 | 24 | 10, 15, 20 | 100, 83.3, 71.4 | 90 | - | 24-Pin XOR PLD | 3-159 |
| GAL22V10 | 24 | $5,6,7.5,10,15,25$ | $\begin{gathered} 200,166,142.8,105 \\ 83.3,38.5 \end{gathered}$ | $\begin{gathered} 55,90,130,140 \\ 150 \end{gathered}$ | - | Universal 24-Pin PLD | 3-173 |
| ispGAL22V10 | 28 | 7.5, 10, 15 | 111, 105, 83.3 | 140 | - | In-System Programmable 22V10 | 3-193 |
| GAL26CV12 | 28 | 7.5, 10, 15, 20 | 142.8, 105, 83.3, 62.5 | 130 | - | 22V10 Superset | 3-213 |
| GAL6001 | 24 | 30 | 27 | 150 | - | FPLA Architecture | 3-231 |
| GAL6002 | 24 | 15,20 | 75,60 | 135 | - | FPLA Architecture | 3-249 |

## In-System Programmable Generic Digital Switch Product Index

| PART\# | Pins | Tpd (ns) | Fmax(MHz) | Icc <br> $(\mathbf{m A})$ | Description | Page |
| :--- | :---: | :---: | :---: | :---: | :--- | :---: |
| ispGDS14 | 20 | 7.5 | 50 | 40 | $7 \times 7$ Programmable Switch Matrix | $4-5$ |
| ispGDS18 | 24 | 7.5 | 50 | 40 | $9 \times 9$ Programmable Switch Matrix | $4-5$ |
| ispGDS22 | 28 | 7.5 | 50 | 40 | $11 \times 11$ Programmable Switch Matrix | $4-5$ |

Thank you for your interest in Lattice Semiconductor's programmable logic products. Lattice offers the world's highest performance and broadest product line of low density and high density CMOS PLDs.

This data book includes our industry standard $G A L{ }^{\circledR}$ product line and our new High-Density PLDs, the pLSI ${ }^{\circledR}$ and ispLSI ${ }^{\text {TM }} 1000,2000$, and 3000 families. The pLSI and ispLSI families combine the performance and ease of use of PLDs with the density and flexibility of FPGAs.

Lattice Semiconductor, the worldwide leader in $\mathrm{E}^{2} \mathrm{CMOS}$ PLDs, is committed to supplying you with the optimal solution to all of your programmable logic requirements.


## Lattice Semiconductor Corporation

## 1994 Data Book

Copyright © 1994 Lattice Semiconductor Corporation
$E^{2}$ CMOS, GAL, ispGAL, pDS, pLSI, Silicon Forest and UltraMOS are registered trademarks of Lattice Semiconductor Corporation. Generic Array Logic, ISP, ispCODE, ispDOWNLOAD, ispGDS, ispLSI, ispSTREAM, Latch-Lock, pDS+ and RFT are trademarks of Lattice Semiconductor Corporation

All brand names or product names mentioned are trademarks or registered trademarks of their respective holders.
Lattice Semiconductor Corporation products are made under one or more of the following U.S. and international patents: $4,761,768$ US, $4,766,569$ US, $4,833,646$ US, $4,852,044$ US, $4,855,954$ US, $4,879,688$ US, $4,887,239$ US, 4,896,296 US, $5,130,574$ US, $5,138,198$ US, $5,162,679$ US, $5,191,243$ US, $5,204,556$ US, $5,231,315$ US, $5,231,316$ US, $5,237,218$ US, 5,245,226 US, 5,251,169 US, 0194091 EP, 0196771 B1 EP, 0196771 UK, 0196771 WG.

## LATTICE SEMICONDUCTOR CORP.

5555 Northeast Moore Court
Hillsboro, Oregon 97124 U.S.A.
Tel.: (503) 681-0118
FAX: (503) 681-3037
TELEX 277338 LSC UR

## Table of Contents

Section 1: Introduction
Introduction ..... 1-1
Section 2: High-Density Programmable Logic
Introduction to pLSI and ispLSI Families ..... 2-1
1000 Family Architectural Description ..... 2-11
2000 Family Architectural Description ..... 2-25
3000 Family Architectural Description ..... 2-31
ispLSI Architecture and Programming ..... 2-39
pLSI and ispLSI 1000 Family Datasheets Introduction to pLSI and ispLSI 1000 Family ..... 2-57
pLSI and ispLSI 1016 ..... 2-61
pLSI and ispLSI 1024 ..... 2-81
pLSI and ispLSI 1032 ..... 2-97
pLSI and ispLSI 1048 ..... 2-117
pLSI and ispLSI 1048C ..... 2-133
pLSI and ispLSI 2000 Family Datasheets
Introduction to pLSI and ispLSI 2000 Family ..... 2-149
pLSI and ispLSI 2032 ..... 2-151
pLSI and ispLSI 3000 Family Datasheets
Introduction to pLSI and ispLSI 3000 Family ..... 2-167
pLSI and ispLSI 3256 ..... 2-169
Section 3: Low-Density Programmable Logic
Introduction to Generic Array Logic ..... 3-1
Commercial / Industrial Product Datasheets
GAL16V8 ..... 3-5
GAL16V8Z/ZD ..... 3-29
GAL16VP8 ..... 3-49
GAL18V10 ..... 3-67
GAL20RA10 ..... 3-79
GAL20V8 ..... 3-97
GAL20V8Z/ZD ..... 3-121
GAL20VP8 ..... 3-141
GAL20XV10 ..... 3-159
GAL22V10 ..... 3-173
ispGAL22V10 ..... 3-193
GAL26CV12 ..... 3-213
GAL6001 ..... 3-231
GAL6002 ..... 3-249
Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices Introduction to ispGDS ..... 4-1
ispGDS22/18/14 Datasheet ..... 4-5
Section 5: Military Program
Military Program Overview ..... 5-1
Military Ordering Information ..... 5-3
Military Product Datasheets
GAL16V8 ..... 5-5
GAL20V8 ..... 5-13
GAL22V10 ..... 5-21
pLSI and ispLSI 1016 (See Commercial Datasheet)pLSI and ispLSI 1024 (See Commercial Datasheet)pLSI and ispLSI 1032 (See Commercial Datasheet)
Section 6: Development Tools
Lattice Design Tool Strategy ..... 6-1
System Design Process ..... 6-3
pLSI and ispLSI Design Flow ..... 6-5
Lattice Development Tool Datasheets pDS Software ..... 6-9
pDS+ ABEL Software ..... 6-15
pDS+ Viewlogic Software ..... 6-19
pDS+ LOG/iC Software ..... 6-25
isp Starter Kit ..... 6-31
ispCODE ..... 6-33
isp Engineering Kit - Model 100 ..... 6-39
isp Engineering Kit - Model 200 ..... 6-43
ispDOWNLOAD Cable ..... 6-49
pLSI and ispLSI Design Tool Selector Guide ..... 6-51
GAL Development Support ..... 6-55
ispGDS Compiler Support ..... 6-57
Section 7: Quality and Reliability
Quality Assurance Program ..... 7-1
Qualification Program ..... 7-3
$E^{2} \mathrm{CMOS}$ Testability Improves Quality ..... 7-5
ISO 9000 Program ..... 7-7
Section 8: General Information
Copying PAL, EPLD \& PEEL Patterns into GAL Devices ..... 8-1
GAL Product Line Cross Reference ..... 8-3
Package Thermal Resistance ..... 8-5
Tape and Reel Specifications ..... 8-6
Package Diagrams ..... 8-7
Sales Offices ..... 8-21

Section 1: Introduction

## Section 2: High-Density Programmable Logic

## Section 3: Low-Density Programmable Logic

Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices
Section 5: Military Program
Section 6: Development Tools
Section 7: Quality and Reliability
Section 8: General Information

## Introduction

## Background

Lattice Semiconductor Corporation, founded in 1983 and based in Hillsboro, Oregon, has completed its tenth year of supplying innovative solutions for the high performance system design needs of its customers. Through its pioneering efforts at applying $\mathrm{E}^{2} \mathrm{CMOS}^{\circledR}$ technology to programmable logic, Lattice has established the GAL ${ }^{\circledR}$ family of products as the industry standard worldwide. With the introduction of the high-density programmable Large Scale Integration ( $\left.\mathrm{pLS}\right|^{\circledR}$ ) devices and in-system programmableLarge Scale Integration (ispLSI ${ }^{\text {TM }}$ ) devices, Lattice has become the world's largest supplier of lowdensity CMOS PLDs and the fastest growing supplier of high-density CMOS PLDs.

Lattice has recently introduced two new low-density insystem programmable devices: the ispGAL22V10 and ispGDS ${ }^{\text {TM }}$. The ispGAL22V10 brings on-the-fly system logic reconfigurability to the industry standard GAL22V10. The ispGDS (in-system programmable Generic Digital Switch) family further extends Lattice's programmable technology beyond logic to board interconnect and signal routing. ispGDS opens new possibilities for system designers and is just the first of a number of application specific programmable solutions which will be addressed by Lattice in the future.

## The Lattice Advantage

## Time-to-Market

$E^{2}$ CMOS PLDs enable system designers to meet evershrinking time-to-market constraints while avoiding the significant development costs, lead times and dedicated inventories associated with traditional ASIC and bipolar PLD solutions.

## Flexibility

Programmable and reprogrammable devices enable fast and easy modifications to system designs.

## Product Differentiation

Programmable devices support end-product differentiation through proprietary feature enhancements. This is particularly true when a system utilizes the non-volatile ISP ${ }^{\text {TM }}$ (In-System Programmable) technology pioneered by Lattice.

## Inventory Reduction

A single standard part type can be used in multiple, diverse applications. Just 5 GAL architectures replace virtually all bipolar $\mathrm{PAL}^{\circledR}$ architectures (see figure 1).

## Products

The Lattice PLD product offering can be segmented into two strategic product thrusts:

## Low Density: GAL Family

- 100-1,000 Gates
- The Highest Performance PLDs from any Supplier
- Superior Replacements for Bipolar and CMOS PLD Architectures
- $E^{2}$ CMOS Low-Power, Quality and Reliability
- Broadest Range of PLD Architectures Offering Features not Available in other PLDs


## High Density: pLSI and ispLSI Families

$-1,000-14,000$ Gates (World's Largest)

- World's Fastest High-Density PLDs (HDPLDs)
- Superior HDPLD Architecture (Flexible, Predictable Performance)
-Pioneering Non-volatile In-System Programmability (ISP)
- Range of Effective Development Tool Options

Figure 1. Five GAL devices replace virtually all bipolar PAL devices.


- GAL20XV10 replaces 20L10, 20X10, 20X8 and 20X4


## Introduction

## Lattice Product Features

There are three fundamental features which Lattice PLDs share: $E^{2}$ CMOS technology, performance leadership and innovation.

## E²$^{2}$ CMOS Technology

All GAL, pLSI and ispLSI devices are manufactured using Lattice's proprietary high-speed UltraMOS ${ }^{\circledR}$ $\mathrm{E}^{2} \mathrm{CMOS}$ technology. Lattice is unique among "fab-less" companies in that the process technology development is actually done by Lattice. UltraMOS technology successfully combines the best features of CMOS and NMOS process technology to yield PLDs with the following key features:

- Industry Leading Performance
- High Logic Densities
- Low Power Consumption
- Non-Volatile, In-System Programmability
- Fast Erase and Reprogram Times
- 100\% Full Parametric Testability
- 100\% Programming and Functional Yields


## Performance Leadership

Lattice continues its long track record of producing the fastest CMOS PLDs in the market. These industryleading high-performance products are typically available to the market months ahead of any other PLD supplier. As a result, Lattice customers have always been able to take full advantage of next generation microprocessor speeds and bring out industry leading end products of their own, thus fueling their own success.

While speed continues to be a top priority, Lattice has also introduced PLD families which address other logic design concerns such as low power ("Zero-Power" GAL16/20V8Z and GAL16/20V8ZD), high output drive (GAL16/20VP8) and logic density (GAL26CV12).

## Innovation

The third, and perhaps the most important attribute of Lattice's products is technology and architectural innovation. Lattice's most far-reaching innovation may have been the decision in 1984 to combine $\mathrm{E}^{2} \mathrm{CMOS}$ technology with the PLD architecture when all other PLD suppliers were offering UV erasable EPROM technology. This marriage yielded the GAL product family - the "1st Revolution in PLD design."

Lattice innovation also started the "2nd Revolution in PLD design" with the introduction of the first non-volatile
in-system programmable high-density PLD family ispLSI, as well as the ispGAL22V10 and ispGDS.

The ISP concept, and the ispLSI, ispGAL and ispGDS families in particular, dramatically impact system development and manufacturing. Lattice ISP solutions deliver:

Effortless Prototyping: Design iterations can be downloaded directly to the ISP device soldered onto the prototype board.

Reconfigurable Systems: A single generic board can be "personalized" to one of many system configurations at final board level test.

Simplified Manufacturing: Eliminates all stand-alone programming steps. Device programming can be done as part of board-level testing. The result is no misprogrammed devices, no inventory headaches keeping track of patterned devices, and no PLD rework costs.

No More Bent Leads: ISP technology also solves the handling problems associated with high pin count, fine pitch packages (PQFP, TQFP etc.). It eliminates bent leads and unreliable solder joints by programming devices in-system.

## Summary

Lattice, the leader in $\mathrm{E}^{2} \mathrm{CMOS}$ PLDs, is committed to providing its customers with industry-leading programmable solutions. We realize that your system design requirements and time-to-market pressures will only get tougher in the future. Lattice is committed to supporting you with state-of-the-art products with the performance, architecture, quality and reliability to meet your needs.
Section 1: Introduction
Section 2: High-Density Programmable Logic Introduction to pLSI and ispLSI Families ..... 2-1
1000 Family Architectural Description ..... 2-11
2000 Family Architectural Description ..... 2-25
3000 Family Architectural Description ..... 2-31
ispLSI Architecture and Programming ..... 2-39
pLSI and ispLSI 1000 Family Datasheets Introduction to pLSI and ispLSI 1000 Family ..... 2-57
pLSI and ispLSI 1016 ..... 2-61
pLSI and ispLSI 1024 ..... 2-81
pLSI and ispLSI 1032 ..... 2-97
pLSI and ispLSI 1048 ..... 2-117
pLSI and ispLSI 1048C ..... 2-133
pLSI and ispLSI 2000 Family Datasheets Introduction to pLSI and ispLSI 2000 Family ..... 2-149
pLSI and ispLSI 2032 ..... 2-151
pLSI and ispLSI 3000 Family Datasheets Introduction to pLSI and ispLSI 3000 Family ..... 2-167
pLSI and ispLSI 3256 ..... 2-169
Section 3: Low-Density Programmable Logic
Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices
Section 5: Military Program
Section 6: Development Tools
Section 7: Quality and Reliability
Section 8: General Information

## Introduction to

# pLSI' and ispLSI" Families 

## The Lattice pLSI and ispLSI Families

The Lattice programmable Large Scale Integration (pLSI) and in-system programmable Large Scale Integration (ispLSI) families are the logical choice for your next design project. They're the first programmable logic devices to combine the performance and ease of use of PLDs with the density and flexibility of FPGAs. And at 135 MHz system speed, and up to 14000 PLD gates, they're the world's fastest and highest density programmable logic devices!

There are three pLSI and ispLSI families to fit your specific application needs. Lattice's premier pLSI and ispLSI 1000 family implements high integration functions such as controllers, LANs and encoders at high speeds. The high performance pLSI and ispLSI 2000 family with its large number of I/Os handles timers, counters as well as timing critical interfaces to high speed RISC/CISC microprocessors. The highest density pLSI and ispLSI 3000 family integrates complete system logic, DSP functions, and entire encryption or compression logic into a single package, while delivering superior performance.

The ispLSI 1000, 2000 and 3000 families pioneer nonvolatile, in-system programmability, a technology that allows real-time programming, less expensive manufacturing and end-user system reconfiguration.

All the development tools you need are available from Lattice - tools ranging from Lattice's own entry level software to higher level, third-party design environments. With these tools, you'll be completing your circuit designs in hours instead of weeks or months.

## pLSI and ispLSI 1000: The Premier High Density Family

- 110 MHz system performance
- 10 ns pin-to-pin delay (maximum)
- 2000-8000 PLD gates
- 44-pin to 128 -pin packages


## pLSI and ispLSI 2000: Unparalleled System Performance

- 135 MHz system performance (world's fastest!)7.5 ns pin-to-pin delay (maximum)

1000-4000 PLD gates

- 44-pin to 128-pin packages
$\square$ High I/O to Logic Ratio


## pLSI and ispLSI 3000: Density with Performance

- 110 MHz system performance

10 ns pin-to-pin delay (maximum)
$\square$ 8000-14000 PLD gates (world's largest!)

- 128-pin to 208-pin packages
$\square$ Boundary scan for enhanced testability
(IEEE 1149.1)


## Lattice's pLSI and ispLSI Families



## Introduction to pLSI and ispLSI

## Family Overview

From registers to counters, from multiplexers to complex state machines, these families of high-density programmable logic will address your high-performance system logic needs.

With PLD gate densities ranging from 1,000 to 14,000 , the pLSI and ispLSI devices provide the range of programmable logic solutions you need to meet design requirements today and tomorrow.

Table 1. pLSI and ispLSI Family Attributes

Each device contains multiple Generic Logic Blocks (GLBs), architectured to maximize system flexibility and performance. And a generous supply of registers and I/O cells provides the optimum balance of internal logic and external connections. A global interconnect scheme ties everything together, enabling high logic utilization.

## pLSI and ispLSI 1000

| Density (PLD Gates) | 2000 | $4000$ |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Speed: <br> Fmax (MHz) | 110 | 90 | 90 | 80 |
| Speed: Tpd (ns) | 10 | 12 | 12 | 15 |
| Macrocells | 64 | 96 | 128 | 192 |
| Registers | 96 | 144 | 192 | 288 |
| Inputs \& I/Os | 36 | 54 | 72 | 106/110 |
| Pins/Package | 44-PLCC 44-TQFP 44-JLCC | $\begin{aligned} & \text { 68-PLCC } \\ & \text { 68-JLCC } \end{aligned}$ | 84-PLCC 100-TQFP 84-CPGA | $\begin{aligned} & \text { 120-PQFP } \\ & \text { 128-PQFP } \end{aligned}$ |

$1 / 2 / 3000-2 \mathrm{~A}$

## pLSI and ispLSI Architecture

The pLSI and ispLSI architecture was constructed with real system design requirements in mind. Figure 1 shows the representation of the pLSI 3256 architecture. This architecture provides the designer with the following advantages.High Speed
$\square$ Predictable performance

## Low power

- Flexible architecture
$\square$ Easy to use
- Design portability across all the families
- Non-volatile in-system programmable (ispLSI)
- Advanced Global Clock Network

Boundary Scan (3000 Family)


## Introduction to pLSI and ispLSI

## The Global Routing Pool

Central to the pLSI and ispLSI architecture is the Global Routing Pool (GRP), which connects all of the internal logic and makes it available to the designer. The GRP provides complete interconnectivity with fixed and predictable delays. This unique interconnect scheme consistently provides high performance and allows effortless implementation of complex designs.

## The Output Routing Pool (ORP)

The Output Routing Pool (ORP) is a unique pLSI and ispLSI architectural feature which provides flexible connections between the GLB outputs and the output pins. This flexibility allows for "last minute" logic design changes to be implemented without changing the external pin-out.

Figure 1. pLSI 3256 Functional Block Diagram


## Generic Logic Block (GLB)

The key element in the pLSI and ispLSI architecture is the Generic Logic Block (GLB). This powerful logic block provides a high input-to-output ratio for best logic efficiency. The GLB (figure 2) used in the pLSI and ispLSI 1000 and 2000 families feature 18 inputs which drive an array of 20 Product Terms (PTs). These product terms feed four outputs which effectively handle both wide and narrow gating functions. The pLSI and ispLSI 3000 family
utilizes a Twin GLB which delivers wider logic functionality. The Twin GLB accepts 24 inputs and feeds two arrays of 20 Product Terms that ultimately drive two sets of four outputs.
The architectural flexibility of the pLSI and ispLSI GLB, combined with its optimum input-to-output ratio, allows the GLB to implement virtually all 4-bit and 8-bit MSI functions.

## Introduction to pLSI and ispLSI

An additional element of architectural flexibility is the Product Term Sharing Array (PTSA). The PTSA allows the 20 PTs from the AND array to be shared with any and all of the four GLB outputs. This ability to share PTs between all of the four GLB outputs provides a highly efficient means to implement complex state machines by eliminating duplicate product term groups.

Each of the four outputs from the PTSA feeds into a flexible Output Logic Macrocell (OLMC), consisting of a D-type flip-flop with an Exclusive-OR gate on the input.

The OLMC allows each GLB output to be configured as either combinatorial or registered. Combinatorial mode is available as AND-OR or Exclusive-OR. Registered mode is available as $\mathrm{D}, \mathrm{T}$ or J-K.
The power of the GLB is further enhanced by a flexible clock distribution network. This network provides a choice of clock signals to each GLB: global synchronous clock signals or internally generated asynchronous product term clock signals.

Figure 2. pLSI and ispLSI 1000 and 2000 Family GLB


Figure 3. pLSI and ispLSI 3000 Family "Twin GLB"


## Introduction to pLSI and ispLSI

Figure 4. GLB: Multi-Mode Configuration


## Standard Configuration

- GLB Outputs Comprised of 4, 4,5 and 7 Product Terms
- The PTSA can Combine up to 20 Product Terms per GLB Output to Meet the Needs of Both Wide and Narrow Logic Functions

High-Speed Bypass Configuration

- For Speed-Critical Timing Paths
- Bypasses the PTSA and the Internal ExclusiveOR gate of the OLMC
- Provides Four Product Terms per Output
[ Supports Design of Fast Address Decoders

Exclusive-XOR Configuration

- Utilizes Powerful Exclusive-XOR Architecture
[. Greatfor Counters, Comparators and ALU Functions


## Single PT Configuration

- Small Logic Functions at Fast Speed


## Multi-Mode Configuration

[ Individual Outputs are Independently Configurable

- PTSA Gives Flexibility in the Number and Selection of Product Terms per Output


# Introduction to pLSI and ispLSI 

## Security Cell

A security cell is provided in the pLSI and ispLSI devices to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by reprogramming the device, so the original configuration can never be examined once this cell is programmed.

## Device Programming

pLSI and ispLSI devices can be programmed using a Lattice-approved device programmer, available from a number of third party manufacturers. Complete programming of the device takes only a few seconds. Erasing of the device is automatic and is completely transparent to the user. In-system programming is also available with ispLSI devices which allows programming on the circuit board using Lattice programming algorithms and standard 5 V system power.

## Latch-up Protection

pLSI and ispLSI devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the internal circuitry to latchup. Additionally, outputs are designed with $n$-channel pull-ups instead of the traditional p-channel pull-ups to eliminate any possibility of SCR induced latching.

## In-system programmability

Lattice's ispLSI devices (in-system programmable) are the industry's only high-density programmable logic family offering non-volatile, in-system reconfigurability.
ispLSI devices are available in all three families: 1000, 2000 and 3000 . The ispLSI devices are 100 percent functionally and parametrically compatible with their pLSI counterparts, with the added capability for 5 -volt insystem programmability and reprogrammability.

Complex logic functions can be implemented in multiple ispLSI devices with complete on-board configurability. In-system programming of a multiple ispLSI chip solution is easily achieved through a proprietary in-system erase/ program/verify technique.

In-system programmability can revolutionize the way you design, manufacture and service systems.

## Prototype Board Designs

In-system programming allows you to program and modify your logic designs "in-system" without removing the device(s) from the board. This accelerates the system and board-level debug process and enables you to define the board layout earlier in the design process.

## Fine Pitch Package Handling

When programming traditional PLDs, manual handling is required during both design/debugging and manufacturing stages. When using PQFPs or TQFPs, fragile leads as thin as 0.5 mm can easily bend in the programmer socket causing coplanarity damage. With ispLSI, you can solder these packages onto your printed circuit board and still program and reprogram the devices during debugging and manufacturing - without ever losing a single part due to bent leads.

## Reconfigurable Systems

Your options become boundless when you have the ability to change the functionality of devices already soldered on a p.c. board. You can now implement multiple hardware configurations with the same circuit board design. A variety of protocols or system interfaces can be implemented on a generic board as the last step in the manufacturing flow.

## Easier Field Updates

With software reconfigurable systems, field updates are as easy as loading a new configuration from a floppy or downloading it through a modem.

## Enhanced Manufacturing Flow with ispLSI

Perhaps the most exciting benefit of the ispLSI family is its potential to streamline the manufacturing process by eliminating the separate programming and labeling steps usually associated with PLDs. Quality is enhanced when product handling steps are reduced, in this case, those associated with programming, labeling and reinventorying multiple device types. Eliminating socketing further improves quality and reduces board cost. Figure 6 shows the enhanced manufacturing with the ispLSI device.

## Introduction to pLSI and ispLSI

Figure 5. In-System Programmable Graphics Board


Figure 6. Manufacturing Flow Comparison

## Standard Flow <br> Using PLDs/FPGAs

Enhanced Flow Using ispLSI Devices


All necessary programming is achieved via five TTL-level logic interface signals (see figure 7). These five signals control the on-chip programming circuitry, which protects against inadvertent reprogramming via on-chip state machines. The ispLSI family can also be programmed using popular third-party logic programmers.

Figure 7. In-System Programming Interface (MultiChip Solution)


## Introduction to pLSI and ispLSI

## Boundary Scan

An emerging trend in board-level testing is boundary scan test, an attractive feature helping designers test system boards efficiently while lowering test and manufacturing costs. The pLSI and ispLSI 3000 family offers dedicated IEEE 1149.1 boundary scan support for all test functions required by the standard. By using pLSI and ispLSI devices you not only eliminate expensive "bed-ofnails" testers but also simplify testing of surface-mount boards, multi-layer boards and boards using fine-pitch packages. Boundary scan is ideal wherever tight board layout limits access to logic signals.

It only takes 4 pins to implement the boundary scan interface. The ispLSI 3000 devices share the four boundary scan signals with the in-system programming pins. This enhances the testability of system designs allowing logic to be reconfigured to improve controllability and observability.

## Lattice Development Systems

The Lattice pLSI/ispLSI Development System (pDS) software is used to implement designs in pLSI and ispLSI devices. Design alternatives can be quickly implemented using Lattice's low cost pDS software or the pDS+ family of Fitters that interface with third-party development software packages. This section describes the pDS and pDS+ Development Systems. Programmer support is also discussed.

## pLSI/ispLSI Development System (pDS)

## Features

- High-Performance, Low-Cost Development Environment
- Supports pLSI and ispLSI Device Families
- Boolean Logic and Text File Design Entry
- Windows Based Graphical User Interface
- Over 275 Macros Available
- Automatic Place and Route
- Static Timing Table
- Logic Simulation with Viewlogic ${ }^{\text {TM }}$ Viewsim $^{\text {TM }}$
- JEDEC File Download Direct to Programmer or ispLSI Device


## General Description

All pLSI and ispLSI families are supported by Lattice'slowcost pDS software. It runs on IBM-compatible (386/486/ Pentium) PCs with Microsoft ${ }^{\circledR}$ Windows.

The graphical user interface employs an easy-to-use mouse and pull-down menu driven approach. Combined with Boolean logic data entry using an ABEL ${ }^{\text {TM }}$-like syntax, pDS makes design entry with pLSI and ispLSI quick and straightforward (see figure 8).

Figure 8. pDS Design Flow


The pDS software supports over 275 macros to assist the design process. These macros cover most TTL functions, from gate primitives to 16 -bit counters. The software also supports user-definable macros which can be modifications of existing macros or custom creations.

The pDS software automatically verifies the design, performs logic minimization and checks for signal availability.

The Lattice Place and Route software assigns pins and critical speed paths while routing the design.

Quick compilation speeds the design, debug and rework process dramatically. Incremental design techniques are also supported.

## Introduction to pLSI and ispLSI

Timing and functional simulation is available from Lattice, using Viewsim simulation software.

The Windows graphical user interface makes programming easy, using pull-down menus, intuitive point-and-click commands and self explanatory instructions. Without any up-front training, designs can be completed within hours instead of days or weeks.

## pLSVIspLSI Development System Plus (pDS+)

## Features

- Supports pLSI and ispLSI Device Families
- Schematic Capture, State Machine, DesignEntry HDL, and Boolean Equations
- Expanded Macro Library (>300)
- Automatic Logic Minimization and Partitioning
- Automatic Place and Route
- Logic and Timing Simulation
- EDIF Compatible
- JEDEC File Download Direct to Programmer or ispLSI Device


## General Description

For higher level design entry environments, Lattice offers pDS+ development software packages, which expand on the core capabilities of pDS. Schematic capture, state machine, HDL and Boolean entry are supported, along with an expanded macro library.

The pDS+ software utilizes industry standard third-party design environments such as Viewlogic's Viewdraw ${ }^{\text {M }}$ and Data I/O's ABEL.

Running on IBM compatible (386/486/Pentium) PCs or workstation platforms, pDS+ software supports automatic logic minimization and partitioning as well as place and route, resulting in high logic utilization.

For logic and timing simulation, support is available from Lattice through Viewlogic Viewsim simulation tools.

## Third Party Programming Support

The pLSI and ispLSI families are supported by popular third-party logic programmers including Data I/O, Logical Devices, BP-Microsystems, Stag, System General, SMS Micro Systems and Advin. Table 2 describes each vendor's specific programmer models that support the
pLSI and ispLSI devices. No proprietary, expensive, high pin-count programmers are required.

High pin-count socket adapters are available from Emulation Technology, Procon Technology, EDI Corporation and Logical Systems Corporation.

Additionally, the ispLSI family can be programmed on the board (in-system), which eliminates the need for a standalone programmer. For specific details refer to the Lattice Programming Tools Guide available from your local Sales Representative.

Table 2. Programming Support

| Programmer Vendor | Model |
| :---: | :--- |
| Advin Systems | Pilot-U84 |
|  | Pilot-U40 |
|  | Pilot-GL/GCE |
| BP Microsystems | PLD-1128 |
|  | CP-1128 |
| Data I/O | 2900 |
|  | 3900 |
|  | Unisite 40/48 |
| Logical Devices | Allpro 40 |
|  | Allpro 88 |
| SMS Micro Systems | Sprint Expert |
| Stag | System 3000 |
|  | ZL30/A |
|  | TURPRO-1 |

## isp Engineering Kit

The ispLSI family may also be programmed with Lattice's isp Engineering Kit Model 100 for PCs and Model 200 for Sun workstations. The kit is designed for engineering purposes only and is not intended for production use. By connecting an 8 wire cable to the parallel printer port of a PC, JEDEC files can be easily downloaded into the ispLSI device. Additionally, this cable can be connected directly to the circuit board facilitating on-board in-system programming.

# 1000 Family 

 Architectural Description
## pLSI and ispLSI 1000 Family Introduction

The basic unit of logic for the pLSI and ispLSI families is the Generic Logic Block (GLB). Figure 1 illustrates the pLSI 1032 with its 32 GLBs labelled A0, A1 .. D7. Each GLB has 18 inputs, a programmable AND/OR/XOR array, and four outputs which can be configured to be either combinatorial or registered. Inputs to the GLB come from the Global Routing Pool (GRP) and dedicated inputs. All of the GLB outputs are brought back into the GRP so that they can be connected to the inputs of any other GLB on the device.

As an example, the pLSI 1032 has 64 I/O cells, each of which is directly connected to an I/O pin. Each I/O cell can be individually programmed to be a combinatorial input, registered input, latched input, output or bi-directional I/O pin with 3-state control. Additionally, all outputs are polarity selectable, active high or active low. The signal levels are TTL compatible voltages and the output drivers can source 4 mA or sink 8 mA .

The I/O cells are grouped into sets of 16 as shown in figure 1. Each of these I/O groups is associated with a Megablock through the use of the Output Routing Pool (ORP).

Eight GLBs, 16 I/O cells, one ORP and two dedicated inputs are connected togetherto make a Megablock. The outputs of the eight GLBs are connected to a set of 16 universal I/O cells by the ORP. Each Megablock shares a common Output Enable (OE) signal. The pLSI 1032 device, shown in figure 1 contains four Megablocks.

The GRP has as its inputs the outputs from all of the GLBs and all of the inputs from the bi-directional I/O cells. All of these signals are made available to the inputs of the GLBs. Delays through the GRP have been equalized to minimize timing skew.

Clocks in the devices are selected using the Clock Distribution Network. The dedicated clock pins (Y0, Y1, Y2 and Y3) are brought into the distribution network, and five outputs (CLK 0, CLK1, CLK 2, IOCLK 0 and IOCLK 1) are provided to route clocks to the GLBs and I/O cells. The Clock Distribution Network can also be driven from a special GLB (CO on the pLSI and ispLSI 1032 device). The logic of this GLB allows the user to create an internal clock from a combination of internal signals within the device.

Figure 1. pLSI 1032 Functional Block Diagram


## 1000 Family Architectural Description

## Generic Logic Block

The Generic Logic Block (GLB) is the standard logic block of the Lattice high-density pLSl and ispLSI devices. A GLB has 18 inputs, four outputs and the logic necessary to implement most standard logic functions. The internal logic of the GLB is divided into four separate sections: the AND Array, the Product Term Sharing Array (PTSA), the Reconfigurable Registers, and the Control Functions (see figure 2). The AND array consists of 20 product terms which can produce the logical sum of any of the 18 GLB inputs. Sixteen of the inputs come from the Global Routing Pool, and are either feedback signals from any of the GLBs or inputs from the external I/O cells. The two remaining inputs come directly from two dedicated input pins. These signals are available to the product terms in both the logical true and the complementedforms which makes boolean logic reduction more efficient.

The PTSA takes the 20 product terms and routes them to the four GLB outputs. There are four OR gates, with four, four, five and seven product terms each (see figure
2). The output of any of these OR gates can be routed to any of the four GLB outputs, and if more product terms are needed, the PTSA can combine them as necessary. In addition, the PTSA can share product terms similar to an FPLA device. If the user's main concern is speed, the PTSA can use a bypass circuit which provides four product terms to each output, to increase the performance of the cell (see figure 3). This can be done to any or all of the four outputs from the GLB.

The Reconfigurable Registers consist of four D-type flipflops with an XOR gate on the input. The XOR gate in the GLB can be used either as a logic element or to reconfigure the D-type flip-flop to emulate a J-K or T-type flip-flop (see figure 4). This greatly simplifies the design of counters, comparators and ALU type functions. The registers can be bypassed if the user needs a combinatorial output. Each register output is brought back into the Global Routing Pool and is also brought to the I/O cells via the Output Routing Pool. Reconfigurable registers are not available when the four product term bypass is used.

Figure 2. GLB: Product Term Sharing Array Example


## 1000 Family Architectural Description

Figure 3. GLB: Four Product Term Bypass Example


Figure 4. GLB: XOR Gate Example


## 1000 Family Architectural Description

## Generic Logic Block (continued)

The PTSA is flexible enough to allow these features to be used in virtually any combination that the user desires. In the GLB shown in figure 5 , Output Three (O3) is configured using the XOR gate while Output Two ( O 2 ) is configured using the four Product Term Bypass. Output One (O1) uses one of the inputs from the five Product Term OR gate while Output Zero ( OO ) combines the remaining four product terms with all of the product terms from the seven Product Term OR gate for a total of eleven $(7+4)$.

Various signals which control the operation of the GLB outputs are driven from the Control Functions (see figure 5). The clock for the registers can come from any of three sources developed in the Clock Distribution Network (see Clock Distribution Network section) orfrom a product term within the GLB. The Reset Signal for the GLB can come from the Global Reset pin (RESET) or from a
product term within the block. The global reset pin is always connected and is logically "ORed" with the PT reset (if used). An active reset signal always sets the Q of the registers to a logic 0 state. The Output Enable for the I/O cells associated with the GLB comes from a product term within the block. Use of a product term for a control function makes that product term unavailable foruse as alogicterm. Referto the Product Term Sharing Matrix (table 1) to determine which logic functions are affected.

There are many additional features in a GLB which allow implementation of logic intensive functions. These features are accessible using the Hard Macros from the software and require no intervention on the part of the user.

Figure 5. GLB: Mixed Mode Configuration Example


## 1000 Family Architectural Description

## Product Term Sharing Matrix

This matrix shows how each of the product terms are used in the various modes. As an example, Product Term 12 can be used as an input to the five input OR gate in the standard configuration. This OR gate under standard configuration can be routed to any of the four GLB outputs. Product Term 12 is not used in the four
product term bypass mode. When GLB output one is used in the XOR mode Product Term 12 becomes one of the inputs to the four input OR Gate. If Product Term 12 is not used in the logic, then it is available for use as either the Asynchronous Clock signal or the GLB Reset signal.

Table 1. Product Term Sharing Matrix

| Product Term \# | Standard Configuration Output Number $3 \quad 2 \quad 1 \quad 0$ | Four Product Term Bypass Output Number $\begin{array}{llll}3 & 2 & 1\end{array}$ |  |  |  | Single Product Term Output Number |  |  |  | XOR Function Output Number |  |  |  |  |  |  |  | Alternate Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | 3 | 2 |  | 0 | 3 | 3 | 2 |  |  |  |  |  |  |
| $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ |  |  |  |  |  | $\square$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\begin{aligned} & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ |  |  | $\square$ |  |  |  | - |  |  |  |  | $\square$ |  |  |  |  |  |  |
| $\begin{gathered} 8 \\ 9 \\ 9 \\ 10 \\ 11 \\ 12 \end{gathered}$ |  |  |  | $\underline{\square}$ |  |  |  |  |  |  |  |  |  |  |  |  |  | mCLK/Reset |
| $\begin{aligned} & 13 \\ & 14 \\ & 15 \\ & 16 \\ & 17 \\ & 18 \\ & 19 \end{aligned}$ |  |  |  |  |  |  |  |  | $\square$ |  |  |  |  |  |  |  |  | - OE/Reset |

## The Megablock

A Megablock consists of eight GLBs, an ORP, 16 I/O cells, two dedicated inputs and a common product term OE. Each of these will be explained in detail in the following sections. These elements are coupled together as shown in figure 6. The various members of the pLSI and ispLSI families combine from one to eight Megablocks on a single device (see table 2).

For the 1000 Family, the eight GLBs within the Megablock share two dedicated input pins. These dedicated input pins are not available to GLBs in any other Megablock. These pins are dedicated (non-registered) inputs only
and are automatically assigned by software. The product term OE signal is generated within the Megablock and is common to all 16 of the I/O cells in the Megablock. The OE signal can be generated using a product term (PT19) in any of the eight GLBs within the Megablock (see the section on the Output Enable Control for further details).

Because of the shared logic within the Megablock, signals which share a common function (counters, busses, etc.) should be grouped within a Megablock. This will allow the user to obtain the best utilization of the logic within the device and eliminate routing bottlenecks.

## 1000 Family Architectural Description

Table 2. Device Resources

| pLSI and ispLSI Devices | Megablocks | GLBs | I/O Cells | Dedicated Inputs |
| :---: | :---: | :---: | :---: | :---: |
| 1016 | 2 | 16 | 32 | 4 |
| 1024 | 3 | 24 | 48 | 6 |
| 1032 | 4 | 32 | 64 | 8 |
| $1048 / 1048 \mathrm{C}$ | 6 | 48 | 96 | $10 / 12$ |

Table 2-0015B
Figure 6. The Megablock Block Diagram


## Input Routing

Signal inputs are handled in two ways within the device. First, each I/O cell within the device has its input routed directly to the GRP. This gives every GLB within the device access to each I/O cell input. Second, each Megablock has two dedicated inputs which are directly routed to the eight GLBs within the Megablock. Both input paths are shown in figure 6.

## The Output Routing Pool

The ORP routes signals from the GLB outputs to I/O cells configured as outputs or bi-directional pins (see figure 7). The purpose of the ORP is to allow greater flexibility when assigning I/O pins. It also simplifies the job for the routing software which results in a higher degree of utilization.

By examining the ORP in figure 7, it can be seen that a GLB output can be connected to one of four I/O cells. Further flexibility is provided by using the PTSA, (figures 2 through 5) which makes the GLB outputs completely interchangeable. This allows the routing program to freely interchange the outputs to achieve the best routability. This is an automatic process and requires no intervention on the part of the user.

The ORP bypass connections (see figure 8) further increase the flexibility of the device. The ORP bypass connects specific GLB outputs to specific I/O cells at a faster speed. The bypass path tends to restrict the routability of the device and should only be used for critical signals.

## 1000 Family Architectural Description

Figure 7. Output Routing Pool


Figure 8. Output Routing Pool Showing Bypass


## I/O Cell

The I/O cell (see figure 9) is used to route input, output or bi-directional signals connected to the I/O pin. The two logic inputs come from the ORP (see figure 9). One comes from the ORP, and the other comes from the faster ORP bypass. A pair of multiplexers select which signal will be used, and its polarity. The Output Enable of the I/O cell is controlled by the OE signal generated within each Megablock.

As with the data path, a multiplexer selects the signal polarity. The Output Enable can be set to a logic high (enabled) when an output pin is desired, or logic low (disabled) when an input pin is needed. The Global Reset (RESET) signal is driven by the active low chip reset pin. This reset is always connected to all GLB and I/O registers. Each I/O cell can individually select one of
the two clock signals (IOCLK 0 or IOCLK 1). These clock signals are generated by the Clock Distribution Network.

Using the multiplexers, the I/O cell can be configured as an input, an output, a 3-stated output or a bi-directional I/O. The D-type register can be configured as a level sensitive transparent latch or an edge triggered flip-flop to store the incoming data. Figure 10 illustrates some of the various I/O cell configurations possible.

There is an active pull-up resistor on the I/O pins which is automatically used when the pin is not connected. An option exists to have active pull-up resistors connected to all pins. This improves the noise immunity and reduces Icc for the device.

## 1000 Family Architectural Description

Figure 9. I/O Cell Architecture


Figure 10. Examples of I/O Cell Configurations


## 1000 Family Architectural Description

## The Output Enable Control

One OE signal can be generated within each GLB using the OE Product Term (PT19). One of the eight OE signals within a Megablock is then routed to all of the I/O cells within that Megablock (see figure 11). This OE signal can simultaneously control all of the 16 I/O cells which are used in 3 -state mode. Individual I/O cells also have independent control for permanently enabling or
disabling the output buffer (refer to the I/O cell section). Only one OE signal is allowed per Megablock for 3-state operation. The advantage to this approach is that the OE signal can be generated in any GLB within the Megablock which happens to have an unused OE product term. This frees up the other OE product terms for use as logic.

Figure 11. Output Enable Control for a Megablock


## 1000 Family Architectural Description

## Global Routing Pool

The GRP is a Lattice proprietary interconnect structure which offers fast predictable speeds with complete connectivity. The GRP allows the outputs from the GLBs or the I/O cell inputs to be connected to the inputs of the GLBs. Any GLB output is available to the input of all other GLBs, and similarly an input from an I/O pin is available
as an input to all of the GLBs. Because of the uniform architecture of the pLSI and ispLSI devices, the delays through the GRP are both consistent and predictable. However, they are slightly affected by GLB loading as shown in the example pLSI 1032-80 GLB Loading Delay graph (see figure 12).

Figure 12. Example Graph of GRP Delay vs GLB Loading


## Clock Distribution Network

The Clock Distribution Networks are shown in figure 13. They generate five global clock signals CLK 0, CLK 1, CLK 2 , IOCLK 0 and IOCLK 1. The first three, CLK 0 , CLK 1 and CLK 2 are used for clocking all the GLBs in the device. Similarly, IOCLK 0 and IOCLK 1 signals are used for clocking all of the I/O cells in the device. There are four dedicated system clock pins (Y0, Y1, Y2, Y3), three for the pLSI and ispLSI 1016 (YO, Y1, Y2), which can be directed to any GLB or any I/O cell using the Clock Distribution Network. The other inputs to the Clock Distribution Network are the four outputs of a dedicated clock GLB ("C0" for the pLSI 1032 is shown in figure 1). These clock GLB outputs can be used to create a userdefined internal clocking scheme.

For example, the clock GLB can be clocked using the external main clock pin YO connected to global clock
signal CLK 0 . The outputs of the clock GLB in turn can generate a "divide by" signal of the CLK 0 which can be connected to CLK 1, CLK 2, IOCLK 0 or IOCLK 1 global clock lines.

All GLBs have the capability of generating their own asynchronous clocks using the clock Product Term (PT12). CLK 0, CLK 1 and CLK 2 feed to their corresponding clock MUX inputs on all the GLBs (see figure 2).

The two I/O clocks generated in the Clock Distribution Network IOCLK 0 and IOCLK 1, are brought to all the I/ O cells and the user programs the I/O cell to use one of the two.

## 1000 Family Architectural Description

Figure 13. Clock Distribution Networks


## Timing Model

The task of determining the timing through the device is simple and straightforward. A device timing model is shown in figure 14. To determine the time that it takes for data to propagate through the device, simply determine the path the data is expected to follow, and add the various delays together (figure 15). Critical timing paths
are shown in figure 14, using data sheet parameters. Note that the Internal timing parameters are given for reference only, and are not tested. (External timing parameters are tested and guaranteed on every device).

Figure 14. pLSI and ispLSI Timing Model ${ }^{1}$

*Note: Y1 and Y2 only for the pLSI and ispLSI 1016.

## 1000 Family Architectural Description

Figure 15. pLSI and ispLSI Timing Model Examples ${ }^{1}$
Combinatorial Paths

| tpd1 | = | tiobp | + | tgrp4 | + | t4ptbp | + | torpbp | + | tob |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \#1 | $=$ | \#20 | + | \#28 | + | \#33 | + | \#46 | + | \#47 |
| tpd2 | = | tiobp | + | tgrp4 | + | txoradj | + | torp | + | tob |
| \#2 | $=$ | \#20 | + | \#28 | + | \#36 | + | \#45 | + | \#47 |

## Registered Paths

General Form:

| tsu | $=$ Logic + | Regsu | - |
| :--- | :--- | :---: | :---: |
| Clock(min) |  |  |  |
| th | $=\operatorname{Clock}(\max )+$ | Regh | - |
| Logic |  |  |  |
| tco | $=\operatorname{Clock}(\max )+$ | Regco | + |
| Output |  |  |  |

Specific Examples:

|  |  | (tiobp | tgrp4 | + | 4ptbp) | + | tgsu |  | tgyo(min) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \#6 | = | (\#20 | \#28 | + | \#33) | + | \#38 | - | \#50 |
|  |  | tgyo(max) | tgh | - | (tiobp | + | tgrp4 | + | t4ptbp) |
|  | $=$ | \#50 | \#39 | - | (\#20 | + | \#28 | + | \#33) |

$$
\operatorname{tco1}=\boldsymbol{t g y} 0(\max )+\mathbf{t g c o}+(\mathbf{t} \text { orpbp }+\mathbf{t} \text { ob })
$$

$$
\# 7=\# 50+\# 40+(\# 46+\# 47)
$$

$$
\text { tsu2 }=(\text { tiobp }+ \text { tgrp4 }+ \text { txoradj })+\text { tgsu }+\operatorname{tgyO}(\text { min })
$$

$$
\# 9=(\# 20+\# 28-\# 36)+\# 38+\# 50
$$

$$
\text { th2 }=\mathbf{t g y} 0(\max )+\mathbf{t g h}-\quad \text { (tiobp }+\mathbf{t g r p 4}+\mathbf{t x o r a d j} \text { ) }
$$

$$
\# 11=\# 50+\# 39-(\# 20+\# 28+\# 36)
$$

$$
\# 10=\# 50+\# 40+(\# 45+\# 47)
$$

1. The timing parameter reference numbers refer to the Internal Timing Parameters contained in the individual data sheets.

## Circuit Timing Example

Figure 16. Timing Calculation Example
A design requires two logic levels (each uses the 20PTXOR path). The design then uses a GLB register before exiting the device using the ORP bypass. Calculate tsu, th and tco.


## 1000 Family Architectural Description

Figure 16. Timing Calculation Example (continued)

$$
\begin{aligned}
& \text { tsu } \quad=\text { Logic }+ \text { Reg su - Clock (min) } \\
& =(\mathbf{t i o b p}+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor}+\mathbf{t g b p}+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor})+\mathbf{t g s u}-\mathbf{t g y} 0(\mathrm{~min}) \\
& =(\# 20+\# 28+\# 35+\# 37+\# 28+\# 35)+\# 38-\# 50 \\
& 19.5 \mathrm{~ns}=(2.0+2.0+8.0+1.0+2.0+8.0)+1.0-4.5 \\
& \text { th } \quad=\text { Clock (max) }+ \text { Reg } \mathrm{h} \text { - Logic } \\
& =\mathbf{t g y} 0(\max )+\mathbf{t g h}-(\mathbf{t i o b p}+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor}+\mathbf{t g b p}+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor}) \\
& =\# 50+\# 39-(\# 20+\# 28+\# 35+\# 37+\# 28+\# 35) \\
& -14.0 \mathrm{~ns}=4.5+4.5-(2.0+2.0+8.0+1.0+2.0+8.0) \\
& \text { tco }=\text { Clock (max) }+ \text { Reg co }+ \text { Output } \\
& =\mathbf{t g y} 0(\max )+\mathbf{t g c o}+(\mathbf{t o r p b p}+\mathbf{t o b}) \\
& =\# 50+\# 40+(\# 46+\# 47) \\
& 10.0 \mathrm{~ns}=4.5+2.0+(0.5+3.0)
\end{aligned}
$$

1. The delay values used are for a pLSI 1032-80 device.

# 2000 Family Architectural Description 

## pLSI and ispLSI 2000 Family Introduction

The basic unit of logic of the pLSI and ispLSI 2000 family is essentially the same as that of the pLSI and ispLSI 1000 family. However, there are some specific architectural differences: Global clock structure, I/O Cell and OE structure, and ORP structure. A functional block diagram of the 2032 device is shown in figure 1 . These architectural differences are described in detail below.

## Global Clock Structure

The clock GLB distribution network of the 1000 family has been eliminated and replaced by three dedicated global

GLB clock input signals CLKO, CLK1, and CLK2. These three clocks are used for clocking all the GLBs configured as registers in the device. They feed directly to the GLB clock input via a clock multiplexer. CLKO is associated with system clock pin Y0, CLK1 corresponds to system clock pin Y1, and finally CLK3 corresponds to system clock pin Y2. This is illustrated in figure 2. The GLB global clocks do not have inversion capability, but all GLBs continue to have the capability of generating their own asynchronous clocks using the clock product term (PT12) with inversion capability. The GLB global clocks and the GLB product term clock feed to their corresponding clock multiplexer shown in figure 3.

Figure 1. pLSI 2032 Functional Block Diagram


## 2000 Family Architectural Description

Figure 2. Global Clock Structure

## Clock Distribution



Dedicated Clock 0095aisp/2000
Input Pins
Figure 3. GLB with Clock Multiplexer Scheme


0133A/2000

## 2000 Family Architectural Description

## I/O Cell and OE Structure

The reconfigurable input register or latch has been removed to simplify the I/O cell architecture. Each I/O cell can be individually programmed to be a combinatorial input, combinatorial output, or a bi-directional I/O pin with 3 -state control. With the simplified I/O cell architecture, the I/O clocks have also been removed. This is illustrated in figure 4. The product term output enable (PTOE)
signal is still generated within each GLB using product term 19. The PTOE is generated in one of the eight GLBs. In addition to the PTOE, there is a global output enable (GOE) pin which can control any of the device's 3 -state output buffers. The multiplexing between the GOE and PTOE is illustrated in figure 5 . The 2032 device has one GOE, and the 2064 and 2096 devices each have 2 GOEs.

Figure 4. pLSI and ispLSI 2000 Family I/O Cell Architecture


Figure 5. pLSI and ispLSI 2000 Family Output Enable Controls


## 2000 Family Architectural Description

## Output Routing Pool (ORP)

Each megablock now contains two ORPs to increase output routability. A set of four GLBs is associated with one of the two ORPs within the megablock. The 16 outputs of the four GLBs within a megablock will feed to any of the 16 associated I/O cells. In the 1000 family, the

32 GLB outputs feed only 16 associated I/O cells. In this device family, 32 GLB outputs of a megablock can feed 32 I/O cells. Output routability has doubled. This is illustrated in figure 6. Each GLB output has an ORP bypass capability so more designs can have critical output signals. This is shown in figure 7.

Figure 6. pLSI and ispLSI 2000 Family Output Routling Pool


Figure 7. pLSI and ispLSI 2000 Family Output Routing Pool Showing Bypass


## 2000 Family Architectural Description

## Timing Model

The task of determining the timing through the device is simple and straightforward. A device timing model is shown in figure 8. To determine the time that it takes for data to propagate through the device, simply determine the path the data is expected to follow, and add the various delays together (figure 8). Critical timing paths
are shown in figure 8, using data sheet parameters. Note that the Internal timing parameters are given for reference only, and are not tested. (External timing parameters are tested and guaranteed on every device).

Figure 8. pLSI and ispLSI 2032 Timing Model


Derivations of tsu, th and tco from the Product Term Clock ${ }^{1}$

```
tsu = Logic + Reg su - Clock (min)
    = (tiobp + tgrp + t20ptxor) +(tgsu)-(tiobp + tgrp + tptck(min))
    = (#24+#28 + #35) +(#38)-(#20 + #28+#44)
2.2 ns = (1.0 + 1.3 + 4.7) + (0.8)-(1.0 + 1.3 + 3.3)
th = Clock (max) + Reg h - Logic
    = (tiobp + tgrp + tptck(max)) +(tgh) - (tiobp + tgrp + t20ptxor)
    = (#20 + #28 + #44) + (#39)-(#20 + #28 + #35)
1.6 ns = (1.0 + 1.3 + 3.3) + (3.0)-(1.0 + 1.3 + 4.7)
tco = Clock (max) + Reg co + Output
    =(tiobp + tgrp + tptck(max))+(tgco) +(torp + tob )
    = (#20 + #28 +#44) +(#40)+(#45 +#47)
8.8 ns=(1.0 + 1.3 + 3.3)+(0.7)+(1.3+1.2)
```

1. Calculations are based upon timing specs for the pLSI and ispLSI 2032-135L

## Notes

# 3000 Family Architectural Description 

## pLSI and ispLSI 3000 Family Introduction

The basic unit of logic of the pLSI and ispLSI 3000 family is closely related to that of the pLSI and ispLSI 1000 family. However, there are some notable architectural
differences: Boundary Scan, Megablock and GLB structure, Global clock structure, and I/O cell structure. A functional block diagram of the ispLSI 3256 device is shown in figure 1. The architectural differences are described in the following sections.

Figure 1. ispLSI 3256 Functional Block Diagram


0139Aisp/3256

## 3000 Family Architectural Description

## Generic Logic Block

The Twin GLB is the standard logic block of the Lattice pLSI and ispLSI 3000 Family. This Twin GLB has 24 inputs, eight outputs and the logic necessary to implement most standard logic functions. The internal logic of the Twin GLB is divided into four separate sections: The AND Array, the Product Term Sharing Array, the Reconfigurable Registers, and the Control section.

The AND array consists of two 20 Product Term Sharing Arrays which can produce the logical sum of any of the 24 Twin GLB inputs. These inputs all come from the GRP, and are either feedback signals from any of the 32 Twin GLBs or inputs from the external I/O Cells. All Twin GLB
input signals are available to the Product Terms in both the logical true and complemented forms which makes Boolean logic reduction easier.

The two Product Term Sharing Arrays (PTSA) take the 20 Product Terms each and allocate them to four Twin GLB outputs. There are four OR gates, withfour, four, five and seven inputs respectively. The output of any of these gates can be routed to any of the four Twin GLB outputs, and if more Product Terms are needed, the PTSA can combine them as necessary. If the user's main concern is speed, the PTSA can use a bypass circuit with four Product Terms to increase the performance of the cell. This can be done to any or all of the eight outputs of the Twin GLB.

Figure 2. Twin GLB: Product Term Sharing Array


## 3000 Family Architectural Description

## Megablock Structure

Four Twin GLBs make up a Megablock. Each GLB has a maximum fan-in of 24 inputs, and no dedicated inputs associated with any Megablock. A GLB has eight asso-
ciated outputs. A total of 32 GLB outputs are fed to the ORP. However, only 16 out of the 32 outputs feed to 16 I/O cells. The Megablock structure is shown in figure 3.

Figure 3. pLSI and ispLSI 3000 Family Megablock Block Diagram


## Global Clock Structure

The global clock structure is made up of five global clock input pins, $\mathrm{Y} 0, \mathrm{Y} 1, \mathrm{Y} 2, \mathrm{Y} 3$, and Y 4 . This is shown in figure 4. Three of the clock pins are dedicated for GLB clocks and the remaining two clock pins are dedicated for I/O register clocks. The clock GLB generation network which
is designed into the 1000 device family has been removed so all input clock signals are fed directly to the GLB clock input via a clock multiplexer. The GLB global clocks do not have inversion capability, but the product term clock does have inversion capability before it reaches the clock multiplexer.

Figure 4. pLSI and ispLSI 3000 Family Global Clock Structure


## 3000 Family Architectural Description

## I/O Cells

The I/O cell structure architecture remains nearly the same as the 1000 Family as illustrated in figure 5 . Each I/O cell now contains Boundary Scan Registers as shown in figure 8. An input pin has only one scan register as shown in figure 9. A global test OE signal is hardwired to
all I/O cells and is useful to perform static testing of all the 3 -state output buffers within the device. In addition to the test OE signal, two global OEs are connected to all I/O pins. The product term OE is shared between two Megablocks resulting in twice the GLBs being able to use a single OE signal. The Megablock OE signal and global OE signals are fed to an OE multiplexer. The OE signals, with the exception of the test $O E$, have inversion capability after going through the OE multiplexer as shown in figure 6.

Figure 5. pLSI and ispLSI 3000 Family I/O Cell Architecture


Note:
0138A/3256
$\boldsymbol{\tau}^{\text {Note: }}$ Represents an E22CMOS Cell.

## 3000 Family Architectural Description

Figure 6. pLSI and ispLSI 3000 Family Output Enable Controls


## Boundary Scan

Boundary Scan (IEEE 1149.1 compatible) is a test feature incorporated within the device to provide on-chip test capabilities during PCB testing. Five input signal pins, BSCAN, TDI, TCLK, TMS, TRST, and one output signal pin, TDO, are associated with the boundary scan logic cells. These signal pins occupy the same dedicated signal pins used for ISP programming. The signal BSCAN is associated with the ispEN pin, TDI corresponds to the SDI pin, TCLK corresponds to the SCLK pin, TMS corre-
sponds to the MODE pin, and TDO corresponds to the SDO pin. When ispEN is asserted low, the MODE, SDI, SDO, and SCLK options become active for ISP programming. Otherwise, BSCAN, TDI, TCLK, TMS, TDO, and TRST options become active for boundary scan testing of the device. The boundary scan block diagram is shown in figure 7. TDI is the test data serial input, TCLK is the boundary scan clock associated with the serial shift register, TMS is the test mode select input, TDO is the test data output, and finally TRST is the reset signal pin.

Figure 7. Boundary Scan Block Diagram


## 3000 Family Architectural Description

The user interfaces to the boundary scan circuitry through the Test Access Port (TAP). The TAP consists of a control state machine, instruction decoder and instruction register.

The TAP is controlled using the test control lines: Test Data IN (TDI), Test Data Out (TDO), Test Mode Select (TMS), Test Reset (TRST) and Test Clock (TCK).

The TAP controls the operation of the Boundary Scan Registers after decoding the instruction code sent to the instruction register (see table 1).

The Boundary Scan Registers for the I/O cells are shown in figure 8. As illustrated in the figure, each I/O cell contains 3 registers, 2 latches and 5 multiplexers to
implement the ability to capture the state of the I/O cell or set the state of the output path of the cell or function as a conventional I/O cell.

The Boundary Scan Registers required for an input only cell are shown in figure 9. An input only cell can only have its state captured, which only requires one MUX and one register.

All of the input cells and I/O cells are serially connected together in a long chain. The scan out of one cell is connected to the scan in of the next cell. The cells are connected in the following order: TDI to IO63 thru IO32 to Y4, Y3, Y2, Y1, Reset, TOE, GOE1, GOE0, Y0, IO31 thru IO0 to IO64 thru IO127 to TDO.

Figure 8. Boundary Scan Registers for I/O Cells


## 3000 Family Architectural Description

Figure 9. Boundary Scan Registers for an Input Only Cell


Table 1. Boundary Scan Instruction Codes

| Instruction Name | Code | Description |
| :---: | :---: | :--- |
| SAMPLE/ PRELOAD | 10 | Loads and shifts data into BScan registers |
| EXTEST | 00 | Drives external I/O with BScan registers |
| BYPASS | 11 | Bypasses registers of selected device(s) |

Note: LSB shifts in 1st.
Table 10-0006

## Timing Model

The task of determining the timing through the device is simple and straightforward. A device timing model is shown in figure 10. To determine the time that it takes for data to propagate through the device, simply determine the path the data is expected to follow, and add the
various delays together (figure 11). Critical timing paths are shown in figure 10, using data sheet parameters. Note that the Internal timing parameters are given for reference only, and are not tested. (External timing parameters are tested and guaranteed on every device).

Figure 10. pLSI and ispLSI 3256 Timing Model


## 3000 Family Architectural Description

Figure 11. Timing Calculation Example
Derivations of tsu, th and tco from the Product Term Clock ${ }^{1}$

```
tsu = Logic + Reg su - Clock (min)
    = (tiobp + tgip4 + t20ptxoui) + (tysu) - (tioop + tgrp4 + tptck(min))
            = (#24+ #31+#39) + (#42)-(#24+ #31+ #48)
    6.5 ns = (2+4+8.5) + (1.5)-(2+4+3.5)
th = Clock (max) + Reg h - Logic
            = (tiobp + tgrp4 + tptck(max)) + (tgh) - (tiobp + tgrp4 + t20ptxor)
            = (#24+ #31+#48) + (#43)-(#24+ #31+ #39)
    8 ns=(2+4+7.5)+(9)-(2+4+8.5)
tco = Clock (max) + Reg co + Output
            = (tiobp + tgrp4 + tptck(max)) +(tgco) + (torp + tob)
            = (#24 + #31 + #48) + (#44) + (#49 + #51)
    20 ns=(2+4+7.5)+(1.5)+(2+3)
```

1. Calculations are based upon timing specs for the pLSI and ispLSI 3256-70L

## ispLSI Architecture and Programming

## ispLSI Programming Information

The following general programming information on the ispLSI (in-system programmable Large Scale Integration) devices describes how the internal state machine is implemented for programming and how to use the five programming interface signals to step through the state machine. The device specific information, such as timing and pin-outs, can be found in the individual data sheets. The programming information given in this section applies to all ispLSI devices.

## Programming Overview

To distinguish between normal operation and programming, two modes are defined: normal mode and edit mode. Once the device is in edit mode, the entire programming operation of the device is controlled by the internal ISP state machine. The in-system programming enable (ispEN) signal controls the device operation modes.

The programming is controlledbytheon-chipstate machine via five programming interface signals. The ispEN signal is used to enable and disable the four programming control signals which include Serial Data In (SDI), Mode (MODE), Serial Data Out (SDO) and Serial Clock (SCLK). Whenthe device is in normal mode, the four programming control signal pins can be used as normal Dedicated Input Pins. Figure 1 illustrates one such possible configuration for programming multiple ispLSI devices. With this scheme the ispEN signal for individual devices is enabled separately and one device is placed in the edit mode at a time. Since the otherdevices are inthe normal mode, they can continue to perform normal system functions. This simple scheme requires connecting all four programming control signal pins together and precludes their use as dedicated inputs fornormal systemfunctions. ispEN is the only programming interface signal that is dedicated to a pin.

Figure 1. ispLSI Programming Interface


# ispLSI Architecture and Programming 

## Normal Mode

In Normal Mode the four programming control pins become Dedicated Input pins. By multiplexing the programming control pins, these programming control pins can have a normal input function during Normal Mode. Figures 2 illustrates how to utilize the four programming control signalpins for performing normal systemfunctions. Internal to the device, the programming functions are completely isolated from the normal operating functions when the device is in Normal Mode. Keeping the ispEN signal high puts the device in Normal Mode. For simplicity, the four programming control pins can be left unused for normal input functions. These pins can be reserved for ISP by using the ISP switch in the development tools. By leaving these pins unused, the programming interface is simplified when the programming signals and the Normal Mode input signals are not multiplexed.

## Edit Mode

Programming circuitry is enabled by driving the ispEN signal low which puts the device in Edit Mode. In Edit Mode, all the functional I/O pins and input pins that are not used during programming are 3-stated. With the exception of the SDO signal, the remainder of the programming interface signals are input signals. When multiplexing the programming interface signals, the input driving the SDO pin must be 3-stated to make sure that there is no signal contention. All programming is accomplished in the Edit Mode by controlling the programming state machine with the MODE and SDI signals. SCLK is used to clock programming data in and out through SDI and SDO pins. SDI has a dual role as one of the two control signals for the state machine and as the serial data input. To avoid any internal register data contentions, Lattice recommends that the device Reset pin be pulled to ground when the device is in Edit Mode.

## Programming Interface

The five programming interface pins are ispEN, SDI, MODE, SDO and SCLK. Once in Edit Mode, programming is controlled by SDI, MODE, SDO and SCLK signals. In Normal Mode, the programming control pins can be used as dedicated inputs to the device.
$\overline{\text { ispEN }}$ is an active low, dedicated enable pin, which enables the four programming control pins when it is driven low ( $\mathrm{V}_{\mathrm{IL}}$ ) and disables the programming control pins when it is driven high ( $\mathrm{V}_{\mathrm{IH}}$ ). All other I/O pins are 3 -stated during Edit Mode and pulled up by the internal active pull-up resistors (equivalent to $100 \mathrm{~K} \Omega$ ).

SDI performs two different functions. First, as the input to the serial shift registerand second, as one of the two control pins for the programming state machine. Because of this dual role, SDI's function is controlled by the MODE signal. When MODE is low SDI is the serial input to the shift registers and when MODE is high SDI becomes the control signal. Internal to the device, the SDI is multiplexed to address shift register, high order data shift register and low order data shift register. The different shift instructions of the state machine determine which of these shift registers gets the input of the SDI.

The MODE signal combined with the SDI signal controls the programming state machine. This signal connects in parallel to all ispLSI devices.

SCLK is the serial shift register clock that is used to clock the internal serial shift registers. A low-to-high (positive) clock transition clocks the state machine. It also connects in parallel to all ispLSI devices. Similar to SDI, the shift instructions determine which of the shift registers are clocked for the data input from SDI.

SDO is the output of the serial shift registers. The selection of the shift register is determined by the state machine's shift instruction. In the flow through instruction and when MODE is driven high, SDO connects directly to SDI, and bypasses the device's shift registers. Since this is the only output pin for the Edit Mode, this signal will drive the external devices that are connected to this pin.

# ispLSI Architecture and Programming 

## Programming Details

Programming is completely controlled by the state machine, once the device is in the Edit Mode. The state machine consists of three states, in which all programming related operations are performed. In order to run these programming operations, five bit instructions are defined (see table 2). Each instruction is then shifted into the device in one of the three states and executed in another state. The initial state of the state machine is used when the device is idle during edit, or to shift out the eight bit device identification code.

The following sections describe the general information about the critical timing parameters, state machine, state machine instructions, and device layout that apply to all the ispLSI devices. Any device specific information like the size of the shift registers and the device specific timing information can be found in the individual device data sheets.

There are various ways of programming the ispLSI devices. The easiest is to dedicate the ISP programming pins only for the programming functions. With dedicated ISP pins, one can either program the devices in a serial daisy chain configuration (figure 1) or in a parallel programming configuration where the programming signals are multiplexed. The parallel multiplexed programming method gives the user another advantage of being able to use the programming pins for system functions. Figure 2 illustrates a multiplexing scheme which allows the user to control the ISP programming through multiple ispEN signals. The multiple ispEN signals not only control the ispEN inputs of the ispLSI devices, but also is the control signal for multiplexing the functional signals and the ISP programming signals. The ISP programming signals MODE, SDI and SCLK function as inputs for normal functional mode as well as the ISP programming mode. SDO, however, functions as an input in normal functional mode and as an output in ISP programming mode. Figure 2 also shows the difference in controlling these different programming signals.

Figure 2. The Scan and Multiplex Programming Mode


## ispLSI Architecture and Programming

## Critical Timing Parameters

When programming ispLSI devices, there are several critical timing parameters that must be met to ensure proper programming. The two most critical parameters are the programming pulse width ( $\mathrm{t}_{\mathrm{pwp}}$ ) and the bulk erase pulse width ( $t_{\text {bew }}$ ). These pulse widths determine the programming and erasing of the $\mathrm{E}^{2}$ cells. Figure 4 shows these critical program and erase timing specifications.

Along with the two programming and erasing specification, the following timing specifications must also be met.
$\mathrm{t}_{\text {isp }}$ - $\quad$ Specifies the time it takes to get into the ISP mode after ispEN signal is activated or the time it takes to come out from the ISP mode after the ispEN becomes inactive.
$t_{\text {su }}$ - Set up time of the control signals before the SCLK or the set up time of input signals against other control signals where applicable.
$t_{h}$ - Hold time of the control signal after the SCLK. It also applies to the same input signals from the set up time.
$\mathrm{t}_{\mathrm{clkl},-} \quad$ Minimum clock pulse width.
$\mathrm{t}_{\mathrm{clkh}}$
$t_{p w v^{-}}$
Verify or read pulse width. The minimum time requirement from the rising clock edge of verify/ load instruction execution to the next rising clock edge (see figure 4).
$\mathrm{t}_{\text {rst }}$ - Power on reset timing requirement. $\mathrm{t}_{\text {rst }}$ must elapse after power up before any operations are performed on the device.
All the programming timing parameters are summarized in the timing diagram (see figure 5).

Figure 4. Program, Verify \& Bulk Erase Timing


Figure 5. ISP Programming Timing Requirements


## ispLSI Architecture and Programming

Figure 6. Programming State Machine


## State Machine Operation

The state machine has three states to control programming and uses the MODE and SDI signals as inputs for each state. Based on these input signals, the state machine makes decisions to either stay in the same state or to branch to another state. The three states are Idle/ID State, CommandShiftState and ExecuteState. The programming state machine diagram in figure 6 shows the three states and the logic levels of the control signals needed to force each transition state.

## Idle/ID State

The Idle/ID state is the first state which is active when the device gets into the Edit Mode. The state machine is in the Idle/ID state when the device is idle, in the Edit Mode, or when the user needs to read the device identification. The eight bit device identification is loaded into the shift register by driving MODE high, SDI low and clocking the state machine with SCLK. Once the ID is loaded, it is read out serially by driving MODE low. Notice that when reading the device ID serially, SDI can either be high or low (don't care) and the state machine needs only seven clocks to read out eight bits of ID. The default state for the control signals is MODE high and SDI low. State transition to Command Shift State occurs when both MODE and SDI are high while state machine gets a clock transition. Table 1 lists the eight bit device ID's for all the ispLSI devices. As with most shift registers the Least Significant Bit (LSB) of the ID gets shifted out from the SDO first.

## Command Shift State

This state is strictly used for shifting in the command instructions into the state machine. The entire five-bit instruction set is listed in the next section. When MODE is low and SDI is don't care in the Command Shift State,

Table 1. ispLSI Device ID Codes

| Device | MSB |
| :---: | :---: |
| ispLSI 1016 | LSB |
| ispLSI 1024 | 00000001 |
| ispLSI 1032 | 00000010 |
| ispLSI 1048 | 00000011 |
| ispLSI 1048C | 00000100 |
| ispLSI 2032 | 00000101 |
| ispLSI 3256 | 00010101 |

SCLK shifts the instruction into the state machine. Once the instruction is shifted into the state machine, the state machine must transition to the Execute State to execute the instruction. Driving both MODE and SDI high and applying the clock will transfer the state machine from the Command ShiftState to Execute State. If needed, the state machine can move from Command Shift State to Idle/ID State by driving MODE high and SDI low.

## Execute State

In the Execute State, the state machine executes instructions that are loaded into the device in the Command Shift State. For some instructions, the state machine requires more than one clock to execute the command. An example of this multiple clock requirement is the address or data shift instruction. The number of clock pulses required for these instructions depends on the device shift register sizes (refer to the ISP programming section of the data sheet). When executing instructions such as Program, Verify or Bulk Erase, the necessary timing requirements must be followed to make sure that the commands are executed properly. For specific timing information refer to the individual data sheets.

## ispLSI Architecture and Programming

To execute a command, the MODE is driven low and SDI is "don't care." For multiple clock instructions the control signals must remain in the same state throughout the duration of the execution. MODE high and SDI high will take the state machine back to the Command Shift State and MODE high and SDI low will take the state machine to the Idie/ID State.

## Instructions

Table 2 lists the instructions that can be loaded into the state machine in the Command Shift State and then executed in the Execute State. Notice that reading the
device identification is done during the Idle/ID State and does not require an instruction.

While it is possible to erase the individual arrays of the device, it is recommended that the entire device be erased (UBE) and programmed in one operation. This Bulk Erase operation should precede every programming cycle as an initialization.

When a device is secured by programming the security cell (PRGMSC), the on-chip verify and load circuitry is disabled. Securing of the device should be done as the last procedure after all the device verifications have been completed. The only way to erase the security cell is to perform a bulk erase on the device.

Table 2. State Machine Instruction Set

| Instruction | Operation | Description |
| :---: | :---: | :--- |
| 00000 | NOP | No operation performed |
| 00001 | ADDSHFT | Address Register Shift: Shifts address into the address shift register from <br> SDIN. |
| 00010 | DATASHFT | Data Register Shift: Shifts data into or out of the data serial shift register. |
| 00011 | UBE | User Bulk Erase: Erase the entire device. |
| 00100 | GRPBE | Global Routing Pool Bulk Erase: Bulk erases the GRP array only. |
| 00101 | GLBBE | Generic Logic Block Bulk Erase: Bulk erases all the GLB array only. |
| 00110 | ARCHBE | Architecture Bulk Erase: Bulk erases the architecture array and l/O <br> configuration only. |
| 00111 | PRGMH | Program High Order Bits: The data in the data shift register is pro- <br> grammed into the addressed row's high order bits. |
| 01000 | PRGML | Program Low Order Bits: The data in the data shift register is pro- <br> grammed into the addressed row's low order bits. |
| 01001 | PRGMSC | Program Security Cell: Programs the security cell of the device. |
| 01010 | VER/LDH | Verify/Load High Order Bits: Load the data from the selected row's high <br> order bits into the data shift register for verification. |
| 01011 | VER/LDL | Verify/Load Low Order Bits: Load the data from the selected row's low <br> order bits into the data shift register for verification. |
| 01100 | GLBPRLD | Generic Logic Block Preload: Preloads the registers in the GLB with the <br> data from SDIN. All registers in the GLB form a serial shift register. Refer <br> to device layout section for details. |
| 01101 | IOPRLD | l/O Preload: Preloads the I/O registers with the data from SDIN. All <br> registers in the I/O cell form a serial shift register (the same order as GLB <br> registers). |
| $\mathbf{0 1 1 1 0}$ | FLOWTHRU | Flow Through: Bypasses all the internal shift registers and SDOUT be- <br> comes the same as SDIN. |
| 10010 | VE/LDH | Verify Erase/Load High Order Bits: Load the data from the selected row's <br> high order bits into the data shift register for erased verification. |
| 10011 | VE/LDL | Verify Erase/Load Low Order Bits: Load the data from the selected row's <br> low order bits into the data shift register for erased verification. |

## Device Layout

The purpose of knowing the device layout is to be able to translate the JEDEC format programming file into the serial data stream format for programming ispLSI devices. Two main factors determine how the translation is implemented: the length of the address shift register and the length of the data shift register. The length of the address shift register indicates how many rows of data are to be programmed into the device. The length of the data shift register indicates how many bits are to be programmed in each row. Both registers operate on the First In First Out (FIFO) basis where the Least Significant Bit (LSB) of the data or address is shifted in first and the Most Significant Bit (MSB) of the data or address is shifted in last. For the data shift register, the low order bits and the high order bits are separately shifted.

Each ispLSI device has a predefined number of address rows and data bits needed to access its $\mathrm{E}^{2} \mathrm{CMOS}^{\circledR}$ cells during programming. The data bits span the columns of the $E^{2}$ array. From this information the number of programming cells (or fuses) are determined. Table 3 highlights the address and data shift register (SR) sizes for all ispLSI devices. The JEDEC file for these ispLSI devices will reflect the number of cells (fuses) seen in table 3. The total number of cells becomes critical if the programming patterns are to be stored in an on-board memory storage of limited capacity such as EPROM or PROM.

The Lfield in the JEDEC programming file indicates the first cell number of each row. The JEDEC standard requires that there is at least the beginning cell number L00000. $L$ fields of the subsequent lines are optional. From this reference cell location all other cell locations can be determined. Zero in the cell location indicates that the $E^{2}$ cell in that particular location is programmed (or has a logic connection equivalent to a metal fuse being intact). A one (1) in the cell location indicates that the cell is erased (equivalent to a blown fuse). The fusemap operation in the Lattice software generates this JEDEC standard programming file.

## Fuse Map to Device Conversion

One of the major elements needed to program an ispLSI device is the JEDEC fuse map in which the specific logic implementation is stored. While the ispCODE software takes care of these details, it is important to understand how this JEDEC fuse map is mapped onto the physical ispLSI device during programming. The physical layout of the fuse pattern begins with Address Row 0 and ends with the maximum Address Row N and is determined by the length of the Address SR as described in table 3. Spanning the Address Rows are the outputs of the High-Order Data SR and Low-Order Data SR, as described in table 4. Programming fuses on a given row are enabled by a "1" within the Address Shift Register for the appropriate row and the use of state machine instructions that selectively operate on the High-Order Data SR or the Low-Order Data SR. For example, the PRGMH instruction programs the High-Order data bits within the device for the selected Address Row and the PRGML instruction programs the Low-Order data bits (table 2 lists the ISP state machine instructions). Referring to figure 7, the starting cell (LOOOOO) of the JEDEC fuse map shifts into the device at the physical location corresponding to Address Row 0, High-Order Data SR bit 0 . $n$ and $m$ in the figure refer to the Address SR length and the Data SR length, respectively, of the device (refer to table 3). A series of sequential shifts eventually results in the last cell location (Total \# of Cells - 1) of the JEDEC fuse map shifting into Address Row ( $n-1$ ), LowOrder Data SR bit ( $\mathrm{m}-1$ ) on the actual device.

The ispCODE Software routines make use of a bit packed data format, called ispSTREAM ${ }^{\text {TM }}$, to transfer data between the JEDEC fuse map and the physical device locations. The JEDEC fuse map can be translated into ispSTREAM using the isp_jedtoisp function and the ispSTREAM format can be translated into a JEDEC fuse map using the isp_isptojed function.

## Command Stream

The first step of programming the ispLSI devices is to determine the type of device to be programmed. This can be done by reading the eight-bit device ID of all the devices.

Table 3. ispLSI Address and Data Shift Register and Total Cell Summary

|  | ispLSI 1016 | ispLSI 1024 | ispLSI 1032 | ispLSI 1048 | ispLSI 2032 | ispLSI 3256 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Address SR Length | 96 | 102 | 108 | 120 | 102 | 180 |
| Data SR Length/Address | 160 | 240 | 320 | 480 | 80 | 676 |
| Total Number of Cells | 15,360 | 24,480 | 34,560 | 57,600 | 8,160 | 121,680 |

Table 4. Summary of Data Shift Register Bits

| Data SR Bits | ispLSI 1016 | ispLSI 1024 | ispLSI 1032 | ispLSI 1048 |
| :--- | :---: | :---: | :---: | :---: |
| High Order Data SR LSB | 0 | 0 | 0 | 0 |
| High Order Data SR MSB | 79 | 119 | 159 | 239 |
| Low Order Data SR LSB | 80 | 120 | 160 | 240 |
| Low Order Data SR MSB | 159 | 239 | 319 | 479 |
| Data SR Size (Bits) | 160 | 240 | 320 | 480 |

Figure 7. ispLSI Device to Fuse Map Translation


By keeping the SDI to a known level (either high or low), the ID shift can be terminated when a sequence of eight ones or eight zeros is read. From the device ID the serial bit stream for programming can be arranged. A typical programming sequence is as follows:

1) ADDSHFT command shift
2) Execute ADDSHFT command
3) Shift address
4) DATASHFT command shift
5) Execute DATASHFT command
6) Shift high order data
7) PRGMH command shift
8) Execute PRGMH
9) DATASHFT command shift
10) Execute DATASHFT command
11) Shift low order data
12) PRGML command shift
13) Execute PRGML
14) Repeat from 1) until all rows are programmed.

## Diagnostic Register Preload

This section explains how to preload all of the buried registers and I/O registers to a known state to test the logic function of a device. The process of loading the register will reduce the time necessary to test a function that is deeply embedded in the logic of an ispLSI device.

To preload a device the ISP state machine is used with the same five pins that are used for programming ispEN, SDI, MODE, SDO and SCLK. Two state machine commands
preload all of the registers: GLBPRLD and IOPRLD. These two commands enable two different shift registers and enable data to be loaded into the device. The process of loading data into the device is:

1. Enter the ISP programming mode by driving ispEN to Vil.
2. Load command GLBPRLD and execute command (wait one tclk).
3. Clock in the GLB preload data.
4. Load the command IOPRLD and execute the command (wait one tclk).
5. Clock in the I/O preload data.
6. Return to the normal mode by driving the $\overline{\operatorname{sisEN}}$ pin to Vih.

## 7. Execute the vectors.

When preloading a device it is important to keep the dedicated input pins (RESET, Y0, Y1, Y2 and Y3) in the same state as the previous vector. If the state of these pins is switched during the preload sequence the register may not load correctly and the results cannot be guaranteed.

The preload feature is not recommended on designs which use product term resets. The asynchronous nature of these resets can cause registers to be reset unexpectedly, therefore the results cannot be guaranteed.
There are two shift registers used to preload an ispLSI device, the GLB shift register and the I/O shift register (see table6). The data format for both devices is shown in figure 9. The GLB registers are listed with their outputs (i.e. (A7 O 0 ) indicating output 0 , of GLB A7).

Table 6. Preload Shift Registers

| Device | GLB Shift Reg. Length | I/O Shift Reg. Length |
| :---: | :---: | :---: |
| ispLSI 1016 | 64 bits | 32 bits |
| ispLSI 1024 | 96 bits | 48 bits |
| ispLSI 1032 | 128 bits | 64 bits |
| ispLSI 1048 | 192 bits | 96 bits |
| ispLSI 2032 | 32 bits | N/A |
| ispLSI 3256 | 256 bits | 128 bits |

Figure 9. GLB Shift Register and I/O Shift Register Format
GLB Shift Register Format





I/O Shift Register Format


## ISP Programming Support

To assist users in implementing the ISP programming, Lattice provides the isp Engineering Kit hardware and ispCODE C language software routines which implement the basic ISP functions for programming. The Lattice ISP programming support uses the PC parallel port to program the devices.

## isp Engineering Kit Hardware Definition

Lattice provides both a PC-based (Model 100) and a Sun Workstation-based (Model 200) isp Engineering Kit. PCbased, parallel I/O port programming interface implementation is explained in this section. For details on the Model 200 refer to the Model 200 isp Engineering Kit datasheet. The main function of this ispLSI programming interface is to provide four properly timed programming signals and the ispEN signal to the device. The PC parallel port is used in the isp Engineering Kit to provide these programming signals. The signals driven by the parallel port can be used either by the Lattice isp Programming Module (part of isp Engineering Kit Model 100) or on the
system board if the circuit board is built with provisions to connect the ISP programming signals to the appropriate traces.

In the case of users using the PC serial port as the I/O port for programming, the serial data must be converted by additional circuitry into the appropriate programming signals. There must also be timing circuitry that translates the serial instructions into timed ISP programming signals. This section only discuss the parallel port interface. Lattice's isp Engineering Kit Model 200 supports serial port programming.

In order to use the PC parallel port, the parallel port operation must be defined properly. After defining the port, it is just a matter of developing the programming software to read and write from the parallel port. To guarantee the signal integrity and drive capability, a 74 HC 367 buffer should be directly connected at the parallel port's DB25 connector. Figure 11 defines the parallel port DB25 pins and the associated ISP programming signals. The global RESET signal is also provided to ensure a proper register reset after programming.

Figure 10. Configuring an ispLSI Device from a Remote System


The buffer then drives the cable that connects the output of the buffer to the ISP pins of the device. It is important to keep the cable length to a minimum to reduce the loading on the signal drivers. Since ispEN, SDI, SCLK and MODE are inputs to the ispLSI device, they are being driven by the buffer connected to the parallel port. SDO, on the other hand, is an output signal which the ispLSI device has to drive. If the load on the SDO signal is more than a minimum length cable and the parallel port input, it is recommended that the user provide a buffer on the circuit board to ensure signal integrity.

For the parallel port interface, the software must access the proper parallel port address. Once the port is defined, the data transfer is accomplished by simply reading from the port and writing to the port. The software must also guarantee proper timing between the ISP programming signals. When the programming software is executed, most of the shorter hardware timing requirements are automatically met due to the relatively long instruction execution times. The programming pulse width (tpwp) and bulk erase pulse width (tbew), which are in the 40 ms to 200 ms range, are the hardware timings that typically require wait states in the software. The example functions in the ispCODE illustrates reading of the computer's timer chip to generate these wait states.

Based on the programming pulse width requirement, the total programming time can be estimated. Since the shifting the address and data is relatively small compared to the programming time, the total programming time can be estimated by the following formula.

Total Programming Time $=$ Address SR Length $X 2 \times$ tpwp
Assuming that the programming pulse width (tpwp) is 100 ms , the total programming time for the ispLSI 1048 is approximately 24 seconds.

## Microprocessor-Based Programming

Similar to PC-based I/O port controlled programming, a processor or a microprocessor can be used to directly supply the ISP programming signals with minimum decoding logic and an optional storage device (see figure 12). The discussion in this section pertains to the implementation of ISP programming on a circuit board with a microprocessor. The discussion is based on the assumption that the patterns and the code are stored in EPROMs. Since an efficient use of storage is desirable, the bit packed ispSTREAM format will use the least amount of storage. The basic requirement here, again, is to supply properly timed ISP programming signals.

Figure 11. PC Parallel Port Buffer \& RJ45 Connector Definition


## Hardware Configuration

There are several ways to define the ISP programming hardware depending on the type of storage device and how the ispLSI devices are to be programmed. The hardware configuration shown in figure 13 uses an 8-bit wide EPROM to store the fuse maps and code. The patterns are then read from the EPROM by the microprocessor and converted into serial stream format. The ISP signals are driven from the decoder and I/O port which decodes the proper ISP read/write address space similar to the I/O port definition of the previous setup. Similarly, fuse map memory addresses must also be defined to be properly read from the EPROM.

Programming pattern storage requirements are directly dependent upon the ispLSI device type and which ISP functions must be executed by the microprocessor. Assuming the bit packed ispSTREAM format for the fuse map, the number of bytes required for each ispLSI device is simply the total number of cells divided by eight. In the case of ispLSI $1048,7.2 \mathrm{~K}$ bytes is required to store the JEDEC fuse map.

Similar to the parallel port interface, most hardware timing requirements can be satisfied by the software instruction execution time. Only the program, verify and bulk erase times requires the software to have wait cycles. Many microprocessor boards will not have a timer chip to time the wait states. However, the instruction execution times typically can be accurately estimated. Therefore, timing loops must be inserted into the instructions control critical hardware timing.

Software support for this case is very similar to the previous. Within the software, however, address spaces for the ISP read/write locations and the EPROM read locations must be defined. The storage space requirement for the code must also be determined if the code is going to reside in the storage device. Based on the ispCODE functions, the object code which is capable of executing basic ISP functions typically does not exceed 8 K byte of memory. This memory requirement is directly proportional to the amount of ISP and user interface functions.

## ISP Software Interface

In addition to the hardware interface, the ispCODE C language routines take care of the ispLSI programming software interface. The software interface must implement routines to read and write from the parallel port, to translate the JEDEC fusemap to and from the stream file format, and to toggle the ISP hardware signals connected at the output port. Predefined routines for these functions such as isp_program, isp_read, isp_verify, etc. are provided with the ispCODE. The ispLSI user only needs to integrate these routines into their overall system software.

The ispCODE routines makes use of the ispSTREAM bit packed data format to transfer data between the JEDEC fuse map and the physical device location. The JEDEC fuse map can be translated into ispSTREAM using the isp_jedtoisp function and the ispSTREAM format can be translated into a JEDEC fuse map using the isp_isptojed function. In addition to the fuse map translation routines, the ispCODE provides functions to check the device ID, to read and write the User Electronic Signature (UES), and to

Figure 12. Configuring an ispLSI Device from an On-Board Microprocessor


## ispLSI Architecture and Programming

keep track of the program cycle counter. Refer to the ispCODE User Manual for more details.

## ispLSI Device Special Features

In addition to transfering the fuse pattern into the ispLSI device with proper ISP timing, there are a few administrative functions that can make device programming more efficient when implemented in the ISP programming algorithm.

All ispLSI devices have hardwired device identification codes. These ID codes should be used to identify proper device and fuse map compatibility. The ID check should be run as the very first procedure before any device programming procedures. The ispCODE routines provided by Lattice include the isp_get_id function to facilitate this process.

The ispLSI devices also provide several programmable locations for the UES and program cycle counter. The UES can be used to identify which pattern is programmed into
the device. This is a very useful way of electronically identifying the devices and their programs, especially when the devices are secured. A 16-bit program cycle counter can be implemented within the reserved loacation, similar to the UES, to keep track of the number of program cycles which the device experiences to avoid exceeding the maximum programming cycle limit. UES and program cycle counter routines are provided as part of Lattice's ispCODE software.

One of the diagnostic features of the ispLSI devices is register preload. GLB and I/O registers become serial shift registers during the register preload command execution. Data can either be shifted into or out of these shift registers for system diagnostic functions. Special attention must be paid to the GLB and I/O clocks in order to use the register preload features properly. One must drive all GLB or all I/O clocks high throughout the execution of the GLB or I/O preload commands. This means that when defining the test pattern that uses the preload commands all GLB or all I/O clock polarities must be the same.

Figure 13. Microprocessor Board Configuration


# ispLSI Architecture and Programming 

## Boundary Scan

The Lattice 3000 family of devices supports the IEEE 1149.1 Boundary Scan specifications. The following sections explain in detail how to interface to the devices through the Test Access Port (TAP), how the boundary scan registers are implemented within the devices, and the boundary scan instructions that are supported by the pLSI and ispLSI 3000 family

## Test Access Port (TAP)

The test access port of the boundary scan is accessed through six interface signals. These interface signals have dual functions in the case of ispLSI 3000 family and are used for Boundary Scan interface and in-system programming interface signals. For the pLSI 3000 family the six interface signals are only used for the boundary scan TAP interface. Table 7 describes the interface signals.

The abovementionedsixsignals are dedicated for Boundary Scan use for the pLSI family of devices. Since ISP programming is accomplished through the same pins, five of the six signals have both Boundary Scan interface and ISP functions on the ispLSI devices. The TRST is the only signal that does not have a dual function. It is only used to reset the TAP controller state machine. The sequencing of test routines are governed by the TAP controller state machine. The state machine uses the TMS and TCK signals as its inputs to sequence the states. Figure 14A is the IEEE1149.1 specified state machine where the condition for the state transtion is the state of the TMS input condition before TCK within a given state. The timing specification is also shown on figure 14B.

The main features of the TAP controller state machine consists of Test-Logic-Reset state to reset the controller and the Run-Test states. Two main components of the Run-Test states are Data Register (DR) control states and Instruction Register (IR) control states. Both of these register control states are organized in a similar manner where one can capture the registers, shift the register string, or update the registers. Capturing the DRs simply loads the $D R$ with the data from the corresponding functional input, output, or I/Opins. The IR capture, on the other hand, loads the IRs with the previously executed instruction bits. Shift register states serially shifts the DR and IR. In the case of DR shift, the data is shifted according to the order of the inputs, outputs, and $\mathrm{I} /$ Os defined in the Boundary Scan section of each device data sheet. The IRs are shifted out from the least significant bit first. During update registers states, the DRs update the latches to drive the external pins and IRs update the instruction bits with the instruction that is to be executed.

## Boundary Scan Registers

In order to support Boundary Scan, two types of data registers are defined for the ispLSI/pLSI devices -- //O cell registers and input cell registers. The main purpose of these registers is to capture test data from the appropriate signals and shift data to either drive the test pins or examine captured test data.

Figure 15 describes the register for the I/O cell. The I/O cell, by definition, must have three components. One register component captures the output enable (OE) signal, the second component captures the output data and the third

## Table 7. Boundary Scan Interface Signals

| pLSI 3000 <br> Family | ispLSI 3000 <br> Family | Pin Function Description |
| :--- | :--- | :--- |
| BSCAN | BSCAN/ispEN | Active high signal on this pin selects the Boundary Scan function while active low signal <br> selects the ISP function on the ispLSI devices. Internal pullup on this pin drives the <br> signal high when the external pin is not driven. |
| TCK | TCK/SCLK | Test Clock function for Boundary Scan and serial clock for the ISP function. |
| TMS | TMS/MODE | Test Mode Select for Boundary Scan and MODE control for ISP function. |
| TDI | TRI/SDI | Test Data Input for Boundary Scan and Serial Data Input for ISP pin functions as serial <br> data input pin for both interfaces. |
| TRST | TDO/SDO | Test Reset Input is an asynchronous signal to initialize the TAP controller to <br> Test-Logic-Reset state. |
| TDO | Test Data Output for Boundary Scan and Serial Data Output for ISP pin functions as <br> serial data output pin for both interfaces. |  |

## ispLSI Architecture and Programming



Figure 14A. TAP Controller State Machine


Figure 14B. TAP Controller Timing Diagram


Figure 15. Boundary Scan I/O Cell
captures the input data. These components make up the three registers that are part of the shift register string for each of the I/O pins. Only parts of the I/O cell registers will have valid data when I/O pins are configured as input only or output only and the test routines must be able to monitor the appropriate registerbits. The update registers are used mainly to store data that is to be driven onto the I/O pins. The multiplexer controls are driven by the signal from the TAP controller at appropriate states.

The function of an input cell register is much simpler than that of an I/O cell. Figure 16 illustrates the single input register cell. The purpose of the I/O cell is to capture the input test data and shift the data out of the shift register string.


Figure 16. Boundary Scan Input Cell

## ispLSI Architecture and Programming

## Boundary Scan Instructions

LatticepLSI and ispLSI devices support the three mandatory instructions defined by the Boundary Scan definition. The following paragraphs describe each of the instructions and its instruction code. A two bit long shift register is defined within the devices to implement the instruction shift register.

TheSAMPLE/PRELOAD (Instruction Code-01) instruction is used to sample the pins that are to be tested. During Capture-DR state, while executing this instruction, the DRs are loaded with the state of the pins which can then be examined after shifting the data through TDO. The PRELOAD part of this instruction is simply loading the DRs during Shift-DR state with the desired condition for each of the pins.

Figure 17. Bypass Register


The EXTEST (Instruction Code-00) instruction drives the external pins with the previously updated values from the DR during Update-DR state.

The BYPASS (Instruction Code-11) instruction is used to bypass any device that is not accessed during any part of the test. The definition of BYPASS instruction allows the TDI not to be driven during Shift-IR state. In order to shift in the correct instruction code the TDI pin has an internal pull-up to drive a logic high. A bypassed boundary scan device has a single bypass register as shown in figure 17 below.

# Introduction to pLSI ${ }^{\circ}$ and ispLSI'" 1000 Family 

## Introduction to pLSI/ispLSI 1000 Family

Lattice Semiconductor's pLSI (programmable Large Scale Integration) and ispLSI (in-system programmable Large Scale Integration) are high-density and high-performance $\mathrm{E}^{2} \mathrm{CMOS}^{\circledR}$ programmable logic devices. They provide design engineers with a superior system solution for integrating high-speed logic on a single chip.

The Lattice pLSI and ispLSI 1000 Families combine the performance and ease of use of PLDs with the density and flexibility of FPGAs.

The pLSI and ispLSI 1000 Families are ideal for designs requiring high speeds with highly integrated logic.

The ispLSI devices have also pioneered non-volatile, insystem programmability, a technology that allows real-time programming, less expensive manufacturing and enduser feature reconfiguration.
Lattice's $\mathrm{E}^{2}$ CMOS technology features reprogrammability, the ability to program the device again and again to easily incorporate any design modifications. This same capability allows full parametric testability during manufacturing, which guarantees 100 percent programming and functional yield.

All necessary development tools are available from Lattice and third-party vendors. Development tools offered range from Lattice's low cost $\mathrm{pDS}^{\circledR}$ software, featuring Boolean entry in a graphical Windows ${ }^{\text {TM }}$ based environment, to the $\mathrm{pDS}+{ }^{\text {TM }}$ family of Fitters that interface with third party development software packages. Design systems interfacing with pDS+ Fitters feature schematic capture, state machine and HDL design entry. Designs can now be completed in hours as opposed to days or weeks.

## pLSI and ispLSI Product 1000 Family

- 110 MHz System Performance
- 10 ns Pin-to-Pin Delay
- Deterministic Performance
] High Density ( $2,000-8,000$ PLD Gates)
- 44 Pin to 128 Pin Package Options
- Flexible Architecture
- Easy-to-Use
- In-System Programmable (ispLSI)


## pLSI and ispLSI Technology

- UltraMOS E ${ }^{2}$ CMOS - the PLD Technology of Choice
- Electrically Erasable/Programmable/ Reprogrammable
- 100\% Tested During Manufacture
- $100 \%$ Programming Yield
- Fast Programming


## pLSI and ispLSI Development Tools

- Low Cost, Fully Integrated pDS Design System for the PC
- pDS+ Support for Industry-Standard ThirdParty Design Environments and Platforms
- HDL, VHDL Boolean Equation, State Machine and Schematic Capture Entry
- Timing and Functional Simulation
- PC and Workstation Platforms


## 1000 Family Overview

The pLSI and ispLSI 1000 family of high-density devices address high-performance system logic needs, ranging from registers, to counters, to multiplexers, to complex state machines.

With PLD densities ranging from 2,000 to 8,000 gates, the pLSI and ispLSI 1000 Families provide a wide range of programmable logic solutions which meet tomorrow's design requirements today.

Each device contains multiple Generic Logic Blocks (GLBs), which are designed to maximize system flexibility and performance. A balanced ratio of registers and I/O cells provides the optimum combination of internal logic and external connections. A global interconnect scheme ties everything together, enabling utilization of up to $80 \%$ of available logic. Table 1 describes the family attributes.

Table 1. pLSI and ispLSI 1000 Family Attributes

| Family Member | 1016 | 1024 | 1032 | $1048 / 1048 \mathrm{C}$ |
| :---: | :---: | :---: | :---: | :---: |
| Density (PLD Gates) | 2,000 | 4,000 | 6,000 | 8,000 |
| Speed: fmax (MHz) | 110 | 90 | 90 | 80 |
| Speed: tpd (ns) | 10 | 12 | 12 | 15 |
| GLBs | 16 | 24 | 32 | 48 |
| Registers | 96 | 144 | 192 | 288 |
| Inputs + //O | 36 | 54 | 72 | $106 / 110^{*}$ |
| Pin/Package | 44-pin PLCC <br> 44-pin TQFP <br> 44-pin JLCC | 68-pin PLCC <br> 68 -pin JLCC | 84 -pin PLCC <br> $100-$ pin TQFP <br> $84-$-in CPGA | $120-$-pin PQFP <br> 128 -pin PQFP* |

*pLSI/ispLSI 1048C Only
Table 1-0003A

## Introduction to pLSI and ispLSI 1000 Family

Figure 1. 1000 Family Packages


44-Pin PLCC
pLSI 1016
ispLSI 1016


44-Pin TQFP

44-Pin JLCC

,


68-Pin PLCC


84-Pin PLCC


100-Pin TQFP
pLSI 1032/883
\&
ispLSI 1032/883

68-Pin JLCC




120-Pin PQFP

## Notes

## Features

- PROGRAMMABLE AND IN-SYSTEM PROGRAMMABLE HIGH DENSITY LOGIC
- High-Speed Global Interconnect
- 2000 PLD Gates
- 32 I/O Pins, Four Dedicated Inputs
- 96 Registers
- Wide Input Gating for Fast Counters, State Machines, Address Decoders, etc.
- Small Logic Block Size for Random Logic
- Security Cell Prevents Unauthorized Copying
- HIGH PERFORMANCE E²CMOS ${ }^{\text {® }}$ TECHNOLOGY
- $f \max =110 \mathrm{MHz}$ Maximum Operating Frequency
- $\mathbf{f m a x}=\mathbf{6 0} \mathbf{~ M H z}$ for Industrial and Military/883 Devices
- tpd = 10 ns Propagation Delay
- TTL Compatible Inputs and Outputs
- Electrically Erasable and Reprogrammable
- Non-Volatile E ${ }^{2}$ CMOS Technology
- 100\% Tested
- ispLSI OFFERS THE FOLLOWING ADDED FEATURES
- In-System Programmable 5-Volt Only
- Change Logic and Interconnects "On-the-Fly" in Seconds
— Reprogram Soldered Device for Debugging
- COMBINES EASE OF USE AND THE FAST SYSTEM SPEED OF PLDs WITH THE DENSITY AND FLEXIBILITY OF FIELD PROGRAMMABLE GATE ARRAYS
- Complete Programmable Device Can Combine Glue Logic and Structured Designs
- Three Dedicated Clock Input Pins
- Synchronous and Asynchronous Clocks
- Flexible Pin Placement
— Optimized Global Routing Pool Provides Global Interconnectivity
- pLSI/ispLSI DEVELOPMENT SYSTEM (pDS ${ }^{\text {® }}$ ) pDS Software
— Easy to Use PC Windows ${ }^{\text {TM }}$ Interface
- Boolean Logic Compiler
- Manual Partitioning
- Automatic Place and Route
- Static Timing Table
pDS+ ${ }^{\text {TM }}$ Software
- Industry Standard, Third Party Design Environments
- Schematic Capture, State Machine, HDL
- Automatic Partitioning
- Automatic Place and Route
- Comprehensive Logic and Timing Simulation
- PC and Workstation Platforms


## Functional Block Diagram



## Description

The Lattice pLSI and ispLSI 1016 are High-Density Programmable Logic Devices containing 96 Registers, 32 Universal I/O pins, four Dedicated Input pins, three Dedicated Clock Input pins and a Global Routing Pool (GRP). The GRP provides complete interconnectivity between all of these elements. The ispLSI 1016 features 5 -Volt in-system programming and in-system diagnostic capabilities. It is the first device which offers non-volatile "on-the-fly" reprogrammability of the logic, as well as the interconnect to provide truly reconfigurable systems. It is architecturally and parametrically compatible to the pLSI 1016 device, but multiplexes four input pins to control insystem programming.
The basic unit of logic on the pLSI and ispLSI 1016 devices is the Generic Logic Block (GLB). The GLBs are labeled A0, A1 .. B7 (see figure 1). There are a total of 16 GLBs in the pLSI and ispLSI 1016 devices. Each GLB has 18 inputs, a programmable AND/OR/XOR array, and four outputs which can be configured to be either combinatorial or registered. Inputs to the GLB come from the GRP and dedicated inputs. All of the GLB outputs are brought back into the GRP so that they can be connected to the inputs of any other GLB on the device.

[^0] 뜨․․․․․

## Functional Block Diagram

Figure 1. pLSI and ispLSI 1016 Functional Block Diagram


The devices also have 32 I/O cells, each of which is directly connected to an I/O pin. Each I/O cell can be individually programmed to be a combinatorial input, registered input, latched input, output or bi-directional I/O pin with 3-state control. Additionally, all outputs are polarity selectable, active high or active low. The signal levels are TTL compatible voltages and the output drivers can source 4 mA or sink 8 mA .

Eight GLBs, 16 I/O cells, two dedicated inputs and one ORP are connected together to make a Megablock (see figure 1). The outputs of the eight GLBs are connected to a set of 16 universal I/O cells by the ORP. The pLSI and ispLSI 1016 devices contain two of these Megablocks.

The GRP has as its inputs the outputs from all of the GLBs and all of the inputs from the bi-directional I/O cells. All of these signals are made available to the inputs of the GLBs. Delays through the GRP have been equalized to minimize timing skew.
Clocks in the pLSI and ispLSI 1016 devices are selected using the Clock Distribution Network. Three dedicated clock pins (Y0, Y1 and Y2) are brought into the distribution network, and five clock outputs (CLK 0, CLK 1, CLK 2, IOCLK 0 and IOCLK 1) are provided to route clocks to the GLBs and I/O cells. The Clock Distribution Network can also be driven from a special clock GLB (BO on the pLSI and ispLSI 1016 devices). The logic of this GLB allows the user to create an internal clock from a combination of internal signals within the device.

## Specifications pLSI and ispLSI 1016

## Absolute Maximum Ratings ${ }^{1}$

Supply Voltage $\mathrm{V}_{\mathrm{cc}} \ldots \ldots \ldots .$.
Input Voltage Applied. . . . . . . . . . . . . . . 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Off-State Output Voltage Applied . . . . . -2.5 to V $\mathrm{CC}+1.0 \mathrm{~V}$
Storage Temperature . . . . . . . . . . . . . . . . . . 65 to $150^{\circ} \mathrm{C}$
Case Temp. with Power Applied . . . . . . . . 55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. Functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

DC Recommended Operating Conditions

| SYMBOL | PARAMETER |  |  | MIN. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | Commercial | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 4.75 | 5.25 | V |
|  |  | Industrial | $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 4.5 | 5.5 |  |
|  |  | Military/883 | $\mathrm{T}_{\mathrm{C}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 4.5 | 5.5 |  |
| VIL | Input Low Voltage |  |  | 0 | 0.8 | V |
| VIH | Input High Voltage |  |  | 2.0 | $\mathrm{Vcc}+1$ | V |

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

| SYMBOL | PARAMETER |  | MAXIMUM $^{1}$ | UNITS | TEST CONDITIONS |
| :--- | :--- | :--- | :---: | :---: | :--- |
| $\mathbf{C}_{1}$ | Dedicated Input Capacitance | Commercial/Industrial | 8 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{~N}}=2.0 \mathrm{~V}$ |
|  |  | Military | 10 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathbb{I N}}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{2}$ | I/O and Clock Capacitance | 10 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{10}, \mathrm{~V}_{\mathrm{Y}}=2.0 \mathrm{~V}$ |  |

1. Guaranteed but not $100 \%$ tested.

## Data Retention Specifications

| PARAMETER | MINIMUM | MAXIMUM | UNITS |
| :--- | :---: | :---: | :---: |
| Data Retention | 20 | - | YEARS |
| ispLSI Erase/Reprogram Cycles | 1000 | - | CYCLES |
| pLSI Erase/Reprogram Cycles | 100 | - | CYCLES |

Table 2-0008A-isp

## Switching Test Conditions

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Time | $\leq$ 3ns $10 \%$ to $90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See figure 2 |

3-state levels are measured 0.5 V from steady-state active level.

## Output Load Conditions (see figure 2)

Figure 2. Test Load

${ }^{*} C_{L}$ includes Test Fixture and Probe Capacitance.

| Test Condition |  | R1 | R2 | CL |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $470 \Omega$ | $390 \Omega$ | 35 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 35 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 35 pF |
| C | Active High to Z <br> at $\mathbf{V}_{\text {OH }}-0.5 \mathrm{~V}$ | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low to Z <br> at $\mathbf{V}_{\text {OL }}+0.5 \mathrm{~V}$ | $470 \Omega$ | $390 \Omega$ | 5 pF |

Table 2-0004A

## DC Electrical Characteristics

## Over Recommended Operating Conditions

| SYMBOL | PARAMETER | CONDITION |  | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | - | - | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 2.4 | - | - | V |
| $\mathrm{I}_{\mathrm{L}}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{IL}}$ (MAX.) |  | - | - | -10 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{H}}$ | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {IL }}$-isp | isp Input Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {in }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -150 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{IL}}-\mathrm{PU}$ | I/O Active Pull-Up Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ |  | - | - | -150 | $\mu \mathrm{A}$ |
| $\mathrm{Ios}^{1}$ | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.5 \mathrm{~V}$ |  | -60 | - | -200 | mA |
| $\mathrm{Icc}^{2}$ | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{TOGGLE}}=1 \mathrm{MHz} \end{aligned}$ | Commercial | - | 100 | 150 | mA |
|  |  |  | Industrial/Military | - | 100 | 170 | mA |

1. One output at a time for a maximum duration of one second. $\mathrm{V}_{\text {out }}=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not 100\% tested.
2. Measured using four 16 -bit counters.
3. Typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$. Specifications pLSI and ispLSI 1016

External Timing Parameters

## Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST } 5 \\ & \text { COND. } \end{aligned}$ | $\#^{2}$ | DESCRIPTION ${ }^{1}$ | -110 |  | -90 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd1 | A | 1 | Data Propagation Delay, 4PT bypass, ORP bypass | - | 10 | - | 12 | ns |
| tpd2 | A | 2 | Data Propagation Delay, Worst Case Path | - | 14.5 | - | 17 | ns |
| $f_{\text {max }}$ | A | 3 | Clock Frequency with Internal Feedback ${ }^{3}$ | 111 | - | 90.9 | - | MHz |
| $f$ max (Ext.) | - | 4 | Clock Frequency with External Feedback $\left(\frac{1}{\text { tsu2 }+\mathrm{tco1}}\right)$ | 70.1 | - | 58.8 | - | MHz |
| fmax (Tog.) | - | 5 | Clock Frequency, Max Toggle ${ }^{4}$ | 125 | - | 125 | - | MHz |
| tsu1 | - | 6 | GLB Reg. Setup Time before Clock, 4PT bypass | 4.5 | - | 6 | - | ns |
| tco1 | A | 7 | GLB Reg. Clock to Output Delay, ORP bypass | - | 7 | - | 8 | ns |
| th1 | - | 8 | GLB Reg. Hold Time after Clock, 4 PT bypass | 0 | - | 0 | - | ns |
| tsu2 | - | 9 | GLB Reg. Setup Time before Clock | 7.5 | - | 9 | - | ns |
| tco2 | - | 10 | GLB Reg. Clock to Output Delay | - | 8.5 | - | 10 | ns |
| th2 | - | 11 | GLB Reg. Hold Time after Clock | 0 | - | 0 | - | ns |
| tr1 | A | 12 | Ext. Reset Pin to Output Delay | - | 14 | - | 15 | ns |
| trw1 | - | 13 | Ext. Reset Pulse Duration | 10 | - | 10 | - | ns |
| ten | B | 14 | Input to Output Enable | - | 15 | - | 15 | ns |
| tdis | C | 15 | Input to Output Disable | - | 15 | - | 15 | ns |
| twh | - | 16 | Ext. Sync. Clock Pulse Duration, High | 4 | - | 4 | - | ns |
| twl | - | 17 | Ext. Sync. Clock Pulse Duration, Low | 4 | - | 4 | - | ns |
| tsu5 | - | 18 | I/O Reg. Setup Time before Ext. Sync. Clock (Y1, Y2) | 2 | - | 2 | - | ns |
| th5 | - | 19 | I/O Reg. Hold Time after Ext. Sync. Clock (Y1, Y2) | 5.5 | - | 6.5 | - | ns |

1. Unless noted otherwise, all parameters use a GRP load of 4 GLBs, 20 PTXOR path, ORP and YO clock.
2. Refer to Timing Model in this data sheet for further details.
3. Standard 16-Bit loadable counter using GRP feedback.
4. fmax (Toggle) may be less than $1 /(t w h+t w l)$. This is to allow for a clock duty cycle of other than $50 \%$.
5. Reference Switching Test Conditions Section.

## Specifications pLSI and ispLSI 1016

## External Timing Parameters

Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST }{ }^{5} \\ & \text { COND. } \end{aligned}$ | $\#^{2}$ | DESCRIPTION ${ }^{1}$ | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd1 | A | 1 | Data Propagation Delay, 4PT bypass, ORP bypass | - | 15 | - | 20 | ns |
| tpd2 | A | 2 | Data Propagation Delay, Worst Case Path | - | 20 | - | 25 | ns |
| $f_{\text {max }}$ | A | 3 | Clock Frequency with Internal Feedback ${ }^{3}$ | 80 | - | 60 | - | MHz |
| $\mathrm{fmax}^{\text {(Ext.) }}$ | - | 4 | Clock Frequency with External Feedback ( $\left.\frac{1}{\text { tsu2 }+ \text { tco1 }}\right)$ | 50 | - | 38 | - | MHz |
| fmax (Tog.) | - | 5 | Clock Frequency, Max Toggle ${ }^{4}$ | 100 | - | 83 | - | MHz |
| tsu1 | - | 6 | GLB Reg. Setup Time before Clock, 4PT bypass | 7 | - | 9 | - | ns |
| tco1 | A | 7 | GLB Reg. Clock to Output Delay, ORP bypass | - | 10 | - | 13 | ns |
| th1 | - | 8 | GLB Reg. Hold Time after Clock, 4 PT bypass | 0 | - | 0 | - | ns |
| tsu2 | - | 9 | GLB Reg. Setup Time before Clock | 10 | - | 13 | - | ns |
| tco2 | - | 10 | GLB Reg. Clock to Output Delay | - | 12 | - | 16 | ns |
| th2 | - | 11 | GLB Reg. Hold Time after Clock | 0 | - | 0 | - | ns |
| tr1 | A | 12 | Ext. Reset Pin to Output Delay | - | 17 | - | 22.5 | ns |
| trw1 | - | 13 | Ext. Reset Pulse Duration | 10 | - | 13 | - | ns |
| ten | B | 14 | Input to Output Enable | - | 18 | - | 24 | ns |
| tdis | C | 15 | Input to Output Disable | - | 18 | - | 24 | ns |
| twh | - | 16 | Ext. Sync. Clock Pulse Duration, High | 5 | - | 6 | - | ns |
| twl | - | 17 | Ext. Sync. Clock Pulse Duration, Low | 5 | - | 6 | - | ns |
| tsu5 | - | 18 | I/O Reg. Setup Time before Ext. Sync. Clock (Y1, Y2) | 2 | - | 2.5 | - | ns |
| th5 | - | 19 | I/O Reg. Hold Time after Ext. Sync. Clock (Y1, Y2) | 6.5 | - | 8.5 | - | ns |

1. Unless noted otherwise, all parameters use a GRP load of 4 GLBs, 20 PTXOR path, ORP and Y0 clock.
2. Refer to Timing Model in this data sheet for further details.
3. Standard 16 -Bit loadable counter using GRP feedback.
4. fmax (Toggle) may be less than $1 /(t w h+t w l)$. This is to allow for a clock duty cycle of other than $50 \%$.
5. Reference Switching Test Conditions Section.

## Internal Timing Parameters ${ }^{1}$

| PARAMETER | \# ${ }^{2}$ | DESCRIPTION | -110 |  | -90 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| Inputs |  |  |  |  |  |  |  |
| tiobp | 20 | I/O Register Bypass | - | 0.8 | - | 1.0 | ns |
| tiolat | 21 | I/O Latch Delay | - | 1.7 | - | 2.0 | ns |
| tiosu | 22 | I/O Register Setup Time before Clock | 4.1 | - | 4.5 | - | ns |
| tioh | 23 | I/O Register Hold Time after Clock | 1.8 | - | 2.0 | - | ns |
| tioco | 24 | I/O Register Clock to Out Delay | - | 1.7 | - | 2.0 | ns |
| tior | 25 | I/O Register Reset to Out Delay | - | 2.1 | - | 2.5 | ns |
| tdin | 26 | Dedicated Input Delay | - | 1.7 | - | 2.0 | ns |
| GRP |  |  |  |  |  |  |  |
| tgrp1 | 27 | GRP Delay, 1 GLB Load | - | 0.6 | - | 0.7 | ns |
| tgrp4 | 28 | GRP Delay, 4 GLB Loads | - | 0.8 | - | 1.0 | ns |
| tgrp8 | 29 | GRP Delay, 8 GLB Loads | - | 1.5 | - | 1.8 | ns |
| tgrp12 | 30 | GRP Delay, 12 GLB Loads | - | 2.1 | - | 2.6 | ns |
| tgrp16 | 31 | GRP Delay, 16 GLB Loads | - | 2.8 | - | 3.4 | ns |
| GLB |  |  |  |  |  |  |  |
| t4ptbp | 33 | 4 Product Term Bypass Path Delay | - | 5.3 | - | 6.5 | ns |
| t1ptxor | 34 | 1 Product Term/XOR Path Delay | - | 6.1 | - | 7.0 | ns |
| t20ptxor | 35 | 20 Product Term/XOR Path Delay | - | 6.6 | - | 8.0 | ns |
| txoradj | 36 | XOR Adjacent Path Delay ${ }^{3}$ | - | 8.2 | - | 9.5 | ns |
| tgbp | 37 | GLB Register Bypass Delay | - | 0.5 | - | 0.5 | ns |
| tgsu | 38 | GLB Register Setup Time before Clock | 0.3 | - | 1.0 | - | ns |
| tgh | 39 | GLB Register Hold Time after Clock | 2.9 | - | 3.5 | - | ns |
| tgco | 40 | GLB Register Clock to Output Delay | - | 1.6 | - | 1.5 | ns |
| tgr | 41 | GLB Register Reset to Output Delay | - | 2.1 | - | 2.5 | ns |
| tptre | 42 | GLB Product Term Reset to Register Delay | - | 8.2 | - | 10.0 | ns |
| tptoe | 43 | GLB Product Term Output Enable to I/O Cell Delay | - | 9.0 | - | 9.0 | ns |
| tptck | 44 | GLB Product Term Clock Delay | 2.8 | 6.2 | 3.5 | 7.5 | ns |
| ORP |  |  |  |  |  |  |  |
| torp | 45 | ORP Delay | - | 2.0 | - | 2.5 | ns |
| torpbp | 46 | ORP Bypass Delay | - | 0.4 | - | 0.5 | ns |

1. Internal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.
3. The XOR Adjacent path can only be used by Lattice Hard Macros.

## Specifications pLSI and ispLSI 1016

## Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -110 |  | -90 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| Outputs |  |  |  |  |  |  |  |
| tob | 47 | Output Buffer Delay | - | 2.1 | - | 2.5 | ns |
| toen | 48 | I/O Cell OE to Output Enabled | - | 3.3 | - | 4.0 | ns |
| todis | 49 | I/O Cell OE to Output Disabled | - | 3.3 | - | 4.0 | ns |
| Clocks |  |  |  |  |  |  |  |
| tgy0 | 50 | Clock Delay, Y0 to Global GLB Clock Line (Ref. clock) | 2.9 | 2.9 | 3.5 | 3.5 | ns |
| tgy $1 / 2$ | 51 | Clock Delay, Y1 or Y2 to Global GLB Clock Line | 2.1 | 3.8 | 2.5 | 4.5 | ns |
| tgcp | 52 | Clock Delay, Clock GLB to Global GLB Clock Line | 0.8 | 4.2 | 1.0 | 5.0 | ns |
| tioy1/2 | 53 | Clock Delay, Y1 or Y2 to I/O Cell Global Clock Line | 2.1 | 3.8 | 2.5 | 4.5 | ns |
| tiocp | 54 | Clock Delay, Clock GLB to I/O Cell Global Clock Line | 0.8 | 4.2 | 1.0 | 5.0 | ns |
| Global Reset |  |  |  |  |  |  |  |
| tgr | 55 | Global Reset to GLB and I/O Registers | - | 7.9 | - | 7.5 | ns |

1. Internal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.


## Specifications pLSI and ispLSI 1016

Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| Inputs |  |  |  |  |  |  |  |
| tiobp | 20 | I/O Register Bypass | - | 2.0 | - | 2.7 | ns |
| tiolat | 21 | I/O Latch Delay | - | 3.0 | - | 4.0 | ns |
| tiosu | 22 | I/O Register Setup Time before Clock | 5.5 | - | 7.3 | - | ns |
| tioh | 23 | I/O Register Hold Time after Clock | 1.0 | - | 1.3 | - | ns |
| tioco | 24 | I/O Register Clock to Out Delay | - | 3.0 | - | 4.0 | ns |
| tior | 25 | I/O Register Reset to Out Delay | - | 2.5 | - | 3.3 | ns |
| tdin | 26 | Dedicated Input Delay | - | 4.0 | - | 5.3 | ns |
| GRP |  |  |  |  |  |  |  |
| tgrp1 | 27 | GRP Delay, 1 GLB Load | - | 1.5 | - | 2.0 | ns |
| tgrp4 | 28 | GRP Delay, 4 GLB Loads | - | 2.0 | - | 2.7 | ns |
| tgrp8 | 29 | GRP Delay, 8 GLB Loads | - | 3.0 | - | 4.0 | ns |
| tgrp12 | 30 | GRP Delay, 12 GLB Loads | - | 3.8 | - | 5.0 | ns |
| tgrp16 | 31 | GRP Delay, 16 GLB Loads | - | 4.5 | - | 6.0 | ns |
| GLB |  |  |  |  |  |  |  |
| t4ptbp | 33 | 4 Product Term Bypass Path Delay | - | 6.5 | - | 8.6 | ns |
| t1ptxor | 34 | 1 Product Term/XOR Path Delay | - | 7.0 | - | 9.3 | ns |
| t20ptxor | 35 | 20 Product Term/XOR Path Delay | - | 8.0 | - | 10.6 | ns |
| txoradj | 36 | XOR Adjacent Path Delay ${ }^{3}$ | - | 9.5 | - | 12.7 | ns |
| tgbp | 37 | GLB Register Bypass Delay | - | 1.0 | - | 1.3 | ns |
| tgsu | 38 | GLB Register Setup Time before Clock | 1.0 | - | 1.3 | - | ns |
| tgh | 39 | GLB Register Hold Time after Clock | 4.5 | - | 6.0 | - | ns |
| tgco | 40 | GLB Register Clock to Output Delay | - | 2.0 | - | 2.7 | ns |
| tgr | 41 | GLB Register Reset to Output Delay | - | 2.5 | - | 3.3 | ns |
| tptre | 42 | GLB Product Term Reset to Register Delay | - | 10.0 | - | 13.3 | ns |
| tptoe | 43 | GLB Product Term Output Enable to I/O Cell Delay | - | 9.0 | - | 12.0 | ns |
| tptck | 44 | GLB Product Term Clock Delay | 3.5 | 7.5 | 4.6 | 9.9 | ns |


| ORP |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| torp | 45 | ORP Delay | - | 2.5 | - | 3.3 | ns |
| torpbp | 46 | ORP Bypass Delay | - | 0.5 | - | 0.7 | ns |

1. Internal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.
3. The XOR Adjacent path can only be used by Lattice Hard Macros.

Internal Timing Parameters ${ }^{1}$

| PARAMETER | \# ${ }^{2}$ | DESCRIPTION | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| Outputs |  |  |  |  |  |  |  |
| tob | 47 | Output Buffer Delay | - | 3.0 | - | 4.0 | ns |
| toen | 48 | I/O Cell OE to Output Enabled | - | 5.0 | - | 6.7 | ns |
| todis | 49 | I/O Cell OE to Output Disabled | - | 5.0 | - | 6.7 | ns |
| Clocks |  |  |  |  |  |  |  |
| tgy0 | 50 | Clock Delay, Y0 to Global GLB Clock Line (Ref. clock) | 4.5 | 4.5 | 6.0 | 6.0 | ns |
| tgy $1 / 2$ | 51 | Clock Delay, Y1 or Y2 to Global GLB Clock Line | 3.5 | 5.5 | 4.6 | 7.3 | ns |
| tgcp | 52 | Clock Delay, Clock GLB to Global GLB Clock Line | 1.0 | 5.0 | 1.3 | 6.6 | ns |
| tioy1/2 | 53 | Clock Delay, Y1 or Y2 to I/O Cell Global Clock Line | 3.5 | 5.5 | 4.6 | 7.3 | ns |
| tiocp | 54 | Clock Delay, Clock GLB to I/O Cell Global Clock Line | 1.0 | 5.0 | 1.3 | 6.6 | ns |
| Global Reset |  |  |  |  |  |  |  |
| tgr | 55 | Global Reset to GLB and I/O Registers | - | 9.0 | - | 12.0 | ns |

[^1]
## Specifications pLSI and ispLSI 1016

## PLSI and ispLSI 1016 Timing Model



## Derivations of tsu, th and tco from the Product Term Clock ${ }^{1}$

```
tsu \(=\) Logic + Reg su - Clock (min)
    \(=(\) tiobp \(+\mathbf{t g r p 4}+\mathbf{t}\) 20ptxor) \()+(\mathbf{t g s u})-(\mathbf{t i o b p}+\mathbf{t g r p 4} 4+\mathbf{t p t c k}(\) min \())\)
    \(=(\# 20+\# 28+\# 35)+(\# 38)-(\# 20+\# 28+\# 44)\)
    \(5.5 \mathrm{~ns}=(1.0+1.0+8.0)+(1.0)-(1.0+1.0+3.5)\)
th \(=\) Clock (max \()+\) Reg \(\mathrm{h}-\) Logic
    \(=(\) tiobp \(+\mathbf{t g r p} 4+\mathbf{t p t c k}(\max ))+(\mathbf{t g h})-(\) tiobp \(+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor})\)
    \(=(\# 20+\# 28+\# 44)+(\# 39)-(\# 20+\# 28+\# 35)\)
    \(3.0 \mathrm{~ns}=(1.0+1.0+7.5)+(3.5)-(1.0+1.0+8.0)\)
tco \(=\) Clock (max) + Reg co + Output
    \(=(\mathbf{t}\) tiobp \(+\boldsymbol{t}\) grp \(4+\mathbf{t p t c k}(\) max \())+(\mathbf{t g c o})+(\mathbf{t o r p}+\mathbf{t o b})\)
    \(=(\# 20+\# 28+\# 44)+(\# 40)+(\# 45+\# 47)\)
\(16.0 \mathrm{~ns}=(1.0+1.0+7.5)+(1.5)+(2.5+2.5)\)
```


## Derivations of tsu, th and tco from the Clock GLB ${ }^{1}$

```
tsu = Logic + Reg su - Clock (min)
    \(=(\mathbf{t}\) tiobp \(+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor})+(\mathbf{t g s u})-(\mathbf{t g y 0}(\mathrm{min})+\mathbf{t g c o}+\mathbf{t g c p}(\mathrm{min}))\)
    \(=(\# 20+\# 28+\# 35)+(\# 38)-(\# 50+\# 40+\# 52)\)
    \(5.0 \mathrm{~ns}=(1.0+1.0+8.0)+(1.0)-(3.5+1.5+1.0)\)
th \(=\operatorname{Clock}(m a x)+\) Reg \(h-\) Logic
    \(=(\mathbf{t g y 0}(\) max \()+\mathbf{t g c o}+\mathbf{t g c p}(\) max \())+(\mathbf{t g h})-(\) tiobp \(+\mathbf{t g r p} 4+\mathbf{t} 20\) ptxor \()\)
    \(=(\# 50+\# 40+\# 52)+(\# 39)-(\# 20+\# 28+\# 35)\)
    \(3.5 \mathrm{~ns}=(3.5+1.5+5.0)+(3.5)-(1.0+1.0+8.0)\)
tco \(=\) Clock (max) + Reg co + Output
    \(=(\operatorname{tgy} 0(\max )+\mathbf{t g c o}+\boldsymbol{t g c p}(\max ))+(\mathbf{t g c o})+(\mathbf{t o r p}+\mathbf{t o b})\)
    \(=(\# 50+\# 40+\# 52)+(\# 40)+(\# 45+\# 47)\)
```

$16.5 \mathrm{~ns}=(3.5+1.5+5.0)+(1.5)+(2.5+2.5)$

1. Calculations are based upon timing specs for the ispLSI 1016-90.

Figure 3. Typical Device Power Consumption vs fmax


Notes: Configuration of Four 16-bit Counters
Typical Current at $5 \mathrm{~V}, 25^{\circ} \mathrm{C}$

ICC can be estimated for the pLSI and ispLSI 1016 using the following equation:
ICC $=31+$ (\# of PTs * 0.45 ) + (\# of nets * Max. freq * 0.009 ) where:
\# of PTs = Number of Product Terms used in design
\# of nets = Number of Signals used in device
Max. freq = Highest Clock Frequency to the device
The ICC estimate is based on typical conditions ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, room temperature) and an assumption of 2 GLB loads on average exists. These values are for estimates only. Since the value of ICC is sensitive to operating conditions and the program in the device, the actual ICC should be verified.

Figure 4. Maximum GRP Delay vs GLB loads
 Specifications pLSI and ispLSI 1016

## In-System Programmability

The ispLSI devices are the in-system programmable versions of the Lattice High-Density programmable Large Scale Integration (pLSI) devices. By integrating all the high voltage programming circuitry on-chip, programming can be accomplished by simply shifting data into the device. Once the function is programmed, the nonvolatile $\mathrm{E}^{2} \mathrm{CMOS}$ cells will not lose the pattern even when the power is turned off.

All necessary programming is done via five TTL level logic interface signals. These five signals are fed into the on-chip programming circuitry where a state machine controls the programming. The interface signals are isp Enable ( $\overline{\mathrm{ispEN}}$ ), Serial Data In (SDI), Serial Data Out (SDO), Serial Clock (SCLK) and Mode (MODE) control. Figure 5 illustrates the block diagram of one possible scheme for programming the ispLSI devices. For details on the operation of the internal state machine and programming of the device please refer to the in-system programming section in this Data Book.

Figure 5. ISP Programming Interface


## Specifications pLSI and ispLSI 1016

ISP Programming Voltage/Timing Specifications ${ }^{1}$

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VCCP | Programming Voltage |  | 4.75 | 5 | 5.25 | V |
| ICCP | Programming Supply Current |  | - | 50 | 100 | mA |
| VIHP | Input Voltage High | ispEN $=$ Low | 2.0 | - | VCCP | V |
| VILP | Input Voltage Low |  | 0 | - | 0.8 | V |
| IIP | Input Current |  | - | 100 | 200 | $\mu \mathrm{A}$ |
| Vohp | Output Voltage High | $\mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ | 2.4 | - | VCCP | V |
| VOLP | Output Voltage Low | $\mathrm{l}_{\mathrm{OL}}=5 \mathrm{~mA}$ | 0 | - | 0.5 | V |
| tr, tf | Input Rise and Fall |  | - | - | 0.1 | $\mu \mathrm{s}$ |
| tispen | ispEN to Output 3-State Enabled |  | - | 2 | 10 | $\mu \mathrm{s}$ |
| tispdis | ispEN to Output 3-State Disabled |  | - | 2 | 10 | $\mu \mathrm{s}$ |
| tsu | Setup Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tco | Clock to Output |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| th | Hold Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tclkh, tclkl | Clock Pulse Width, High and Low |  | 0.5 | 1 | - | $\mu \mathrm{s}$ |
| tpwv | Verify Pulse Width |  | 20 | 30 | - | $\mu \mathrm{s}$ |
| tpwp | Programming Pulse Width |  | 40 | - | 100 | ms |
| tbew | Bulk Erase Pulse Width |  | 200 | - | - | ms |
| trst | Reset Time From Valid $\mathrm{V}_{\text {ccP }}$ |  | 45 | - | - | $\mu \mathrm{s}$ |

1. ISP Programming is guaranteed for $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Operation only.

## Specifications pLSI and ispLSI 1016

Figure 6. Timing Waveforms for In-System Programming (ispLSI 1016)


Figure 7. Program, Verify \& Bulk Erase Waveforms (ispLSI 1016)


## Specifications pLSI and ispLSI 1016

Figure 8 illustrates the address and data shift register bits for the ispLSI 1016. For a detailed explanation refer to
the Device Layout discussion in the pLSI and ispLSI Architectural Description section of this Data Book.

Figure 8. ispLSI 1016 Shift Register Layout


Note: A logic "1" in the Address Shift Register bit position enables the row for programming or verification.
A logic "0" disables it.

Specifications pLSI and ispLSI 1016

## Pin Description

| Name | TQFP Pin Numbers | PLCC <br> Pin Numbers | JLCC <br> Pin Numbers | Description |
| :---: | :---: | :---: | :---: | :---: |
| I/O $0-$ I/O 3 I/O 4 - I/O 7 I/O 8 - I/O 11 I/O $12-$ I/O 15 I/O $16-$ I/O 19 I/O $20-$ I/O 23 I/O $24-$ I/O 27 I/O $28-$ I/O 31 | $\left\|\begin{array}{llll} 9, & 10, & 11, & 12, \\ 13, & 14, & 15 & 16, \\ 19, & 20, & 21, & 22, \\ 23, & 24, & 25, & 26, \\ 31, & 32, & 33, & 34, \\ 35, & 36, & 37, & 38, \\ 41, & 42, & 43, & 44, \\ 1, & 2, & 3, & 4 \end{array}\right\|$ | $15,16,17,18$, $15,16,17,18$,   <br> $19,20,21,22$, $19,20,21,22$,   <br> $25,26,27,28$, $25,26,27,28$,   <br> $29,30,31,32$, $29,30,31,32$,   <br> $37,38,39,40$, $37,38,39,40$,   <br> $41,42,43,44$, $41,42,43,44$,   <br> 3, 4, 5, 6, <br> 7, 8, 9, 10 <br> 7, 4, 5, 9, |  | Input/Output Pins - These are the general purpose I/O pins used by the logic array. |
| IN 3 | 40 | 2 | 2 | Dedicated input pins to the device. |
| $\overline{\mathrm{ispEN}}{ }^{*}$ | 7 | 13 | 13 | Input - Dedicated in-system programming enable input pin. This pin is brought low to enable the programming mode. The MODE, SDI, SDO and SCLK options become active. |
| SDI*/N 0 | 8 | 14 | 14 | Input - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an input pin to load programming data into the device. SDI/IN 0 also is used as one of the two control pins for the isp state machine. |
| MODE*/IN 2 | 30 | 36 | 36 | Input - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as a pin to control the operation of the isp state machine. |
| SDO*/IN 1 | 18 | 24 | 24 | Input/Output - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an output pin to read serial shift register data. |
| SCLK*/Y2 | 27 | 33 | 33 | Input - This pin performs two functions. It is a dedicated clock input when ispEN is logic high. This clock input is brought into the Clock Distribution Network, and can optionally be routed to any GLB and/or l/O cell on the device. When ispEN is logic low, it functions as a clock pin for the Serial Shift Register. |
| YO | 5 29 | 11 | 11 | Dedicated Clock input. This clock input is connected to one of the clock inputs of all of the GLBs on the device. <br> This pin performs two functions: <br> - Dedicatedclockinput. This clockinputis brought into the Clock Distribution Network, and can optionally be routed to any GLB and/or I/O cell on the device. <br> - Active Low (0) Reset pin which resets all of the GLB and I/O registers in the device. |
| Y1/RESET | 29 | 35 | 35 |  |
| GND | 17, 39 | 1, 23 | 1, 23 | Ground (GND) |
| VCC |  | 12, 34 | 12, 34 |  |

[^2]
## Specifications pLSI and ispLSI 1016

## Pin Configuration

## pLSI and ispLSI 1016 44-Pin PLCC Pinout Diagram



* Pins have dual function capability for ispLSI 1016 only (except pin 13 , which is $\overline{\text { ispEN only). }}$
pLSI and ispLSI 1016 44-Pin JLCC Pinout Diagram

* Pins have dual function capability for ispLSI 1016 only (except pin 13, which is $\overline{\text { ispEN }}$ only).

Pin Configuration
pLSI and ispLSI 1016 44-Pin TQFP Pinout Diagram


* Pins have dual function capability for ispLSI 1016 only (except pin 7, which is ispEN only).

Part Number Description


## pLSI and ispLSI 1016 Ordering Information

COMMERCIAL

| Family | $\mathrm{fmax}_{\text {( }}^{\text {(MHz }}$ ) | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 110 | 10 | pLSI 1016-110LJ | 44-Pin PLCC |
|  | 110 | 10 | pLSI 1016-110LT | 44-Pin TQFP |
|  | 90 | 12 | pLSI 1016-90LJ | 44-Pin PLCC |
|  | 90 | 12 | pLSI 1016-90LT | 44-Pin TQFP |
|  | 80 | 15 | pLSI 1016-80LJ | 44-Pin PLCC |
|  | 80 | 15 | pLSI 1016-80LT | 44-Pin TQFP |
|  | 60 | 20 | pLSI 1016-60LJ | 44-Pin PLCC |
|  | 60 | 20 | pLSI 1016-60LT | 44-Pin TQFP |
| ispLSI | 110 | 10 | ispLSI 1016-110LJ | 44-Pin PLCC |
|  | 110 | 10 | ispLSI 1016-110LT | 44-Pin TQFP |
|  | 90 | 12 | ispLSI 1016-90LJ | 44-Pin PLCC |
|  | 90 | 12 | ispLSI 1016-90LT | 44-Pin TQFP |
|  | 80 | 15 | ispLSI 1016-80LJ | 44-Pin PLCC |
|  | 80 | 15 | ispLSI 1016-80LT | 44-Pin TQFP |
|  | 60 | 20 | ispLSI 1016-60LJ | 44-Pin PLCC |
|  | 60 | 20 | ispLSI 1016-60LT | 44-Pin TQFP |

INDUSTRIAL

| Family | fmax (MHz) | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 60 | 20 | pLSI 1016-60LJI | 44 -Pin PLCC |
| ispLSI | 60 | 20 | ispLSI 1016-60LJI | $44-$ Pin PLCC |

MILITARY/883

| Family | fmax (MHz) | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 60 | 20 | pLSI 1016-60LH/883 | $44-$ Pin JLCC |
| ispLSI | 60 | 20 | ispLSI 1016-60LH/883 | $44-$ Pin JLCC |

pLSI ${ }^{\circ}$ and ispLSI'" 1024
High-Density Programmable Logic

## Features

- PROGRAMMABLE AND IN-SYSTEM PROGRAMMABLE HIGH DENSITY LOGIC
- High-Speed Global Interconnect
- 4000 PLD Gates
- 48 VO Pins, Six Dedicated Inputs
- 144 Registers
- Wide Input Gating for Fast Counters, State Machines, Address Decoders, etc.
- Small Logic Block Size for Fast Random Logic
- Security Cell Prevents Unauthorized Copying
- HIGH PERFORMANCE E²CMOS ${ }^{\ominus}$ TECHNOLOGY
- fmax $=\mathbf{9 0} \mathbf{M H z}$ Maximum Operating Frequency
- $\mathrm{fmax}=\mathbf{6 0} \mathrm{MHz}$ for Industrial and Military/883 Devices
- tpd = 12 ns Propagation Delay
- TTL Compatible Inputs and Outputs
- Electrically Erasable and Reprogrammable
- Non-Volatile E ${ }^{2}$ CMOS Technology
- 100\% Tested
- ispLSI OFFERS THE FOLLOWING ADDED FEATURES
— In-System Programmable 5-Volt Only
- Change Logic and Interconnects "On-the-Fly" in Seconds
- Reprogram Soldered Device for Debugging
- COMBINES EASE OF USE AND THE FAST SYSTEM SPEED OF PLDs WITH THE DENSITY AND FLEX-
IBILITY OF FIELD PROGRAMMABLE GATE ARRAYS
- Complete Programmable Device Can Combine Glue Logic and Structured Designs
- Four Dedicated Clock Input Pins
- Synchronous and Asynchronous Clocks
- Flexible Pin Placement
- Optimized Global Routing Pool Provides Global Interconnectivity
- pLSVispLSI DEVELOPMENT SYSTEM (pDS*)
pDS Software
- Easy to Use PC Windows ${ }^{\text {TM }}$ Interface
- Boolean Logic Compiler
- Manual Partitioning
- Automatic Place and Route
- Static Timing Table
pDS+ ${ }^{\text {™ }}$ Software
- Industry Standard, Third Party Design Environments
- Schematic Capture, State Machine, HDL
- Automatic Partitioning and Place and Route
- Comprehensive Logic and Timing Simulation
- PC and Workstation Platforms

Functional Block Diagram


0139-A-isp

## Description

The Lattice pLSI and ispLSI 1024 are High-Density Programmable Logic Devices containing 144 Registers, 48 Universal I/O pins, six Dedicated Input pins, four Dedicated Clock Input pins and a Global Routing Pool (GRP). The GRP provides complete interconnectivity between all of these elements. The ispLSI 1024 features 5 -Volt in-system programmability and in-system diagnostic capabilities. It is the first device which offers non-volatile "on-the-fly" reprogrammability of the logic, as well as the interconnect to provide truly reconfigurable systems. It is architecturally and parametrically compatible to the pLSI 1024 device, but multiplexes four of the dedicated input pins to control in-system programming.
The basic unit of logic on the pLSI and ispLSI 1024 devices is the Generic Logic Block (GLB). The GLBs are labeled AO, A1 .. C7 (see figure 1). There are a total of 24 GLBs in the pLSI and ispLSI 1024 devices. Each GLB has 18 inputs, a programmable AND/OR/XOR array, and four outputs which can be configured to be either combinatorial or registered. Inputs to the GLB come from the GRP and dedicated inputs. All of the GLB outputs are brought back into the GRP so that they can be connected to the inputs of any other GLB on the device.

[^3]
## Functional Block Diagram

Figure 1.pLSI and ispLSI 1024 Functional Block Diagram


The devices also have 48 I/O cells, each of which is directly connected to an I/O pin. Each I/O cell can be individually programmed to be a combinatorial input, registered input, latched input, output or bi-directional I/O pin with 3-state control. Additionally, all outputs are polarity selectable, active high or active low. The signal levels are TTL compatible voltages and the output drivers can source 4 mA or sink 8 mA .

Eight GLBs, 16 I/O cells, two dedicated inputs and one ORP are connected together to make a Megablock (see figure 1). The outputs of the eight GLBs are connected to a set of 16 universal I/O cells by the ORP. The I/O cells within the Megablock also share a common Output Enable (OE) signal. The pLSI and ispLSI 1024 devices contain three of these Megablocks.

The GRP has as its inputs the outputs from all of the GLBs and all of the inputs from the bi-directional I/O cells. All of these signals are made available to the inputs of the GLBs. Delays through the GRP have been equalized to minimize timing skew.

Clocks in the pLSI and ispLSI 1024 devices are selected using the Clock Distribution Network. Four dedicated clock pins (Y0, Y1, Y2 and Y3) are brought into the distribution network, and five clock outputs (CLK 0, CLK 1, CLK 2, IOCLK 0 and IOCLK 1) are provided to route clocks to the GLBs and I/O cells. The Clock Distribution Network can also be driven from a special clock GLB (B4 on the pLSI and ispLSI 1024 devices). The logic of this GLB allows the user to create an internal clock from a combination of internal signals within the device.

## Specifications pLSI and ispLSI 1024

## Absolute Maximum Ratings ${ }^{1}$

Supply Voltage $\mathrm{V}_{\mathrm{cc}} \ldots . .$.
Input Voltage Applied. . . . . . . . . . . . . . . 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Off-State Output Voltage Applied . . . . . -2.5 to V $\mathrm{CC}+1.0 \mathrm{~V}$
Storage Temperature . . . . . . . . . . . . . . . . . . 65 to $150^{\circ} \mathrm{C}$
Case Temp. with Power Applied . . . . . . . . 55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. Functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

DC Recommended Operating Conditions

| SYMBOL | PARAMETER |  |  | MIN. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | Commercial | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 4.75 | 5.25 | V |
|  |  | Industrial | $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 4.5 | 5.5 |  |
|  |  | Military/883 | $\mathrm{T}_{\mathrm{C}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 4.5 | 5.5 |  |
| VIL | Input Low Voltage |  |  | 0 | 0.8 | V |
| VIH | Input High Voltage |  |  | 2.0 | Vcc + 1 | V |

Table 2-0005Alep w/mil.eps

## Capacitance $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| SYMBOL | PARAMETER |  | MAXIMUM ${ }^{1}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $C_{1}$ | Dedicated Input Capacitance | Commercial/Industrial | 8 | pf | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 N}=2.0 \mathrm{~V}$ |
|  |  | Military | 10 | pf | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{~N}}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{2}$ | I/O and Clock Capacitance |  | 10 | pf | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{10}, \mathrm{~V}_{\mathrm{r}}=2.0 \mathrm{~V}$ |

1. Guaranteed but not $100 \%$ tested.

Table 2. 0006

## Data Retention Specifications

| PARAMETER | MINIMUM | MAXIMUM | UNITS |
| :--- | :---: | :---: | :---: |
| Data Retention | 20 | - | YEARS |
| ispLSI Erase/Reprogram Cycles | 1000 | - | CYCLES |
| pLSI Erase/Reprogram Cycles | 100 | - | CYCLES |

attice

## Specifications pLSI and ispLSI 1024

Switching Test Conditions

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Time | $\leq 3 \mathrm{~ns} \mathrm{10} \mathrm{\%} \mathrm{to} 90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See figure 2 |

3 -state levels are measured 0.5 V from steady-state active level.

## Output Load Conditions (see figure 2)

| Test Condition |  | R1 | R2 | CL |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $470 \Omega$ | $390 \Omega$ | 35 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 35 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 35 pF |
| C | Active High to Z <br> at $\mathrm{V}_{\text {OH }}-0.5 \mathrm{~V}$ | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low to Z <br> at $\mathrm{V}_{\text {OL }}+0.5 \mathrm{~V}$ | $470 \Omega$ | $390 \Omega$ | 5 pF |

Table 2-0004A

Figure 2. Test Load

${ }^{*} C_{L}$ includes Test Fixture and Probe Capacitance.

## DC Electrical Characteristics

Over Recommended Operating Conditions

| SYMBOL | PARAMETER | CONDITION |  | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | - | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 2.4 | - | - | V |
| IIL | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {cc }}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| IIL-isp | isp Input Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -150 | $\mu \mathrm{A}$ |
| IIL-PU | I/O Active Pull-Up Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ |  | - | - | -150 | $\mu \mathrm{A}$ |
| IOS ${ }^{1}$ | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.5 \mathrm{~V}$ |  | -60 | - | -200 | mA |
| Icc ${ }^{2}$ | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{TOGGLE}}=1 \mathrm{MHz} \end{aligned}$ | Commercial | - | 130 | 190 | mA |
|  |  |  | Industria/Military | - | 135 | 220 | mA |

1. One output at a time for a maximum duration of one second. $\mathrm{V}_{\text {out }}=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
2. Measured using six 16 -bit counters.
3. Typical values are at $\mathrm{V}_{C C}=5 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$.

External Timing Parameters

## Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST } \\ & \text { COND. } \end{aligned}$ | $*^{2}$ | DESCRIPTION ${ }^{1}$ | -90 |  | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd1 | A | 1 | Data Propagation Delay, 4PT bypass, ORP bypass | - | 12 | - | 15 | - | 20 | ns |
| tpd2 | A | 2 | Data Propagation Delay, Worst Case Path | - | 17 | - | 20 | - | 25 | ns |
| fmax | A | 3 | Clock Frequency with Internal Feedback ${ }^{3}$ | 90.9 | - | 80 | - | 60 | - | MHz |
| $f_{\text {max }}$ (Ext.) | - | 4 | Clock Frequency with External Feedback $\left(\frac{1}{\text { tsu2 }+ \text { tcol }}\right.$ ( $)$ | 58.8 | - | 50 | - | 38 | - | MHz |
| fmax (Tog.) | - | 5 | Clock Frequency, Max Toggle ${ }^{4}$ | 125 | - | 100 | - | 83 | - | MHz |
| tsu1 | - | 6 | GLB Reg. Setup Time before Clock, 4PT bypass | 6 | - | 7 | - | 9 | - | ns |
| tco1 | A | 7 | GLB Reg. Clock to Output Delay, ORP bypass | - | 8 | - | 10 | - | 13 | ns |
| th1 | - | 8 | GLB Reg. Hold Time after Clock, 4 PT bypass | 0 | - | 0 | - | 0 | - | ns |
| tsu2 | - | 9 | GLB Reg. Setup Time before Clock | 9 | - | 10 | - | 13 | - | ns |
| tco2 | - | 10 | GLB Reg. Clock to Output Delay | - | 10 | - | 12 | - | 16 | ns |
| th2 | - | 11 | GLB Reg. Hold Time after Clock | 0 | - | 0 | - | 0 | - | ns |
| tr1 | A | 12 | Ext. Reset Pin to Output Delay | - | 15 | - | 17 | - | 22.5 | ns |
| trw1 | - | 13 | Ext. Reset Pulse Duration | 10 | - | 10 | - | 13 | - | ns |
| ten | B | 14 | Input to Output Enable | - | 15 | - | 18 | - | 24 | ns |
| tdis | C | 15 | Input to Output Disable | - | 15 | - | 18 | - | 24 | ns |
| twh | - | 16 | Ext. Sync. Clock Pulse Duration, High | 4 | - | 5 | - | 6 | - | ns |
| twl | - | 17 | Ext. Sync. Clock Pulse Duration, Low | 4 | - | 5 | - | 6 | - | ns |
| tsu5 | - | 18 | I/O Reg. Setup Time before Ext. Sync. Clock (Y2, Y3) | 2 | - | 2 | - | 2.5 | - | ns |
| th5 | - | 19 | I/O Reg. Hold Time after Ext. Sync. Clock (Y2, Y3) | 6.5 | - | 6.5 | - | 8.5 | - | ns |

Table 2-0030-24/90,80,60C

1. Unless noted otherwise, all parameters use a GRP load of 4 GLBs, 20 PTXOR path, ORP and YO clock.
2. Refer to Timing Model in this data sheet for further details.
3. Standard 16 -Bit loadable counter using GRP feedback.
4. fmax (Toggle) may be less than $1 /(t w h+t w l)$. This is to allow for a clock duty cycle of other than $50 \%$.
5. Reference Switching Test Conditions Section.

## Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -90 |  | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| Inputs |  |  |  |  |  |  |  |  |  |
| tiobp | 20 | I/O Register Bypass | - | 1.6 | - | 2.0 | - | 2.7 | ns |
| tiolat | 21 | I/O Latch Delay | - | 2.4 | - | 3.0 | - | 4.0 | ns |
| tiosu | 22 | I/O Register Setup Time before Clock | 4.8 | - | 5.5 | - | 7.3 | - | ns |
| tioh | 23 | I/O Register Hold Time after Clock | 2.1 | - | 1.0 | - | 1.3 | - | ns |
| tioco | 24 | I/O Register Clock to Out Delay | - | 2.4 | - | 3.0 | - | 4.0 | ns |
| tior | 25 | I/O Register Reset to Out Delay | - | 2.8 | - | 2.5 | - | 3.3 | ns |
| tdin | 26 | Dedicated Input Delay | - | 3.2 | - | 4.0 | - | 5.3 | ns |
| GRP |  |  |  |  |  |  |  |  |  |
| tgrp1 | 27 | GRP Delay, 1 GLB Load | - | 1.2 | - | 1.5 | - | 2.0 | ns |
| tgrp4 | 28 | GRP Delay, 4 GLB Loads | - | 1.6 | - | 2.0 | - | 2.7 | ns |
| tgrp8 | 29 | GRP Delay, 8 GLB Loads | - | 2.4 | - | 3.0 | - | 4.0 | ns |
| tgrp12 | 30 | GRP Delay, 12 GLB Loads | - | 3.0 | - | 3.8 | - | 5.0 | ns |
| tgrp16 | 31 | GRP Delay, 16 GLB Loads | - | 3.6 | - | 4.5 | - | 6.0 | ns |
| tgrp24 | 32 | GRP Delay, 24 GLB Loads | - | 5.0 | - | 6.3 | - | 8.3 | ns |
| GLB |  |  |  |  |  |  |  |  |  |
| t4ptbp | 33 | 4 Product Term Bypass Path Delay | - | 5.2 | - | 6.5 | - | 8.6 | ns |
| t1ptxor | 34 | 1 Product Term/XOR Path Delay | - | 5.7 | - | 7.0 | - | 9.3 | ns |
| t20ptxor | 35 | 20 Product Term/XOR Path Delay | - | 7.0 | - | 8.0 | - | 10.6 | ns |
| txoradj | 36 | XOR Adjacent Path Delay ${ }^{3}$ | - | 8.2 | - | 9.5 | - | 12.7 | ns |
| tgbp | 37 | GLB Register Bypass Delay | - | 0.8 | - | 1.0 | - | 1.3 | ns |
| tgsu | 38 | GLB Register Setup Time before Clock | 1.2 | - | 1.0 | - | 1.3 | - | ns |
| tgh | 39 | GLB Register Hold Time after Clock | 3.6 | - | 4.5 | - | 6.0 | - | ns |
| tgco | 40 | GLB Register Clock to Output Delay | - | 1.6 | - | 2.0 | - | 2.7 | ns |
| tgr | 41 | GLB Register Reset to Output Delay | - | 2.0 | - | 2.5 | - | 3.3 | ns |
| tptre | 42 | GLB Product Term Reset to Register Delay | - | 8.0 | - | 10.0 | - | 13.3 | ns |
| tptoe | 43 | GLB Product Term Output Enable to I/O Cell Delay | - | 7.8 | - | 9.0 | - | 12.0 | ns |
| tptck | 44 | GLB Product Term Clock Delay | 2.8 | 6.0 | 3.5 | 7.5 | 4.6 | 9.9 | ns |
| ORP |  |  |  |  |  |  |  |  |  |
| torp | 45 | ORP Delay | - | 2.4 | - | 2.5 | - | 3.3 | ns |
| torpbp | 46 | ORP Bypass Delay | - | 0.4 | - | 0.5 | - | 0.7 | ns |

1. Internal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.
3. The XOR Adjacent path can only be used by Lattice Hard Macros.

Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -90 |  | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| Outputs |  |  |  |  |  |  |  |  |  |
| tob | 47 | Output Buffer Delay | - | 2.4 | - | 3.0 | - | 4.0 | ns |
| toen | 48 | I/O Cell OE to Output Enabled | - | 4.0 | - | 5.0 | - | 6.7 | ns |
| todis | 49 | I/O Cell OE to Output Disabled | - | 4.0 | - | 5.0 | - | 6.7 | ns |
| Clocks |  |  |  |  |  |  |  |  |  |
| tgyo | 50 | Clock Delay, Y0 to Global GLB Clock Line (Ref. clock) | 3.6 | 3.6 | 4.5 | 4.5 | 6.0 | 6.0 | ns |
| tgy $1 / 2$ | 51 | Clock Delay, Y1 or Y2 to Global GLB Clock Line | 2.8 | 4.4 | 3.5 | 5.5 | 4.6 | 7.3 | ns |
| tgcp | 52. | Clock Delay, Clock GLB to Global GLB Clock Line | 0.8 | 4.0 | 1.0 | 5.0 | 1.3 | 6.6 | ns |
| tioy2/3 | 53 | Clock Delay, Y2 or Y3 to I/O Cell Global Clock Line | 2.8 | 4.4 | 3.5 | 5.5 | 4.6 | 7.3 | ns |
| tiocp | 54 | Clock Delay, Clock GLB to I/O Cell Global Clock Line | 0.8 | 4.0 | 1.0 | 5.0 | 1.3 | 6.6 | ns |
| Global Reset |  |  |  |  |  |  |  |  |  |
| tgr | 55 | Global Reset to GLB and 1/O Registers | - | 8.2 | - | 9.0 | - | 12.0 | ns |

1. Intemal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.

## pLSI and ispLSI 1024 Timing Model



Derivations of tsu, th and tco from the Product Term Clock ${ }^{1}$

$$
\begin{aligned}
\text { tsu } & =\text { Logic }+ \text { Reg su }- \text { Clock (min) } \\
& =(\text { tiobp }+ \text { tgrp4 }+ \text { t20ptxor })+(\text { tgsu })-(\text { tiobp }+ \text { tgrp4 }+ \text { tptck(min })) \\
& =(\# 20+\# 28+\# 35)+(\# 38)-(\# 20+\# 28+\# 44) \\
5.5 \mathrm{~ns} & =(2.0+2.0+8.0)+(1.0)-(2.0+2.0+3.5) \\
\text { th } & =\text { Clock (max) }+ \text { Reg h }- \text { Logic } \\
& =(\text { tiobp }+ \text { tgrp4 }+ \text { tptck(max) })+(\text { tgh })-(\text { tiobp }+ \text { tgrp4 }+ \text { t } 20 \text { ptxor }) \\
& =(\# 20+\# 28+\# 44)+(\# 39)-(\# 20+\# 28+\# 35) \\
4.0 \mathrm{~ns} & =(2.0+2.0+7.5)+(4.5)-(2.0+2.0+8.0) \\
\text { tco } & =\text { Clock (max })+ \text { Reg co }+ \text { Output } \\
& =(\text { tiobp }+ \text { tgrp4 }+ \text { tptck(max) })+(\text { tgco })+(\text { torp }+ \text { tob }) \\
& =(\# 20+\# 28+\# 44)+(\# 40)+(\# 45+\# 47) \\
19.0 \mathrm{~ns} & =(2.0+2.0+7.5)+(2.0)+(2.5+3.0)
\end{aligned}
$$

## Derivations of tsu, th and tco from the Clock GLB ${ }^{1}$

```
tsu = Logic + Reg su - Clock (min)
    \(=(\) tiobp \(+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor})+(\mathbf{t g s u})-(\mathbf{t g y} 0(\mathrm{~min})+\mathbf{t g c o}+\mathbf{t g c p}(\mathrm{min}))\)
    \(=(\# 20+\# 28+\# 35)+(\# 38)-(\# 50+\# 40+\# 52)\)
    \(5.5 \mathrm{~ns}=(2.0+2.0+8.0)+(1.0)-(4.5+2.0+1.0)\)
th \(=\operatorname{Clock}(\max )+\) Reg \(\mathrm{h}-\) Logic
    \(=(\mathbf{t g y 0}(\max )+\mathbf{t g c o}+\boldsymbol{t g c p}(\max ))+(\mathbf{t g h})-(\) tiobp \(+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor})\)
    \(=(\# 50+\# 40+\# 52)+(\# 39)-(\# 20+\# 28+\# 35)\)
    \(4.0 \mathrm{~ns}=(4.5+2.0+5.0)+(4.5)-(2.0+2.0+8.0)\)
    tco \(=\) Clock (max) + Reg co + Output
    \(=(\operatorname{tgy} 0(\) max \()+\boldsymbol{t g c o}+\operatorname{tgcp}(\max ))+(\operatorname{tgco})+(\mathbf{t o r p}+\mathbf{t o b})\)
    \(=(\# 50+\# 40+\# 52)+(\# 40)+(\# 45+\# 47)\)
\(19.0 \mathrm{~ns}=(4.5+2.0+5.0)+(2.0)+(2.5+3.0)\)
```

1. Calculations are based upon timing specs for the pLSI and ispLSI 1024-80.

## Specifications pLSI and ispLSI 1024

Figure 3. Typical Device Power Consumption vs fmax


ICC can be estimated for the pLSI and ispLSI 1024 using the following equation:
ICC= $42+(\#$ of PTs * 0.45$)+(\#$ of nets * Max. freq * 0.008$)$ where:
\# of PTs = Number of Product Terms used in design
\# of nets = Number of Signals used in device
Max. freq $=$ Highest Clock Frequency to the device
The ICC estimate is based on typical conditions ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, room temperature) and an assumption of 2 GLB loads on average exists. These values are for estimates only. Since the value of ICC is sensitive to operating conditions and the program in the device, the actual ICC should be verified.

Figure 4. Maximum GRP Delay vs GLB Loads


## In-System Programmability

The ispLSI devices are the in-system programmable versions of the Lattice High-Density programmable Large Scale Integration (pLSI) devices. By integrating all the high voltage programming circuitry on-chip, programming can be accomplished by simply shifting data into the device. Once the function is programmed, the nonvolatile $\mathrm{E}^{2} \mathrm{CMOS}$ cells will not lose the pattern even when the power is turned off.

All necessary programming is done via five TTL level logic interface signals. These five signals are fed into the on-chip programming circuitry where a state machine controls the programming. The interface signals are isp Enable (ispEN), Serial Data In (SDI), Serial Data Out (SDO), Serial Clock (SCLK) and Mode (MODE) control. Figure 5 illustrates the block diagram of one possible scheme for programming the ispLSI devices. For details on the operation of the internal state machine and programming of the device please refer to the in-system programming section in this Data Book.

Figure 5. ISP Programming Interface


## Specifications pLSI and ispLSI 1024

ISP Programming Voltage/Timing Specifications ${ }^{1}$

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VCCP | Programming Voltage |  | 4.75 | 5 | 5.25 | V |
| ICCP | Programming Supply Current |  | - | 50 | 100 | mA |
| VIHP | Input Voltage High | $\overline{\text { ispEN }}=$ Low | 2.0 | - | VCCP | V |
| VILP | Input Voltage Low |  | 0 | - | 0.8 | V |
| IIP | Input Current |  | - | 100 | 200 | $\mu \mathrm{A}$ |
| VOHP | Output Voltage High | $\mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ | 2.4 | - | Vccp | V |
| VOLP | Output Voltage Low | $\mathrm{l}_{\mathrm{OL}}=5 \mathrm{~mA}$ | 0 | - | 0.5 | V |
| tr, tf | Input Rise and Fall |  | - | - | 0.1 | $\mu \mathrm{s}$ |
| tispen | ispEN to Output 3-State Enabled |  | - | 2 | 10 | $\mu \mathrm{s}$ |
| tispdis | ispEN to Output 3-State Disabled |  | - | 2 | 10 | $\mu \mathrm{s}$ |
| tsu | Setup Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tco | Clock to Output |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| th | Hold Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tclkh, tclkl | Clock Pulse Width, High and Low |  | 0.5 | 1 | - | $\mu \mathrm{s}$ |
| tpwv | Verify Pulse Width |  | 20 | 30 | - | $\mu \mathrm{s}$ |
| tpwp | Programming Pulse Width |  | 40 | - | 100 | ms |
| tbew | Bulk Erase Pulse Width |  | 200 | - | - | ms |
| trst | Reset Time From Valid $\mathrm{V}_{\text {CCP }}$ |  | 45 | - | - | $\mu \mathrm{s}$ |

1. ISP Programming is guaranteed for $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Operation only.

Specifications pLSI and ispLSI 1024

Figure 6. Timing Waveforms for In-System Programming (ispLSI 1024)


772 Don't Care
888 Undefined State

Figure 7. Program, Verify \& Bulk Erase Waveforms (ispLSI 1024)


Figure 8 illustrates the address and data shift register bits for the ispLSI 1024. For a detailed explanation refer to
the Device Layout discussion in the pLSI and ispLSI Architectural Description section of this Data Book.

Figure 8. IspLSI 1024 Shift Register Layout


Note: A logic "1" in the Address Shift Register bit position enables the row for programming or verification.
A logic "0" disables it.

## Specifications pLSI and ispLSI 1024

## Pin Description

| Name | PLCC and JLCC Pin Numbers |  |  |  | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I/O 0 - I/O 3 I/O 4 - I/O 7 I/O 8 - I/O 11 I/O 12 - I/O 15 I/O 16 - I/O 19 I/O 20 - I/O 23 I/O 24 - I/O 27 I/O 28 - I/O 31 I/O 32 - I/O 35 I/O 36 - I/O 39 I/O 40 - I/O 43 I/O 44 - I/O 47 | 22, 26, 30 37 41 45 56 60 64, 3, 7, 11, | 23, <br> 27, <br> 31, <br> 38 , <br> 42, <br> 46, <br> 57, <br> 61, <br> 65, <br> 4, <br> 8 , <br> 12, | 24, <br> 28, <br> 32, <br> 39, <br> 43, <br> 47, <br> 58, <br> 62, <br> 66, <br> 5, <br> 9, <br> 13, | 25, <br> 29, <br> 33, <br> 40, <br> 44, <br> 48, <br> 59, <br> 63, <br> 67, <br> 6, <br> 10, <br> 14 | Input/Output Pins - These are the general purpose I/O pins used by the logic array. |
| IN $4-$ IN 5 | 2, | 15 |  |  | Dedicated input pins to the device. |
| $\overline{\operatorname{ispEN}}{ }^{\star} / \mathrm{NC}$ | 19 |  |  |  | Input - Dedicated in-system programming enable input pin. This pin is brought low to enable the programming mode. The MODE, SDI, SDO and SCLK options become active. |
| SDI*/IN 0 | 21 |  |  |  | Input-This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an input pin to load programming data into the device. SDI/IN 0 also is used as one of the two control pins for the isp state machine. |
| MODE*/IN 3 | 55 |  |  |  | Input-This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as a pin to control the operation of the isp state machine. |
| $\text { SDO*/IN } 1$ | 34 |  |  |  | Input/Output - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an output pin to read serial shift register data. |
| SCLK*/IN 2 | 49 |  |  |  | Input - This pin performs two functions. It is a dedicated input when ispEN is logic high. When ispEN is logic low, it functions as a clock pin for the Serial Shift Register. |
| $\overline{\text { RESET }}$ | 20 |  |  |  | Active Low (0) Reset pin which resets all of the GLB and I/O registers in the device. |
| YO | 16 |  |  |  | Dedicated Clock input. This clock input is connected to one of the clock inputs of all of the GLBs on the device. |
| Y1 | 54 |  |  |  | Dedicated clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB on the device. |
| Y2 | 51 |  |  |  | Dedicated clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB and/or any I/O cell on the device. |
| Y3 | 50 |  |  |  | Dedicated clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any I/O cell on the device. |
| $\begin{aligned} & \text { GND } \\ & \text { Vcc } \end{aligned}$ | 1, 17 | $\begin{aligned} & 18, \\ & 36, \end{aligned}$ | $\begin{aligned} & 35, \\ & 53, \end{aligned}$ | $\begin{aligned} & 52 \\ & 68 \end{aligned}$ | Ground (GND) $\mathrm{V}_{\mathrm{cc}}$ |

*For ispLSI 1024 Only

## Pin Configuration

## pLSI and ispLSI 1024 68-Pin PLCC Pinout Diagram



## pLSI and ispLSI 1024 68-Pin JLCC Pinout Diagram



* Pins have dual function capability for ispLSI 1024 only (except pin 19, which is ispEN only).


## Specifications pLSI and ispLSI 1024

## Part Number Description



## pLSI and ispLSI 1024 Ordering Information

COMMERCIAL

| Family | $f_{\text {max }}(\mathrm{MHz}$ ) | tpd ( ns ) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 90 | 12 | pLSI 1024-90LJ | 68-Pin PLCC |
|  | 80 | 15 | pLSI 1024-80LJ | 68-Pin PLCC |
|  | 60 | 20 | pLSI 1024-60LJ | 68-Pin PLCC |
| ispLSI | 90 | 12 | ispLSI 1024-90LJ | 68-Pin PLCC |
|  | 80 | 15 | ispLSI 1024-80LJ | 68-Pin PLCC |
|  | 60 | 20 | ispLSI 1024-60LJ | 68-Pin PLCC |

INDUSTRIAL

| Family | $f_{\max }(\mathrm{MHz})$ | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 60 | 20 | pLSI 1024-60LJI | 68 -Pin PLCC |
| ispLSI | 60 | 20 | ispLSI 1024-60LJI | 68 -Pin PLCC |

MILITARY/883

| Family | $f_{\max }(\mathrm{MHz})$ | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 60 | 20 | pLSI 1024-60LH/883 | $68-$ Pin JLCC |
| ispLSI | 60 | 20 | ispLSI 1024-60LH/883 | $68-$ Pin JLCC |

pLSI ${ }^{\circ}$ and ispLSI'" 1032
High-Density Programmable Logic

## Features

## - PROGRAMMABLE AND IN-SYSTEM PROGRAMMABLE HIGH DENSITY LOGIC

- High Speed Global Interconnect
- 6000 PLD Gates
- 64 I/O Pins, Eight Dedicated Inputs
- 192 Registers
- Wide Input Gating for Fast Counters, State Machines, Address Decoders, etc.
- Small Logic Block Size for Fast Random Logic
- Security Cell Prevents Unauthorized Copying
- HIGH PERFORMANCE E ${ }^{2}$ CMOS $^{\circledR}$ TECHNOLOGY
- $\mathrm{fmax}=\mathbf{9 0} \mathbf{M H z}$ Maximum Operating Frequency
— $\mathrm{fmax}=60 \mathrm{MHz}$ for Industrial and Military/883 Devices
- tpd = 12 ns Propagation Delay
- TTL Compatible Inputs and Outputs
- Electrically Erasable and Reprogrammable
- Non-Volatile E ${ }^{2}$ CMOS Technology
- 100\% Tested
- ispLSI OFFERS THE FOLLOWING ADDED FEATURES
- In-System Programable 5-Volt Only
- Change Logic and Interconnects "On-the-Fly" in Seconds
- Reprogram Soldered Device for Debugging
- COMBINES EASE OF USE AND THE FAST SYSTEM SPEED OF PLDs WITH THE DENSITY AND FLEXIBILITY OF FIELD PROGRAMMABLE GATE ARRAYS
- Complete Programmable Device Can Combine Glue Logic and Structured Designs
- Four Dedicated Clock Input Pins
- Synchronous and Asynchronous Clocks
- Flexible Pin Placement
— Optimized Global Routing Pool Provides Global Interconnectivity
- pLSI/ispLSI DEVELOPMENT SYSTEM (pDS ${ }^{\circledR}$ ) pDS Software
- Easy to Use PC Windows ${ }^{\text {TM }}$ Interface
- Boolean Logic Compiler
- Manual Partitioning
- Automatic Place and Route
- Static Timing Table
pDS+ ${ }^{\text {TM }}$ Software
- Industry Standard, Third Party Design Environments
— Schematic Capture, State Machine, HDL
- Automatic Partitioning and Place and Route
- Comprehensive Logic and Timing Simulation
- PC and Workstation Platforms


## Functional Block Diagram



## Description

The Lattice pLSI and ispLSI 1032 are High-Density Programmable Logic Devices containing 192 Registers, 64 Universal I/O pins, eight Dedicated Input pins, four Dedicated Clock Input pins and a Global Routing Pool (GRP). The GRP provides complete interconnectivity between all of these elements. The ispLSI 1032 features 5 -Volt in-system programming and in-system diagnostic capabilities. It is the first device which offers non-volatile "on-the-fly" reprogrammability of the logic, as well as the interconnect to provide truly reconfigurable systems. It is architecturally and parametrically compatible to the pLSI 1032 device, but multiplexes four of the dedicated input pins to control in-system programming.
The basic unit of logic on the pLSI and ispLSI 1032 devices is the Generic Logic Block (GLB). The GLBs are labeled A0, A1 .. D7 (see figure 1). There are a total of 32 GLBs in the pLSI and ispLSI 1032 devices. Each GLB has 18 inputs, a programmable AND/OR/XOR array, and four outputs which can be configured to be either combinatorial or registered. Inputs to the GLB come from the GRP and dedicated inputs. All of the GLB outputs are brought back into the GRP so that they can be connected to the inputs of any other GLB on the device.

[^4]
## Functional Block Diagram

Figure 1. pLSI and ispLSI 1032 Functional Block Diagram


The devices also have 64 I/O cells, each of which is directly connected to an I/O pin. Each I/O cell can be individually programmed to be a combinatorial input, registered input, latched input, output or bi-directional I/O pin with 3 -state control. Additionally, all outputs are polarity selectable, active high or active low. The signal levels are TTL compatible voltages and the output drivers can source 4 mA or sink 8 mA .

Eight GLBs, 16 I/O cells, two dedicated inputs and one ORP are connected together to make a Megablock (see figure 1). The outputs of the eight GLBs are connected to a set of 16 universal I/O cells by the ORP. The I/O cells within the Megablock also share a common Output Enable (OE) signal. The pLSI and ispLSI 1032 devices contain four of these Megablocks.

The GRP has as its inputs the outputs from all of the GLBs and all of the inputs from the bi-directional I/O cells. All of these signals are made available to the inputs of the GLBs. Delays through the GRP have been equalized to minimize timing skew.

Clocks in the pLSI and ispLSI 1032 devices are selected using the Clock Distribution Network. Four dedicated clock pins (Y0, Y1, Y2 and Y3) are brought into the distribution network, and five clock outputs (CLK 0, CLK 1, CLK 2, IOCLK 0 and IOCLK 1) are provided to route clocks to the GLBs and I/O cells. The Clock Distribution Network can also be driven from a special clock GLB (C0 on the pLSI and ispLSI 1032 devices). The logic of this GLB allows the user to create an internal clock from a combination of internal signals within the device.

## Absolute Maximum Ratings ${ }^{1}$

Supply Voltage $\mathrm{V}_{\mathrm{cc}} \ldots \ldots . .$.
Input Voltage Applied. . . . . . . . . . . . . . . 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Off-State Output Voltage Applied . . . . . . 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$
Case Temp. with Power Applied . . . . . . . . 55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. Functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

DC Recommended Operating Conditions

| SYMBOL | PARAMETER |  |  | MIN. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | Commercial | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 4.75 | 5.25 | V |
|  |  | Industrial | $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 4.5 | 5.5 |  |
|  |  | Military/883 | $\mathrm{T}_{\mathrm{C}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 4.5 | 5.5 |  |
| VIL | Input Low Voltage |  |  | 0 | 0.8 | V |
| VIH | Input High Voltage |  |  | 2.0 | $\mathrm{Vcc}+1$ | V |

Capacitance $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| SYMBOL | PARAMETER |  | MAXIMUM ${ }^{1}$ | UNITS | TEST CONDITIONS |
| :--- | :--- | :--- | :---: | :---: | :--- |
| $\mathbf{C}_{1}$ | Dedicated Input Capacitance | Commercial/Industrial | 8 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{~N}}=2.0 \mathrm{~V}$ |
|  |  | Military | 10 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{I N}=2.0 \mathrm{~V}$ |
| $\mathbf{C}_{2}$ | I/O and Clock Capacitance | 10 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{10}, \mathrm{~V}_{\mathrm{Y}}=2.0 \mathrm{~V}$ |  |

1. Guaranteed but not $100 \%$ tested.

## Data Retention Specifications

| PARAMETER | MINIMUM | MAXIMUM | UNITS |
| :--- | :---: | :---: | :---: |
| Data Retention | 20 | - | YEARS |
| ispLSI Erase/Reprogram Cycles | 1000 | - | CYCLES |
| pLSI Erase/Reprogram Cycles | 100 | - | CYCLES |

Table 2-0008A-isp

## Specifications pLSI and ispLSI 1032

## Switching Test Conditions

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Time | $\leq 3 \mathrm{~ns} \mathrm{10} \mathrm{\%} \mathrm{to} 90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See figure 2 |

3-state levels are measured 0.5 V from steady-state active level.

## Output Load Conditions (see figure 2)

| Test Condition |  | R1 | R2 | CL |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $470 \Omega$ | $390 \Omega$ | 35 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 35 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 35 pF |
| C | Active High to Z <br> at $\mathbf{V}_{\text {OH }}-0.5 \mathrm{~V}$ | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low to Z <br> at $\mathbf{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$ | $470 \Omega$ | $390 \Omega$ | 5 pF |

## DC Electrical Characteristics

## Over Recommended Operating Conditions

| SYMBOL | PARAMETER | CONDITION |  | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Output Low Voltage | $\mathrm{l}_{\alpha}=8 \mathrm{~mA}$ |  | - | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{l}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 2.4 | - | - | V |
| IIL | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {cc }}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| IIL-isp | isp Input Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -150 | $\mu \mathrm{A}$ |
| IIL-PU | I/O Active Pull-Up Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ |  | - | - | -150 | $\mu \mathrm{A}$ |
| IOS1 | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.5 \mathrm{~V}$ |  | -60 | - | -200 | mA |
| ICC2 | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {TOGGLE }}=1 \mathrm{MHz} \end{aligned}$ | Commercial | - | 130 | 190 | mA |
|  |  |  | Industrial | - | 135 | 220 | mA |

1. One output at a time for a maximum duration of one second.
2. Measured using eight 16 -bit counters.
3. Typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## Specifications pLSI and ispLSI 1032

## External Timing Parameters

Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST } 5 \\ & \text { COND. } \end{aligned}$ | $*^{2}$ | DESCRIPTION ${ }^{1}$ | -90 |  | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd1 | A | 1 | Data Propagation Delay, 4PT bypass, ORP bypass | - | 12 | - | 15 | - | 20 | ns |
| tpd2 | A | 2 | Data Propagation Delay, Worst Case Path | - | 17 | - | 20 | - | 25 | ns |
| $f$ max | A | 3 | Clock Frequency with Internal Feedback ${ }^{3}$ | 90.9 | - | 80 | - | 60 | - | MHz |
| $f^{\prime}$ max (Ext.) | - | 4 | Clock Frequency with External Feedback $\left(\frac{1}{\text { tal } 2+\text { tcol }}\right.$ ) | 58.8 | - | 50 | - | 38 | - | MHz |
| fmax (Tog.) | - | 5 | Clock Frequency, Max Toggle ${ }^{4}$ | 125 | - | 100 | - | 83 | - | MHz |
| tsu1 | - | 6 | GLB Reg. Setup Time before Clock, 4PT bypass | 6 | - | 7 | - | 9 | - | ns |
| tco1 | A | 7 | GLB Reg. Clock to Output Delay, ORP bypass | - | 8 | - | 10 | - | 13 | ns |
| th1 | - | 8 | GLB Reg. Hold Time after Clock, 4 PT bypass | 0 | - | 0 | - | 0 | - | ns |
| tsu2 | - | 9 | GLB Reg. Setup Time before Clock | 9 | - | 10 | - | 13 | - | ns |
| tco2 | - | 10 | GLB Reg. Clock to Output Delay | - | 10 | - | 12 | - | 16 | ns |
| th2 | - | 11 | GLB Reg. Hold Time after Clock | 0 | - | 0 | - | 0 | - | ns |
| tr1 | A | 12 | Ext. Reset Pin to Output Delay | - | 15 | - | 17 | - | 22.5 | ns |
| trw1 | - | 13 | Ext. Reset Pulse Duration | 10 | - | 10 | - | 13 | - | ns |
| ten | B | 14 | Input to Output Enable | - | 15 | - | 18 | - | 24 | ns |
| tdis | C | 15 | Input to Output Disable | - | 15 | - | 18 | - | 24 | ns |
| twh | - | 16 | Ext. Sync. Clock Pulse Duration, High | 4 | - | 5 | - | 6 | - | ns |
| twl | - | 17 | Ext. Sync. Clock Pulse Duration, Low | 4 | - | 5 | - | 6 | - | ns |
| tsu5 | - | 18 | I/O Reg. Setup Time before Ext. Sync. Clock (Y2, Y3) | 2 | - | 2 | - | 2.5 | - | ns |
| th5 | - | 19 | I/O Reg. Hold Time after Ext. Sync. Clock (Y2, Y3) | 6.5 | - | 6.5 | - | 8.5 | - | ns |

1. Unless noted otherwise, all parameters use a GRP load of 4 GLBs, ORP and YO clock.

Table 2-0030-32/90,80,60C
2. Refer to Timing Model in this data sheet for further details.
3. Standard $\mathbf{1 6 - B i t}$ counter using GRP feedback.
4. fmax (Toggle) may be less than $1 /($ twh + twl). This is to allow for a clock duty cycle of other than $50 \%$.
5. Reference Switching Test Conditions Section. Specifications pLSI and ispLSI 1032

## Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -90 |  | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| Inputs |  |  |  |  |  |  |  |  |  |
| tiobp | 20 | I/O Register Bypass | - | 1.6 | - | 2.0 | - | 2.7 | ns |
| tiolat | 21 | I/O Latch Delay | - | 2.4 | - | 3.0 | - | 4.0 | ns |
| tiosu | 22 | I/O Register Setup Time before Clock | 4.8 | - | 5.5 | - | 7.3 | - | ns |
| tioh | 23 | I/O Register Hold Time after Clock | 2.1 | - | 1.0 | - | 1.3 | - | ns |
| tioco | 24 | I/O Register Clock to Out Delay | - | 2.4 | - | 3.0 | - | 4.0 | ns |
| tior | 25 | I/O Register Reset to Out Delay | - | 2.8 | - | 2.5 | - | 3.3 | ns |
| tdin | 26 | Dedicated Input Delay | - | 3.2 | - | 4.0 | - | 5.3 | ns |
| GRP |  |  |  |  |  |  |  |  |  |
| tgrp1 | 27 | GRP Delay, 1 GLB Load | - | 1.2 | - | 1.5 | - | 2.0 | ns |
| tgrp4 | 28 | GRP Delay, 4 GLB Loads | - | 1.6 | - | 2.0 | - | 2.7 | ns |
| tgrp8 | 29 | GRP Delay, 8 GLB Loads | - | 2.4 | - | 3.0 | - | 4.0 | ns |
| tgrp12 | 30 | GRP Delay, 12 GLB Loads | - | 3.0 | - | 3.8 | - | 5.0 | ns |
| tgrp16 | 31 | GRP Delay, 16 GLB Loads | - | 3.6 | - | 4.5 | - | 6.0 | ns |
| tgrp32 | 32 | GRP Delay, 32 GLB Loads | - | 6.4 | - | 8.0 | - | 10.6 | ns |
| GLB |  |  |  |  |  |  |  |  |  |
| t4ptbp | 33 | 4 Product Term Bypass Path Delay | - | 5.2 | - | 6.5 | - | 8.6 | ns |
| t1ptxor | 34 | 1 Product Term/XOR Path Delay | - | 5.7 | - | 7.0 | - | 9.3 | ns |
| t20ptxor | 35 | 20 Product Term/XOR Path Delay | - | 7.0 | - | 8.0 | - | 10.6 | ns |
| txoradj | 36 | XOR Adjacent Path Delay ${ }^{3}$ | - | 8.2 | - | 9.5 | - | 12.7 | ns |
| tgbp | 37 | GLB Register Bypass Delay | - | 0.8 | - | 1.0 | - | 1.3 | ns |
| tgsu | 38 | GLB Register Setup Time before Clock | 1.2 | - | 1.0 | - | 1.3 | - | ns |
| tgh | 39 | GLB Register Hold Time after Clock | 3.6 | - | 4.5 | - | 6.0 | - | ns |
| tgco | 40 | GLB Register Clock to Output Delay | - | 1.6 | - | 2.0 | - | 2.7 | ns |
| tgr | 41 | GLB Register Reset to Output Delay | - | 2.0 | - | 2.5 | - | 3.3 | ns |
| tptre | 42 | GLB Product Term Reset to Register Delay | - | 8.0 | - | 10.0 | - | 13.3 | ns |
| tptoe | 43 | GLB Product Term Output Enable to I/O Cell Delay | - | 7.8 | - | 9.0 | - | 12.0 | ns |
| tptck | 44 | GLB Product Term Clock Delay | 2.8 | 6.0 | 3.5 | 7.5 | 4.6 | 9.9 | ns |
| ORP |  |  |  |  |  |  |  |  |  |
| torp | 45 | ORP Delay | - | 2.4 | - | 2.5 | - | 3.3 | ns |
| torpbp | 46 | ORP Bypass Delay | - | 0.4 | - | 0.5 | - | 0.7 | ns |

[^5]
## Specifications pLSI and ispLSI 1032

## Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -90 |  | -80 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| Outputs |  |  |  |  |  |  |  |  |  |
| tob | 47 | Output Buffer Delay | - | 2.4 | - | 3.0 | - | 4.0 | ns |
| toen | 48 | I/O Cell OE to Output Enabled | - | 4.0 | - | 5.0 | - | 6.7 | ns |
| todis | 49 | I/O Cell OE to Output Disabled | - | 4.0 | - | 5.0 | - | 6.7 | ns |
| Clocks |  |  |  |  |  |  |  |  |  |
| tgy0 | 50 | Clock Delay, Y0 to Global GLB Clock Line (Ref. clock) | 3.6 | 3.6 | 4.5 | 4.5 | 6.0 | 6.0 | ns |
| tgy $1 / 2$ | 51 | Clock Delay, Y1 or Y2 to Global GLB Clock Line | 2.8 | 4.4 | 3.5 | 5.5 | 4.6 | 7.3 | ns |
| tgcp | 52 | Clock Delay, Clock GLB to Global GLB Clock Line | 0.8 | 4.0 | 1.0 | 5.0 | 1.3 | 6.6 | ns |
| tioy2/3 | 53 | Clock Delay, Y2 or Y3 to I/O Cell Global Clock Line | 2.8 | 4.4 | 3.5 | 5.5 | 4.6 | 7.3 | ns |
| tiocp | 54 | Clock Delay, Clock GLB to I/O Cell Global Clock Line | 0.8 | 4.0 | 1.0 | 5.0 | 1.3 | 6.6 | ns |
| Global Reset |  |  |  |  |  |  |  |  |  |
| tgr | 55 | Global Reset to GLB and I/O Registers | - | 8.2 | - | 9.0 | - | 12.0 | ns |

1. Internal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.

## pLSI and ispLSI 1032 Timing Model



## Derivations of tsu, th and tco from the Product Term Clock ${ }^{1}$

```
tsu \(=\) Logic + Reg su - Clock (min)
    \(=(\) tiobp + tgrp \(4+\) t20ptxor \()+(\) tgsu \()-(\) tiobp \(+\mathbf{t g r p} 4+\) tptck \((m i n))\)
    \(=(\# 20+\# 28+\# 35)+(\# 38)-(\# 20+\# 28+\# 44)\)
    \(5.5 \mathrm{~ns}=(2.0+2.0+8.0)+(1.0)-(2.0+2.0+3.5)\)
th \(=\operatorname{Clock}(\max )+\) Reg h - Logic
    \(=(\) tiobp + tgrp4 + tptck(max) \()+(\) tgh \()-(\) tiobp + tgrp4 + t20ptxor \()\)
    \(=(\# 20+\# 28+\# 44)+(\# 39)-(\# 20+\# 28+\# 35)\)
    \(4.0 \mathrm{~ns}=(2.0+2.0+7.5)+(4.5)-(2.0+2.0+8.0)\)
tco \(=\) Clock (max) + Reg co + Output
    \(=(\) tiobp + tgrp \(4+\) tptck \((\) max \())+(\) tgco \()+(\) torp + tob \()\)
    \(=(\# 20+\# 28+\# 44)+(\# 40)+(\# 45+\# 47)\)
\(19.0 \mathrm{~ns}=(2.0+2.0+7.5)+(2.0)+(2.5+3.0)\)
```


## Derivations of tsu, th and tco from the Clock GLB ${ }^{1}$

```
tsu \(=\) Logic + Reg su - Clock (min)
    \(=(\) tiobp \(+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor})+(\mathbf{t g s u})-(\mathbf{t g y O}(\min )+\mathbf{t g c o}+\mathbf{t g c p}(\mathbf{m i n}))\)
    \(=(\# 20+\# 28+\# 35)+(\# 38)-(\# 50+\# 40+\# 52)\)
    \(5.5 \mathrm{~ns}=(2.0+2.0+8.0)+(1.0)-(4.5+2.0+1.0)\)
th \(=\) Clock (max) + Reg \(\mathrm{h}-\) Logic
    \(=(\operatorname{tgy} \mathbf{( m a x})+\mathbf{t g c o}+\boldsymbol{t g c p}(\max ))+(\mathbf{t g h})-(\) tiobp \(+\mathbf{t g r p} 4+\mathbf{t} 20 \mathrm{ptxor})\)
    \(=(\# 50+\# 40+\# 52)+(\# 39)-(\# 20+\# 28+\# 35)\)
    \(4.0 \mathrm{~ns}=(4.5+2.0+5.0)+(4.5)-(2.0+2.0+8.0)\)
tco \(=\) Clock (max) + Reg co + Output
    \(=(\operatorname{tgy} 0(\max )+\mathbf{t g c o}+\operatorname{tgcp}(\max ))+(\operatorname{tgco})+(\) torp \(+\mathbf{t o b})\)
    \(=(\# 50+\# 40+\# 52)+(\# 40)+(\# 45+\# 47)\)
\(19.0 \mathrm{~ns}=(4.5+2.0+5.0)+(2.0)+(2.5+3.0)\)
```

1. Calculations are based upon timing specs for the pLSI and ispLSI 1032-80. Specifications pLSI and ispLSI 1032

Figure 3. Typical Device Power Consumption vs fmax


ICC can be estimated for the pLSI and ispLSI 1032 using the following equation:
ICC $=52+$ (\# of PTs * 0.30 ) + (\# of nets * Max. freq * 0.009 ) where:
\# of PTs = Number of Product Terms used in design
\# of nets = Number of Signals used in device
Max. freq = Highest Clock Frequency to the device
The ICC estimate is based on typical conditions ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, room temperature) and an assumption of 2 GLB loads on average exists. These values are for estimates only. Since the value of ICC is sensitive to operating conditions and the program in the device, the actual ICC should be verified.

Figure 4. Maximum GRP Delay vs GLB Loads


## Specifications pLSI and ispLSI 1032

## In-System Programmability

The ispLSI devices are the in-system programmable versions of the Lattice High-Density programmable Large Scale Integration (pLSI) devices. By integrating all the high voltage programming circuitry on-chip, programming can be accomplished by simply shifting data into the device. Once the function is programmed, the nonvolatile $\mathrm{E}^{2} \mathrm{CMOS}$ cells will not lose the pattern even when the power is turned off.

All necessary programming is done via five TTL level logic interface signals. These five signals are fed into the on-chip programming circuitry where a state machine controls the programming. The interface signals are isp Enable ( (ispEN), Serial Data In (SDI), Serial Data Out (SDO), Serial Clock (SCLK) and Mode (MODE) control. Figure 5 illustrates the block diagram of one possible scheme for programming the ispLSI devices. For details on the operation of the internal state machine and programming of the device please refer to the in-system programming section in this Data Book.

Figure 5. ISP Programming Interface
 Specifications pLSI and ispLSI 1032

ISP Programming Voltage/Timing Specifications ${ }^{1}$

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VCCP | Programming Voltage |  | 4.75 | 5 | 5.25 | V |
| ICCP | Programming Supply Current |  | - | 50 | 100 | mA |
| VIHP | Input Voltage High | $\overline{\text { ispEN }}=$ Low | 2.0 | - | VCCP | V |
| VILP | Input Voltage Low |  | 0 | - | 0.8 | V |
| IIP | Input Current |  | - | 100 | 200 | $\mu \mathrm{A}$ |
| VOHP | Output Voltage High | $\mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ | 2.4 | - | Vcce | V |
| Volp | Output Voltage Low | $\mathrm{l}_{\mathrm{OL}}=5 \mathrm{~mA}$ | 0 | - | 0.5 | V |
| tr, tf | Input Rise and Fall |  | - | - | 0.1 | $\mu \mathrm{s}$ |
| tispen | ispEN to Output 3-State Enabled |  | - | 2 | 10 | $\mu \mathrm{s}$ |
| tispdis | ispEN to Output 3-State Disabled |  | - | 2 | 10 | $\mu \mathrm{s}$ |
| tsu | Setup Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tco | Clock to Output |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| th | Hold Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tclkh, tclkl | Clock Pulse Width, High and Low |  | 0.5 | 1 | - | $\mu \mathrm{s}$ |
| tpwv | Verify Pulse Width |  | 20 | 30 | - | $\mu \mathrm{s}$ |
| tpwp | Programming Pulse Width |  | 40 | - | 100 | ms |
| tbew | Bulk Erase Pulse Width |  | 200 | - | - | ms |
| trst | Reset Time From Valid $\mathrm{V}_{\text {CCP }}$ |  | 45 | - | - | $\mu \mathrm{s}$ |

1. ISP Programming is guaranteed for $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Operation only.

Figure 6. Timing Waveforms for In-System Programming (ispLSI 1032)


Figure 7. Program, Verify \& Bulk Erase Waveforms (ispLSI 1032)


Figure 8 illustrates the address and data shift register bits the Device Layout discussion in the pLSI and ispLSI for the ispLSI 1032. For a detailed explanation refer to Architectural Description section of this Data Book.

Figure 8. ispLSI 1032 Shift Register Layout


Note: A logic "1" in the Address Shift Register bit position enables the row for programming or verification. A logic " 0 " disables it.

Pin Description

| Name | PLCC Pin Numbers |  |  |  | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I/O 0 - I/O 3 <br> I/O 4 - I/O 7 <br> I/O 8 - I/O 11 <br> I/O 12 - I/O 15 <br> I/O 16-I/O 19 <br> I/O 20-I/O 23 <br> I/O 24 - I/O 27 <br> I/O 28 - I/O 31 <br> I/O 32 - I/O 35 <br> I/O 36 - I/O 39 <br> I/O 40 - I/O 43 <br> I/O 44 - I/O 47 <br> I/O 48 - I/O 51 <br> I/O 52 - I/O 55 <br> I/O 56 - I/O 59 <br> I/O 60 - I/O 63 | 26, <br> 30 , <br> 34, <br> 38, <br> 45, <br> 49, <br> 53, <br> 57, <br> 68, <br> 72, <br> 76, <br> 80, <br> 3 , <br> 7, <br> 11, <br> 15, | 27, <br> 31, <br> 35, <br> 39, <br> 46, <br> 50, <br> 54, <br> 58, <br> 69, <br> 73, <br> 77, <br> 81, <br> 4, <br> 8 , <br> 12, <br> 16, | 28, <br> 32, <br> 36, <br> 40, <br> 47, <br> 51, <br> 55, <br> 59, <br> 70, <br> 74, <br> 78, <br> 82, <br> 5 , <br> 9, <br> 13, <br> 17, | 29, <br> 33, <br> 37, <br> 41, <br> 48, <br> 52, <br> 56, <br> 60 , <br> 71, <br> 75, <br> 79, <br> 83 , <br> 6 , <br> 10, <br> 14, <br> 18 | Input/Output Pins - These are the general purpose I/O pins used by the logic array. |
| IN 4 -IN 7 | 67, | 84, | 2, | 19 | Dedicated input pins to the device. |
| $\overline{\mathrm{ispEN}}{ }^{\star} / \mathrm{NC}$ | 23 |  |  |  | Input - Dedicated in-system programming enable input pin. This pin is brought low to enable the programming mode. The MODE, SDI, SDO and SCLK options become active. |
| SDI*/IN 0 | 25 |  |  |  | Input - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an input pin to load programming data into the device. SDI/IN 0 also is used as one of the two control pins for the isp state machine. |
| MODE*/IN 1 | 42 |  |  |  | Input-This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as a pin to control the operation of the isp state machine. |
| SDO*/IN 2 | 44 |  |  |  | Input/Output - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an output pin to read serial shift register data. |
| SCLK*/IN 3 | 61 |  |  |  | Input - This pin performs two functions. It is a dedicated input when ispEN is logic high. When ispEN is logic low, it functions as a clock pin for the Serial Shift Register. |
| RESET | 24 |  |  |  | Active Low (0) Reset pin which resets all of the GLB and I/O registers in the device. |
| YO | 20 |  |  |  | Dedicated Clock input. This clock input is connected to one of the clock inputs of all of the GLBs on the device. |
| Y1 | 66 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB on the device. |
| Y2 | 63 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB and/or any I/O cell on the device. |
| Y3 | 62 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any I/O cell on the device. |
| $\begin{aligned} & \text { GND } \\ & \text { VcC } \end{aligned}$ |  | $\begin{aligned} & 22, \\ & 65 \end{aligned}$ |  | 64 | Ground (GND) $\mathrm{V}_{\mathrm{cc}}$ |

[^6]Specifications pLSI and ispLSI 1032

## Pin Description

| Name | TQFP Pin Numbers |  |  |  | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I/O 0 - I/O 3 <br> I/O 4 - I/O 7 <br> I/O 8 - I/O 11 <br> I/O 12 - I/O 15 <br> I/O 16-I/O 19 <br> I/O 20 - I/O 23 <br> I/O 24 - I/O 27 <br> I/O 28 - I/O 31 <br> I/O 32 - I/O 35 <br> I/O 36 - I/O 39 <br> I/O 40 - I/O 43 <br> I/O 44 - I/O 47 <br> I/O 48 - I/O 51 <br> I/O 52 - I/O 55 <br> I/O 56 - I/O 59 <br> I/O 60 - I/O 63 | 17, <br> 21, <br> 29, <br> 33, <br> 40, <br> 44, <br> 48, <br> 56, <br> 67, <br> 71, <br> 79, <br> 83, <br> 90, <br> 94, <br> 98 , <br> 6, | 18, <br> 22, <br> 30, <br> 34, <br> 41, <br> 45, <br> 53, <br> 57, <br> 68, <br> 72, <br> 80, <br> 84 , <br> 91, <br> 95, <br> 3 , <br> 7, | 19, <br> 23, <br> 31, <br> 35, <br> 42, <br> 46, <br> 54, <br> 58, <br> 69, <br> 73 , <br> 81, <br> 85, <br> 92, <br> 96, <br> 4, <br> 8, | $\begin{aligned} & 20, \\ & 28, \\ & 32, \\ & 36, \\ & 43, \\ & 47, \\ & 55, \\ & 59, \\ & 70, \\ & 78, \\ & 82, \\ & 86, \\ & 93, \\ & 99, \\ & 5, \\ & 9 \\ & \hline \end{aligned}$ | Input/Output Pins - These are the general purpose I/O pins used by the logic array. |
| IN 4 - IN 7 | 66, | 87, | 89, | 10 | Dedicated input pins to the device. |
| ispEN*/NC SDI*/IN 0 | 14 16 |  |  |  | Input - Dedicated in-system programming enable input pin. This pin is brought low to enable the programming mode. The MODE, SDI, SDO and SCLK options become active. <br> Input-This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an input pin to load programming data into the device. SDI/IN 0 also is used as one of the two control pins for the isp state machine. |
| MODE*/IN 1 | 37 |  |  |  | Input - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as a pin to control the operation of the isp state machine. |
| SDO*/IN 2 | 39 |  |  |  | Input/Output - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an output pin to read serial shift register data. |
| SCLK*/IN 3 | 60 |  |  |  | Input - This pin performs two functions. It is a dedicated input when ispEN is logic high. When ispEN is logic low, it functions as a clock pin for the Serial Shift Register. |
| NC | $\begin{aligned} & 1, \\ & 26, \\ & 51, \\ & 76, \end{aligned}$ | $\begin{aligned} & 2, \\ & 27, \\ & 52, \\ & 77, \end{aligned}$ | $\begin{aligned} & 24, \\ & 49, \\ & 74, \\ & 99 \end{aligned}$ | $\begin{aligned} & 25 \\ & 50, \\ & 75 \\ & 100 \end{aligned}$ | These pins are not used. |
| RESET | 15 |  |  |  | Active Low (0) Reset pin which resets all of the GLB and I/O registers in the device. |
| YO | 11 |  |  |  | Dedicated Clock input. This clock input is connected to one of the clock inputs of all of the GLBs on the device. |
| Y1 | 65 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB on the device. |
| Y2 | 62 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB and/or any I/O cell on the device. |
| Y3 | 61 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any I/O cell on the device. |
| $\begin{aligned} & \text { GND } \\ & \text { VCC } \end{aligned}$ | $\begin{aligned} & 13, \\ & 12, \end{aligned}$ | $\begin{aligned} & 38, \\ & 64 \end{aligned}$ | $63 \text {, }$ | 88 | Ground (GND) $\mathrm{V}_{\mathrm{cc}}$ |

[^7]
## Pin Description

| Name | CPGA Pin Numbers |  |  |  | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1/O O-I/O 3 I/O 4 - I/O 7 I/O 8 - I/O 11 I/O 12 - I/O 15 I/O 16 - I/O 19 I/O 20 - I/O 23 I/O 24 - I/O 27 I/O 28 - I/O 31 I/O 32 - I/O 35 I/O 36 - I/O 39 I/O 40 - I/O 43 I/O 44 - I/O 47 I/O 48 - I/O. 51 I/O 52 - I/O 55 I/O 56 - I/O 59 I/O 60 - I/O 63 | F1, <br> K1, <br> K3, <br> L4, <br> L7, <br> K8, <br> L11, <br> J11, <br> E9, <br> B11, <br> B9, <br> AB, <br> A5, <br> B4, <br> A1, <br> C1, | H1, <br> J2, <br> L2, <br> J5, <br> K7, <br> L9, <br> K10, <br> H10, <br> D11, <br> C10, <br> A10, <br> B6, <br> B5, <br> A3, <br> B2, <br> D2, | H2, <br> L1, <br> L3, <br> K5, <br> L6, <br> L10, <br> J10, <br> H11, <br> D10, <br> A11, <br> A9, <br> B7, <br> C5, <br> A2, <br> C2, <br> D1, | J1, <br> K2, <br> K4, <br> L5, <br> L8, <br> K9, <br> K11, <br> F10, <br> C11, <br> B10, <br> B8, <br> A7, <br> A4, <br> B3, <br> B1, <br> E3 | Input/Output Pins - These are the general purpose I/O pins used by the logic array. |
| IN 4 -IN 7 | E10, | C7, | A6, | E2 | Dedicated input pins to the device. |
| ispEN ${ }^{*} / \mathrm{NC}$ | G3 |  |  |  | Input - Dedicated in-system programming enable input pin. This pin is brought low to enable the programming mode. The MODE, SDI, SDO and SCLK options become active. |
| SDI*/IN 0 | G2 |  |  |  | Input - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an input pin to load programming data into the device. SDIIIN $O$ also is used as one of the two control pins for the isp state machine. |
| MODE*/IN 1 | K6 |  |  |  | Input-This pin performs two functions. It is a dedicated input pin when ispen is logic high. When ISpEN is logic low, it functions as a pin to control the operation of the isp state machine. |
| SDO*/N 2 | J7 |  |  |  | Input/Output - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ISpEN is logic low, it functions as an output pin to read serial shift register data. |
| SCLK*/N 3 | G10 |  |  |  | Input - This pin performs two functions. It is a dedicated input when ispEN is logic high. When ispEN is logic low, it functions as a clock pin for the Serial Shift Register. |
| $\overline{\text { RESET }}$ | G1 |  |  |  | Active Low (0) Reset pin which resets all of the GLB and I/O registers in the device. |
| YO | E1 |  |  |  | Dedicated Clock input. This clock input is connected to one of the clock inputs of all of the GLBs on the device. |
| Y1 | E11 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB on the device. |
| Y2 | G9 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB and/or any I/O cell on the device. |
| Y3 | G11 |  |  |  | Dedicated Clock input. This clock input is brought into the clock distribution network, and canoptionally be routed to any I/O cell on the device. |
| NC | G3 |  |  |  | This pin should be left floating or tied to $\mathrm{V}_{\mathrm{cc}}$. This pin should never be tied to GND. |
| $\begin{aligned} & \text { GND } \\ & \text { Vcc } \end{aligned}$ | $\begin{aligned} & \text { C6, } \\ & \text { F2, } \end{aligned}$ | $\begin{aligned} & \text { F3, } \\ & \text { F11 } \end{aligned}$ | F9, | J6 | $\begin{aligned} & \text { Ground (GND) } \\ & V_{c c} \end{aligned}$ |

## Pin Configuration

pLSI and ispLSI 1032 84-Pin PLCC Pinout Diagram

*Pins have dual function capability for ispLSI 1032 only (except pin 23 , which is $\overline{\text { ispEN }}$ only).

## Pin Configuration

pLSI and ispLSI 1032 100-pin TQFP Pinout Diagram

*Pins have dual function capability for ispLSI 1032 only (except pin 14, which is $\overline{\text { ispEN }}$ only).

## Specifications pLSI and ispLSI 1032

## Pin Configuration

pLSI and ispLSI 1032/883 84-Pin CPGA Pinout Diagram


[^8]
## Specifications pLSI and ispLSI 1032

## Part Number Description



## pLSI and ispLSI 1032 Ordering Information

COMMERCIAL

| Family | $f_{\text {max }}(\mathrm{MHz})$ | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 90 | 12 | pLSI 1032-90LJ | 84-Pin PLCC |
|  | 90 | 12 | pLSI 1032-90LT | 100-Pin TQFP |
|  | 80 | 15 | pLSI 1032-80LJ | 84-Pin PLCC |
|  | 80 | 15 | pLSI 1032-80LT | 100-Pin TQFP |
|  | 60 | 20 | pLSI 1032-60LJ | 84-Pin PLCC |
|  | 60 | 20 | pLSI 1032-60LT | 100-Pin TQFP |
| IsplSI | 90 | 12 | isplSI 1032-90LJ | 84-Pin PLCC |
|  | 90 | 12 | ispLSI 1032-90LT | 100-Pin TQFP |
|  | 80 | 15 | isplSI 1032-80LJ | 84-Pin PLCC |
|  | 80 | 15 | isplSI 1032-80LT | 100-Pin TQFP |
|  | 60 | 20 | isplSI 1032-60LJ | 84-Pin PLCC |
|  | 60 | 20 | isplSI 1032-60LT | 100-Pin TQFP |

industrial

| Family | fmax (MHz) | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 60 | 20 | pLSI 1032-60LJI | 84-Pin PLCC |
| ispLSI | 60 | 20 | ispLSI 1032-60LJI | 84-Pin PLCC |

MILITARY/883

| Family | $f_{\max (M H z)}$ | $t_{\text {pd (ns) }}$ | Ordering Number | SMD Number | Package |
| :---: | :---: | :---: | :---: | :---: | :---: |
| pLSI | 60 | 20 | pLSI 1032-60LG/883 | $5962-9466801$ MXC | 84-Pin CPGA |
| IspLSI | 60 | 20 | ispLSI 1032-60LG/883 | $5962-9308501$ MXC | 84-Pin CPGA |

Table 2-0041A-32-kpp

## Features

- PROGRAMMABLE AND IN-SYSTEM PROGRAMMABLE HIGH DENSITY LOGIC
- High-Speed Global Interconnects
- 8000 PLD Gates
- 96 I/O Pins, Ten Dedicated Inputs
- 288 Registers
- Wide Input Gating for Fast Counters, State Machines, Address Decoders, etc.
- Small Logic Block Size for Random Logic
- Security Cell Prevents Unauthorized Copying
- HIGH PERFORMANCE E ${ }^{2}$ CMOS ${ }^{\oplus}$ TECHNOLOGY
- $\mathrm{fmax}=\mathbf{8 0} \mathbf{~ M H z}$ Maximum Operating Frequency
- $\mathrm{fmax}=\mathbf{5 0} \mathrm{MHz}$ for Industrial Devices
- tpd = 15 ns Propagation Delay
- TTL Compatible Inputs and Outputs
- Electrically Eraseable and Reprogrammable
- Non-Volatile $\mathrm{E}^{2}$ CMOS Technology
- 100\% Tested
- ispLSI OFFERS THE FOLLOWING ADDED FEATURES
- In-System Programmable 5-Volt Only
— Change Logic and Interconnects "On-the-Fly" in Seconds
- Reprogram Soldered Device for Debugging
- COMBINES EASE OF USE AND THE FAST SYSTEM

SPEED OF PLDs WITH THE DENSITY AND FLEX-
IBILITY OF FIELD PROGRAMMABLE GATE ARRAYS

- Complete Programmable Device Can Combine Glue

Logic and Structured Designs

- Four Dedicated Clock Input Pins
- Synchronous and Asynchronous Clocks
- Flexible Pin Placement
- Optimized Global Routing Pool Provides Global Interconnectivity
- pLSI/ispLSI DEVELOPMENT SYSTEM (pDS ${ }^{\text {® }}$ ) pDS Software
— Easy to Use PC Windows ${ }^{\text {TM }}$ Interface
- Boolean Logic Compiler
- Manual Partitioning
- Automatic Place and Route
- Static Timing Table
pDS ${ }^{+1 m}$ Software
— Industry Standard, Third Party Design Environments
- Schematic Capture, State Machine, HDL
- Automatic Partitioning and Place and Route
- Comprehensive Logic and Timing Simulation
- PC and Workstation Platforms


## Functional Block Diagram



## Description

The Lattice pLSI and ispLSI 1048 are High-Density Programmable Logic Devices which contain 288 Registers, 96 Universal I/O pins, ten Dedicated Input pins, four Dedicated Clock Input pins and a Global Routing Pool (GRP). The GRP provides complete interconnectivity between all of these elements. The ispLSI 1048 features 5 -Volt in-system programming and in-system diagnostic capabilities. It is the first device which offers non-volatile "on-the-fly" reprogrammability of the logic, as well as the interconnect to provide truly reconfigurable systems. It is architecturally and parametrically compatible to the pLSI 1048 device, but multiplexes four of the dedicated input pins to control in-system programming.

The basic unit of logic on the pLSI and ispLSI 1048 devices is the Generic Logic Block (GLB). The GLBs are labeled A0, A1 .. F7 (see figure 1). There are a total of 48 GLBs in the pLSI and ispLSI 1048 devices. Each GLB has 18 inputs, a programmable AND/OR/XOR array, and four outputs which can be configured to be either combinatorial or registered. Inputs to the GLB come from the GRP and dedicated inputs. All of the GLB outputs are brought back into the GRP so that they can be connected to the inputs of any other GLB on the device.

## Specifications pLSI and ispLSI 1048

## Functional Block Diagram

Figure 1. pLSI and ispLSI 1048 Functional Block Diagram

*ISP Control Functions for ispLSI 1048 Only
0139F(1)-48-isp

The devices also have 96 I/O cells, each of which is directly connected to an I/O pin. Each I/O cell can be individually programmed to be a combinatorial input, registered input, latched input, output or bi-directional I/O pin with 3-state control. Additionally, all outputs are polarity selectable, active high or active low. The signal levels are TTL compatible voltages and the output drivers can source 4 mA or sink 8 mA .

Eight GLBs, 16 I/O cells, two dedicated inputs (one dedicated input in Megablock $B$ and $E$ ) and one ORP are connected together to make a Megablock (see figure 1). The outputs of the eight GLBs are connected to a set of 16 universal I/O cells by the ORP. The pLSI and ispLSI 1048 devices contain six of these Megablocks.

The GRP has as its inputs the outputs from all of the GLBs and all of the inputs from the bi-directional I/O cells. All of these signals are made available to the inputs of the GLBs. Delays through the GRP have been equalized to minimize timing skew.

Clocks in the pLSI and ispLSI 1048 devices are selected using the Clock Distribution Network. Four dedicated clockpins (Y0, Y1, Y2 and Y3) are brought into the distribution network, and five clock outputs (CLK 0, CLK 1, CLK 2, IOCLK 0 and IOCLK 1) are provided to route clocks to the GLBs and I/O cells. The Clock Distribution Network can also be driven from a special clock GLB (D0 on the pLSI and ispLSI 1048 devices). The logic of this GLB allows the user to create an internal clock from a combination of internal signals within the device.

## Specifications pLSI and ispLSI 1048

## Absolute Maximum Ratings ${ }^{1}$

Supply Voltage $\mathrm{V}_{\text {cc }} \ldots . .$.
Input Voltage Applied. . . . . . . . . . . . . . . 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Off-State Output Voltage Applied . . . . . - 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Storage Temperature
.65 to $150^{\circ} \mathrm{C}$
Case Temp. with Power Applied . . . . . . . . 55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. Functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

DC Recommended Operating Conditions

| SYMBOL | PARAMETER |  |  | MIN. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vcc | Supply Voltage | Commercial | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 4.75 | 5.25 | V |
|  |  | Industrial | $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 4.5 | 5.5 |  |
| VIL | Input Low Voltage |  |  | 0 | 0.8 | V |
| VIH | Input High Voltage |  |  | 2.0 | $\mathrm{Vcc}+1$ | V |

Capacitance $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| SYMBOL | PARAMETER | MAXIMUM ${ }^{1}$ | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :--- |
| $\mathbf{C}_{1}$ | Dedicated Input Capacitance | 8 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{2}$ | I/O and Clock Capacitance | 10 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{I}}, \mathrm{V}_{\mathrm{Y}}=2.0 \mathrm{~V}$ |

1. Guaranteed but not $100 \%$ tested.

## Data Retention Specifications

| PARAMETER | MINIMUM | MAXIMUM | UNITS |
| :--- | :---: | :---: | :---: |
| Data Retention | 20 | - | YEARS |
| ispLSI Erase/Reprogram Cycles | 1000 | - | CYCLES |
| pLSI Erase/Reprogram Cycles | 100 | - | CYCLES |

## Specifications pLSI and ispLSI 1048

## Switching Test Conditions

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Time | $\leq 3 \mathrm{~ns} \mathrm{10} \mathrm{\%} \mathrm{to} 90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See figure 2 |

3-state levels are measured 0.5 V from steady-state active level.

## Output Load Conditions (see figure 2)

| Test Condition |  | R1 | R2 | CL |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $470 \Omega$ | $390 \Omega$ | 35 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 35 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 35 pF |
| C | Active High to Z <br> at $\mathbf{V}_{\text {OH }}-0.5 \mathrm{~V}$ | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low to Z <br> at $\mathbf{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$ | $470 \Omega$ | $390 \Omega$ | 5 pF |

Figure 2. Test Load

${ }^{*} C_{L}$ includes Test Fixture and Probe Capacitance.

## DC Electrical Characteristics

## Over Recommended Operating Conditions

| SYMBOL | PARAMETER | CONDITION |  | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Output Low Voltage | $\mathrm{l}_{\mathrm{oL}}=8 \mathrm{~mA}$ |  | - | - | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 2.4 | - | - | V |
| IIL | Input or l/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IS }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {cc }}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| IIL-isp | isp Input Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -150 | $\mu \mathrm{A}$ |
| IIL-PU | I/O Active Pull-Up Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{IL}}$ |  | - | - | -150 | $\mu \mathrm{A}$ |
| Ios1 | Output Short Circuit Current | $\mathrm{V}_{\text {cc }}=5 \mathrm{~V}, \mathrm{~V}_{\text {out }}=0.5 \mathrm{~V}$ |  | -60 | - | -200 | mA |
| ICC ${ }^{2}$ | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{LL}}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {TOGGLE }}=1 \mathrm{MHz} \end{aligned}$ | Commercial | - | 165 | 235 | mA |
|  |  |  | Industrial | - | 165 | 260 | mA |

1. One output at a time for a maximum duration of one second. $\mathrm{V}_{\text {out }}=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
2. Measured using twelve 16 -bit counters.
3. Typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

External Timing Parameters
Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST }{ }^{5} \\ & \text { COND. } \end{aligned}$ | $\#^{2}$ | DESCRIPTION ${ }^{1}$ | -80 |  | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd1 | A | 1 | Data Propagation Delay, 4PT bypass, ORP bypass | - | 15 | - | 18 | - | 24 | ns |
| tpd2 | A | 2 | Data Propagation Delay, Worst Case Path | - | 20 | - | 23 | - | 30.7 | ns |
| fmax | A | 3 | Clock Frequency with Internal Feedback ${ }^{3}$ | 80 | - | 71.4 | - | 53.6 | - | MHz |
| $f$ max (Ext.) | - | 4 | Clock Frequency with External Feedback $\left(\frac{1}{\text { tsu2 }+ \text { tcol }}\right.$ ) | 50 | - | 41.7 | - | 31.3 | - | MHz |
| fmax (Tog.) | - | 5 | Clock Frequency, Max Toggle ${ }^{4}$ | 100 | - | 83 | - | 71.4 | - | MHz |
| tsu1 | - | 6 | GLB Reg. Setup Time before Clock, 4PT bypass | 7 | - | 9 | - | 12 | - | ns |
| tco1 | A | 7 | GLB Reg. Clock to Output Delay, ORP bypass | - | 10 | - | 12 | - | 16 | ns |
| th1 | - | 8 | GLB Reg. Hold Time after Clock, 4 PT bypass | 0 | - | 0 | - | 0 | - | ns |
| tsu2 | - | 9 | GLB Reg. Setup Time before Clock | 10 | - | 12 | - | 16 | - | ns |
| tco2 | - | 10 | GLB Reg. Clock to Output Delay | - | 12 | - | 14 | - | 18.7 | ns |
| th2 | - | 11 | GLB Reg. Hold Time after Clock | 0 | - | 0 | - | 0 | - | ns |
| tr1 | A | 12 | Ext. Reset Pin to Output Delay | - | 17 | - | 17 | - | 22.7 | ns |
| trw1 | - | 13 | Ext. Reset Pulse Duration | 10 | - | 10 | - | 13 | - | ns |
| ten | B | 14 | Input to Output Enable | - | 18 | - | 20 | - | 26.7 | ns |
| tdis | C | 15 | Input to Output Disable | - | 18 | - | 20 | - | 26.7 | ns |
| twh | - | 16 | Ext. Sync. Clock Pulse Duration, High | 5 | - | 6 | - | 7 | - | ns |
| twl | - | 17 | Ext. Sync. Clock Pulse Duration, Low | 5 | - | 6 | - | 7 | - | ns |
| tsu5 | - | 18 | I/O Reg. Setup Time before Ext. Sync. Clock (Y2, Y3) | 2 | - | 2 | - | 2.7 | - | ns |
| th5 | - | 19 | I/O Reg. Hold Time after Ext. Sync. Clock (Y2, Y3) | 6.5 | - | 6.5 | - | 8.7 | - | ns |

1. Unless noted otherwise, all parameters use a GRP load of 4 GLBs, 20 PTXOR path, ORP and YO clock.
2. Refer to Timing Model in this data sheet for further details.
3. Standard 16 -Bit loadable counter using GRP feedback.
4. fmax (Toggle) may be less than $1 /(t w h+t w l)$. This is to allow for a clock duty cycle of other than $50 \%$.
5. Reference Switching Test Conditions Section.

Internal Timing Parameters ${ }^{1}$

| PARAMETER | \# ${ }^{2}$ | DESCRIPTION | -80 |  | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| Inputs |  |  |  |  |  |  |  |  |  |
| tiobp | 20 | I/O Register Bypass | - | 2.5 | - | 3.0 | - | 4.0 | ns |
| tiolat | 21 | I/O Latch Delay | - | 3.3 | - | 4.0 | - | 5.3 | ns |
| tiosu | 22 | I/O Register Setup Time before Clock | 5.3 | - | 6.0 | - | 8.1 | - | ns |
| tioh | 23 | I/O Register Hold Time after Clock | 1.5 | - | 0.5 | - | 0.9 | - | ns |
| tioco | 24 | I/O Register Clock to Out Delay | - | 2.5 | - | 3.0 | - | 3.9 | ns |
| tior | 25 | I/O Register Reset to Out Delay | - | 2.9 | - | 3.5 | - | 4.6 | ns |
| tdin | 26 | Dedicated Input Delay | - | 5.0 | - | 6.0 | - | 8.0 | ns |
| GRP |  |  |  |  |  |  |  |  |  |
| tgrp1 | 27 | GRP Delay, 1 GLB Load | - | 2.1 | - | 2.5 | - | 3.3 | ns |
| tgrp4 | 28 | GRP Delay, 4 GLB Loads | - | 2.5 | - | 3.0 | - | 4.0 | ns |
| tgrp8 | 29 | GRP Delay, 8 GLB Loads | - | 3.3 | - | 4.0 | - | 5.3 | ns |
| tgrp12 | 30 | GRP Delay, 12 GLB Loads | - | 4.2 | - | 5.0 | - | 6.7 | ns |
| tgrp16 | 31 | GRP Delay, 16 GLB Loads | - | 5.0 | - | 6.0 | - | 8.0 | ns |
| tgrp48 | 32 | GRP Delay, 48 GLB Loads | - | 13.3 | - | 16.0 | - | 21.3 | ns |
| GLB |  |  |  |  |  |  |  |  |  |
| t4ptbp | 33 | 4 Product Term Bypass Path Delay | - | 5.4 | - | 6.5 | - | 8.6 | ns |
| t1ptxor | 34 | 1 Product Term/XOR Path Delay | - | 6.5 | - | 7.0 | - | 9.3 | ns |
| t20ptxor | 35 | 20 Product Term/XOR Path Delay | - | 7.6 | - | 7.5 | - | 10.0 | ns |
| txoradj | 36 | XOR Adjacent Path Delay ${ }^{3}$ | - | 8.4 | - | 9.5 | - | 12.7 | ns |
| tgbp | 37 | GLB Register Bypass Delay | - | 0.8 | - | 1.0 | - | 1.3 | ns |
| tgsu | 38 | GLB Register Setup Time before Clock | 0.8 | - | 1.5 | - | 2.0 | - | ns |
| tgh | 39 | GLB Register Hold Time after Clock | 5.0 | - | 6.0 | - | 8.0 | - | ns |
| tgco | 40 | GLB Register Clock to Output Delay | - | 2.1 | - | 2.5 | - | 3.3 | ns |
| tgr | 41 | GLB Register Reset to Output Delay | - | 2.1 | - | 2.5 | - | 3.3 | ns |
| tptre | 42 | GLB Product Term Reset to Register Delay | - | 8.3 | - | 10.0 | - | 13.3 | ns |
| tptoe | 43 | GLB Product Term Output Enable to I/O Cell Delay | - | 8.8 | - | 9.0 | - | 11.9 | ns |
| tptck | 44 | GLB Product Term Clock Delay | 2.9 | 6.3 | 3.5 | 7.5 | 4.6 | 9.9 | ns |
| ORP |  |  |  |  |  |  |  |  |  |
| torp | 45 | ORP Delay | - | 3.2 | - | 3.5 | - | 4.7 | ns |
| torpbp | 46 | ORP Bypass Delay | - | 1.3 | - | 1.5 | - | 2.0 | ns |

1. Internal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.
3. The XOR Adjacent path can only be used by Lattice Hard Macros.

Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -80 |  | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| Outputs |  |  |  |  |  |  |  |  |  |
| tob | 47 | Output Buffer Delay | - | 2.5 | - | 3.0 | - | 4.0 | ns |
| toen | 48 | I/O Cell OE to Output Enabled | - | 4.2 | - | 5.0 | - | 6.7 | ns |
| todis | 49 | I/O Cell OE to Output Disabled | - | 4.2 | - | 5.0 | - | 6.7 | ns |
| Clocks |  |  |  |  |  |  |  |  |  |
| tgy0 | 50 | Clock Delay, Y0 to Global GLB Clock Line (Ref. clock) | 4.2 | 4.2 | 5.0 | 5.0 | 6.7 | 6.7 | ns |
| tgy $1 / 2$ | 51 | Clock Delay, Y1 or Y2 to Global GLB Clock Line | 3.3 | 5.0 | 4.0 | 6.0 | 5.3 | 8.0 | ns |
| tgcp | 52 | Clock Delay, Clock GLB to Global GLB Clock Line | 0.8 | 4.2 | 1.0 | 5.0 | 1.3 | 6.6 | ns |
| tioy2/3 | 53 | Clock Delay, Y2 or Y3 to I/O Cell Global Clock Line | 3.3 | 5.0 | 4.0 | 6.0 | 5.3 | 8.0 | ns |
| tiocp | 54 | Clock Delay, Clock GLB to I/O Cell Global Clock Line | 0.8 | 4.2 | 1.0 | 5.0 | 1.3 | 6.6 | ns |
| Global Reset |  |  |  |  |  |  |  |  |  |
| tgr | 55 | Global Reset to GLB and I/O Registers | - | 9.2 | - | 8.0 | - | 10.6 | ns |

[^9]
## Specifications pLSI and ispLSI 1048

## pLSI and ispLSI 1048 Timing Model



Derivations of tsu, th and tco from the Product Term Clock ${ }^{1}$
tsu = Logic + Reg su - Clock (min)
$=($ tiobp $+\mathbf{t g r p} 4+\mathbf{t}$ 20ptxor $)+(\mathbf{t g s u})-($ tiobp $+\mathbf{t g r p} 4+\mathbf{t p t c k}($ min $))$
$=(\# 20+\# 28+\# 35)+(\# 38)-(\# 20+\# 28+\# 44)$
$5.5 \mathrm{~ns}=(3.0+3.0+7.5)+(1.5)-(3.0+3.0+3.5)$
th $=\operatorname{Clock}(\max )+$ Reg h - Logic
$=($ tiobp $+\mathbf{t g r p} 4+\mathbf{t p t c k}(\max ))+(\mathbf{t g h})-($ tiobp $+\mathbf{t g r p} 4+\mathbf{t} 20$ ptxor $)$
$=(\# 20+\# 28+\# 44)+(\# 39)-(\# 20+\# 28+\# 35)$
$6.0 \mathrm{~ns}=(3.0+3.0+7.5)+(6.0)-(3.0+3.0+7.5)$
tco $=$ Clock (max) + Reg co + Output
$=($ tiobp $+\mathbf{t g r p} 4+\mathbf{t p t c k}($ max $))+(\mathbf{t g c o})+(\mathbf{t o r p}+\mathbf{t o b})$
$=(\# 20+\# 28+\# 44)+(\# 40)+(\# 45+\# 47)$
$22.5 \mathrm{~ns}=(3.0+3.0+7.5)+(2.5)+(3.5+3.0)$

## Derivations of tsu, th and tco from the Clock GLB ${ }^{1}$

```
tsu = Logic + Reg su - Clock (min)
    = (tiobp + tgrp4 + t2Optxor) +(tgsu)-(tgy0(min) + tgco + tgcp(min))
    = (#20 + #28 + #35) + (#38) - (#50 + #40 +#52)
6.5 ns=(3.0+3.0+7.5)+(1.5)-(5.0+2.5+1.0)
th = Clock (max) + Reg h - Logic
    = (tgy0(max) + tgco + tgcp(max)) +(tgh) - (tiobp + tgrp4 + t20ptxor)
    =(#50 +#40 + #52) + (#39)-(#20 + #28 +#35)
5.0 ns=(5.0 + 2.5 + 5.0) + (6.0)-(3.0+3.0 + 7.5)
tco = Clock (max) + Reg co + Output
    = (tgy0(max) + tgco + tgcp(max)) +(tgco) +(torp + tob)
    = (#50+#40 + #52) +(#40)+(#45 + #47)
21.5 ns=(5.0+2.5+5.0)+(2.5)+(3.5+3.0)
```

1. Calculations are based upon timing specs for the pLSI and ispLSI 1048-70.

Specifications pLSI and ispLSI 1048

Figure 3. Typical Device Power Consumption vs fmax


ICC can be estimated for the pLSI and ispLSI 1048 using the following equation:
ICC $=73+(\#$ of PTs * 0.23$)+(\#$ of nets * Max. freq * 0.010$)$ where:
\# of PTs = Number of Product Terms used in design
\# of nets = Number of Signals used in device
Max. freq = Highest Clock Frequency to the device
The ICC estimate is based on typical conditions ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, room temperature) and an assumption of 2 GLB loads on average exists. These values are for estimates only. Since the value of ICC is sensitive to operating conditions and the program in the device, the actual ICC should be verified.

Figure 4. Maximum GRP Delay vs GLB Loads


## Specifications pLSI and ispLSI 1048

## In-System Programmability

The ispLSI devices are the in-system programmable versions of the Lattice High-Density programmable Large Scale Integration (pLSI) devices. By integrating all the high voltage programming circuitry on-chip, programming can be accomplished by simply shifting data into the device. Once the function is programmed, the nonvolatile $\mathrm{E}^{2} \mathrm{CMOS}$ cells will not lose the pattern even when the power is turned off.

All necessary programming is done via five TTL level logic interface signals. These five signals are fed into the on-chip programming circuitry where a state machine controls the programming. The interface signals are isp Enable (ispEN), Serial Data In (SDI), Serial Data Out (SDO), Serial Clock (SCLK) and Mode (MODE) control. Figure 5 illustrates the block diagram of one possible scheme for programming the ispLSI devices. For details on the operation of the internal state machine and programming of the device please refer to the in-system programming section in this Data Book.

Figure 5. ISP Programming Interface


0294B

## Specifications pLSI and ispLSI 1048

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VCCP | Programming Voltage |  | 4.75 | 5 | 5.25 | V |
| ICCP | Programming Supply Current |  | - | 50 | 100 | mA |
| VIHP | Input Voltage High | $\overline{\text { ispEN }}=$ Low | 2.0 | - | VCCP | V |
| VILP | Input Voltage Low |  | 0 | - | 0.8 | V |
| IIP | Input Current |  | - | 100 | 200 | $\mu \mathrm{A}$ |
| VOHP | Output Voltage High | $\mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ | 2.4 | - | VCCP | V |
| VOLP | Output Voltage Low | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ | 0 | - | 0.5 | V |
| tr, tf | Input Rise and Fall |  | - | - | 0.1 | $\mu \mathrm{s}$ |
| tispen | ispEN to Output 3-State Enabled |  | - | 2 | 10 | $\mu \mathrm{s}$ |
| tispdis | ispEN to Output 3-State Disabled |  | - | 2 | 10 | $\mu \mathrm{s}$ |
| tsu | Setup Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tco | Clock to Output |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| th | Hold Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tclkh, tclkl | Clock Pulse Width, High and Low |  | 0.5 | 1 | - | $\mu \mathrm{s}$ |
| tpw | Verify Pulse Width |  | 20 | 30 | - | $\mu \mathrm{s}$ |
| tpwp | Programming Pulse Width |  | 40 | - | 100 | ms |
| tbew | Bulk Erase Pulse Width |  | 200 | - | - | ms |
| trst | Reset Time From Valid $\mathrm{V}_{\text {CCP }}$ |  | 45 | - | - | $\mu \mathrm{s}$ |

1. ISP Programming is guaranteed for $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Operation only.

Table 2. 0029 isp-C

Figure 6. Timing Waveforms for In-System Programming (ispLSI 1048)


Don't Care
88 Undefined State

Figure 7. Program, Verify \& Bulk Erase Waveforms (ispLSI 1048)


## Specifications pLSI and ispLSI 1048

Figure 8 illustrates the address and data shift register bits the Device Layout discussion in the pLSI and ispLSI for the ispLSI 1048. For a detailed explanation refer to Architectural Description section of this Data Book.

Figure 8. ispLSI 1048 Shift Register Layout



Note: A logic "1" in the Address Shift Register bit position enables the row for programming or verification. A logic " 0 " disables it.

## Specifications pLSI and ispLSI 1048

Pin Description

| Name | PQFP Pin Numbers | Description |
| :---: | :---: | :---: |
| I/O O-I/O 5 <br> I/O 6 - I/O 11 <br> I/O 12 - I/O 17 <br> I/O 18 - I/O 23 <br> I/O 24 - I/O 29 <br> I/O 30 - I/O 35 <br> I/O 36 - I/O 41 <br> I/O 42 - I/O 47 <br> I/O 48 - I/O 53 <br> I/O 54 - I/O 59 <br> I/O 60 - I/O 65 <br> I/O 66 - I/O 71 <br> I/O 72 - I/O 77 <br> I/O 78 - I/O 83 <br> I/O 84 - I/O 89 <br> I/O 90 - I/O 95 | 20, 21, 22, 23, 24, 25, <br> 26, 27, 28, 29, 30, 31, <br> 32, 33, 34, 35, 36, 37, <br> 38, 39, 40, 41, 42, 43, <br> 49, 50, 51, 52, 53, 54, <br> 55, 56, 57, 58, 59, 60, <br> 61, 62, 63, 64, 65, 66, <br> 67, 68, 69, 70, 71, 72, <br> 80, 81, 82, 83, 84, 85, <br> 86, 87, 88, 89, 90, 91, <br> 92, 93, 94, 95, 96, 97, <br> 98, 99, 100, 101, 102, 103, <br> 109,110,111,112,113,114, <br> 115,116, 117, 118, 119, 120, <br> $\begin{array}{lllrrr}1, & 2, & 3, & 4 & 5, & 6, \\ 7, & 8, & 9, & 10, & 11, & 12\end{array}$ | Input/Output Pins-These are the general purpose I/O pins used by the logic array. |
| IN 4 <br> IN 6 - IN 11 | $\begin{aligned} & 48, \\ & 79,104,105,-108,13 \end{aligned}$ | Dedicated input pins to the device. (IN 2 and IN 9 not available) |
| $\overline{\text { ispEN }}$ */NC <br> SDI*/IN 0 | 17 19 | Input - Dedicated in-system programming enable input pin. This pin is brought low to enable the programming mode. The MODE, SDI, SDO and SCLK options become active. <br> Input-This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as an input pin to load programming data into the device. SDI/IN 0 also is used as one of the two control pins for the isp state machine. |
| MODE*/IN 1 | 44 | Input-This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When ispEN is logic low, it functions as a pin to control the operation of the isp state machine. |
| $\text { SDO*/IN } 3$ | 47 | Input/Output - This pin performs two functions. It is a dedicated input pin when ispEN is logic high. When IspEN is logic low, it functions as an output pin to read serial shift register data. |
| SCLK*/IN 5 | 73 | Input - This pin performs two functions. It is a dedicated input when $\overline{\text { ispEN }}$ is logic high. When ispEN is logic low, it functions as a clock pin for the Serial Shift Register. |
| RESET | 18 | Active Low (0) Reset pin which resets all of the GLB and I/O registers in the device. |
| Yo | 14 | Dedicated Clock input. This clock input is connected to one of the clock inputs of all of the GLBs on the device. |
| Y1 | 78 | Dedicated clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB on the device. |
| Y2 | 75 | Dedicated clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any GLB and/or any I/O cell on the device. |
| Y3 | 74 | Dedicated clock input. This clock input is brought into the clock distribution network, and can optionally be routed to any I/O cell on the device. |
| $\begin{aligned} & \text { GND } \\ & \text { VCC } \end{aligned}$ | $\begin{aligned} & 46,76,106,16 \\ & 15,45,77,107 \end{aligned}$ | Ground (GND) $V_{c c}$ |

[^10]
## Pin Configuration

## pLSI and ispLSI 1048 120-Pin PQFP Pinout Diagram



* Pins have dual function capability for ispLSI 1048 only (except pin 17, which is ispEN only).


## Part Number Description



## pLSI and ispLSI 1048 Ordering Information

COMMERCIAL

| Family | $f_{\max (M H z)}$ | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 80 | 15 | pLSI 1048-80LQ | 120-Pin PQFP |
|  | 70 | 18 | pLSI 1048-70LQ | 120-Pin PQFP |
|  | 50 | 24 | pLSI 1048-50LQ | 120-Pin PQFP |
| ispLSI | 70 | 15 | pLSI 1048-80LQ | 120-Pin PQFP |
|  | 70 | 18 | ispLSI 1048-70LQ | 120-Pin PQFP |
|  | 50 | 24 | ispLSI 1048-50LQ | 120-Pin PQFP |

INDUSTRIAL

| Family | fmax (MHz) | tpd (ns) | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 50 | 24 | pLSI 1048-50LQI | $120-$ Pin PQFP |
| ispLSI | 50 | 24 | ispLSI 1048-50LQI | $120-$-Pin PQFP |

pLSI ${ }^{\circ}$ and ispLSI"' 1048C

## Features

- HIGH-DENSITY PROGRAMMABLE LOGIC
- High-Speed Global Interconnects
- 96 I/O Pins, 12 Dedicated Inputs, 2 Global Output Enables
- 288 Registers
- Wide Input Gating for Fast Counters, State Machines, Address Decoders, etc.
- Small Logic Block Size for Random Logic
- Security Cell Prevents Unauthorized Copying
- HIGH PERFORMANCE E ${ }^{2}$ CMOS $^{\oplus}$ TECHNOLOGY
- $\mathbf{f m a x}=\mathbf{7 0} \mathbf{M H z}$ Maximum Operating Frequency
- $\mathbf{f m a x}=\mathbf{5 0} \mathbf{~ M H z}$ for Industrial Devices
- tpd = 18 ns Propagation Delay
- TTL Compatible Inputs and Outputs
- Electrically Eraseable and Reprogrammable
- Non-Volatile E ${ }^{2}$ CMOS Technology
- 100\% Tested at Time of Manufacture
- ispLSI OFFERS THE FOLLOWING ADDED FEATURES
- In-System Programmable 5-Volt Only
— Change Logic and Interconnects "On-the-Fly" in Seconds
- Reprogram Soldered Device for Debugging
- COMBINES EASE OF USE AND THE FAST SYSTEM SPEED OF PLDs WITH THE DENSITY AND FAEX IBILITY OF FIELD PROGRAMMABLE GATE ARRA YS
- Complete Programmable Device GanCombine Glue

Logic and Structured Designs

- Four Dedicated Clock Input Pins
- Synchronous and Asynchronous Clocks
- Flexible Pin Placement
- Optimized Global Routing Popl Provides Global Interconnectivity
- pLSI/ispLSIDEVELOPMENT SYSTEM (pDS® ${ }^{\oplus}$ ) pDS Software
- Easy to Use PC Windows ${ }^{\text {TM }}$ Interface
- Boolean Logic Compiler
- Manual Pertitioning
- Automatic Place and Route
- Static Timing Table
pDS+ ${ }^{\text {TM }}$ Software
- Industry Standard, Third Party Design Environments
- Schematic Capture, State Machine, HDL
- Automatic Partitioning and Place and Route
- Comprehensive Logic and Timing Simulation
- PC and Workstation Platforms


## Functional Block Diagram



## Description

The Lattice pLSt and ispLSI 1048C are High-Density frogrammable, Logic Devices containing 288 Registers, 96 Universa/1/O pins, 12 Dedicated Input pins, two global output enables (GOE), four Dedicated Clock Input pins and A Global Routing Pool (GRP). The GRP provides comblete interconnectivity between all of these elements. The ispLSI 1048C features 5-Volt in-system programming and in-system diagnostic capabilities. It is the first device which offers non-volatile "on-the-fly" reprogrammability of the logic, as well as the interconnect to provide truly reconfigurable systems. It is architecturally and parametrically compatible to the pLSI 1048C device, but multiplexes four of the dedicated input pins to control in-system programming. Compared to the pLSI and ispLSI 1048, the pLSI and ispLSI 1048C offers two additional dedicated inputs and two new global output enable pins.

The basic unit of logic on the pLSI and ispLSI 1048C devices is the Generic Logic Block (GLB). The GLBs are labeled A0, A1 .. F7 (see figure 1). There are a total of 48 GLBs in the pLSI and ispLSI 1048C devices. Each GLB has 18 inputs, a programmable AND/OR/XOR array, and four outputs which can be configured to be either combinatorial or registered. Inputs to the GLB come from the GRP and dedicated inputs. All of the GLB outputs are brought back into the GRP so that they can be connected to the inputs of any other GLB on the device.

## Specifications pLSI and ispLSI 1048C

## Functional Block Diagram

Figure 1. pLSI and ispLSI 1048C Functional Block Diagram


The devices also have $961 / Q$ cemers, each of which is directly connected to ant/O pin. Eeoh I/O cell can be individually programmed to besa combinatorial input, registered input atahed inpts, output or bi-directional I/O pin with 2-state control. Additionally, all outputs are polarity selectable, active high or active low. The signal levels are TTL compatible voltages and the output drivers can source 4 mA or sink 8 mA .

Eight GLBs, 16 I/O cells, two dedicated inputs and one ORP are connected together to make a Megablock (see figure 1). The outputs of the eight GLBs are connected to a set of 16 universal I/O cells by the ORP. The pLSI and ispLSI 1048C devices contains six of these Megablocks.

The GRP has as its inputs the outputs from all of the GLBs and all of the inputs from the bi-directional I/O cells. All of these signals are made available to the inputs of the GLBs. Delays through the GRP have been equalized to minimize timing skew.

Clocks in the pLSI and ispLSI 1048C devices are selected using the Clock Distribution Network. Four dedicated clock pins (Y0, Y1, Y2 and Y3) are brought into the distribution network, and five clock outputs (CLK 0, CLK 1, CLK 2, IOCLK 0 and IOCLK 1) are provided to route clocks to the GLBs and I/O cells. The Clock Distribution Network can also be driven from a special clock GLB (D0 on the pLSI and ispLSI 1048C devices). The logic of this GLB allows the user to create an internal clock from a combination of internal signals within the device. Specifications pLSI and ispLSI 1048C

## Absolute Maximum Ratings 1

Supply Voltage $\mathrm{V}_{\mathrm{cc}} \ldots \ldots \ldots \ldots \ldots \ldots \ldots . .$.
Input Voltage Applied. . . . . . . . . . . . . . . 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Off-State Output Voltage Applied . . . . . .-2.5 to V $\mathrm{CC}+1.0 \mathrm{~V}$
Storage Temperature . . . . . . . . . . . . . . . . . 65 to $150^{\circ} \mathrm{C}$
Case Temp. with Power Applied . . . . . . . . 55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. Functional operation of the device at these or at any other conditions above those indicated in the operational segttons pf this specification is not implied (while programming, follow the programming specifications).

## DC Recommended Operating Conditions

## Capacitance $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| SYMBOL | AMETER | MAXIMUM ${ }^{1}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ |  | 8 | pf | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{2}$ | I/O ant Coock Capaciource | 10 | pf | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{10}, \mathrm{~V}_{\mathrm{V}}=2.0 \mathrm{~V}$ |

1. Guaranteed but nge 10 outested

Data Retention Specifications

| PARAMETER | MINIMUM | MAXIMUM | UNITS |
| :--- | :---: | :---: | :---: |
| Data Retention | 20 | - | YEARS |
| ispLSI Erase/Reprogram Cycles | 1000 | - | CYCLES |
| pLSI Erase/Reprogram Cycles | 100 | - | CYCLES |

## Specifications pLSI and ispLSI 1048C

## Switching Test Conditions

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Time | $\leq 3 \mathrm{~ns} \mathrm{10} \mathrm{\%} \mathrm{to} 90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See figure 2 |

3-state levels are measured 0.5 V from steady-state active level.

Output Load Conditions (see figure 2)

| Test Condlition |  | R1 | R2 | CL |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $470 \Omega$ | $390 \Omega$ | 35 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 35 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 35 pF |
| C | Active High to Z <br> at $\mathbf{V}_{\text {OH }}-0.5 \mathrm{~V}$ | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low to Z <br> at $\mathbf{V}_{\text {OL }}+0.5 \mathrm{~V}$ | $470 \Omega$ | $390 \Omega$ | 5 pF |

## DC Electrical Characteristics

| SYMBOL | ARAM | CONDITION |  | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Output Low | $\mathrm{I}_{\alpha}=8 \mathrm{~mA}$ |  | - | - | 0.4 | V |
| VoH |  | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 2.4 | - | - | V |
| IIL | Ipput on/ Low vykage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{IL}}$ (MAX.) |  | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | input \& / O Hiğk Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {cc }}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| IIL-isp | isp Input tow Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{IL}}$ (MAX.) |  | - | - | -150 | $\mu \mathrm{A}$ |
| IIL-PU | I/O Active Pull-Up Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{IL}}$ |  | - | - | -150 | $\mu \mathrm{A}$ |
| IOS ${ }^{1}$ | Output Short Circuit Current | $\mathrm{V}_{\mathrm{Cc}}=5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.5 \mathrm{~V}$ |  | -60 | - | -200 | mA |
| ICC2 | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{TOGGLE}}=1 \mathrm{MHz} \end{aligned}$ | Commercial | - | 165 | 235 | mA |
|  |  |  | Industrial | - | 165 | 260 | mA |

1. One output at a time for a maximum duration of one second. $V_{\text {out }}=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
2. Measured using twelve 16 -bit counters.
3. Typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$. Table 2-0007A-48-isp

External Timing Parameters
Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST }{ }^{5} \\ & \text { SOND. } \end{aligned}$ | $\#^{2}$ | DESCRIPTION ${ }^{1}$ | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd1 | A | 1 | Data Propagation Delay, 4PT bypass, ORP bypass | - | 18.0 | - | 24.0 | ns |
| tpd2 | A | 2 | Data Propagation Delay | - | 20.5 | - | 27.0 | ns |
| fmax | A | 3 | Clock Frequency with Internal Feedback ${ }^{3}$ | 71.4 | - | 54.1 | - | MHz |
| fmax (Ext.) | - | 4 | Clock Frequency with External Feedback ( $\frac{1}{\text { tsu2 }+ \text { tcoi }}$ ) | 46.5 | - | 35.1 | - | MHz |
| fmax (Tog.) | - | 5 | Clock Frequency, Max Toggle ${ }^{4}$ | 83.3 |  | 62.5 | - | MHz |
| tsu1 | - | 6 | GLB Reg. Setup Time before Clock, 4PT bypass | 90 |  | 12.0 | - | ns |
| tco1 | A | 7 | GLB Reg. Clock to Output Delay, ORP bypass |  | 11.0 |  | 14.5 | ns |
| th1 | - | 8 | GLB Reg. Hold Time after Clock, 4 PT bypass | 0 |  | 0 | - | ns |
| tsu2 | - | 9 | GLB Reg. Setup Time before Clock | 10.5 |  | 14.0 | - | ns |
| tco2 | - | 10 | GLB Reg. Clock to Output Delay |  | 12.0 | - | 15.5 | ns |
| th2 | - | 11 | GLB Reg. Hold Time after Clock | 0 | - | 0 | - | ns |
| tr1 | A | 12 | Ext. Reset Pin to Output Delay | - | 15.0 | - | 20.0 | ns |
| trw1 | - | 13 | Ext. Reset Pulse Duration | 10.0 | - | 13.0 | - | ns |
| tptoeen | B | 14 | Input to Output Enable | - | 20.0 | - | 26.5 | ns |
| tptoedis | C | 15 | Input to Output Disable | - | 20.0 | - | 26.5 | ns |
| tgoeen | B | 16 | Global OE Output Enable | - | 15.0 | - | 20.0 | ns |
| tgoedis | C | 17 | Global OE Output Disable | - | 15.0 | - | 20.0 | ns |
| twh | - | 20 | Ext. Sync. Clock Pulse Duratiog + High | 6.0 | - | 8.0 | - | ns |
| twl | - | 21 | Ext. Sync, Clack Pulse Purdion, Low | 6.0 | - | 8.0 | - | ns |
| tsu3 | - | 22 | I/O Reg. Sotup kime before Ext. Sync. Clock (Y2, Y3) | 2.0 | - | 2.5 | - | ns |
| th3 | - | 23 | I/GReg Hotd Time after Ext. Sync. Clock (Y2, Y3) | 6.5 | - | 8.5 | - | ns |

1. Unless noted otherwise, all payameters use a GRP load of 4 GLBs, 20 PTXOR path, ORP and YO clock.
2. Refer to Timing Model in this data shef for further details.
3. Standard $16-\mathrm{Bit}$ łoadale oounter using GRP feedback.
4. fmax (Toggle)may be less than 1/(twh + twl). This is to allow for a clock duty cycle of other than $50 \%$.
5. Reference Switching Test Conditions Section.

## Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| Inputs |  |  |  |  |  |  |  |
| tiobp | 24 | 1/O Register Bypass | - | 3.1 | - | 4.1 | ns |
| tiolat | 25 | I/O Latch Delay | - | 4.0 | - | 5.3 | ns |
| tiosu | 26 | I/O Register Setup Time before Clock | 6.5 | - | 8.5 | - | ns |
| tioh | 27 | I/O Register Hold Time after Clock | 0.1 | - | 0.1 | - | ns |
| tioco | 28 | I/O Register Clock to Out Delay | - | 31 | If | 4.1 | ns |
| tior | 29 | I/O Register Reset to Out Delay |  |  |  | 4.5 | ns |
| tdin | 30 | Dedicated Input Delay |  | 5.4 | $\bigcirc$ | 7.2 | ns |
| GRP |  |  |  |  |  |  |  |
| tgrp1 | 31 | GRP Delay, 1 GLB Load | - | 4.5 | - | 6.0 | ns |
| tgrp4 | 32 | GRP Delay, 4 GLB Loads | $\rightarrow$ | 4.9 | - | 6.5 | ns |
| tgrp8 | 33 | GRP Delay, 8 GLB Loads | - | 5.8 | - | 7.7 | ns |
| tgrp12 | 34 | GRP Delay, 12 GLB Loads | - | 6.7 | - | 8.9 | ns |
| tgrp16 | 35 | GRP Delay, 16 GLB Loads | - | 7.6 | - | 10.1 | ns |
| tgrp48 | 36 | GRP Delay, 48 GLB Loads | - | 16.5 | - | 22.0 | ns |
| GLB |  |  |  |  |  |  |  |
| t4ptbp | 37 | 4 Product Term Bypass Patb Qelay | - | 5.0 | - | 6.7 | ns |
| t1ptxor | 38 | 1 Product Term/XOR Path'Delay | - | 5.8 | - | 7.8 | ns |
| t20ptxor | 39 | 20 Product Term/XOF Path Delay | - | 6.5 | - | 8.7 | ns |
| txoradj | 40 | XOR Adjacent Path Relay ${ }^{3}$ | - | 8.0 | - | 10.7 | ns |
| tgbp | 41 | GLB Register Bypass Delay | - | 0.9 | - | 1.2 | ns |
| tgsu | 42 | GLB Register Setwo Jine before Clock | 1.4 | - | 1.9 | - | ns |
| tgh | 43 | GLB'Register Holy fime after Clock | 5.3 | - | 7.1 | - | ns |
| tgco |  | GLB Fegister Clock to Output Delay | - | 1.5 | - | 1.8 | ns |
| tgr |  | GLBRegister Reset to Output Delay | - | 2.1 | - | 2.8 | ns |
| tptre |  | GLB Product Term Reset to Register Delay | - | 8.6 | - | 11.5 | ns |
| tptoe |  | Gi B Product Term Output Enable to I/O Cell Delay | - | 7.0 | - | 9.2 | ns |
| tptck |  | GLB Product Term Clock Delay | 3.0 | 6.5 | 4.0 | 8.7 | ns |
| ORP |  |  |  |  |  |  |  |
| torp | 49 | ORP Delay | - | 2.5 | - | 3.0 | ns |
| torpbp | 50 | ORP Bypass Delay | - | 1.5 | - | 1.7 | ns |

1. Internal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.
3. The XOR Adjacent path can only be used by Lattice Hard Macros.

## Specifications pLSI and ispLSI 1048C

Internal Timing Parameters ${ }^{1}$

| PARAMETER | $\#^{2}$ | DESCRIPTION | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| Outputs |  |  |  |  |  |  |  |
| tob | 51 | Output Buffer Delay | - | 2.6 | - | 3.5 | ns |
| toen | 52 | I/O Cell OE to Output Enabled | - | 5.0 | - | 6.7 | ns |
| todis | 53 | I/O Cell OE to Output Disabled | - | 5.0 | - | 6.7 | ns |
| Clocks |  |  |  |  |  |  |  |
| tgy0 | 54 | Clock Delay, Y0 to Global GLB Clock Line (Ref. clock) |  | 5.4 | 7.2 | 7.2 | ns |
| tgy $1 / 2$ | 55 | Clock Delay, Y1 or Y2 to Global GLB Clock Line | 4.5 | 6.4 | 6.0 | 8.6 | ns |
| tgep | 56 | Clock Delay, Clock GLB to Global GLB Clock Line |  | 5.53 | 2.5 | 7.3 | ns |
| tioy2/3 | 57 | Clock Delay, Y2 or Y3 to I/O Cell Global Clock Line | 4.5 | 6.4 | 6.0 | 8.6 | ns |
| tiocp | 58 | Clock Delay, Clock GLB to I/O Cell Global Clock Line | 19 | 5.5 | 2.5 | 7.3 | ns |
| Global Reset |  |  |  |  |  |  |  |
| tgr | 59 | Global Reset to GLB and I/O Registers | - | 7.8 | - | 10.3 | ns |

1. Internal Timing Parameters are not tested and are for reference only
2. Refer to Timing Model in this data sheet for further details.
pLSI and ispLSI 1048C Timing Model

tsu $=$ Logic + Reg su - Clook (min)
$=($ tiobp + tgrp4 + tioptior) + (tgsy) $-($ tiobp + tgrp4 + tptck(min) $)$
$=(\# 24+\# 32+\# 39)+(\# 42)-(124+\# 32+\# 48)$
$5.5 \mathrm{~ns}=(3.0+3.0+7.5)+(1.5)-8.0+3.0+3.5)$
th $=$ Clock (max) + Reg h - Logic
$=$ (tionp $+t$ ghp $4+$ tplck $(\max ))+($ tgh $)-($ tiobp $+\mathbf{t g r p} 4+$ t20ptxor $)$
$=(\# 24+\# 32+\# 40)+(\# 43)-(\# 24+\# 32+\# 39)$
$6.0 \mathrm{n} s(3.0+3.0+2.5)+(6.0)-(3.0+3.0+7.5)$


Olock (pax) + Reg co + Output
$2($ tiopp 4 tgrp $4+$ tptck $(\max ))+($ tgco $)+($ torp + tob $)$
(\#24 + \#32 + \#48) $+(\# 44)+(\# 49+\# 51)$
22. 5 ns. $7.0+3.0+7.5)+(2.5)+(3.5+3.0)$

Berivations of tsu, th and tco from the Clock GLB ${ }^{1}$
1. Calculations are based upon timing specs for the pLSI/ispLSI 1048C-70.

Specifications pLSI and ispLSI 1048C

Figure 3. Typical Device Power Consumption vs fmax


Notes: Configuration of Twelve 16-bit Counters Typical Current at $5 \mathrm{~V}, 25^{\circ} \mathrm{C}$

ICC can be estimated for the pLSI and ispLSI 1048C using the following equatio
ICC $=73+(\#$ of PTs * 0.23$)+(\#$ of nets *Max. freq * 0.010$)$ where:
\# of PTs = Number of Product Terms used in design
\# of nets = Number of Signals used in device
Max. freq = Highest Clock Frequency to the device
The ICC estimate is based on typical conditions ( $V_{C C}=50$, room tempesture) and an assumption of 2 GLB loads on average exists. These values are for estimates only. Sinca the valus of CC is sensitive to operating conditions and the program in the device, the actual ICC should be verifed Il

Figure 4. Maximum GRP Delay vs GLB Loads


## In-System Programmability

The ispLSI devices are the in-system programmable versions of the Lattice High-Density programmable Large Scale Integration (pLSI) devices. By integrating all the high voltage programming circuitry on-chip, programming can be accomplished by simply shifting data into the can be accomplished by simply shifting data into the
device. Once the function is programmed, the nonvolatile $E^{2}$ CMOS cells will not lose the pattern even when the power is turned off.

## Specifications pLSI and ispLSI 1048C

All necessary programming is done via five TTL level logic interface signals. These five signals are fed into the on-chip programming circuitry where a state machine controls the programming. The interface signals are isp Enable (ispEN), Serial Data In (SDI), Serial Data Out (SDO), Serial Clock (SCLK) and Mode (MODE) control. Figure 5 illustrates the block diagram of one possible scheme for programming the ispLSI devices. For details on the operation of the internal state machine and programming of the device please refer to the in-system programming section in this Data Book.

Figure 5. ISP Programming Interface

## ISP Programming Voltage/Timing Specifications ${ }^{1}$

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VCCP | Programming Voltage |  | 4.75 | 5 | 5.25 | V |
| ICCP | Programming Supply Current |  | - | 50 | 100 | mA |
| VIHP | Input Voltage High | IspEN = Low | 2.0 | - | VCCP | V |
| VILP | Input Voltage Low |  | 0 | - | 0.8 | V |
| IIP | Input Current |  | - | 100 | 200 | $\mu \mathrm{A}$ |
| VOHP | Output Voltage High | $\mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ | 2.4 |  | $\vee \mathrm{VCCP}$ | V |
| VOLP | Output Voltage Low | $\mathrm{l}_{\mathrm{OL}}=5 \mathrm{~mA}$ | 0 | $\stackrel{*}{*}$ | 0.5 | V |
| tr, $\mathbf{t}$ | Input Rise and Fall |  |  | > | *, | $\mu \mathrm{s}$ |
| tispen | ispEN to Output 3-State Enabled |  | $\mathscr{F}$ | \%2 | \% 10 | $\mu \mathrm{s}$ |
| tispdis | ispEN to Output 3-State Disabled |  | , | 2 | 10 | $\mu \mathrm{s}$ |
| tsu | Setup Time |  | Q 1 | $\not{0.5}$ | - | $\mu s$ |
| tco | Clock to Output |  | Q. ${ }^{\text {\% }}$ | 0.5 | - | $\mu \mathrm{s}$ |
| th | Hold Time | ${ }_{\text {\% }}$ | $\stackrel{0.1}{ }$ | 0.5 | - | $\mu s$ |
| tclkh, tclkl | Clock Pulse Width, High and Low |  | 0.5 | 1 | - | $\mu \mathrm{s}$ |
| tpw | Verify Pulse Width | $\geqslant \gg$ | 20 | 30 | - | $\mu \mathrm{s}$ |
| tpwp | Programming Pulse Width | , | 40 | - | 100 | ms |
| tbew | Bulk Erase Pulse Width |  | 200 | - | - | ms |
| trst | Reset Time From Valid $V_{C,}$ S |  | 45 | - | - | $\mu \mathrm{s}$ |

1. ISP Programming is guaranteed for $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Operation onfly.

Specifications pLSI and ispLSI 1048C

Figure 6. Timing Waveforms for In-System Programming


Figure 7. Program, Verify \& Bulk Erase Waveforms


Figure 8 illustrates the address and data shift register bits the Device Layout discussion in the pLSI and ispLSI for the ispLSI 1048C. For a detailed explanation refer to Architectiural Description section of this Data Book.

Figure 8. ispLSI 1048C Shift Register Layout


Note: A logic "1" in the Address Shift Register bit position enables the row for programming or verification. A logic " 0 " disables it.

## Pin Description



[^11]Specifications pLSI and ispLSI 1048C

## Pin Configuration

## pLSI and ispLSI 1048C 128-Pin PQFP Pinout Diagram


*Pins have dual function capability for ispLSI 1048C only (except pin 18, which is ispEN only).

## Part Number Description


pLSI and ispLSI 1048C Ordering Information

COMMEFCMAL

| Family | $f_{\text {max }}(\mathrm{MHz})$ | tpd ( ns ) | drering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| pLSI | 70 | $18 / 8$ | R-5 1048C-70LQ | 128-Pin PQFP |
|  | 50 |  | \%isl 1048C-50LQ | 128-Pin PQFP |
| ispLSI | $70 \%$ | $8$ | pLSI 1048C-70LQ | 128-Pin PQFP |
|  |  | $24$ | ispLSI 1048C-50LQ | 128-Pin PQFP |



Table 2-004 1A-48C-isp

# Introduction to pLSI ${ }^{\circ}$ and ispLSI'" 2000 Family 

## Introduction to pLSI and ispLSI 2000 Family

Lattice Semiconductor's pLSI (programmable Large Scale Integration) and ispLSI (in-system programmable Large Scale Integration) are high-density and high-performance $\mathrm{E}^{2} \mathrm{CMOS}^{\circledR}$ programmable logic devices. They provide design engineers with a superior system solution for integrating high-speed logic on a single chip.

The Lattice pLSI and ispLSI 2000 Families are I/O intensive, programmable logic devices that combine high performance and ease of use of PLDs with the density and flexibility of FPGAs.

The pLSI and ispLSI 2000 families are ideal for designs needing high performance in conjunction with high I/O requirements.

The ispLSI devices have also pioneered non-volatile, insystem programmability, atechnology that allows real-time programming, less expensive manufacturing and enduser feature reconfiguration.

Lattice's $E^{2}$ CMOS technology features reprogrammability, the ability to program the device again and again to easily incorporate any design modifications. This same capability allows full parametric testability during manufacturing, which guarantees 100 percent programming and functional yield.

All necessary development tools are available from Lattice and third-party vendors. Development tools offered range from Lattice's low cost pDS ${ }^{\circledR}$ software, featuring Boolean entry in a graphical Windows ${ }^{\text {TM }}$ based environment, to the $\mathrm{pDS}+{ }^{\mathrm{TM}}$ family of fitters that interfaces with third party development software packages. Design systems interfacing with pDS+ Fitters feature schematic capture, state machine and HDL design entry. Designs can now be completed in hours as opposed to days or weeks.

## pLSI and ispLSI Product 2000 Family

- 135 MHz System Performance
- 7.5 ns Pin-to-Pin Delay
- Deterministic Performance
- High Density (1,000-4,000 PLD Gates)
- 44 Pin to 128 Pin Package Options
- Flexible Architecture
- Easy-to-Use
- In-System Programmable (ispLSI)
- Ideal for I/O Intensive Designs


## pLSI and ispLSI Technology

- UltraMOS E ${ }^{2}$ CMOS - the PLD Technology of Choice
- Electrically Erasable/Programmable/ Reprogrammable
- 100\% Tested During Manufacture
- 100\% Programming Yield
- Fast Programming


## pLSI and ispLSI Development Tools

- Low Cost, Fully Integrated pDS Design System for the PC
- Boolean Equations and Macro Input
- HDL and Schematic Capture Entry
- pDS+ Support for Industry-Standard ThirdParty Design Environments and Platforms
- Timing and Functional Simulation
- PC and Workstation Platforms


## Introduction to pLSI and ispLSI 2000 Family

## 2000 Family Overview

The pLSI and ispLSI 2000 families of high-density devices address high-performance system logic needs, implementing logic functions ranging from registers, to counters, to multiplexers, to complex state machines.

With PLD density ranging from 1,000 to 4,000 gates, the pLSI and ispLSI 2000 Families provide a wide range of programmable logic solutions which meet tomorrow's design requirements today.

Each device contains multiple Generic Logic Blocks (GLBs), which are designed to maximize system flexibility and performance. A balanced ratio of registers and I/O cells provides the optimum combination of internal logic and external connections. A global interconnect scheme ties everything together, enabling utilization of up to $80 \%$ of available logic. Table 1 describes the family attributes.

Table 1. pLSI and ispLSI 2000 Family Attributes

| Family Member | 2032 | 2064 | 2096 |
| :---: | :---: | :---: | :---: |
| Density (PLD Gates) | 1,000 | 2,000 | 4,000 |
| Speed: fmax (MHz) | 135 | 135 | 110 |
| Speed: tpd (ns) | 7.5 | 7.5 | 10 |
| Macrocells | 32 | 64 | 96 |
| Registers | 32 | 64 | 96 |
| Inputs + I/O | 34 | 68 | 102 |
| Pin/Package | $44-$ pin PLCC <br> $44-p i n ~ T Q F P ~$ | 84-pin PLCC <br> 100-pin TQFP | $128-$ pin PQFP |

Tab 1-0003A-2000

Figure 1. 2000 Family Packages


## 44-Pin PLCC



84-Pin PLCC


128-Pin PQFP


44-Pin TQFP
\&
ispLSI 2064


100-Pin TQFP

# 䔜attice 

Features

# pLSI' and ispLSI" 2032 

## High Density Programmable Logic

## - HIGH DENSITY PROGRAMMABLE LOGIC

— High Speed Global Interconnect

- 1000 PLD Gates
- 32 I/O Pins, Two Dedicated Inputs
- 32 Registers
- Wide Input Gating for Fast Counters, State Machines, Address Decoders, etc.
- Small Logic Block Size for Random Logic
- HIGH PERFORMANCE E²CMOS ${ }^{\circledR}$ TECHNOLOGY
- fmax $=135 \mathrm{MHz}$ Maximum Operating Frequency
- tpd = 7.5 ns Propagation Delay
- TTL Compatible Inputs and Outputs
- Electrically Erasable and Reprogrammable
- Non-Volatile
- 100\% Tested at Time of Manufacture
- Unused Product Term Shutdown Saves Power
- ispLSI OFFERS THE FOLLOWING ADDED FEATURES
- In-System Programmable 5-Volt Only
- Change Logic and Interconnects "On-the-Fly" in Seconds
— Reprogram Soldered Devices for Debugging
- OFFERS THE EASE OF USE AND FAST SYSTEM SPEED OF PLDs WITH THE DENSITY AND FLEXIBILITY OF FIELD PROGRAMMABLE GATE ARRAYS
- Complete Programmable Device Can Combine Glue Logic and Structured Designs
- Three Dedicated Clock Input Pins?
- Synchronous and Asynchronous Clocks
- Flexible Pin Placement
- Optimized Global Routing Pool Provides GIobal Interconnectivity
- pLSI/ispLSI DEVELOPMENT SYSTEM (PDS®) pDS Software
- Easy to Use PC Windowsn Interface
- Boolean Logic Compier
- Manual Partitioning
- Automatic Placeand Route
- Static Tining Table
pDS+ ${ }^{\text {TM }}$ Softyare
- Industry Standard, Third Party Design Environments
- Schematic Capture, State Machine, HDL
- Automatic Partitioning and Place and Route
- Comprehensive Logic and Timing Simulation
- PC and Workstation Platforms

Functional Block Diagram


## Description

The Lattice pLSI and ispLSI 2032 are High Density Programpable Logic Devices. The devices contain 32 Registers, 32 Universal I/O pins, two Dedicated Input Pins, three Dedicated Clock Input Pins, one dedicated Global OE input pin and a Global Routing Pool (GRP). The GRP provides complete interconnectivity between all of these elements. The ispLSI 2032 features 5-Volt insystem programmability and in-system diagnostic capabilities. The ispLSI 2032 offers non-volatile "on-thefly" reprogrammability of the logic, as well as the interconnects to provide truly reconfigurable systems. It is architecturally and parametrically compatible to the pLSI 2032 device, but multiplexes four input pins to control in-system programming.
The basic unit of logic on the pLSI and ispLSI 2032 devices is the Generic Logic Block (GLB). The GLBs are labeled $A 0, A 1$.. $A 7$ (see figure 1). There are a total of eight GLBs in the pLSI and ispLSI 2032 devices. Each GLB is made up of four macrocells. Each GLB has 18 inputs, a programmable AND/OR/Exclusive OR array, and four outputs which can be configured to be either combinatorial or registered. Inputs to the GLB come from the GRP. All of the GLB outputs are brought back into the GRP so that they can be connected to the inputs of any GLB on the device.

[^12]
## Functional Block Diagram

Figure 1. pLSI and ispLSI 2032 Functional Block Diagram


The devices also have 32 I/C cetrs, each of which is directly connectoo to an 70 op Each I/O cell can be individually programmed to be a combinatorial input, output or bidirectional $1 / 0$ pin with 3 -state control. The signal levels are TTL compatible voltages and the output drivers can spurce 4 mA or sink 8 mA .

Eight GLBs, 32 I/O cells, two dedicated inputs and two ORPs are connected together to make a Megablock (see figure 1). The outputs of the eight GLBs are connected to a set of 32 universal I/O cells by the ORP. Each pLSI and ispLSI 2032 devices contain one Megablock.

The GRP has as its inputs, the outputs from all of the GLBs and all of the inputs from the bi-directional I/O cells. All of these signals are made available to the inputs of the GLBs. Delays through the GRP have been equalized to minimize timing skew.

Clocks in the pLSI and ispLSI 2032 devices are selected using the dedicated clock pins. Three dedicated clock pins (Y0, Y1, Y2) or an asynchronous clock can be selected on a GLB basis. The asynchronous or Product Term clock can be generated in any GLB for its own clock.

## Absolute Maximum Ratings 1

Supply Voltage $\mathrm{V}_{\mathrm{cc}} \ldots . .$.
Input Voltage Applied. . . . . . . . . . . . . . . 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Off-State Output Voltage Applied . . . . . .2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Storage Temperature . . . . . . . . . . . . . . . . . . 65 to $125^{\circ} \mathrm{C}$
Ambient Temp. with Power Applied . . . . . . . . 55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. Functional operation of the device at these or at any other conditions above those indicated in the operational sections q/fyhis specification is not implied (while programming, follow the programming specifications).

DC Recommended Operating Condition

## Capacitance $\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right.$ )

| SYMBOL | PARAMETER | MAXIMUM ${ }^{1}$ | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: |
| $\mathbf{C}_{1}$ | Dedicated Input Capacitince | 8 | pf | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{2}$ | I/O and Clock Capgettane | 10 | pf | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{10}, \mathrm{~V}_{\mathrm{Y}}=2.0 \mathrm{~V}$ |

1. Guaranteed but not $100 \%$ ses

Table 2.0006A

## Data Retention Specifications

| PARAMETER | MINIMUM | MAXIMUM | UNITS |
| :---: | :---: | :---: | :---: |
| Data Reteltion | 20 | - | YEARS |
| ispLSI Erase/goprogram Cycles | 1000 | - | CYCLES |
| pLSI Erase/Reprogram Cycles | 100 | - | CYCLES |

## Switching Test Conditions

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Time | $\leq 3 n s 10 \%$ to $90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See figure 2 |

3-state levels are measured 0.5 V from steady-state active level.

Table 2-0003

## Output Load Conditions (see figure 2)

| Test Condition |  | R1 | R2 | CL |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $470 \Omega$ | $390 \Omega$ | 35 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 35 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 35 pF |
| C | Active High to Z <br> at $\mathrm{V}_{\text {OH }}-0.5 \mathrm{~V}$ | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low to Z <br> at $\mathrm{V}_{\text {OL }}+0.5 \mathrm{~V}$ | $470 \Omega$ | $390 \Omega$ | 5 pF |

## DC Electrical Characteristics

## Over Recominendedoperating Conditions

| SYMBOL | PARAMETER | F CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ | - | - | 0.4 | V |
| VOH | Output High Voltưg | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ | 2.4 | - | - | V |
| IIL | Input or I/gtaw yoakage cugrent | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{HL}}$ (MAX.) | - | - | -10 | $\mu \mathrm{A}$ |
| IIH |  | $3.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\text {cC }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| IIL-isp | Becanis EN Insut ${ }^{\text {a }}$ | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ | - | - | -150 | $\mu \mathrm{A}$ |
| IIL-PL/ | JOAC和e Publy | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ | - | - | -150 | $\mu \mathrm{A}$ |
| $\mathrm{lOS}^{1}$ | O'estaut Short Circuit Current | $\mathrm{V}_{\text {CC }}=5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.5 \mathrm{~V}$ | -60 | - | -200 | mA |
| ICC2 | Opely | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {TOGGLE }}=1 \mathrm{MHz} \end{aligned}$ | - | 40 | - | mA |

1. One output at a time for a maximum duration of one second. $\mathrm{V}_{\text {out }}=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not 100\% tested.
2. Measured using two 16 -bit counters.
3. Typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$.

Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST } \\ & \text { COND. } \end{aligned}$ | .$^{2}$ | DESCRIPTION ${ }^{1}$ | -135 |  | -110 |  | -80 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd1 | A | 1 | Data Propagation Delay, 4PT bypass, ORP bypass | - | 7.5 | - | 10.0 | - | 15.0 | ns |
| tpd2 | A | 2 | Data Propagation Delay | - | 10.0 | - | 13.3 | - | 20.0 | ns |
| fmax | A | 3 | Clock Frequency with Internal Feedback ${ }^{3}$ | 137 | - | 110.7 | - | 80 | - | MHz |
| fmax (Ext.) | - | 4 | Clock Frequency with External Feedback ( $\frac{1}{\text { tsu2 }+ \text { tcol }}$ ) | 100 | - | 79.2 | - | 50 | - | MHz |
| $f^{\text {max (Tog.) }}$ | - | 5 | Clock Frequency, Max Toggle ${ }^{4}$ | 167 | - | 125 | - | 100 | - | MHz |
| tsu1 | - | 6 | GLB Reg. Setup Time before Clock, 4PT bypass | 4 | - | 5.3 | - | \% | - | ns |
| tco1 | A | 7 | GLB Reg. Clock to Output Delay, ORP bypass | - | 4.5 | - | 5.3 |  | 10.0 | ns |
| th1 | - | 8 | GLB Reg. Hold Time after Clock, 4 PT bypass | 0 | - | 0 |  |  |  | ns |
| tsu2 | - | 9 | GLB Reg. Setup Time before Clock | 5.5 | - | 7\% | 5 | 10.0 |  | ns |
| tco2 | - | 10 | GLB Reg. Clock to Output Delay | - | 5.5 |  | 5 |  | 12.0 | ns |
| th2 | - | 11 | GLB Reg. Hold Time after Clock | 0 |  | 0 |  | 0 | - | ns |
| tr1 | A | 12 | Ext. Reset Pin to Output Delay | \% | 990. |  | 3.3 | - | 17.0 | ns |
| trw1 | - | 13 | Ext. Reset Pulse Duration | He | \% | \%60 | - | 10.0 | - | ns |
| tptoeen | B | 14 | Input to Output Enable |  | 14.8 | - | 14.5 | - | 18.0 | ns |
| tptoedis | C | 15 | Input to Output Disable |  | \$2.0 | - | 14.5 | - | 18.0 | ns |
| tgoeen | B | 16 | Global OE to Output Enable | \% | 6.0 | - | 6.7 | - | 9.5 | ns |
| tgoedis | C | 17 | Global OE to Output Disable | - | 6.0 | - | 6.7 | - | 9.5 | ns |
| twh | - | 18 | External Synchronous Cloof"pulse | 3.0 | - | 4.0 | - | 5.0 | - | ns |
| twl | - | 19 | External Synchronousforock Melise Daraion, Low | 3.0 | - | 4.0 | - | 5.0 | - | ns |


2. Refer to Timing Model in this data sheet fogyurther details,
3. Standard 16-Bit loadable counter using, बfhe feedback.

5. Reference Switching Test Conditions s . sectian.


## Specifications pLSI and ispLSI 2032

Internal Timing Parameters ${ }^{1}$

## Over Recommended Operating Conditions

| PARAMETER | $\#^{2}$ | DESCRIPTION | －135 |  | －110 |  | －80 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN． | MAX． | MIN． | MAX． | MIN． | MAX． |  |
| Inputs |  |  |  |  |  |  |  |  |  |
| tiobp | 20 | I／O Register Bypass | － | 1.0 | － | 1.3 | － | 2.0 | ns |
| tdin | 26 | Dedicated Input Delay | － | 2.6 | － | 3.5 | － | 4.0 | ns |
| GRP |  |  |  |  |  |  |  |  |  |
| tgrp | 28 | GRP Delay | － | 1.3 | － | 1.7 | \％\％ | 2.0 | ns |
| GLB |  |  |  |  |  |  |  |  |  |
| t4ptbp | 33 | 4 Product Term Bypass Path Delay | － | 3.2 | － | 4＊＊ | － | 6.5 | ns |
| t1ptxor | 34 | 1 Product Term／XOR Path Delay | － | 4.0 |  | 53 |  | \％$\%$ | ns |
| t20ptxor | 35 | 20 Product Term／XOR Path Delay | － | 4.7 |  | $\stackrel{3}{ }$ | \％ | 8.0 | ns |
| txoradj | 36 | XOR Adjacent Path Delay ${ }^{3}$ | － | \％ 6.4 |  | 7.4 | － | 9.5 | ns |
| tgbp | 37 | GLB Register Bypass Delay | 永 | \％${ }^{\text {a }}$ |  | $0 \% 7$ | － | 1.0 | ns |
| tgsu | 38 | GLB Register Setup Time before Clock | ＂${ }^{4}$ | \％ | \％ 1 | － | 1.0 | － | ns |
| tgh | 39 | GLB Register Hold Time after Clock | ＂3：0 ${ }^{3}$ | ， 24 | 4.5 | － | 4.5 | － | ns |
| tgco | 40 | GLB Register Clock to Output Delay | － | － 6.7 | － | 0.2 | － | 2.0 | ns |
| tgr | 41 | GLB Register Reset to Output Delay $\%^{*}$＊ | 名 | 1.1 | － | 1.5 | － | 2.5 | ns |
| tptre | 42 | GLB Product Term Reset to Register＂elay | － | 4.4 | － | 5.9 | － | 10.0 | ns |
| tptoe | 43 | GLB Product Term Output Enable tor M Cell Deley | － | 6.5 | － | 7.2 | － | 9.0 | ns |
| tptck | 44 | GLB Product Term Clock DAjay $\$ ，\％$\psi \nRightarrow$ | 3.3 | 3.3 | 4.4 | 4.4 | 3.5 | 3.5 | ns |
| ORP |  |  |  |  |  |  |  |  |  |
| torp | 45 | ORP Delay $\not 2$＊ | － | 1.3 | － | 1.7 | － | 2.5 | ns |
| torpbp | 46 | ORP Bypass，elay， | － | 0.3 | － | 0.4 | － | 0.5 | ns |
| Outputs $\not 2$ 会 |  |  |  |  |  |  |  |  |  |
| tob | 47 | Outpưt Euftek Qajy＊ | － | 1.2 | － | 1.6 | － | 3.0 | ns |
| toen |  | \％OCel O No Qtiput Enabled | － | 2.2 | － | 4.3 | － | 5.0 | ns |
| todis |  |  | － | 2.2 | － | 4.3 | － | 5.0 | ns |
| Clocks |  |  |  |  |  |  |  |  |  |
| tgyo／1\％\ | 40 | Clock Delay，Y0 to Global GLB Clock Line（Ref．clock） | 2.3 | 2.3 | 3.1 | 3.1 | 4.5 | 4.5 | ns |
| Global Resats |  |  |  |  |  |  |  |  |  |
| tgr | \％ 65 | Global Reset to GLB | － | 6.4 | － | 8.5 | － | 9.0 | ns |

1．Intemal Timing Parameters are not tested and are for reference only．
Table 2－0036A－16／135／110
2．Refer to Timing Model in this data sheet for further details．
3．The XOR Adjacent path can only be used by Lattice Hard Macros．

## pLSI and ispLSI 2032 Timing Model



Note: Calculations are based upon timing specifications for the pLSI and ispLSI 2032-135L.

## Specifications pLSI and ispLSI 2032

## Power Consumption

Power Consumption in the pLSI and ispLSI 2032 device depends on two primary factors: the speed at which the device is operating and the number of Product Terms
used. Figure 3 shows the relationship between power and operating speed.

Figure 3. Typical Device Power Consumption vs fmax



ICC can be estimated for the pLSI and ispLSI 2032 using the followiog equation:
ICC $=23+(\#$ of PTs * 0.33$)+(\#$ of nets * Max freq * 0.011$)$ yhere:
\# of PTs = Number of Product Terms used in design
\# of nets = Number of Signals used in device
Max freq = Highest Clock Frequency to the device
The ICC estimate is based on typical conditions (VCC $5: Q \mathrm{~V}$, room temperature) and an assumption of 2 GLB loads on average exists. These values are for estimates only. Sincesthe value of ICC is sensitive to operating conditions and the program in the device, the actual ICC should be verified

## In-System Programmability

The ispLSI devices are the in-system programmable versions of the Lattice high density programmable Large Scale Integration (pLSI) devices. By integrating all the high voltage programming circuitry on-chip, programming can be accomplished by simply shifting data into the device. Once the function is programmed, the nonvolatile $E^{2}$ CMOS cells will not lose the pattern even when the power is turned off.

All necessary programming is done via five TTL level logic interface signals. These five signals are fed into the on-chip programming circuitry where a state machine controls the programming. The simple signals for interface include isp Enable (ispEN), Serial Data In (SDI), Serial Data Out (SDO), Serial Clock (SCLK) and Mode (MODE) control. Figure 4 illustrates the block diagram of one possible scheme of the programming interface for the ispLSI devices. For details on the operation of the internal state machine and programming of the device please refer to the in-system programming section in this Data Book.

Figure 4. ISP Programming Interface


## Specifications pLSI and ispLSI 2032

ISP Programming Voltage/Timing Specifications ${ }^{1}$

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VccP | Programming Voltage |  | 4.75 | 5 | 5.25 | V |
| ICCP | Programming Supply Current |  | - | 50 | 100 | mA |
| VIHP | Input Voltage High | $\overline{\text { ispEN }}=$ Low | 2.0 | - | Vccp | V |
| VILP | Input Voltage Low |  | 0 | - | 0.8 | V |
| IIP | Input Current |  | - | 100 | 200 | $\mu \mathrm{A}$ |
| Vohp | Output Voltage High | $\mathrm{I}_{\text {OH }}=-3.2 \mathrm{~mA}$ | 2.4 | - | VCCP | V |
| Volp | Output Voltage Low | $\mathrm{I}_{\mathrm{LL}}=5 \mathrm{~mA}$ | 0 | - | 4.5 | V |
| tr, tif | Input Rise and Fall |  | - | 7 | ${ }^{3} 1$ | $\mu \mathrm{s}$ |
| tispen | ispen to Output 3-State Enabled |  |  | 3 | 10 | $\mu \mathrm{s}$ |
| tispdis | ispEN to Output 3-State Disabled |  | \% |  | \% | $\mu \mathrm{s}$ |
| tsu | Setup Time |  | 0.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tco | Clock to Output | ${ }^{2}$ | Q 1 | $2 \%$ | - | $\mu \mathrm{s}$ |
| th | Hold Time | 41 | 80.1 | 0.5 | - | $\mu \mathrm{s}$ |
| tclkh, tcılkl | Clock Pulse Width, High and Low | $\cdots$ | 40.5 | 1 | - | $\mu \mathrm{s}$ |
| tpw | Verify Pulse Width | $R^{2} 1$ | 20 | 30 | - | $\mu \mathrm{s}$ |
| tpwp | Programming Pulse Width | , 1 | 40 | - | 100 | ms |
| tbew | Bulk Erase Pulse Width | 12 ${ }^{2}$ | 200 | - | - | ms |
| trst | Reset Time From Valid $\mathrm{V}_{\text {ccP }}$ | In a | 45 | - | - | $\mu \mathrm{s}$ |

1. ISP Programming is guaranteed for $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ}{ }^{\circ}$ pormatimenly

Table 2. 0029 isp-C

## Specifications pLSI and ispLSI 2032

Figure 5. Timing Waveform for In-System Programming


Figure 6. Program, Verify \& Bank Exast Wayeform


Figure 7. ispLSI 2032 Shift Register Layout


Note:
A logic "1" in the address shift register enables the row for programming or verification. A logic "0" disables it.

## Pin Description



* ispLSI 2032 Only

Specifications pLSI and ispLSI 2032

Pin Description


[^13]
## Pin Configuration

pLSI and ispLSI 2032 44-pin PLCC


## Pin Configuration

pLSI and ispLSI 2032 44-pin TQFP


Part Number Description

## Specifications pLSI and ispLSI 2032


blishza

| Device Family | $\left.\mathrm{fmax}^{(M H z}\right)$ | tpd (fis) | Ordarigh Number | Package |
| :---: | :---: | :---: | :---: | :---: |
| SI | 135 | \% 5 | QSf 2032-135LJ44 | 44-Pin PLCC |
|  | 135 \% | \% 5 | pLSI 2032-135LT44 | 44-Pin TQFP |
|  | +10 | 10\% | pLSI 2032-110LJ44 | 44-Pin PLCC |
|  | \% 10 | 10 | pLSI 2032-110LT44 | 44-Pin TQFP |
|  | $880$ | 15 | pLSI 2032-80LJ44 | 44-Pin PLCC |
|  | 86 | 15 | pLSI 2032-80LT44 | 44-Pin TQFP |
|  | 135 | 7.5 | ispLSI 2032-135LJ44 | 44-Pin PLCC |
|  | 135 | 7.5 | ispLSI 2032-135LT44 | 44-Pin TQFP |
|  | 110 | 10 | ispLSI 2032-110LJ44 | 44-Pin PLCC |
|  | 110 | 10 | ispLSI 2032-110LT44 | 44-Pin TQFP |
|  | 80 | 15 | ispLSI 2032-80LJ44 | 44-Pin PLCC |
|  | 80 | 15 | ispLSI 2032-80LT44 | 44-Pin TQFP |

Table 2-0041A-08isp/2000

# Introduction to pLSI ${ }^{\circ}$ and ispLSI'" 3000 Family 

## Introduction to pLSI and ispLSI 3000 Family

Lattice Semiconductor'spLSI (programmable Large Scale Integration) and ispLSI (in-system programmable Large Scale Integration) are high-density and high-performance $\mathrm{E}^{2} \mathrm{CMOS}^{\circledR}$ programmable logic devices. They provide design engineers with a superior system solution for integrating high-speed logic on a single chip.

The Lattice pLSI and ispLSI 3000 Families are the third generation to combine the performance and ease of use of PLDs with the density and flexibility of FPGAs.

The pLSI and ispLSI 3000 Family is ideal for high density designs, where integration of complete logic sub-systems into a single device is necessary.

The ispLSI devices have also pioneered non-volatile, insystem programmability, a technology that allows real-time programming, less expensive manufacturing and enduser feature reconfiguration.

Lattice's $E^{2}$ CMOS technology features reprogrammability, the ability to program the device again and again to easily incorporate any design modifications. This same capability allows full parametric testability during manufacturing, which guarantees 100 percent programming and functional yield.

All necessary development tools are available from Lattice and third-party vendors. Development tools offered range from Lattice's low cost $\mathrm{pDS}^{\circledR}$ software, featuring Boolean entry in a graphical Windows ${ }^{\text {TM }}$ based environment, to the $\mathrm{pDS}+{ }^{\text {TM }}$ family of Fitters that interface with third party development software packages. pDS+ systems support schematic capture, state machine, Boolean, and HDL Design entry. Designs can now be completed in hours as opposed to days or weeks.
pLSI and ispLSI Product 3000 Family

- 110 MHz System Performance
- 10 ns Pin-to-Pin Delay
- Deterministic Performance
- High Density (8000-14,000 PLD Gates)
- Flexible Easy-to-Use Architecture
- In-System Programmable (ispLSI)
- Boundary Scan (IEEE 1149.1)


## pLSI and ispLSI Technology

- UltraMOS E ${ }^{2}$ CMOS - the PLD Technology of Choice
- Electrically Erasable/Programmable/ Reprogrammable
[ 100\% Tested During Manufacture
] $100 \%$ Programming Yield
] Fast Programming


## pLSI and ispLSI Development Tools

- Low Cost, Fully Integrated pDS Design System for the PC
- HDL Boolean Equation and Schematic Capture Entry
- pDS+ Support for Industry-Standard ThirdParty Design Environments and Platforms
- Timing and Functional Simulation
- PC and Workstation Platforms


## Introduction to pLSI and ispLSI 3000 Family

## 3000 Family Overview

The pLSI and ispLSI 3000 family of high-density devices address high-performance system logic designs implementing logic functions, ranging from registers, to counters, to multiplexers, to complex state machines.

With up to 14,000 PLD gates density, the pLSI and ispLSI 3000 Family provides a wide range of programmable logic solutions which meet tomorrow's design requirements today.

Each device contains multiple Generic Logic Blocks (GLBs), which are designed to maximize system flexibility and performance. A balanced ratio of registers and I/O cells provides the optimum combination of internal logic and external connections. A global interconnect scheme ties everything together, enabling utilization of up to 80\% of available logic. Table 1 describes the family attributes.

Table 1. pLSI and ispLSI 3000 Family Attributes

| Family Member | 3192 | 3256 | 3320 |
| :---: | :---: | :---: | :---: |
| Density (PLD Gates) | 8,000 | 11,000 | 14,000 |
| Speed: fmax (MHz) | 110 | 80 | 80 |
| Speed: tpd (ns) | 10 | 15 | 15 |
| Macrocells | 192 | 256 | 320 |
| Registers | 288 | 384 | 480 |
| Inputs + //O | 96 | 128 | 160 |
| Pin/Package | 128 -pin PQFP | 160 -pin MQFP <br> $167-$-pin CPGA | 208-pin MQFP <br> 207 -pin CPGA |

Table 1-0003A-3000
Figure 1. 3000 Family Packages


128-Pin PQFP


160-Pin MQFP


167-Pin CPGA


208-Pin MQFP


207-Pin CPGA

# pLSI ${ }^{\circ}$ and ispLSI" ${ }^{\text {™ }} 3256$ 

High Density Programmable Logic

## Features

## - HIGH DENSITY PROGRAMMABLE LOGIC

- High Speed Global Interconnect
- 128 I/O Pins
- 11000 PLD Gates
- 384 Registers
- Wide Input Gating for Fast Counters, State Machines, Address Decoders, etc.
- Small Logic Block Size for Random Logic
- HIGH PERFORMANCE E ${ }^{2}$ CMOS $^{\circledR}$ TECHNOLOGY
- $\mathbf{f}_{\max }=\mathbf{8 0} \mathbf{M H z}$ Maximum Operating Frequency
- tpd = 15 ns Propagation Delay
- TTL Compatible Inputs and Outputs
- Electrically Erasable and Reprogrammable
- Non-Volatile
- 100\% Tested at Time of Manufacture
- Unused Product Term Shutdown Saves Power
- ispLSI OFFERS THE FOLLOWING ADDED FEATURES
- In-System Programmable 5-Volt Only
— Change Logic and Interconnects "On-the-Fly" in Seconds
— Reprogram Soldered Devices for Debugging
- 100\% IEEE 1149.1 BOUNDARY SCAN COMPATIBLE
- OFFERS THE EASE OF USE AND FAST\$YSTEM SPEED OF PLDs WITH THE DENSITVAND FLEXIBLLITY OF FIELD PROGRAMMABLE GATE ARRAYS
- Complete Programmable gevice can Combine Glue Logic and Structured Designs
- Five Dedicated Clogkinpyt Pins
- Synchronous ap, Asypchrangus Clocks
- Flexible Pin Pracement
- Optimized GIODal Routing?Pool Provides Global Intercomectivity
- pLSI/ispLSI DEVELOPMENT SYSTEM (pDS ${ }^{\text { }}$ ) pDS Software
- Easy to Use PC Windows ${ }^{\text {TM }}$ Interface
- Boolean Logic Compiler
- Manual Partitioning
- Automatic Place and Route
- Static Timing Table
pDS+ ${ }^{\text {TM }}$ Software
- Industry Standard, Third Party Design Environments
- Schematic Capture, State Machine, HDL
- Automatic Partitioning and Place and Route
- Comprehensive Logic and Timing Simulation
- PC and Workstation Platforms


## Functional Block Diagram



## Description

The Lattice pLSI and ispLSI 3256 are High Density Programmable Logic Devices which contain 384 Registers, 128 Universal I/O pins, five Dedicated Clock Input Pins, eight Output Routing Pools (ORP), and a Global Routing Pool (GRP) which allows complete inter-connectivity between all of these elements. The ispLSI 3256 features 5 -Volt in-system programmability and in-system diagnostic capabilities. The ispLSI 3256 offers nonvolatile "on-the-fly" reprogrammability of the logic, as well as the interconnects to provide truly reconfigurable systems. It is architecturally and parametrically compatible to the pLSI 3256 devices, but multiplexes four input pins to control in-system programming.
The basic unit of logic on the pLSI and ispLSI 3256 devices is the Twin Generic Logic Block (Twin GLB) labelled A0, A1 ... H 3 . There are a total of 32 of these Twin GLBs in the pLSI and ispLSI 3256 devices. Each Twin GLB has 24 inputs, a programmable AND array and two OR/Exclusive-OR Arrays, and eight outputs which can be configured to be either combinatorial or registered. All Twin GLB inputs come from the GRP.

## Specifications pLSI and ispLSI 3256

## Functional Block Diagram

Figure 1. pLSI and ispLSI 3256 Functional Block Diagram


## Specifications pLSI and ispLSI 3256

## Description (continued)

All local logic block outputs are brought back into the GRP so they can be connected to the inputs of any other logic block on the device. The device also has 128 I/O cells, each of which is directly connected to an I/O pin. Each I/O cell can be individually programmed to be a combinatorial input, a registered input, a latched input, an output or a bidirectional I/O pin with 3 -state control. The signal levels are TTL compatible voltages and the output drivers can source 4 mA or sink 8 mA .

The 128 I/O Cells are grouped into eight sets of 16 bits. Each of these I/O groups is associated with a logic Megablock through the use of the ORP. These groups of 16 I/O cells share one Product Term Output Enable and two Global Output Enable signals.

Four Twin GLBs, 16 I/O Cells and one ORP are connected together to make a logic Megablock. The Megablock is defined by the resources that it shares. The outputs of the four Twin GLBs are connected to a set of 16 I/O cells by the ORP. The pLSI and ispLSI 3256 Device contains eight of these Megablocks.

The GRP has as its inputs the outputs from all of the win GLBs and all of the inputs from the bidirectionah 10 cels. All of these signals are made available to the inputs of the Twin GLBs. Delays through the GRP have been equar ized to minimize timing skew and logra glitching

Clocks in the pLSI and ispLSI 3256 devices are provided through five dedicated clock pins. The five pins provide three clocks to the Twin GLBs and two clocks to the I/O cells.

The table below lists key attributes of the device along with the number of resources available.

An additional feature of the pLSI and isplSI 3256 is the Boundary Scan capability, which iscomposed of cells connected between the on-chip system logic and the device's input and output pins. AIN/O pins have associated boundary scan registers, with 3 -stateyO using three boundary scan registers and infuts using one.

The pLSI and ispLSI 3256 supports all IEEE 1149.1 mandatory instructions, mhich include BYPASS, EXTEST and SAMPLE.

Key Attributes of the pLSI and ispLSI 3256

| Device | pLSI and <br> ispLSI 3256 |
| :---: | :---: |
| Twin GLBs | 32 |
| Registers | 384 |
| I/O Pins | 128 |
| Global OE | 2 |
| Test OE | 1 |

Table 1-0003Aisp/3256

## Absolute Maximum Ratings 1

Supply Voltage $\mathrm{V}_{\text {cc }} \ldots . .$.
Input Voltage Applied. . . . . . . . . . . . . . . 2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Off-State Output Voltage Applied . . . . . -2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Storage Temperature . . . . . . . . . . . . . . . . . . 65 to $125^{\circ} \mathrm{C}$
Ambient Temp. with Power Applied . . . . . . . . 55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage tos device. Functional
operation of the device at these or at any other conditions above those indicated in the operational setionsf this specification
2. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to device. Functional
operation of the device at these or at any other conditions above those indicated in the operational section this specification is not implied (while programming, follow the programming specifications).

## Specifications pLSI and ispLSI 3256

## DC Recommended Operating Condition



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

| SYMBOL | ARAMETE | MAXIMUM ${ }^{1}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ |  | 8 | pf | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{2}$ |  | 10 | pf | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{10}, \mathrm{~V}_{\mathrm{Y}}=2.0 \mathrm{~V}$ |

1. Guaranteed bytnit $100 /$ toste

## Data Retention Specifications

| PARAMETER | MINIMUM | MAXIMUM | UNITS |
| :--- | :---: | :---: | :---: |
| Data Retention | 20 | - | YEARS |
| ispLSI Erase/Reprogram Cycles | 1000 | - | CYCLES |
| pLSI Erase/Reprogram Cycles | 100 | - | CYCLES |

## Specifications pLSI and ispLSI 3256

## Switching Test Conditions

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Time | $\leq 3 n s 10 \%$ to $90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See figure 2 |

3-state levels are measured 0.5 V from steady-state active level.

Output Load conditions (figure 2)

| Test Condition |  | R1 | R2 | CL |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $470 \Omega$ | $390 \Omega$ | 35 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 35 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 35 pF |
| C | Active High to Z <br> at $\mathrm{V}_{\text {OH }}-0.5 \mathrm{~V}$ | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low to Z <br> at $V_{\text {OL }}+0.5 \mathrm{~V}$ | $470 \Omega$ | $390 \Omega$ | 5 pF |

Figure 2. Test Load


## DC Electrical Characteristics

| SYMBOL | TAMESER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Output jok koliug | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ | - | - | 0.4 | V |
| VOH | Outpit Hinh volangey | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ | 2.4 | - | - | V |
| IIL | Input ordto Low Eeakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{IL}}$ (MAX.) | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | Input of / Offigh Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ | - | - | 10 | $\mu \mathrm{A}$ |
| IIL-isp | Bscan/isipEN Input Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ | - | - | -150 | $\mu \mathrm{A}$ |
| IIL-PU | I/O Active Pull-Up Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ | - | - | -150 | $\mu \mathrm{A}$ |
| IOS ${ }^{1}$ | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.5 \mathrm{~V}$ | -60 | - | -200 | mA |
| ICC2 | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {TOGGLE }}=1 \mathrm{MHz} \end{aligned}$ | - | 150 | - | mA |

1. One output at a time for a maximum duration of one second. $\mathrm{V}_{\text {out }}=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
2. Measured using sixteen 16 -bit counters.
3. Typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$. Teble 2-0007isp/3256

## External Switching Characteristics ${ }^{1,2,3}$

## Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST } \\ & \text { COND. } \end{aligned}$ | $*^{2}$ | DESCRIPTION ${ }^{1}$ | $-80^{6}$ |  | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd1 | A | 1 | Data Propagation Delay, 4PT bypass, ORP bypass | - | 15 | - | 17 | - | 23 | ns |
| tpd2 | A | 2 | Data Propagation Delay | - |  | - |  |  |  | ns |
| fmax | A | 3 | Clock Frequency with Internal Feedback ${ }^{3}$ | 80 | - | 70 |  | 0 | - | MHz |
| fmax (Ext.) | - | 4 | Clock Frequency with External Feedback ( $\frac{1}{1 \text { tau2 }+ \text { coit }}$ ) |  | - |  |  | \% | - | MHz |
| fmax (Tog.) | - | 5 | Clock Frequency, Max Toggle ${ }^{4}$ |  | - |  | - |  | - | MHz |
| tsu1 | - | 6 | GLB Reg. Setup Time before Clock, 4PT bypass |  | - |  |  | * | - | ns |
| tco1 | A | 7 | GLB Reg. Clock to Output Delay, ORP bypass | - |  | - |  | - |  | ns |
| th1 | - | 8 | GLB Reg. Hold Time after Clock, 4 PT bypass |  |  |  |  |  | - | ns |
| tsu2 | - | 9 | GLB Reg. Setup Time before Clock |  |  |  | - |  | - | ns |
| tco2 | - | 10 | GLB Reg. Clock to Output Delay |  |  | - |  | - |  | ns |
| th2 | - | 11 | GLB Reg. Hold Time after Clock |  | - |  | - |  | - | ns |
| tr1 | A | 12 | Ext. Reset Pin to Output Delay |  |  | - |  | - |  | ns |
| trw1 | - | 13 | Ext. Reset Pulse Duration \% |  | - |  | - |  | - | ns |
| tptoeen | B | 14 | Input to Output Enable 20 \% | - |  | - |  | - |  | ns |
| tptoedis | C | 15 | Input to Output Disably\% | - |  | - |  | - |  | ns |
| tgoeen | B | 16 | Global OE Output Eifable ${ }^{\text {a }}$, ${ }^{\text {a }}$ | - |  | - |  | - |  | ns |
| tgoedis | C | 17 |  | - |  | - |  | - |  | ns |
| ttoeen | - | 18 | Test OE Q ¢ | - |  | - |  | - |  | ns |
| ttoedis | - | 19 | Test<E Q Qutput Qjsaby | - |  | - |  | - |  | ns |
| twh | - | 20 |  | - | - |  | - |  | - | ns |
| twl |  |  | Ex Syınc. Clok Pulse Duration, Low | - | - |  | - |  | - | ns |
| tsu3 | $4$ |  | IO Rego \%etup Time before Ext. Sync. Clock (Y3,Y4) | - | - |  | - |  | - | ns |
| th3 | \% | 20 | Mesieg. Hold Time after Ext. Sync. Clock (Y3, Y4) | - | - |  | - |  | - | ns |


2. Refer to Timing Model in this data sheet for further details.
3. Standard 16-E4t cơ解ter using GRP feedback.
4. fmax (Toggle) day be less than $1 /($ twh + twi). This is to allow for a clock duty cycle of other than $50 \%$.
5. Reference Switching Test Conditions Section.
6. Contact factory for additional information. Specifications pLSI and ispLSI 3256

Internal Timing Parameters ${ }^{1}$

## Over Recommended Operating Conditions

| PARAMETER | $\#^{2}$ | DESCRIPTION | -80 ${ }^{4}$ |  | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| Inputs |  |  |  |  |  |  |  |  |  |
| tiobp | 24 | I/O Register Bypass | - |  | - | 2 | 4 | 2.7 | ns |
| tiolat | 25 | I/O Latch Delay | - |  | - | 3 | 7 | 4.1 | ns |
| tiosu | 26 | I/O Register Setup Time before Clock |  | - | 9 | - | 12.2 | - | ns |
| tioh | 27 | I/O Register Hold Time after Clock |  | - |  | 7 | -1.4 |  | ns |
| tioco | 28 | I/O Register Clock to Out Delay | - |  | - | 2 | 3 | 2.7 | ns |
| tior | 29 | I/O Register Reset to Out Delay | - |  |  | 35 | - | 4.7 | ns |
| GRP |  |  |  |  |  |  |  |  |  |
| tgrp | 31 | GRP Delay | $+$ | 1 |  | 4 | - | 5.4 | ns |
| GLB |  |  |  |  |  |  |  |  |  |
| t4ptbp | 37 | 4 Product Term Bypass Path Delay |  |  | - | 6.5 | - | 8.8 | ns |
| t1ptxor | 38 | 1 Product Term/XOR Path Delay | - |  | - | 7 | - | 9.5 | ns |
| t20ptxor | 39 | 20 Product Term/XOR Path Delay | - |  | - | 8.5 | - | 11.5 | ns |
| txoradj | 40 | XOR Adjacent Path Delay ${ }^{3}$, | - |  | - | 10 | - | 13.5 | ns |
| tgbp | 41 | GLB Register Bypass Delay | - |  | - | 1 | - | 1.4 | ns |
| tgsu | 42 | GLB Register Setup Fime before Clogk |  | - | 1.5 | - | 2 | - | ns |
| tgh | 43 | GLB Register Hold jime after Clack |  | - | 9 | - | 12.2 | - | ns |
| tgco | 44 | GLB Register Clook to QutpurDelay | - |  | - | 1.5 | - | 2 | ns |
| tgr | 45 | GLB Register Beset to Qutput Delay | - |  | - | 2.5 | - | 3.4 | ns |
| tptre | 46 | GLB Rroduct Termbeset to Register Delay | - |  | - | 10 | - | 13.5 | ns |
| tptoe | 47 | GLB Product Jerm Output Enable to I/O Cell Delay | - |  | - | 9 | - | 12.2 | ns |
| tptck |  | GLB Prodyet Term Clock Delay |  |  | 3.5 | 7.5 | 4.7 | 10.1 | ns |
| ORP |  |  |  |  |  |  |  |  |  |
| torp |  | ORP Delay | - |  | - | 2 | - | 2.7 | ns |
| torpbp | 50 | ORP Bypass Delay | - |  | - | 0.5 | - | 0.7 | ns |

1. Internal Timing Parameters are not tested and are for reference only.
2. Refer to Timing Model in this data sheet for further details.
3. The XOR Adjacent path can only be used by Lattice Hard Macros.
4. Contact factory for additional information.

Internal Timing Parameters ${ }^{1}$

## Over Recommended Operating Conditions

| PARAMETER | $\#^{2}$ | DESCRIPTION | $-80^{3}$ |  | -70 |  | -50 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| Outputs |  |  |  |  |  |  |  |  |  |
| tob | 51 | Output Buffer Delay | - |  | - | 3 |  | 4.1 | ns |
| toen | 52 | I/O Cell OE to Output Enabled | - |  | - | 5 | - | 6.8 | ns |
| todis | 53 | I/O Cell OE to Output Disabled | - |  |  | 5 |  | 6.8 | ns |
| Clocks |  |  |  |  |  |  |  |  |  |
| tgy0/1/2 | 54 | Clock Delay, Y0 or Y1 or Y2 to Global GLB Clock Line (Ref. clock) |  |  |  | $34$ | 4.1 | 4.1 | ns |
| tioy3/4 | 56 | Clock Delay, Y3 or Y4 to I/O Cell Global Clock Line |  |  | 1 | 1 | 1.4 | 1.4 | ns |
| Global Reset |  |  |  |  |  |  |  |  |  |
| tgr | 57 | Global Reset to GLB and I/O Registers |  |  | - | 7.5 | - | 10.1 | ns |

1. Internal Timing Parameters are not tested and are for reference only
2. Refer to Timing Model in this data sheet for further details.
3. Contact factory for additional information.


pLSI and ispLSI 3256 Timing. Model



Note: Calculations are based on timing specs for the ispLSI 3256-70L.

## Power Consumption

Power Consumption in the pLSI and ispLSI 3256 device depends on two primary factors: the speed at which the device is operating and the number of product terms
used. Figure 3 shows the relationship between power and operating speed.

Figure 3. Typical Device Power Consumption vs fmax


ICC can be estimated for the pLSI and ispLSI 3256-4sing the folloying equation:
ICC $=44+(\#$ of PTs * 0.18$)+(\#$ of nets * Max. freq * 0.013 ) Where:
\# of PTs = Number of Product Terms used in design
\# of nets = Number of Signals used in device
Max. freq $=$ Highest Clock Frequency to the device
The ICC estimate is based on typical conditions ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, room temperature) and an assumption of 2 GLB loads on average exists. These values are forestriates only. Since the value of ICC is sensitive to operating conditions and the program in the device the actual ICC Should be verified.

## In-System Programmability

## Specifications pLSI and ispLSI 3256

The ispLSI devices are the in-system programmable versions of the Lattice high density programmable Large Scale Integration ( pLSI ) devices. By integrating all the Scale Integration (pLSI) devices. By integrating all the
high voltage programming circuitry on-chip, programming can be accomplished by simply shifting data into the device. Once the function is programmed, the nonvolatile $E^{2}$ CMOS cells will not lose the pattern even when the power is turned off. -

All necessary programming is done via five TTL level logic interface signals. These five signals are fed into the on-chip programming circuitry where a state machine controls the programming. The simple signals for interface include isp Enable (ispEN), Serial Data In (SDI), Serial Data Out (SDO), Serial Clock (SCLK) and Mode (MODE) control. Figure 4 illustrates the block diagram of one possible scheme of the programming interface for the ispLSI devices. For details on the qperation of the internal state machine and programming of the device please refer to the in-system progfammingsection in this Data Book.

Figure 4. ISP Programming Interface

## ISP Programming Voltage／Timing Specifications

| SYMBOL | PARAMETER | CONDITION | MIN． | TYP． | MAX． | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VCCP | Programming Voltage |  | 4.75 | 5 | 5.25 | V |
| ICCP | Programming Supply Current |  | － | 50 | 100 | mA |
| VIHP | Input Voltage High | $\overline{\text { ispEN }}=$ Low | 2.0 | － | VCCP | V |
| VILP | Input Voltage Low |  | 0 | － | 0.8 | V |
| IIP | Input Current |  | － | 100 | 200 | $\mu \mathrm{A}$ |
| VoHP | Output Voltage High | $\mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ | 2.4 | 72 | $\mathrm{V}_{\text {ccp }}$ | V |
| VOLP | Output Voltage Low | $\mathrm{l}_{\mathrm{OL}}=5 \mathrm{~mA}$ | 0 |  | 0.5 | V |
| tr，tf | Input Rise and Fall |  | 4 | ＋ | 2\％ | $\mu \mathrm{s}$ |
| tispen | ispEN to Output 3－State Enabled |  | ， | 2 | 10 | $\mu \mathrm{s}$ |
| tispdis | ispEN to Output 3－State Disabled |  | － | \％ 2 | 10 | $\mu \mathrm{s}$ |
| tsu | Setup Time |  | 0． | 0.5 | － | $\mu \mathrm{s}$ |
| tco | Clock to Output |  | ${ }^{\text {\％}} 1$ | 0.5 | － | $\mu \mathrm{s}$ |
| th | Hold Time | ／2\％ | 0.1 | 0.5 | － | $\mu \mathrm{s}$ |
| tclkh，tclkl | Clock Pulse Width，High and Low | 金安 | 0.5 | 1 | － | $\mu \mathrm{s}$ |
| tpw | Verify Pulse Width | 级 | 20 | 30 | － | $\mu \mathrm{s}$ |
| tpwp | Programming Pulse Width |  | 80 | － | 160 | ms |
| tbew | Bulk Erase Pulse Width |  | 200 | － | － | ms |
| trst | Reset Time From Valid $\mathrm{V}_{\text {cch }}$ P | $\stackrel{1}{4}$ | 45 | － | － | $\mu \mathrm{s}$ |

1．ISP Programming is guaranteed for $T_{A}=9^{\circ}$ दito $70^{\circ} \mathrm{C}$ Q ${ }^{\circ}$ pration only．

Figure 5. Timing Waveform for ISP Operation


Figure 6. Program, Verify \& Buk Erase Waveform


Figure 7. ispLSI 3256 Shift Register Layout


0182A/3256
Note: $\quad$ A logic "1" in the address shift register enables the row for programming or verification. A logic " 0 " disables it.

## Boundary Scan

Lattice offers support for the IEEE 1149.1 Boundary Scan specification on the 3000 Family of devices.

The user interfaces to the boundary scan circuitry through the Test Access Port (TAP). The TAP consists of a
control state machine, instruction decoder and instructhe Test Access Port (TAP). The TAP consists of a
control state machine, instruction decoder and instruction register.

## Specifications pLSI and ispLSI 3256

The TAP is controlled using the test control lines: Test Data IN (TDI), Test Data Out (TDO), Test Mode Select (TMS), Test Reset (TRST) and Test Clock (TCK).

The timing specifications for Boundary Scan are listed below. The waveforms are shown in figure 9.

Boundary Scan Timing Specifications

| SYMBOL | PARAMETER | CONDITION | MIN. TY |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VCC | Supply Voltage |  | 475 |  | V |
| trst | Reset Time from Valid $\mathrm{V}_{\mathrm{cc}}$ |  | 45 |  | $\mu \mathrm{s}$ |
| tsu | Setup Time |  | 20.5 | - | $\mu \mathrm{s}$ |
| th | Hold Time |  | 0.5 | - | $\mu \mathrm{s}$ |
| tco | Clock to Output | $2$ | 0. 1 | - | $\mu \mathrm{s}$ |



Pin Description


[^14]
## Pin Description



[^15]
## Pin Configuration

pLSI and ispLSI 3256 167-pin CPGA Pinout Diagram


* ispLSI 3256 Only

0123Bisp

## Specifications pLSI and ispLSI 3256

## Pin Configuration

## pLSI and ispLSI 3256 160-Pin MQUAD Pinout Diagram


*ispLSI 3256 Only

## Specifications pLSI and ispLSI 3256

## Part Number Description



Ordering Information
COMMERCIAL

| Family | fmax (MHz) | tpg $n$ ns | Ordering Number | Package |
| :---: | :---: | :---: | :---: | :---: |
|  | $80$ | 15 | OLSI 3256-80LM160 | 160-Pin MQUAD |
|  | 80 | 15 | pLSI 3256-80LG167 | 167-Pin CPGA |
|  | 70 | 17 | pLSI 3256-70LM160 | 160-Pin MQUAD |
| , |  | 17 | pLSI 3256-70LG167 | 167-Pin CPGA |
| ) | 50 | 23 | pLSI 3256-50LM160 | 160-Pin MQUAD |
|  | 50 | 23 | pLSI 3256-50LG160 | 167-Pin CPGA |
| ispLSI | 80 | 15 | ispLSI 3256-80LM160 | 160-Pin MQUAD |
|  | 80 | 15 | ispLSI 3256-80LG167 | 167-Pin CPGA |
|  | 70 | 17 | ispLSI 3256-70LM160 | 160-Pin MQUAD |
|  | 70 | 17 | ispLSI 3256-70LG167 | 167-Pin CPGA |
|  | 50 | 23 | ispLSI 3256-50LM160 | 160-Pin MQUAD |
|  | 50 | 23 | ispLSI 3256-50LG167 | 167-Pin CPGA |

Table 2-0041A-08isp/3256
Section 1: Introduction
Section 2: High-Density Programmable Logic
Section 3: Low-Density Programmable Logic Introduction to Generic Array Logic ..... 3-1
Commercial / Industrial Product Datasheets GAL16V8 ..... 3-5
GAL16V8Z/ZD ..... 3-29
GAL16VP8 ..... 3-49
GAL18V10 ..... 3-67
GAL20RA10 ..... 3-79
GAL20V8 ..... 3-97
GAL20V8Z/ZD ..... 3-121
GAL20VP8 ..... 3-141
GAL20XV10 ..... 3-159
GAL22V10 ..... 3-173
ispGAL22V10 ..... 3-193
GAL26CV12 ..... 3-213
GAL6001 ..... 3-231
GAL6002 ..... 3-249
Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices
Section 5: Military Program
Section 6: Development Tools
Section 7: Quality and Reliability
Section 8: General Information

# Introduction to Generic Array Logic 

## Overview

Lattice, the inventor of the Generic Array Logic $\left(\mathrm{GAL}^{\circledR}\right)$ family of low density, $\mathrm{E}^{2} \mathrm{CMOS}$ PLDs is the leading supplier of low density CMOS PLDs in the world. Features such as industry leading performance, low power $E^{2}$ CMOS technology, $100 \%$ testability and $100 \%$ programming yields make the GAL family the preferred choice among system designers.

The GAL family contains 14 product architectures with a variety of performance levels specified across commercial, industrial and military (MIL-STD-883) operating ranges to meet the demands of any system logic design.

These GAL products can be segmented into two broad categories:

Base Products - Aimed at providing a superior design alternative to the bipolar PLD, these five architectures replace over $98 \%$ of all bipolar PAL devices. The GAL16V8 and GAL20V8 replace 42 different PAL devices. The GAL22V10, GAL20RA10 and GAL20XV10 round out the Base products. These GAL devices meet, and in most cases beat bipolar PAL performance specifications while consuming significantly lower power and offering higher quality and reliability via Lattice's electrically reprogrammable $\mathrm{E}^{2} \mathrm{CMOS}$ technology.

Extension Products - These products build upon the Base GAL product features to provide enhanced functionality including innovative architectures (GAL18V10, GAL26CV12, GAL6001/6002), 64mA high output drive (GAL16VP8 \& GAL20VP8), "Zero power" operation (GAL16V8Z/ZD \& GAL20V8Z/ZD) and insystem programmability (ispGAL22V10).

## A PRODUCT FOR ANY SYSTEM DESIGN NEED

Lattice GAL products have the performance, architectural features, low power, and high quality to meet the needs of the most demanding system designs.

## The GAL16V8 and GAL20V8

- Performance ranges from the industry's fastest, at 5ns Tpd to popular 25ns versions
- Low power consumption with Low Power versions rated at 75 mA typical and Quarter Power versions at 45 mA typical
- 8 Powerful Output Logic Macrocells (OLMCs) with 8 Product Terms each
- Standard 20-pin (DIP and PLCC) and 24/28-pin (DIP/PLCC) packages


## The GAL22V10

- Available in industry leading $5 \mathrm{~ns} / 200 \mathrm{MHz}$ versions through 25ns versions
- Low power consumption with Low Power versions at 90 mA and Quarter Power versions at 45 mA typical
- 10 OLMCS with variable Product Terms per OLMC ranging from 8 to 16 for increased logic capability
- Standard 24-pin DIP and 28-pin PLCC packages


## The GAL18V10

10 Outputs in a 20 -pin Package

- 20-pin space-saving subset of the popular GAL22V10
- 8-10 Product Terms per OLMC
- Ideal for p.c. board area constrained designs
- Only 10 output, 20 -pin PLD in the market


## The GAL26CV12

Expanded Logic Density in a 28 -pin DIP/PLCC Package

- 28-pin superset of the popular GAL22V10
- World's fastest 28 -pin PLD at 7.5 ns
- 26 inputs, 12 outputs
- Flexible 22V10 OLMC
- Fully utilized 28 -pin PLCC package give added functionality over the 22 V 10 at no space premium!


## Introduction to Generic Array Logic

The GAL20RA10
High Performance Asynchronous Logic

- 10 OLMCs
- 10 Independently programmable clocks
- Each macrocell has an independent product term clock
- Fast 10ns Tpd performance
- Faster and lower power than bipolar PAL
- Available in 24/28-pin DIP/PLCC packages


## The GAL20XV10

Perfect for Fast Counters, Decoders or Comparators

- Utilizes powerful XOR function for efficient implementation of arithmetic functions
- Replaces: PAL20L10, 20X10, 20X8 and 20X4, 12 L10
-10ns/100MHz performance significantly outperforms bipolar PALs
- Perfect for video, multimedia and graphics applications
- Available in 24/28-pin DIP/PLCC packages


## The GAL16VP8 and GAL20VP8

Ideal for Bus Interface or Memory Control Logic

- High output drive versions of the GAL16V8 and GAL20V8
- $\mathrm{IOL}=64 \mathrm{~mA}$ vs standard 24 mA
- Combines GAL architecture with high drive of 74XX244 buffer families
- Fast $15 \mathrm{~ns} / 80 \mathrm{MHz}$ performance
- Available in 20-pin DIP/PLCC and 24/28-pin DIP/PLCC packages


## The GAL16V8Z/ZD and GAL20V8Z/ZD

Zero Stand-by Power

- $50 \mu \mathrm{~A}$ Icc typical stand-by power ( $100 \mu \mathrm{~A}$ MAX)
- 12ns Tpd performance
- Two power-down modes
- Input transition detection (Z)
- Dedicated power-down pin (ZD)
- Available in 20-pin DIP/PLCC/SOIC and 24/28-pin DIP/PLCC packages


## The GAL6001 and GAL6002

The Logic Density of an FPLA Architecture

- Unprecedented logic density in a 24/28-pin DIP/PLCC
- Functional equivalent of 2 GAL22V10s
- 38 Macrocells
- 10 Input Macrocells
- 10 Output Macrocells
- 10 I/O Macrocells
- 8 Buried Logic Macrocells
- $15 \mathrm{~ns} / 75 \mathrm{MHz}$ performance
- Ideal for register-intensive applications


## The ispGAL22V10

Offers In-System Programmability

- Popular 22V10 architecture
- In-system programmable
- Same 28-pin PLCC as GAL22V10
- Fast $7.5 \mathrm{~ns} / 111 \mathrm{MHz}$ performance
- Unprecedented design and manufacturing flexibility


## Introduction to Generic Array Logic

## Commercial/Industrial/Military Grades Available

The Lattice GAL family is available in a wide range of commercial, industrial and military Grade versions. In the military arena, Lattice offers a MIL-STD-883 family as well as a family of Standard Military Drawing (SMD) devices.

The following table summarizes the Lattice GAL product offering.

Table 1. Lattice GAL Product Offering

|  | Speed Options by Grade (Tpd in ns) |  |  |
| :---: | :---: | :---: | :---: |
|  | Commercial | Industrial | 883 / Military |
| GAL16V8 Low Power | 5, 7.5, 10, 15, 25 | 7.5, 10, 15, 25 | 10, 15, 20, 30 |
| GAL16V8 Quarter Power | 15, 25 | 20, 25 | - |
| GAL16V8ZIZD Zero Power | 12, 15 | - | - |
| GAL16VP8 | 15, 25 | - | - |
| GAL18V10 | 15, 20 | - | - |
| GAL20RA10 | 10, 15, 20, 30 | 20 | - |
| GAL20V8 Low Power | 5, 7.5, 10, 15, 25 | 10, 15, 25 | 10, 15, 20 |
| GAL20V8 Quarter Power | 15, 25 | 20, 25 | - |
| GAL20V8Z/ZD Zero Power | 12, 15 | - | - |
| GAL20VP8 | 15, 25 | - | - |
| GAL20XV10 | 10, 15, 20 | - | - |
| GAL22V10 Low Power | $5,6,7.5,10,15,25$ | 10, 15, 20, 25 | 15, 20, 25, 30 |
| GAL22V10 Quarter Power | 15, 25 | - | - |
| ispGAL22V10 | 7.5, 10, 15 | - | - |
| GAL26CV12 | 7.5, 10, 15, 20 | 10, 15, 20 | - |
| GAL6001 | 30 | - | - |
| GAL6002 | 15, 20 | - | - |
| Vcc | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 10 \%$ | $5 \mathrm{~V} \pm 10 \%$ |
| Temperature | 0 to $75^{\circ} \mathrm{C}$ | -40 to $85^{\circ} \mathrm{C}$ | -55 to $125^{\circ} \mathrm{C}$ |
| Packaging | Plastic DIP, PLCC \& SOIC | Plastic DIP \& PLCC | CERDIP \& LCC |

Notes

## FEATURES

- HIGH PERFORMANCE E ${ }^{2}$ CMOS $^{\oplus}{ }^{\text {T }}$ TECHNOLOGY
- 5 ns Maximum Propagation Delay
- Fmax $=166 \mathrm{MHz}$
- 4 ns Maximum from Clock Input to Data Output
- UltraMOS® Advanced CMOS Technology
- 50\% to 75\% REDUCTION IN POWER FROM BIPOLAR
- 75mA Typ Icc on Low Power Device
- 45mA Typ Icc on Quarter Power Device
- ACTIVE PULL-UPS ON ALL PINS
- E² CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
— High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- EIGHT OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- Programmable Output Polarity
- Also Emulates 20-pin PAL* Devices with Full Function/Fuse Map/Parametric Compatibility
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS - 100\% Functional Testability
- APPLICATIONS INCLUDE:


## - DMA Control

- State Machine Control
- High Speed Graphics Processing
- Standard Logic Speed Upgrade
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL16V8C, at 5 ns maximum propagation delay time, combines a high performance CMOS process with Electrically Erasable $\left(E^{2}\right)$ floating gate technology to provide the highest speed performance available in the PLD market. High speed erase times ( $<100 \mathrm{~ms}$ ) allow the devices to be reprogrammed quickly and efficiently.

The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. An important subset of the many architecture configurations possible with the GAL16V8 are the PAL architectures listed in the table of the macrocell description section. GAL16V8 devices are capable of emulating any of these PAL architectures with full function/fuse map/parametric compatibility.
Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all GAL ${ }^{\oplus}$ products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.

FUNCTIONAL BLOCK DIAGRAM


[^16]
## GAL16V8 ORDERING INFORMATION

## Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 5 | 3 | 4 | 115 | GAL16V8C-5LP | 20-Pin Plastic DIP |
|  |  |  | 115 | GAL16V8C-5LJ | 20-Lead PLCC |
| 7.5 | 7 | 5 | 115 | GAL16V8B-7LP | 20-Pin Plastic DIP |
|  |  |  | 115 | GAL16V8B-7LJ | 20-Lead PLCC |
| 10 | 10 | 7 | 115 | GAL16V8B-10LP | 20-Pin Plastic DIP |
|  |  |  | 115 | GAL16V8B-10LJ | 20-Lead PLCC |
| 15 | 12 | 10 | 55 | GAL16V8B-15QP | 20-Pin Plastic DIP |
|  |  |  | 55 | GAL16V8B-15QJ | 20-Lead PLCC |
|  |  |  | 90 | GAL16V8B-15LP | 20-Pin Plastic DIP |
|  |  |  | 90 | GAL16V8B-15LJ | 20-Lead PLCC |
| 25 | 15 | 12 | 55 | GAL16V8B-25QP | 20-Pin Plastic DIP |
|  |  |  | 55 | GAL16V8B-25QJ | 20-Lead PLCC |
|  |  |  | 90 | GAL16V8B-25LP | 20-Pin Plastic DIP |
|  |  |  | 90 | GAL16V8B-25LJ | 20-Lead PLCC |

## Industrial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 7.5 | 7 | 5 | 130 | GAL16V8C-7LPI | 20-Pin Plastic DIP |
|  |  |  | 130 | GAL16V8C-7LJI | 20-Lead PLCC |
| 10 | 10 | 7 | 130 | GAL16V8B-10LPI | 20-Pin Plastic DIP |
|  |  |  | 130 | GAL16V8B-10LJI | 20-Lead PLCC |
| 15 | 12 | 10 | 130 | GAL16V8B-15LPI | 20-Pin Plastic DIP |
|  |  |  | 130 | GAL16V8B-15LJI | 20-Lead PLCC |
| 20 | 13 | 11 | 65 | GAL16V8B-20QPI | 20-Pin Plastic DIP |
|  |  |  | 65 | GAL16V8B-20QJI | 20-Lead PLCC |
| 25 | 15 | 12 | 65 | GAL16V8B-25QPI | 20-Pin Plastic DIP |
|  |  |  | 65 | GAL16V8B-25QJI | 20-Lead PLCC |
|  |  |  | 130 | GAL16V8B-25LPI | 20-Pin Plastic DIP |
|  |  |  | 130 | GAL16V8B-25LJI | 20-Lead PLCC |

## PART NUMBER DESCRIPTION



## OUTPUT LOGIC MACROCELL (OLMC)

The following discussion pertains to configuring the output logic macrocell. It should be noted that actual implementation is accomplished by development software/hardware and is completely transparent to the user.

There are three global OLMC configuration modes possible: simple, complex, and registered. Details of each of these modes are illustrated in the following pages. Two global bits, SYN and ACO, control the mode configuration for all macrocells. The XOR bit of each macrocell controls the polarity of the output in any of the three modes, while the AC1 bit of each of the macrocells controls the input/output configuration. These two global and 16 individual architecture bits define all possible configurations in a GAL16V8. The information given on these architecture bits is only to give a better understanding of the device. Compiler software will transparently set these architecture bits from the pin definitions, so the user should not need to directly manipulate these architecture bits.

The following is a list of the PAL architectures that the GAL16V8 can emulate. It also shows the OLMC mode under which the GAL16V8 emulates the PAL architecture.

| PAL Architectures Emulated by GAL16V8 | $\begin{gathered} \text { GAL16V8 } \\ \text { Global OLMC Mode } \end{gathered}$ |
| :---: | :---: |
| 16R8 | Registered |
| 16R6 | Registered |
| 16R4 | Registered |
| 16RP8 | Registered |
| 16RP6 | Registered |
| 16RP4 | Registered |
| 16L8 | Complex |
| $16 \mathrm{H8}$ | Complex |
| 16P8 | Complex |
| 10 L 8 | Simple |
| 12L6 | Simple |
| 14L4 | Simple |
| 16L2 | Simple |
| 10H8 | Simple |
| $12 \mathrm{H6}$ | Simple |
| 14H4 | Simple |
| 16H2 | Simple |
| 10P8 | Simple |
| 12P6 | Simple |
| 14P4 | Simple |
| 16P2 | Simple |

## COMPILER SUPPORT FOR OLMC

Software compilers support the three different global OLMC modes as different device types. These device types are listed in the table below. Most compilers have the ability to automatically select the device type, generally based on the register usage and output enable (OE) usage. Register usage on the device forces the software to choose the registered mode. All combinatorial outputs with OE controlled by the product term will force the software to choose the complex mode. The software will choose the simple mode only when all outputs are dedicated combinatorial without OE control. The different device types listed in the table can be used to override the automatic device selection by the software. For further details, refer to the compiler software manuals.

In registered mode pin 1 and pin 11 are permanently configured as clock and output enable, respectively. These pins cannot be configured as dedicated inputs in the registered mode.

In complex mode pin 1 and pin 11 become dedicated inputs and use the feedback paths of pin 19 and pin 12 respectively. Because of this feedback path usage, pin 19 and pin 12 do not have the feedback option in this mode.

In simple mode all feedback paths of the output pins are routed via the adjacent pins. In doing so, the two inner most pins ( pins 15 and 16) will not have the feedback option as these pins are always configured as dedicated combinatorial output.

When using compiler software to configure the device, the user must pay special attention to the following restrictions in each mode.

|  | Registered | Complex | Simple | Auto Mode Select |
| :--- | :---: | :---: | :---: | :---: |
| ABEL | P16V8R | P16V8C | P16V8AS | P16V8 |
| CUPL | G16V8MS | G16V8MA | G16V8AS | G16V8 |
| LOG/iC | GAL16V8_R | GAL16V8_C7 | GAL16V8_C8 | GAL16V8 |
| OrCAD-PLD | "Registered"1 | "Complex" | "Simple"1 | GAL16V8A |
| PLDesigner | P16V8R ${ }^{2}$ | P16V8C ${ }^{2}$ | P16V8C $^{2}$ | P16V8A |
| TANGO-PLD | G16V8R | G16V8C | G16V8AS $^{3}$ | G16V8 |

[^17]
## REGISTERED MODE

In the Registered mode, macrocells are configured as dedicated registered outputs or as I/O functions.

Architecture configurations available in this mode are similar to the common 16R8 and 16RP4 devices with various permutations of polarity, I/O and register placement.

All registered macrocells share common clock and output enable control pins. Any macrocell can be configured as registered or I/O. Up to eight registers or up to eight I/O's are possible in this
mode. Dedicated input or output functions can be implemented as subsets of the I/O function.

Registered outputs have eight product terms per output. I/O's have seven product terms per output.

The JEDEC fuse numbers, including the User Electronic Signature (UES) fuses and the Product Term Disable (PTD) fuses, are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

REGISTERED MODE LOGIC DIAGRAM


## COMPLEX MODE

In the Complex mode, macrocells are configured as output only

Architecture configurations available in this mode are similar to the common 16L8 and 16P8 devices with programmable polarity in each macrocell.

Up to six I/O's are possible in this mode. Dedicated inputs or outputs can be implemented as subsets of the I/O function. The two outer most macrocells (pins 12 \& 19) do not have input ca-

## or I/O functions.

## Specifications GAL16V8

pability. Designs requiring eight I/O's can be implemented in the Registered mode.

All macrocells have seven product terms per output. One product term is used for programmable output enable control. Pins 1 and 11 are always available as data inputs into the AND array.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## Specifications GAL16V8

## COMPLEX MODE LOGIC DIAGRAM

DIP \& PLCC Package Pinouts


## SIMPLE MODE

In the Simple mode, macrocells are configured as dedicated inputs
or as dedicated, always active, combinatorial outputs.

Architecture configurations available in this mode are similar to the common 10L8 and 12P6 devices with many permutations of generic output polarity or input choices.

All outputs in the simple mode have a maximum of eight product terms that can control the logic. In addition, each output has programmable polarity.

## Specifications GAL16V8

Pins 1 and 11 are always available as data inputs into the AND array. The center two macrocells (pins $15 \& 16$ ) cannot be used as input or l/O pins, and are only available as dedicated outputs.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

Specifications GAL16V8

## SIMPLE MODE LOGIC DIAGRAM



Specifications GAL16V8C

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $V_{c c}$ $\qquad$ -0.5 to +7 V
Input voltage applied $\qquad$ -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ -65 to $150^{\circ} \mathrm{C}$

## Ambient Temperature with

Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$
1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) ..... 0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ )with Respect to Ground
+4.75 to +5.25 V

## Industrial Devices:

Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) .......................... -40 to $85^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) with Respect to Ground +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathbf{V} \leq \mathbf{V i n} \leq \mathrm{V}_{\text {cc }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | IoL $=$ MAX. Vin $=\mathbf{V}$ IL or $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| $1 \mathrm{OS}^{2}$ | Output Short Circuit Current | VCC $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -150 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f}_{\text {toggle }}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-5$ | - | 75 | 115 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :---: |

## INDUSTRIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-7$ | - | 75 | 130 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | mA 

1) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

|  |  |  | CO | M |  | D |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TEST |  | -5 | 5 | -7 | 7 |  |
| PARAMETER | COND ${ }^{1}$. | DESCRIPTION | MIN. | MAX. | MIN. | MAX. | UNITS |
| tpd | A | Input or I/O to Combinational Output | 1 | 5 | 1 | 7.5 | ns |
| tco | A | Clock to Output Delay | 1 | 4 | 1 | 5 | ns |
| tcf ${ }^{2}$ | - | Clock to Feedback Delay | - | 3 | - | 3 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 3 | - | 7 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, $1 /(t s u+t c o)$ | 142.8 | - | 83.3 | - | MHz |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with Internal Feedback, 1/(tsu + tcf) | 166 | - | 100 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 166 | - | 100 | - | MHz |
| twh | - | Clock Pulse Duration, High | 3 | - | 5 | - | ns |
| twl | - | Clock Pulse Duration, Low | 3 | - | 5 | - | ns |
| ten | B | Input or I/O to Output Enabled | 1 | 6 | 1 | 9 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | 1 | 6 | 1 | 6 | ns |
| tdis | C | Input or I/O to Output Disabled | 1 | 5 | 1 | 9 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | 1 | 5 | 1 | 6 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Descriptions section.
3) Refer to fmax Descriptions section. Characterized initially and after any design or process changes that may affect these parameters.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{c \mathrm{c}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{10}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{10}=2.0 \mathrm{~V}$ |

*Guaranteed but not $100 \%$ tested.

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$ Input voltage aple Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ -65 to $150^{\circ} \mathrm{C}$

## Ambient Temperature with

Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$
1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) $\qquad$ 0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.75 to +5.25 V

## Industrial Devices:

Ambient Temperature ( $T_{A}$ ) -40 to $85^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss -0.5 | - | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.0 | - | $\mathrm{Vcc}+1$ | V |
| IIL' | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{VIN}^{\text {S }} \mathbf{V}$ CC | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | Iol $=$ MAX. $\mathrm{Vin}_{\text {in }}=\mathrm{V}_{\text {IL }}$ or $\mathrm{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 24 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| los ${ }^{2}$ | Output Short Circuit Current | Vcc $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -150 | mA |

## COMMERCIAL

| ICC | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {toggle }}=15 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ | L -7/-10 | - | 75 | 115 | mA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | L-15/-25 | - | 75 | 90 | mA |
|  |  |  | Q-15/-25 | - | 45 | 55 | mA |

## INDUSTRIAL

| ICC | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{HH}}=3.0 \mathrm{~V} \\ & \text { ftoggle }=15 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ | L-10/-15/-25 | - | 75 | 130 | mA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Q -20/-25 | - | 45 | 65 | mA |

1) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

| PARAM. | TEST COND ${ }^{1}$. |  |  | C | M | COM | / IND | COM | /IND | IN | D | COM | /IND |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | DESCRIPTION |  | -7 |  | -10 |  | -15 |  | -20 |  | -25 |  | UNITS |
|  |  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to | 8 outputs switching | 3 | 7.5 | 3 | 10 | 3 | 15 | 3 | 20 | 3 | 25 | ns |
|  |  | Comb. Output | 1 output switching | - | 7 | - | - | - | - | - | - | - | - | ns |
| tco | A | Clock to Output Delay |  | 2 | 5 | 2 | 7 | 2 | 10 | 2 | 11 | 2 | 12 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay |  | - | 3 | - | 6 | - | 8 | - | 9 | - | 10 | ns |
| tsu | - | Setup Time, Input or Fdbk before Clk $\uparrow$ |  | 7 | - | 10 | - | 12 | - | 13 | - | 15 | - | ns |
| th | - | Hold Time, Input or Fdbk after Clk $\uparrow$ |  | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, 1/(tsu + tco) |  | 83.3 | - | 58.8 | - | 45.5 | - | 41.6 | - | 37 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) |  | 100 | - | 62.5 | - | 50 | - | 45.4 | - | 40 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback |  | 100 | - | 62.5 | - | 62.5 | - | 50 | - | 41.6 | - | MHz |
| twh | - | Clock Pulse Duration, High |  | 5 | - | 8 | - | 8 | - | 10 | - | 12 | - | ns |
| twl | - | Clock Pulse Duration, Low |  | 5 | - | 8 | - | 8 | - | 10 | - | 12 | - | ns |
| ten | B | Input or I/O to Output Enabled |  | 3 | 9 | 3 | 10 | - | 15 | - | 20 | - | 25 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled |  | 2 | 6 | 2 | 10 | - | 15 | - | 18 | - | 20 | ns |
| tdis | C | Input or I/O to Output Disabled |  | 2 | 9 | 2 | 10 | - | 15 | - | 20 | - | 25 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled |  | 1.5 | 6 | 1.5 | 10 | - | 15 | - | 18 | - | 20 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Descriptions section.
3) Refer to fmax Descriptions section.

CAPACITANCE ( $\mathrm{T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / \mathrm{O}}=2.0 \mathrm{~V}$ |

[^18]
## Specifications GAL16V8

## SWITCHING WAVEFORMS



Combinatorial Output

INPUT or
I/O FEEDBACK

COMBINATIONAL OUTPUT


Input or I/O to Output Enable/Disable


Clock Width


Registered Output

$\overline{O E}$ to Output Enable/Disable

fmax with Feedback

## fmax DESCRIPTIONS


fmax with External Feedback 1/(tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.

fmax with No Feedback
Note: fmax with no feedback may be less than $1 /(\mathrm{twh}+\mathrm{twl})$. This is to allow for a clock duty cycle of other than $50 \%$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels |  | GND to 3.0V |
| :--- | :---: | :---: |
| Input Rise and <br> Fall Times | GAL16V8B | $2-3 n s 10 \%-90 \%$ |
|  | GAL16V8C | $1.5 \mathrm{~ns} \mathrm{10} \mathrm{\%-90} \mathrm{\%}$ |
| Input Timing Reference Levels | 1.5 V |  |
| Output Timing Reference Levels | 1.5 V |  |
| Output Load |  | See Figure |

3 -state levels are measured 0.5 V from steady-state active level.


* ${ }^{\text {L }}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

GAL16V8C Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathrm{CL}_{\mathrm{L}}$ |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $200 \Omega$ | $200 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $200 \Omega$ | 50 pF |
|  | Active Low | $200 \Omega$ | $200 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $200 \Omega$ | 5 pF |
|  | Active Low | $200 \Omega$ | $200 \Omega$ | 5 pF |

## ELECTRONIC SIGNATURE

An electronic signature is provided in every GAL16V8 device. It contains 64 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature is included in checksum calculations. Changing the electronic signature will alter the checksum.

## SECURITY CELL

A security cell is provided in the GAL16V8 devices to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell.

## LATCH-UP PROTECTION

GAL16V8 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias minimizes the potential of latch-up caused by negative input undershoots. Additionally, outputs are designed with n-channel pull-ups instead of the traditional p-channel pull-ups in order to eliminate latch-up due to output overshoots.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers. Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because, in system operation, certain events occur that may throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

GAL16V8 devices include circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing text vectors perform output register preload automatically.

## INPUT BUFFERS

GAL16V8 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.

The GAL16V8 input and I/O pins have built-in active pull-ups. As a result, unused inputs and I/O's will float to a TTL "high" (logical "1"). Lattice recommends that all unused inputs and tri-stated I/O pins be connected to another active input, VCc, or Ground. Doing this will tend to improve noise immunity and reduce lcc for the device.

## Typical Input Pull-up Characteristic



## POWER-UP RESET



Circuitry within the GAL16V8 provides a reset signal to all registers during power-up. All internal registers will have their $Q$ outputs set low after a specified time (tpr, $1 \mu \mathrm{~s} \mathrm{MAX}$ ). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. Because of the asynchronous nature of system power-up, some
conditions must be met to guarantee a valid power-up reset of the device. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

## INPUT/OUTPUT EQUIVALENT SCHEMATICS



Typ. $\mathrm{Vref}=3.2 \mathrm{~V}$


PIN


Typical Output

## GAL 16V8C-5: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


Specifications GAL16V8

GAL 16V8C-5: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


GAL 16V8B-7/10: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Delta Tpd vs \# of Outputs
Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


Specifications GAL16V8

GAL 16V8B-7/10: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


GAL 16V8B-15/25: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Delta Tpd vs \# of Outputs
Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading



Normalized Icc vs Vcc


Delta Icc vs Vin（1 input）


Vin（V）

Vol vs lol

Voh ve loh


Normalized Icc vs Temp


Input Clamp（VIk）


Voh vs loh


Normalized Icc vs Freq．


Frequency（MHz）

GAL16V8Z GAL16V8ZD
Zero Power E²CMOS PLD

## FEATURES

- ZERO POWER E²CMOS TECHNOLOGY


## - 100 1 A Standby Current

- Input Transition Detection on GAL16V8Z
- Dedicated Power-down Pin on GAL16V8ZD
- Input and Output Latching During Power Down
- HIGH PERFORMANCE E²CMOS TECHNOLOGY
- 12 ns Maximum Propagation Delay
- Fmax $=83.3 \mathrm{MHz}$
- 8 ns Maximum from Clock Input to Data Output
- TTL Compatible 16 mA Output Drive
- UltraMOS ${ }^{\oplus}$ Advanced CMOS Technology
- E ${ }^{2}$ CELL TECHNOLOGY


## - Reconfigurable Logic

- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
— High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- EIGHT OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- Programmable Output Polarity
- Architecturally Similar to Standard GAL16V8
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS - 100\% Functional Testability
- APPLICATIONS INCLUDE:


## - Battery Powered Systems

- DMA Control
- State Machine Control
- High Speed Graphics Processing
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL16V8Z and GAL16V8ZD, at $100 \mu$ A standby current and 12ns propagation delay provides the highest speed and lowest power combination PLD available in the market. The GAL16V8Z/ ZD is manufactured using Lattice's advanced zero power $\mathrm{E}^{2} \mathrm{CMOS}$ process, which combines CMOS with Electrically Erasable ( $E^{2}$ ) floating gate technology.

The GAL16V8Z uses Input Transition Detection (ITD) to put the device in standby mode and is capable of emulating the full functionality of the standard GAL16V8. The GAL16V8ZD utilizes a dedicated power-down pin (DPP) to put the device in standby mode. It has 15 inputs available to the AND array.
Unique test circuitry and reprogrammable cells allow complete AC, DC, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all GAL products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.

## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION

## DIP/SOIC

## Chip Carrier



[^19]
## GAL16V8Z/ZD ORDERING INFORMATION

GAL16V8Z: Commercial Grade Specifications


GAL16V8ZD: Commercial Grade Specifications

| Cpd (ns) | Tsu (ns) | Two (ns) | Icc (mA) | Usb ( $\mu \mathbf{A})$ | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :--- | :--- |
| 12 | 10 | 8 | 55 | 100 | GAL16V8ZD-12QP | 20-Pin Plastic DIP |
|  |  |  | 55 | 100 | GAL16V8ZD-12QJ | $20-$ Lead PLCC |
| 15 | 15 | 10 | 55 | 100 | GAL16V8ZD-15QP | 20 -Pin Plastic DIP |
|  |  |  | 55 | 100 | GAL16V8ZD-15QJ | 20-Lead PLCC |

## PART NUMBER DESCRIPTION

Device Name


GAL16V8Z (Zero Power ITD) GAL16V8ZD (Zero Power DPP)

## Speed (ns)

Active Power
Q = Quarter Power

## Specifications GAL16V8Z GAL16V8ZD



## Specifications GAL16V8Z <br> GAL16V8ZD

## OUTPUT LOGIC MACROCELL (OLMC)

The following discussion pertains to configuring the output logic macrocell. It should be noted that actual implementation is accomplished by development software/hardware and is completely transparent to the user.

There are three global OLMC configuration modes possible: simple, complex, and registered. Details of each of these modes is illustrated in the following pages. Two global bits, SYN and ACO, control the mode configuration for all macrocells. The

XOR bit of each macrocell controls the polarity of the output in any of the three modes, while the AC1 bit of each of the macrocells controls the input/output configuration. These two global and 16 individual architecture bits define all possible configurations in a GAL16V8Z/ZD. The information given on these architecture bits is only to give a better understanding of the device. Compiler software will transparently set these architecture bits from the pin definitions, so the user should not need to directly manipulate these architecture bits.

## COMPILER SUPPORT FOR OLMC

Software compilers support the three different global OLMC modes as different device types. Most compilers also have the ability to automatically select the device type, generally based on the register usage and output enable (OE) usage. Register usage on the device forces the software to choose the registered mode. All combinatorial outputs with OE controlled by the product term will force the software to choose the complex mode. The software will choose the simple mode only when all outputs are dedicated combinatorial without OE control. For further details, refer to the compiler software manuals.

When using compiler software to configure the device, the user must pay special attention to the following restrictions in each mode.

In registered mode pin 1 and pin 11 are permanently configured as clock and output enable, respectively. These pins cannot be configured as dedicated inputs in the registered mode.

In complex mode pin 1 and pin 11 become dedicated inputs and use the feedback paths of pin 19 and pin 12 respectively. Because of this feedback path usage, pin 19 and pin 12 do not have the feedback option in this mode.

In simple mode all feedback paths of the output pins are routed via the adjacent pins. In doing so, the two inner most pins ( pins 15 and 16) will not have the feedback option as these pins are always configured as dedicated combinatorial output.

When using the standard GAL16V8 JEDEC fuse pattern generated by the logic compilers for the GAL16V8ZD, special attention must be given to pin 4 (DPP) to make sure that it is not used as one of the functional inputs.

## REGISTERED MODE

In the Registered mode, macrocells are configured as dedicated registered outputs or as I/O functions.

Architecture configurations available in this mode are similar to the common 16R8 and 16RP4 devices with various permutations of polarity, I/O and register placement.

All registered macrocells share common clock and output enable control pins. Any macrocell can be configured as registered or I/O. Up to eight registers or up to eight I/O's are possible in this mode. Dedicated input or output functions can be implemented as subsets of the l/O function.

Registered outputs have eight product terms per output. I/O's have seven product terms per output.

Pin 4 is used as dedicated power-down pin on GAL16V8ZD. It cannot be used as functional input.

The JEDEC fuse numbers, including the User Electronic Signature (UES) fuses and the Product Term Disable (PTD) fuses, are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

Specifications GAL16V8Z GAL16V8ZD

REGISTERED MODE LOGIC DIAGRAM



## Specifications GAL16V8Z GAL16V8ZD

## COMPLEX MODE

In the Complex mode, macrocells are configured as output only or I/O functions.

Architecture configurations available in this mode are similar to the common 16L8 and 16P8 devices with programmable polarity in each macrocell.

Up to six I/O's are possible in this mode. Dedicated inputs or outputs can be implemented as subsets of the I/O function. The two outer most macrocells (pins 12 \& 19) do not have input capability. Designs requiring eight I/O's can be implemented in the Registered mode.

All macrocells have seven product terms per output. One product term is used for programmable output enable control. Pins 1 and 11 are always available as data inputs into the AND array.

Pin 4 is used as dedicated power-down pin on GAL16V8ZD. It cannot be used as functional input.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

COMPLEX MODE LOGIC DIAGRAM


## Specifications GAL16V8Z <br> GAL16V8ZD

## SIMPLE MODE

In the Simple mode, macrocells are configured as dedicated inputs or as dedicated, always active, combinatorial outputs.

Architecture configurations available in this mode are similar to the common 10L8 and 12P6 devices with many permutations of generic output polarity or input choices.

All outputs in the simple mode have a maximum of eight porduct terms that can control the logic. In addition, each output has programmable polarity.

Pins 1 and 11 are always available as data inputs into the AND array. The center two macrocells (pins $15 \& 16$ ) cannot be used in the input configuration.

Pin 4 is used as dedicated power-down pin on GAL16V8ZD. It cannot be used as functional input.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## SIMPLE MODE LOGIC DIAGRAM



## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$......................................... -.5 to +7 V
Input voltage applied
-2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature -65 to $150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature $\left(T_{A}\right)$.............................. 0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{CC}}$ )
with Respect to Ground $\qquad$

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{2}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss -0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | $\mathrm{Vcc}+1$ | V |
| IIL | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{IL}}$ (MAX.) | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {in }} \leq \mathrm{V}_{\text {cc }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | Iol $=$ MAX. $\mathrm{Vin}_{\text {in }}=\mathrm{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}^{\text {a }}$ MAX. $\quad \mathbf{V i n}=\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\text {IH }}$ | 2.4 | - | - | V |
|  |  | $\mathrm{IOH}^{\text {a }}=-100 \mu \mathrm{~A} \quad \mathrm{Vin}=\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\text {IH }}$ | Vcc-1 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| los ${ }^{1}$ | Output Short Circuit Current | $\mathrm{Vcc}=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -150 | mA |

## COMMERCIAL

| ISB | Stand-by Power <br> Supply Current | $\mathbf{V I L}_{\mathrm{IL}}=$ GND VIH = Vcc Outputs Open | Z-12/-15 <br> ZD-12/-15 | - | 50 | 100 | $\mu \mathrm{~A}$ |
| :---: | :--- | :--- | :--- | :--- | :---: | :---: | :---: |
| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{HH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | Z-12/-15 <br> ZD-12/-15 | - | - | 55 | mA |

1) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
2) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

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

| SYMBOL | PARAMETER | MAXIMUM* $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 \mathrm{O}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / \mathrm{O}}=2.0 \mathrm{~V}$ |

*Guaranteed but not $100 \%$ tested.

AC SWITCHING CHARACTERISTICS
Over Recommended Operating Conditions

|  |  |  | CO | M | CO | M |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | EST |  |  | 12 | -1 | 15 |  |
| PARAMETER | COND ${ }^{1}$. |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinational Output | 3 | 12 | 3 | 15 | ns |
| tco | A | Clock to Output Delay | 2 | 8 | 2 | 10 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay | - | 6 | - | 7 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 10 | - | 15 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, 1/(tsu + tco) | 55 | - | 40 | - | MHz |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with Internal Feedback, $1 /$ (tsu + tcf) | 62.5 | - | 45.5 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 83.3 | - | 62.5 | - | MHz |
| twh | - | Clock Pulse Duration, High | 6 | - | 8 | - | ns |
| twl | - | Clock Pulse Duration, Low | 6 | - | 8 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 12 | - | 15 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 12 | - | 15 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 15 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output DIsabled | - | 12 | - | 15 | ns |
| tas | - | Last Active Input to Standby | 60 | 140 | 50 | 150 | ns |
| tsa ${ }^{4}$ | - | Standby to Active Output | 6 | 13 | 5 | 15 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Specification section.
3) Refer to fmax Specification section.
4) Add tsa to tpd, tsu, ten and tdis when the device is coming out of standby state.

## STANDBY POWER TIMING WAVEFORMS



## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

|  |  |  | CO | M |  | OM |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ST | D |  | 12 |  | 15 |  |
| PARAMETER | COND ${ }^{1}$. | DESCRIPT | MIN. | MAX. | MIN. | MAX. | UNITS |
| tpd | A | Input or I/O to Combinational Output | 3 | 12 | 3 | 15 | ns |
| tco | A | Clock to Output Delay | 2 | 8 | 2 | 10 | ns |
| tcf ${ }^{2}$ | - | Clock to Feedback Delay | - | 6 | - | 7 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 10 | - | 15 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco) | 55 | - | 40 | - | MHz |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 62.5 | - | 45.5 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 83.3 | - | 62.5 | - | MHz |
| twh | - | Clock Pulse Duration, High | 6 | - | 8 | - | ns |
| twl | - | Clock Pulse Duration, Low | 6 | - | 8 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 12 | - | 15 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 12 | - | 15 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 15 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | - | 12 | - | 15 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Specification section.
3) Refer to fmax Specification section.

## Specifications GAL16V8ZD

## DEDICATED POWER-DOWN PIN SPECIFICATIONS

## Over Recommended Operating Conditions

| PARAMETER | TEST COND' | DESCRIPTION | $\begin{array}{r} \hline \text { COM } \\ \hline-12 \\ \hline \end{array}$ |  | $\begin{array}{c\|} \hline \text { COM } \\ \hline-15 \\ \hline \end{array}$ |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| twhd | - | DPP Pulse Duration High | 12 | - | 15 | - | ns |
| twid | - | DPP Pulse Duration Low | 25 | - | 30 | - | ns |
| ACTIVE TO STANDBY |  |  |  |  |  |  |  |
| tivdh | - | Valid Input before DPP High | 5 | - | 8 | - | ns |
| tgvdh | - | Valid OE before DPP High | 0 | - | 0 | - | ns |
| tcvdh | - | Valid Clock Before DPP High | 0 | - | 0 | - | ns |
| tdhix | - | Input Don't Care after DPP High | - | 2 | - | 5 | ns |
| tdhgx | - | $\overline{\mathrm{OE}}$ Don't Care after DPP High | - | 6 | - | 9 | ns |
| tdhcx | - | Clock Don't Care after DPP High | - | 8 | - | 11 | ns |
| STANDBY TO ACTIVE |  |  |  |  |  |  |  |
| tdliv | - | DPP Low to Valid Input | 12 | - | 15 | - | ns |
| tdlgv | - | DPP Low to Valid $\overline{\mathrm{OE}}$ | 16 | - | 20 | - | ns |
| tdicv | - | DPP Low to Valid Clock | 18 | - | 20 | - | ns |
| tdiov | A | DPP Low to Valid Output | 5 | 24 | 5 | 30 | ns |

1) Refer to Switching Test Conditions section.

## DEDICATED POWER-DOWN PIN (DPP) TIMING WAVEFORMS



SWITCHING WAVEFORMS


Combinatorial Output

INPUT or I/O FEEDBACK

COMBINATIONAL OUTPUT


Input or I/O to Output Enable/Disable


Clock Width


## Registered Output



OE to Output Enable/Disable

fmax with Feedback

## Specifications GAL16V8Z GAL16V8ZD

fmax SPECIFICATIONS


Note: fmax with external feedback is calculated from measured tsu and tco.


## fmax with No Feedback

Note: fmax with no feedback may be less than $1 /(\mathrm{twh}+\mathrm{twl})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback 1/(tsu+tcf)
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback (tcf = $1 /$ fmax - tsu). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to tcf + tpd.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | $3 \mathrm{~ns} \mathrm{10} \mathrm{\%-90} \mathrm{\%}$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3-state levels are measured 0.5 V from steady-state active level.

FROM OUTPUT (O/Q) UNDER TEST


* ${ }^{\text {C }}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

Specifications GAL16V8Z GAL16V8ZD

## ELECTRONIC SIGNATURE

An electronic signature word is provided in every GAL16V8Z/ZD device. It contains 64 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature is included in checksum calculations. Changing the electronic signature will alter checksum.

## SECURITY CELL

A security cell is provided in the GAL16V8Z/ZD devices to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. The electronic signature data is always available to the user, regardless of the state of this security cell.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers (see the Development Tools Section of the Data Book). Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle

## INPUT TRANSITION DETECTION (ITD)

The GAL16V8Z relies on its internal input detection circuitry to put the device in power down mode. If there is no input transition for the specified period of time, the device will go into the power down state. Any valid input transition will put the device back into the active state. The first rising clock transition from power-down state only acts as a wake up signal to the device and will not clock the data input through to the output (refer to standby power timing waveform for more detail). Any input pulse widths greater than 5 ns at input voltage level of 1.5 V will be detected as input transition. The device will not detect any input pulse widths less than 1 ns measured at input voltage level of 1.5 V as an input transition.

## DEDICATED POWER-DOWN PIN (DPP)

The GAL16V8ZD uses pin 4 as the dedicated power-down signal to put the device in to the power-down state. DPP is an active high signal where a logic high driven on this signal puts the device into power-down state. Input pin 4 cannot be used as a functional input on this device.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because, in system operation, certain events occur that may throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

The GAL16V8Z/ZD devices includes circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing test vectors perform output register preload automatically.

## INPUT BUFFERS

GAL16V8Z/ZD devices are designed with TTL level compatible input buffers. These buffers, with their characteristically high impedance, load driving logic much less than traditional bipolar devices. This allows for a greater fan out from the driving logic.

GAL16V8Z/ZD input buffers have latches within the buffers. As a result, when the device goes into standby mode the inputs will be latched to its values prior to standby. In order to overcome the input latches, they will have to be driven by an external source. Lattice recommends that all unused inputs and tri-stated I/O pins for both devices be connected to another active input, $\mathrm{V}_{\mathrm{cc}}$, or GND. Doing this will tend to improve noise immunity and reduce $I_{C C}$ for the device.


## Specifications GAL16V8Z GAL16V8ZD

## POWER-UP RESET



Circuitry within the GAL16V8Z/ZD provides a reset signal to all registers during power-up. All internal registers will have their Q outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown below. Because of the
asynchronous nature of system power-up, some conditions must be met to guarantee a valid power-up reset of the GAL16V8Z/ZD. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

## INPUT/OUTPUT EQUIVALENT SCHEMATICS



TYPICAL AC AND DC CHARACTERISTICS


Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


TYPICAL AC AND DC CHARACTERISTICS


GAL16VP8

## FEATURES

- HIGH DRIVE E ${ }^{2}$ CMOS $^{\otimes}{ }^{\text {GAL }}{ }^{\otimes}$ DEVICE
- TTL Compatible 64 mA Output Drive
- 15 ns Maximum Propagation Delay
- Fmax $=80 \mathrm{MHz}$
- 10 ns Maximum from Clock Input to Data Output
- UltraMOS ${ }^{*}$ Advanced CMOS Technology
- ENHANCED INPUT AND OUTPUT FEATURES
- Schmitt Trigger Inputs
- Programmable Open-Drain or Totem-Pole Outputs
- Active Pull-Ups on All Inputs and I/O pins
- E ${ }^{2}$ CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed $100 \%$ Yields
- High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- EIGHT OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- Programmable Output Polarity
- Architecturally Compatible with Standard GAL16V8
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS - 100\% Functional Testability
- APPLICATIONS INCLUDE:
— Ideal for Bus Control \& Bus Arbitration Logic
- Bus Address Decode Logic
- Memory Address, Data and Control Circuits
- DMA Control
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL16VP8, with 64 mA drive capability and 15 ns maximum propagation delay time is ideal for Bus and Memory control applications. The GAL16VP8 is manufactured using Lattice's advanced $\mathrm{E}^{2} \mathrm{CMOS}$ process which combines CMOS with Electrically Erasable ( $E^{2}$ ) floating gate technology. High speed erase times ( $<100 \mathrm{~ms}$ ) allow the devices to be reprogrammed quickly and efficiently.

System bus and memory interfaces require control logic before driving the bus or memory interface signals. The GAL16VP8 combines the familiar GAL16V8 architecture with bus drivers as its outputs. The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The 64 mA output drive eliminates the need for additional devices to provide bus driving capability.
Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all GAL products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.

FUNCTIONAL BLOCK DIAGRAM


PIN CONFIGURATION


[^20]


GAL16VP8 ORDERING INFORMATION
Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 15 | 8 | 10 | 115 | GAL16VP8B-15LP | 20-Pin Plastic DIP |
|  |  |  | 115 | GAL16VP8B-15LJ | 20-Lead PLCC |
| 25 | 10 | 15 | 115 | GAL16VP8B-25LP | 20-Pin Plastic DIP |
|  |  |  | 115 | GAL16VP8B-25LJ | 20-Lead PLCC |

## PART NUMBER DESCRIPTION



## OUTPUT LOGIC MACROCELL (OLMC)

The following discussion pertains to configuring the output logic macrocell. It should be noted that actual implementation is accomplished by development software/hardware and is completely transparent to the user.

There are three global OLMC configuration modes possible: simple, complex, and registered. Details of each of these modes is illustrated in the following pages. Two global bits, SYN and ACO, control the mode configuration for all macrocells. The XOR bit of each macrocell controls the polarity of the output in
any of the three modes, while the AC1 and AC2 bit of each of the macrocells controls the input/output and totem-pole/open-drain configuration. These two global and 24 individual architecture bits define all possible configurations in a GAL16VP8. The information given on these architecture bits is only to give a better understanding of the device. Compiler software will transparently set these architecture bits from the pin definitions, so the user should not need to directly manipulate these architecture bits.

## COMPILER SUPPORT FOR OLMC

Software compilers support the three different global OLMC modes as different device types. Most compilers also have the ability to automatically select the device type, generally based on the register usage and output enable (OE) usage. Register usage on the device forces the software to choose the registered mode. All combinatorial outputs with OE controlled by the product term will force the software to choose the complex mode. The software will choose the simple mode only when all outputs are dedicated combinatorial without OE control. For further details, refer to the compiler software manuals.

When using compiler software to configure the device, the user must pay special attention to the following restrictions in each mode.
In registered mode pin 1 and pin 10 are permanently configured as clock and output enable, respectively. These pins cannot be configured as dedicated inputs in the registered mode.

In complex mode pin 1 and pin 10 become dedicated inputs and use the feedback paths of pin19 and pin 11 respectively. Because of this feedback path usage, pin19 and pin 11 do not have the feedback option in this mode.

In simple mode all feedback paths of the output pins are routed via the adjacent pins. In doing so, the two inner most pins ( pins 14 and 16) will not have the feedback option as these pins are always configured as dedicated combinatorial output.

In addition to the architecture configurations, the logic compiler software also supports configuration of either totem-pole or opendrain outputs. The actual architecture bit configuration, again, is transparent to the user with the default configuration being the standard totem-pole output.

## REGISTERED MODE

In the Registered mode, macrocells are configured as dedicated registered outputs or as I/O functions.

All registered macrocells share common clock and output enable control pins. Any macrocell can be configured as registered or I/O. Up to eight registers or up to eight I/O's are possible in this mode. Dedicated input or output functions can be implemented as subsets of the I/O function.

Registered outputs have eight product terms per output. I/O's have seven product terms per output.

The JEDEC fuse numbers, including the User Electronic Signature (UES) fuses and the Product Term Disable (PTD) fuses, are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

Specifications GAL16VP8

## REGISTERED MODE LOGIC DIAGRAM



## COMPLEX MODE <br> COMPLEXINODE

In the Complex mode, macrocells are configured as output only
or I/O functions.

Up to six I/O's are possible in this mode. Dedicated inputs or outputs can be implemented as subsets of the I/O function. The
two outer most macrocells (pins $11 \& 19$ ) do not have input caoutputs can be implemented as subsets of the l/O function. The
two outer most macrocells (pins $11 \& 19$ ) do not have input capability. Designs requiring eight I/O's can be implemented in the Registered mode.

## Specifications GAL16VP8

All macrocells have seven product terms per output. One product term is used for programmable output enable control. Pins 1 and 10 are always available as data inputs into the AND array.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram on the following page.

|  | Combinatorial I/O Configuration for Complex Mode |
| :--- | :--- | :--- |

Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

COMPLEX MODE LOGIC DIAGRAM
DIP and PLCC Package Pinouts


## SIMPLE MODE

In the Simple mode, macrocells are configured as dedicated inputs
or as dedicated, always active, combinatorial outputs.

All outputs in the simple mode have a maximum of eight product terms that can control the logic. In addition, each output has programmable polarity.

## Specifications GAL16VP8

Pins 1 and 10 are always available as data inputs into the AND array. The center two macrocells (pins 14 \& 16) cannot be used in the input configuration.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

SIMPLE MODE LOGIC DIAGRAM
DIP and PLCC Package Pinouts


64-USER ELECTRONIC SIGNATURE FUSES

|  | 64- | ER EL | URE FUSES | $\begin{aligned} & \text { SYN-2192 } \\ & \text { AC0-2193 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
|  | 2056, 2055, ... |  | .... 2118, 2119 |  |
|  | Byte7 | Byte6 .... | .... Byte1 Byte0 |  |
| MSB |  | LSB |  |  |

## Specifications GAL16VP8

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$.......................................- .5 to +7 V
Input voltage applied ..........................-2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cC}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$
Ambient Temperature with
Power Applied $\qquad$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) $\qquad$ 0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.75 to +5.25 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{4}$ | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| $\mathrm{V}_{1}{ }^{1}$ | Input Clamp Voltage | Vcc $=$ Min. $\quad$ lin $=-32 m A$ | - |  | -1.2 | V |
| IIL. ${ }^{\text {2 }}$ | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{ViN} \leq \mathrm{V}_{\text {cc }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage |  | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}_{\text {O }}$ MAX. Vin $=\mathrm{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 64 | mA |
| IOH | High Level Output Current |  | - | - | -32 | mA |
| $\mathrm{lOS}^{3}$ | Output Short Circuit Current | V cc $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -60 | - | -400 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{HH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-15 /-25$ | - | 90 | 115 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | mA 

[^21]AC SWITCHING CHARACTERISTICS
Over Recommended Operating Conditions

|  |  |  |  | M |  | OM |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TEST |  |  | 5 |  | 5 |  |
| PARAMETER | COND ${ }^{1}$. | DESCRIPTION | MIN. | MAX. | MIN. | MAX. | ITS |
| tpd | A | Input or I/O to Combinational Output | 3 | 15 | 3 | 25 | ns |
| tco | A | Clock to Output Delay | 2 | 10 | 2 | 15 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay | - | 4.5 | - | 10 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 8 | - | 10 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco $)$ | 55.5 | - | 40 | - | MHz |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 80 | - | 50 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 80 | - | 50 | - | MHz |
| twh | - | Clock Pulse Duration, High | 6 | - | 10 | - | ns |
| $t_{w l}$ | - | Clock Pulse Duration, Low | 6 | - | 10 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 15 | - | 20 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 12 | - | 15 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 20 | ns |
|  | C | OE to Output Disabled | - | 12 | - | 15 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Specification section.
3) Refer to fmax Specification section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{10 \mathrm{O}}$ | I/O Capacitance | 15 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / 0}=2.0 \mathrm{~V}$ |

[^22]SWITCHING WAVEFORMS


Combinatorial Output

INPUT or I/O FEEDBACK

OUTPUT


Input or I/O to Output Enable/Disable

CLK


Clock Width


Registered Output

$\overline{O E}$ to Output Enable/Disable

fmax with Feedback

fmax DESCRIPTIONS

## Specifications GAL16VP8



Note: $f_{m a x}$ with external feedback is calculated from measured $\mathbf{t s u}$ and $\mathbf{t c o}$.


## fmax with No Feedback

## fmax with External Feedback 1/(tsu+tco)

Note: fmax with no feedback may be less than $1 /(\mathbf{t w h}+\mathbf{t w l})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback $\mathbf{1 / ( t s u + t c f )}$
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback ( $\mathbf{t c f}=1 / \mathbf{f m a x}-\mathbf{t s u}$ ). The value of $\mathbf{t c f}$ is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to $\mathbf{t c f}+\mathbf{t p d}$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | $3 \mathrm{~ns} \mathrm{10} \mathrm{\%-90} \mathrm{\%}$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3 -state levels are measured 0.5 V from steady-state active level.

FROM OUTPUT (O/Q) UNDER TEST

${ }^{*} \mathrm{C}_{\mathrm{L}}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

ELECTRONIC SIGNATURE
An electronic signature word is provided in every GAL16VP8 device. It contains 64 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature is included in checksum calculations. Changing the electronic signature will alter the checksum.

## SECURITY CELL

The security cell is provided on all GAL16VP8 devices to prevent unauthorized copying of the array patterns. Once programmed, the circuitry enabling array is disabled, preventing further programming or verification of the array. The cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. Signature data is always available to the user.

## LATCH-UP PROTECTION

GAL16VP8 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with $n$-channel pullups instead of the traditional p-channel pull-ups to eliminate any possibility of SCR induced latching.

## BULK ERASE MODE

During a programming cycle, a clear function performs a bulk erase of the array and the architecture word. In addition, the electronic signature word and the security cell are erased. This mode resets a previously configured device back to its original state, which is all JEDEC ones.

## SCHMITT TRIGGER INPUTS

One of the enhancements of the GAL 16VP8 for bus interface logic implementation is input hysteresis. The threshold of the positive going edge is 1.5 V , while the threshold of the negative going edge is 1.3 V . This provides a typical hysteresis of 200 mV between positive and negative transitions of the inputs.

## HIGH DRIVE OUTPUTS

All eight outputs of the GAL16VP8 are capable of driving 64 mA loads when driving low and 32 mA loads when driving high. Near symmetrical high and low output drive capability provides small skews between high-to-low and low-to-high output transitions.

## Specifications GAL16VP8

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because, in system operation, certain events occur that may throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

The GAL16VP8 device includes circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing test vectors can perform output register preload automatically.

## INPUT BUFFERS

GAL16VP8 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.

GAL16VP8 input buffers have active pull-ups within their input structure. As a result, unused inputs and I/O's will float to a TTL "high" (logical "1"). Lattice recommends that all unused inputs and tri-stated I/O pins for both devices be connected to another active input, $\mathrm{V}_{\mathrm{cc}}$, or GND. Doing this will tend to improve noise immunity and reduce $I_{c \mathrm{C}}$ for the device.

## Typical Input Pull-up Characteristic



## PROGRAMMABLE OPEN-DRAIN OUTPUTS

In addition to the standard GAL16V8 type configuration, the outputs of the GAL16VP8 are individually programmable either as a standard totempole output or an open-drain output. The totempole output drives the specified $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ levels whereas the open-drain output drives only the specified $\mathrm{V}_{\mathrm{OL}}$. The $\mathrm{V}_{\mathrm{OH}}$ level on the open-drain ouput depends on the external loading and pullup. This output configuration is controlled by the AC2 fuse. When AC2 cell is erased (JEDEC "1") the output is configured as a totempole output and when AC2 cell is programmed (JEDEC "0") the output is configured as an open-drain. The default configuration when the device is in bulk erased state is totempole configuration. The AC2 fuses associated with each of the outputs is included in all of the logic diagrams.



## POWER-UP RESET



Circuitry within the GAL16VP8 provides a reset signal to all registers during power-up. All internal registers will have their Q outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown above. Because of the asynchro-
nous nature of system power-up, some conditions must be met to guarantee a valid power-up reset of the GAL16VP8. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

INPUT/OUTPUT EQUIVALENT SCHEMATICS


Vref $=3.1 \mathrm{~V}$


Vref $=3.1 \mathrm{~V}$
Typical Output

Specifications GAL16VP8

## TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs
Switching


Delta Tco vs Output Loading


TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Normalized Icc vs Vcc


Voh vs loh


Normalized Icc vs Temp


Delta Icc vs Vin (1 input)


Input Clamp (Vik)


Voh vs loh


Normalized lcc vs Freq.


Frequency ( MHz )

## FEATURES

- HIGH PERFORMANCE E² ${ }^{2}$ OS $^{\oplus}{ }^{\text {TECHNOLOGY }}$
- 15 ns Maximum Propagation Delay
- Fmax $=62.5 \mathrm{MHz}$
- 10ns Maximum from Clock Input to Data Output
- TTL Compatible 16 mA Outputs
- UltraMOS ${ }^{\oplus}$ Advanced CMOS Technology
- LOW POWER CMOS
- 75 mA Typical Icc
- ACTIVE PULL-UPS ON ALL PINS
- E ${ }^{2}$ CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure (<100ms)
- 20 Year Data Retention
- TEN OUTPUT LOGIC MACROCELLS
— Uses Standard 22V10 Macrocell Architecture
- Maximum Flexibility for Complex Logic Designs
- PRELOAD AND POWER-ON RESET OF REGISTERS
- 100\% Functional Testability
- APPLICATIONS INCLUDE:


## - DMA Control

- State Machine Control
- High Speed Graphics Processing
- Standard Logic Speed Upgrade
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL18V10, at 15 ns maximum propagation delay time, combines a high performance CMOS process with Electrically Erasable $\left(E^{2}\right)$ floating gate technology to provide a very flexible 20-pin PLD. CMOS circuitry allows the GAL18V10 to consume much less power when compared to its bipolar counterparts. The $\mathrm{E}^{2}$ technology offers high speed ( $<100 \mathrm{~ms}$ ) erase times, providing the ability to reprogram or reconfigure the device quickly and efficiently.

By building on the popular 22V10 architecture, the GAL18V10 eliminates the learning curve usually associated with using a new device architecture. The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The GAL18V10 OLMC is fully compatible with the OLMC in standard bipolar and CMOS 22V10 devices.

Unique test circuitry and reprogrammable cells allow complete AC, DC, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all $\mathrm{GAL}^{\circledR}$ products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.


PACKAGE DIAGRAMS


[^23]
## GAL18V10 ORDERING INFORMATION

Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 15 | 10 | 10 | 115 | GAL18V10-15LP | 20-Pin Plastic DIP |
|  |  |  | 115 | GAL18V10-15LJ | 20 -Lead PLCC |
| 20 | 12 | 12 | 115 | GAL18V10-20LP | 20-Pin Plastic DIP |
|  |  |  | 115 | GAL18V10-20LJ | 20-Lead PLCC |

## PART NUMBER DESCRIPTION



## Specifications GAL18V10

## OUTPUT LOGIC MACROCELL (OLMC)

The GAL18V10 has a variable number of product terms per OLMC. Of the ten available OLMCs, two OLMCs have access to ten product terms (pins 14 and 15), and the other eight OLMCs have eight product terms each. In addition to the product terms available for logic, each OLMC has an additional product-term dedicated to output enable control.

The output polarity of each OLMC can be individually programmed to be true or inverting, in either combinatorial or registered mode. This allows each output to be individually configured as either active high or active low.

The GAL18V10 has a product term for Asynchronous Reset (AR) and a product term for Synchronous Preset (SP). These two product terms are common to all registered OLMCs. The Asynchronous Reset sets all registered outputs to zero any time this dedicated product term is asserted. The Synchronous Preset sets all registers to a logic one on the rising edge of the next clock pulse after this product term is asserted.

NOTE: The AR and SP product terms will force the Q output of the flip-flop into the same state regardless of the polarity of the output. Therefore, a reset operation, which sets the register output to a zero, may result in either a high or low at the output pin, depending on the pin polarity chosen.

GAL18V10 OUTPUT LOGIC MACROCELL (OLMC)

## OUTPUT LOGIC MACROCELL CONFIGURATIONS

Each of the Macrocells of the GAL18V10 has two primary functional modes: registered, and combinatorial I/O. The modes and the output polarity are set by two bits ( SO and S 1 ), which are normally controlled by the logic compiler. Each of these two primary modes, and the bit settings required to enable them, are described below and on the the following page.

## REGISTERED

In registered mode the output pin associated with an individual OLMC is driven by the Q output of that OLMC's D-type flip-flop. Logic polarity of the output signal at the pin may be selected by specifying that the output buffer drive either true (active high) or inverted (active low). Output tri-state control is available as an individual product term for each OLMC, and can therefore be defined by a logic equation. The D flip-flop's /Q output is fed back into the AND array, with both the true and complement of the feedback available as inputs to the AND array.

NOTE: In registered mode, the feedback is from the /Q output of the register, and not from the pin; therefore, a pin defined as registered is an output only, and cannot be used for dynamic I/O, as can the combinatorial pins.

## COMBINATORIAL I/O

In combinatorial mode the pin associated with an individual OLMC is driven by the output of the sum term gate. Logic polarity of the output signal at the pin may be selected by specifying that the output buffer drive either true (active high) or inverted (active low). Output tri-state control is available as an individual product-term for each output, and may be individually set by the compiler as either "on" (dedicated output), "off" (dedicated input), or "productterm driven" (dynamic I/O). Feedback into the AND array is from the pin side of the output enable buffer. Both polarities (true and inverted) of the pin are fed back into the AND array.

## REGISTERED MODE



ACTIVE LOW


ACTIVE HIGH
$S_{0}=1$
$S_{1}=0$

COMBINATORIAL MODE


## GAL18V10 LOGIC DIAGRAM / JEDEC FUSE MAP



## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$.
Input voltage applied $\qquad$ -2.5 to.....
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ -65 to $150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature $\left(T_{A}\right)$........................... 0 to $+75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.75 to +5.25 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{V}_{\text {cc }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VoL | Output Low Voltage | $\mathbf{l o l}=$ MAX. $\quad \mathbf{V i n}=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I o H}=$ MAX. $\mathbf{V i n}=\mathbf{V I L}$ or $\mathbf{V}_{\mathbf{H}}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | $-3.2$ | mA |
| $1 \mathrm{OS}^{2}$ | Output Short Circuit Current | $\mathrm{Vcc}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {out }}=0.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -50 | - | -135 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-15 /-20$ | - | 75 | 115 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :---: |

1) The leakage current is due to the internal pull-up on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ Specifications GAL18V10

## AC SWITCHING CHARACTERISTICS

| Over Recommended Operating Conditions |  |  | COM |  | COM |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | DESCRIPTION | -15 |  | -20 |  | UNITS |
| PARAMETER | COND. ${ }^{1}$ |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinatorial Output | - | 15 | - | 20 | ns |
| tco | A | Clock to Output Delay | - | 10 | - | 12 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay | - | 7 | - | 10 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 10 | - | 12 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, 1/(tsu +tco) | 50 | - | 41.6 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 58.8 | - | 45.4 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 62.5 | - | 62.5 | - | MHz |
| twh | - | Clock Pulse Duration, High | 8 | - | 8 | - | ns |
| twl | - | Clock Pulse Duration, Low | 8 | - | 8 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 15 | - | 20 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 20 | ns |
| tar | A | Input or I/O to Asynchronous Reset of Register | - | 20 | - | 20 | ns |
| tarw | - | Asynchronous Reset Pulse Duration | 10 | - | 15 | - | ns |
| tarr | - | Asynchronous Reset to Clock Recovery Time | 15 | - | 15 | - | ns |
| tspr | - | Synchronous Preset to Clock Recovery Time | 10 | - | 12 | - | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Description section.
3) Refer to fmax Description section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{I} / \mathrm{O}}=2.0 \mathrm{~V}$ |

[^24]
## Specifications GAL18V10

SWITCHING WAVEFORMS


Combinatorial Output

INPUT or I/O FEEDBACK

OUTPUT


Input or I/O to Output Enable/Disable


Clock Width


Synchronous Preset


Registered Output

fmax with Feedback


Asynchronous Reset
fmax DESCRIPTIONS

fmax with External Feedback 1/(tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.

fmax with No Feedback
Note: fmax with no feedback may be less than $1 /(t w h+t w l)$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback $\mathbf{1 / ( t s u + t c f )}$
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback (tcf = $1 / \mathrm{fmax}-\mathrm{tsu}$ ). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to tcf + tpd.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns 10\%-90\% |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3-state levels are measured 0.5V from steady-state active level.

Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $300 \Omega$ | $390 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 5 pF |

FROM OUTPUT (O/Q) UNDER TEST

${ }^{*} C_{L}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

## ELECTRONIC SIGNATURE

An electronic signature is provided in every GAL18V10 device. It contains 64 bits of reprogrammable memory that can contain user-defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

## SECURITY CELL

A security cell is provided in every GAL18V10 device to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell.

## LATCH-UP PROTECTION

GAL18V10 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with n-channel pullups instead of the traditional p-channel pullups to eliminate any possibility of SCR induced latching.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers (see the the GAL Development Tools section). Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because certain events may occur during system operation that throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

The GAL18V10 device includes circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing test vectors perform output register preload automatically.

## INPUT BUFFERS

GAL18V10 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.

The input and I/O pins also have built-in active pull-ups. As a result, floating inputs will float to a TTL high (logic 1). However, Lattice recommends that all unused inputs and tri-stated I/O pins be connected to an adjacent active input, Vcc, or ground. Doing so will tend to improve noise immunity and reduce lcc for the device.

Typical Input Current


## Specifications GAL18V10

## POWER-UP RESET



Circuitry within the GAL18V10 provides a reset signal to all registers during power-up. All internal registers will have their $Q$ outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will be either high or low on power-up, depending on the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. Because of the asynchronous nature of system power-up, some
conditions must be met to guarantee a valid power-up reset of the device. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

## INPUT/OUTPUT EQUIVALENT SCHEMATICS















## FEATURES

- HIGH PERFORMANCE E²CMOS* TECHNOLOGY
- 10 ns Maximum Propagation Delay
- Fmax $=71.4 \mathrm{MHz}$
- 11 ns Maximum from Clock Input to Data Output
- TTL Compatible 8 mA Outputs
- UltraMOS ${ }^{\circledR}$ Advanced CMOS Technology
- 50\% to 75\% REDUCTION IN POWER FROM BIPOLAR
- 75mA Typ $\mathrm{I}_{\mathrm{cc}}$
- ACTIVE PULL-UPS ON ALL PINS
- E² CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure (<100 ms)
- 20 Year Data Retention
- TEN OUTPUT LOGIC MACROCELLS
- Independent Programmable Clocks
- Independent Asynchronous Reset and Preset
- Registered or Combinatorial with Polarity
- Full Function and Parametric Compatibility with PAL20RA10
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS
- 100\% Functional Testability
- APPLICATIONS INCLUDE:
- State Machine Control
- Standard Logic Consolidation
- Multiple Clock Logic Designs
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL20RA10 combines a high performance CMOS process with electrically erasable ( $\mathrm{E}^{2}$ ) floating gate technology to provide the highest speed performance available in the PLD market. Lattice's $E^{2}$ CMOS circuitry achieves power levels as low as 75 mA typical $I_{c c}$ which represents a substantial savings in power when compared to bipolar counterparts. $\mathrm{E}^{2}$ technology offers high speed ( $<100 \mathrm{~ms}$ ) erase times providing the ability to reprogram, reconfigure or test the devices quickly and efficiently.

The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The GAL20RA10 is a direct parametric compatible CMOS replacement for the PAL20RA10 device.

Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacturing. Therefore, LATTICE guarantees $100 \%$ field programmability and functionality of all GAL products. LATTICE also guarantees 100 erase/rewrite cycles and that data retention exceeds 20 years.


PIN CONFIGURATION


## GAL20RA10 ORDERING INFORMATION

Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 10 | 4 | 11 | 100 | GAL20RA10B-10LP | 24-Pin Plastic DIP |
|  |  |  | 100 | GAL20RA10B-10LJ | 28-Lead PLCC |
| 15 | 7 | 15 | 100 | GAL20RA10-15LP | 24-Pin Plastic DIP |
|  |  |  | 100 | GAL20RA10-15LJ | 28-Lead PLCC |
| 20 | 10 | 20 | 100 | GAL20RA10-20LP | 24-Pin Plastic DIP |
|  |  |  | 100 | GAL20RA10-20LJ | 28-Lead PLCC |
| 30 | 20 | 30 | 100 | GAL20RA10-30LP | 24-Pin Plastic DIP |
|  |  |  | 100 | GAL20RA10-30LJ | 28-Lead PLCC |

Industrial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 20 | 10 | 20 | 120 | GAL20RA10-20LPI | 24-Pin Plastic DIP |
|  |  |  | 120 | GAL20RA10-20LJI | 28-Lead PLCC |

## PART NUMBER DESCRIPTION



## Specifications GAL20RA10

## OUTPUT LOGIC MACROCELL (OLMC)

The GAL20RA10 OLMC consists of 10 D flip-flops with individual asynchronous programmable reset, preset and clock product terms. The sum of four product terms and an ExclusiveOR provide a programmable polarity D-input to each flip-flop. An output enable term combined with the dedicated output enable pin provides tri-state control of each output. Each OLMC has a flip-flop bypass, allowing any combination of registered or combinatorial outputs.

The GAL20RA10 has 10 dedicated input pins and 10 programmable I/O pins, which can be either inputs, outputs, or dynamic I/O. Each pin has a unique path to the logic array. All macrocells have the same type and number of data and control product terms, allowing the user to exchange I/O pin assignments without restriction.

## INDEPENDENT PROGRAMMABLE CLOCKS

An independent clock control product term is provided for each GAL20RA10 macrocell. Data is clocked into the flip-flop on the active edge of the clock product term. The use of individual clock control product terms allow up to ten separate clocks. These clocks can be derived from any pin or combination of pins and/ or feedback from other flip-flops. Multiple clock sources allow a number of asynchronous register functions to be combined into a single GAL20RA10. This allows the designer to combine discrete logic functions into a single device.

## PROGRAMMABLE POLARITY

The polarity of the D-input to each macrocell flip-flop is individually programmable to be active high or low. This is accomplished with a programmable Exclusive-OR gate on the D-input of each flipflop. While any one of the four logic function product terms are active the D-input to the flip-flop will be low if the Exclusive-OR bit is set to zero(0) and high if the Exclusive-OR bit is set to one(1). It should be noted that the programmable polarity only affects the data latched into the flip-flop on the active edge of the clock product term. The reset, preset and preload will alter the state of the flipflop independent of the state of programmable polarity bit. The ability to program the active polarity of the D-inputs can be used to reduce the total number of product terms used, by allowing the DeMorganization of the logic functions. This logic reduction is accomplished by the logic compiler, and does not require the designer to define the polarity.

## OUTPUT ENABLE

The output of each GAL20RA10 macrocell is controlled by the "AND'ing" of an independent output enable product term and a common active low output enable pin(13). The output is enabled while the output enable product term is active and the output enable pin(13) is low. This output control structure allows several output enable alternatives.

## ASYNCHRONOUS RESET AND PRESET

Each GAL20RA10 macrocell has an independent asynchronous reset and preset control product term. The reset and preset product terms are level sensitive, and will hold the flip-flop in the reset or preset state while the product term is active independent of the clock or D-inputs. It should be noted that the reset and preset term alter the state of the flip-flop whose output is inverted by the output buffer. A reset of the flip-flop will result in the output pin becoming a logic high and a preset will result in a logic low.

| RESET | PRESET | FUNCTION |
| :---: | :---: | :---: |
| 0 | 0 | Registered function of data product term |
| 1 | 0 | Reset register to "0" (device pin = "1") |
| 0 | 1 | Preset register to "1" (device pin = "0") |
| 1 | 1 | Register-bypass (combinatorial output) |

## COMBINATORIAL CONTROL

The register in each GAL20RA10 macrocell may be bypassed by asserting both the reset and preset product terms. While both product terms are active the flip-flop is bypassed and the D -input is presented directly to the inverting output buffer. This provides the designer the ability to dynamically configure any macrocell as a combinatorial output, or to fix the macrocell as combinatorial only by forcing both reset and preset product terms active. Some logic compilers will configure macrocells as registered or combinatorial based on the logic equations, others require the designer to force the reset and preset product terms active for combinatorial macrocells.

## PARALLEL FLIP-FLOP PRELOAD

The flip-flops of a GAL20RA10 can be reset or preset from the I/O pins by applying a logic low to the preload pin (1) and applying the desired logic level to each I/O pin. The I/O pins must remain valid for the preload setup and hold time. All 10 flip-flops are reset or preset during preload, independent of all other OLMC inputs.

A logic low on an I/O pin during preload will preset the flip-flop, a logic high will reset the flip-flop. The output of any flip-flop to be preloaded must be disabled. Enabling the output during preload will maintain the current logic state. It should be noted that the preload alters the state of the flip-flop whose output is inverted by the output buffer. A reset of the flip-flop will result in the output pin becoming a logic high and a preset will result in a logic low. Note that the common output enable pin (13) will disable all 10 outputs of the GAL20RA10 when held high.

## Specifications GAL20RA10

## OUTPUT LOGIC MACROCELL DIAGRAM



## OUTPUT LOGIC MACROCELL CONFIGURATION (REGISTERED with POLARITY)



## OUTPUT LOGIC MACROCELL CONFIGURATION (COMBINATORIAL with POLARITY)



## GAL20RA10 LOGIC DIAGRAM

DIP (PLCC) Package Pinouts


## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$



## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{VIN}^{\text {¢ }}$ Vcc | - | - | 10 | $\mu \mathrm{A}$ |
| VoL | Output Low Voltage | Iol $=$ MAX. $\mathbf{V i n}_{\text {in }}=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I} \mathbf{O H}=$ MAX. $\mathbf{V i n}=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\mathbf{H}}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 8 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| lOS ${ }^{2}$ | Output Short Circuit Current | $\mathrm{V}_{\text {cc }}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {out }}=0.5 \mathrm{~V}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -50 | - | -135 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-10$ | - | 75 | 100 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

1) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

## AC SWITCHING CHARACTERISTICS

## Over Recommended Operating Conditions

|  |  |  |  | OM |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 10 |  |
| PARAMETER | COND. ${ }^{1}$ | DESCRIPTION | MIN. | MAX. | UNITS |
| tpd | A | Input or I/O to Combinatorial Output | 2 | 10 | ns |
| tco | A | Clock to Output Delay | 2 | 11 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 4 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 3 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco) | 66.7 | - | MHz |
|  | A | Maximum Clock Frequency without Feedback | 71.4 | - | MHz |
| twh | - | Clock Pulse Duration, High | 7 | - | ns |
| twl | - | Clock Pulse Duration, Low | 7 | - | ns |
| ten / tdis | B, C | Input or I/O to Output Enabled / Disabled | - | 10 | ns |
| ten / tdis | B, C | $\overline{\mathrm{OE}}$ to Output Enabled / Disabled | - | 9 | ns |
| tar/tap | A | Input or I/O to Asynchronous Reset / Preset | - | 11 | ns |
| tarw / tapw | - | Asynchronous Reset / Preset Pulse Duration | 10 | - | ns |
| tarr / tapr | - | Asynchronous Reset / Preset Recovery Time | 7 | - | ns |
| twp | - | Preload Pulse Duration | 10 | - | ns |
| tsp | - | Preload Setup Time | 7 | - | ns |
| thp | - | Preload Hold Time | 7 | - | ns |

1) Refer to Switching Test Conditions section.
2) Refer to fmax Descriptions section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / \mathrm{O}}=2.0 \mathrm{~V}$ |

[^25]
## Specifications GAL20RA10

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

$$
\begin{aligned}
& \text { Supply voltage } \mathrm{V}_{\mathrm{c}} \\
& \text { Input voltage applied } \\
& -25 \text { V }+1.0 \mathrm{~V} \\
& \text { Off-state output voltage applied .......... }-2.5 \text { to } \mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V} \\
& \text { Storage Temperature } \\
& -65 \text { to } 150^{\circ} \mathrm{C} \\
& \text { Power Applied } \\
& -55 \text { to } 125^{\circ} \mathrm{C} \\
& \text { 1. Stresses above those listed under the "Absolute Maximum } \\
& \text { Ratings" may cause permanent damage to the device. These } \\
& \text { are stress only ratings and functional operation of the device } \\
& \text { at these or at any other conditions above those indicated in the } \\
& \text { operational sections of this specification is not implied (while } \\
& \text { programming, follow the programming specifications). }
\end{aligned}
$$

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) $\qquad$ 0 to $+75^{\circ} \mathrm{C}$ Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.75 to +5.25 V

Industrial Devices:
Ambient Temperature ( $T_{A}$ ) ........................... -40 to $+85^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss -0.5 | - | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.0 | - | $\mathrm{Vcc}+1$ | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{Vin} \leq \mathrm{Vcc}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage |  | - | - | 0.5 | V |
| VOH | Output High Voltage |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 8 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| lOS ${ }^{2}$ | Output Short Circuit Current | V cc $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -50 | - | -135 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f}_{\text {toggle }}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-15 /-20 /-30$ | - | 75 | 100 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :---: |

## INDUSTRIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathrm{f}_{\text {toggle }}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-20$ | - | 75 | 120 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

1) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

## AC SWITCHING CHARACTERISTICS

## Over Recommended Operating Conditions

|  |  |  |  | OM | COM | / IND |  | OM |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 15 |  | 20 |  | 30 |  |
| PARAMETER | COND. ${ }^{\text {- }}$ | DESCRIPTION | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | UNITS |
| tpd | A | Input or I/O to Combinatorial Output | - | 15 | - | 20 | - | 30 | ns |
| tco | A | Clock to Output Delay | - | 15 | - | 20 | - | 30 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 7 | - | 10 | - | 20 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 3 | - | 3 | - | 10 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco $)$ | 45.0 | - | 33.3 | - | 20.0 | - | MHz |
|  | A | Maximum Clock Frequency without Feedback | 50.0 | - | 41.7 | - | 25.0 | - | MHz |
| twh | - | Clock Pulse Duration, High | 10 | - | 12 | - | 20 | - | ns |
| twl | - | Clock Pulse Duration, Low | 10 | - | 12 | - | 20 | - | ns |
| ten / tdis | B,C | Input or I/O to Output Enabled / Disabled | - | 15 | - | 20 | - | 30 | ns |
| ten / tdis | B,C | $\overline{\mathrm{OE}}$ to Output Enabled/ Disabled | - | 12 | - | 15 | - | 20 | ns |
| tar / tap | A | Input or I/O to Asynchronous Reset / Preset | - | 15 | - | 20 | - | 30 | ns |
| tarw / tapw | - | Asynchronous Reset / Preset Pulse Duration | 15 | - | 20 | - | 20 | - | ns |
| tarr / tapr | - | Asynchronous Reset / Preset Recovery Time | 10 | - | 12 | - | 20 | - | ns |
| twp | - | Preload Pulse Duration | 15 | - | 20 | - | 30 | - | ns |
| tsp | - | Preload Setup Time | 10 | - | 15 | - | 25 | - | ns |
| thp | - | Preload Hold Time | 10 | - | 15 | - | 25 | - | ns |

1) Refer to Switching Test Conditions section.
2) Refer to fmax Descriptions section.

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

| SYMBOL | PARAMETER | MAXIMUM* | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{vo}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{v}}=2.0 \mathrm{~V}$ |

*Guaranteed but not $100 \%$ tested.

## Specifications GAL20RA10

## SWITCHING WAVEFORMS



INPUT or I/O FEEDBACK

OUTPUT


Input or I/O to Output Enable/Disable

CLK


Clock Width


Parallel Preload
$\overline{O E}$

OUTPUT


OE to Enable / Disable

INPUT or I/O FEEDBACK

CLK

REGISTERED OUTPUT

## Registered Output



## Asynchronous Reset and Preset

INPUT or I/O FEEDBACK DRIVING AP or AR

CLK


Asynchronous Reset and Preset Recovery


fmax DESCRIPTIONS

fmax with External Feedback 1/(tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.

fmax with No Feedback
Note: fmax with no feedback may be less than $1 /(t w h+t w l)$. This is to allow for a clock duty cycle of other than $50 \%$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3-state levels are measured 0.5V from steady-state active level.
Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}_{\mathbf{L}}$ |
| :---: | :---: | :---: | :---: | :---: |
| A |  | $470 \Omega$ | $390 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low | $470 \Omega$ | $390 \Omega$ | 5 pF |

FROM OUTPUT (O/Q) UNDER TEST

${ }^{*} C_{L}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

Specifications GAL20RA10

## ELECTRONIC SIGNATURE

An electronic signature word is provided in every GAL20RA10 device. It contains 64 bits of reprogrammable memory that contains user defined data. Some uses include user ID codes, revision numbers, pattern identification or inventory control codes. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature bits if programmed to any value other then zero(0) will alter the checksum of the device.

## SECURITY CELL

A security cell is provided in every GAL20RA10 devices as a deterrent to unauthorized copying of the device pattern. Once programmed, this cell prevents further read access of the device pattern information. This cell can be only be reset by reprogramming the device. The original pattern can never be examined once this cell is programmed. The Electronic Signature is always available regardless of the security cell state.

## LATCH-UP PROTECTION

GAL20RA10 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with n-channel pullups instead of the traditional p-channel pullups to eliminate any possibility of SCR induced latching.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers (see the the GAL Development Tools section). Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle.

## INPUT BUFFERS

GAL20RA10 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance and present a much lighter load to the driving logic than traditional bipolar devices.

GAL20RA10 input buffers have active pull-ups within their input structure. As a result, unused inputs and I/O's will float to a TTL "high" (logical "1"). Lattice recommends that all unused inputs and tri-stated I/O pins be connected to another active input, Vcc, or GND. Doing this will tend to improve noise immunity and reduce Icc for the device.

Typical Input Pull-up Characteristic


## POWER-UP RESET

Circuitry within the GAL20RA10 provides a reset signal to all registers during power-up. All internal registers will have their Q outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will be high on power-up, because of the inverting buffer on the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown to the right. Because of the asynchronous nature of system power-up, some conditions must be met to guarantee a valid power-up reset of the GAL20RA10. First, the Vcc rise must be monotonic. Second, the clock input must be at a static TTL level as shown in the diagram during power up. The registers will reset within a maximum of $1 \mu \mathrm{~s}$. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

## INPUT/OUTPUT EQUIVALENT SCHEMATICS



Typical Input



Typical Output

## Specifications GAL20RA10

## GAL20RA10B: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


GAL20RA10B: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)


Voh vs loh


Normalized Icc vs Temp


Voh vs loh


Normalized Icc vs Freq.


Input Clamp (Vik)


## Specifications GAL20RA10

GAL20RA10: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs
Switching


Delta Tco vs Output Loading


## GAL20RA10: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)


Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


Voh vs loh


Normalized Icc vs Freq.


FEATURES

- HIGH PERFORMANCE E²CMOS ${ }^{\circledR}$ TECHNOLOGY - 5 ns Maximum Propagation Delay
- Fmax $=166 \mathrm{MHz}$
- 4 ns Maximum from Clock Input to Data Output
- UltraMOS ${ }^{\oplus}$ Advanced CMOS Technology
- 50\% to 75\% REDUCTION IN POWER FROM BIPOLAR
- 75mA Typ Icc on Low Power Device
- 45mA Typ Icc on Quarter Power Device
- ACTIVE PULL-UPS ON ALL PINS
- E2 CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure (<100ms)
- 20 Year Data Retention
- EIGHT OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- Programmable Output Polarity
- Also Emulates 24-pin PAL ${ }^{\otimes}$ Devices with Full Function/Fuse Map/Parametric Compatibility
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS - 100\% Functional Testability
- APPLICATIONS INCLUDE:


## — DMA Control

- State Machine Control
- High Speed Graphics Processing
- Standard Logic Speed Upgrade
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL20V8C, at 5 ns maximum propagation delay time, combines a high performance CMOS process with Electrically Erasable $\left(\mathrm{E}^{2}\right)$ floating gate technology to provide the highest speed performance available in the PLD market. High speed erase times ( $<100 \mathrm{~ms}$ ) allow the devices to be reprogrammed quickly and efficiently.
The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. An important subset of the many architecture configurations possible with the GAL20V8 are the PAL architectures listed in the table of the macrocell description section. GAL20V8 devices are capable of emulating any of these PAL architectures with full function/fuse map/parametric compatibility.

Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all $\mathrm{GAL}^{\circledR}$ products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.


PIN CONFIGURATION

DIP

ICLK

[^26]
## Specifications GAL20V8

## GAL20V8 ORDERING INFORMATION

## Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 5 | 3 | 4 | 115 | GAL20V8C-5LJ | 28-Lead PLCC |
| 7.5 | 7 | 5 | 115 | GAL20V8B-7LP | 24-Pin Plastic DIP |
|  |  |  | 115 | GAL20V8B-7LJ | 28-Lead PLCC |
| 10 | 10 | 7 | 115 | GAL20V8B-10LP | 24-Pin Plastic DIP |
|  |  |  | 115 | GAL20V8B-10LJ | 28-Lead PLCC |
| 15 | 12 | 10 | 55 | GAL20V8B-15QP | 24-Pin Plastic DIP |
|  |  |  | 55 | GAL20V8B-15QJ | 28-Lead PLCC |
|  |  |  | 90 | GAL20V8B-15LP | 24-Pin Plastic DIP |
|  |  |  | 90 | GAL20V8B-15LJ | 28-Lead PLCC |
| 25 | 15 | 12 | 55 | GAL20V8B-25QP | 24-Pin Plastic DIP |
|  |  |  | 55 | GAL20V8B-25QJ | 28-Lead PLCC |
|  |  |  | 90 | GAL20V8B-25LP | 24-Pin Plastic DIP |
|  |  |  | 90 | GAL20V8B-25LJ | 28-Lead PLCC |

Industrial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 10 | 10 | 7 | 130 | GAL20V8B-10LPI | 24-Pin Plastic DIP |
|  |  |  | 130 | GAL20V8B-10LJI | 28-Lead PLCC |
| 15 | 12 | 10 | 130 | GAL20V8B-15LPI | 24-Pin Plastic DIP |
|  |  |  | 130 | GAL20V8B-15LJI | 28-Lead PLCC |
| 20 | 13 | 11 | 65 | GAL20V8B-20QPI | 24-Pin Plastic DIP |
|  |  |  | 65 | GAL20V8B-20QJI | 28-Lead PLCC |
| 25 | 15 | 12 | 65 | GAL20V8B-25QPI | 24-Pin Plastic DIP |
|  |  |  | 65 | GAL20V8B-25QJI | 28-Lead PLCC |
|  |  |  | 130 | GAL20V8B-25LPI | 24-Pin Plastic DIP |
|  |  |  | 130 | GAL20V8B-25LJ | 28-Lead PLCC |

## PART NUMBER DESCRIPTION



Specifications GAL20V8

## OUTPUT LOGIC MACROCELL (OLMC)

The following discussion pertains to configuring the output logic macrocell. It should be noted that actual implementation is accomplished by development software/hardware and is completely transparent to the user.

There are three global OLMC configuration modes possible: simple, complex, and registered. Details of each of these modes is illustrated in the following pages. Two global bits, SYN and ACO, control the mode configuration for all macrocells. The XOR bit of each macrocell controls the polarity of the output in any of the three modes, while the AC1 bit of each of the macrocells controls the input/output configuration. These two global and 16 individual architecture bits define all possible configurations in a GAL20V8. The information given on these architecture bits is only to give a better understanding of the device. Compiler software will transparently set these architecture bits from the pin definitions, so the user should not need to directly manipulate these architecture bits.

The following is a list of the PAL architectures that the GAL20V8 can emulate. It also shows the OLMC mode under which the devices emulate the PAL architecture.

| PAL Architectures Emulated by GAL20V8 | $\begin{gathered} \text { GAL20V8 } \\ \text { Global OLMC Mode } \end{gathered}$ |
| :---: | :---: |
| 20R8 | Registered |
| $20 \mathrm{R6}$ | Registered |
| 20R4 | Registered |
| 20RP8 | Registered |
| 20RP6 | Registered |
| 20RP4 | Registered |
| 2028 | Complex |
| $20 \mathrm{H8}$ | Complex |
| 20P8 | Complex |
| 14L8 | Simple |
| 16L6 | Simple |
| 18L4 | Simple |
| 20 L 2 | Simple |
| 14H8 | Simple |
| 16H6 | Simple |
| 18H4 | Simple |
| 20 H 2 | Simple |
| 14P8 | Simple |
| 16P6 | Simple |
| 18P4 | Simple |
| 20P2 | Simple |

## COMPILER SUPPORT FOR OLMC

Software compilers support the three different global OLMC modes as different device types. These device types are listed in the table below. Most compilers have the ability to automatically select the device type, generally based on the register usage and output enable (OE) usage. Register usage on the device forces the software to choose the registered mode. All combinatorial outputs with OE controlled by the product term will force the software to choose the complex mode. The software will choose the simple mode only when all outputs are dedicated combinatorial without OE control. The different device types listed in the table can be used to override the automatic device selection by the software. For further details, refer to the compiler software manuals.

In registered mode pin 1 and pin 13 (DIP pinout) are permanently configured as clock and output enable, respectively. These pins cannot be configured as dedicated inputs in the registered mode.

In complex mode pin 1 and pin 13 become dedicated inputs and use the feedback paths of pin 22 and pin 15 respectively. Because of this feedback path usage, pin 22 and pin 15 do not have the feedback option in this mode.

In simple mode all feedback paths of the output pins are routed via the adjacent pins. In doing so, the two inner most pins ( pins 18 and 19) will not have the feedback option as these pins are always configured as dedicated combinatorial output.

When using compiler software to configure the device, the user must pay special attention to the following restrictions in each mode.

|  | Registered | Complex | Simple | Auto Mode Select |
| :--- | :---: | :---: | :---: | :---: |
| ABEL | P20V8R | P20V8C | P20V8AS | P20V8 |
| CUPL | G20V8MS | G20V8MA | G20V8AS | G20V8 |
| LOG/iC | GAL20V8_R | GAL20V8_C7 | GAL20V8_C8 | GAL20V8 |
| OrCAD-PLD | "Registered"1 | "Complex"1 | "Simple"1 | GAL20V8A |
| PLDesigner | P20V8R ${ }^{2}$ | P20V8C ${ }^{2}$ | P20V8C $^{2}$ | P20V8A |
| TANGO-PLD | G20V8R | G20V8C | G20V8AS $^{3}$ | G20V8 |

1) Used with Configuration keyword.
2) Prior to Version 2.0 support.
3) Supported on Version 1.20 or later.


## REGISTERED MODE

In the Registered mode, macrocells are configured as dedicated registered outputs or as I/O functions.

Architecture configurations available in this mode are similar to the common 20R8 and 20RP4 devices with various permutations of polarity, I/O and register placement.

All registered macrocells share common clock and output enable control pins. Any macrocell can be configured as registered or I/O. Up to eight registers or up to eight I/O's are possible in this
mode. Dedicated input or output functions can be implemented as subsets of the I/O function.

Registered outputs have eight product terms per output. I/O's have seven product terms per output.

The JEDEC fuse numbers, including the User Electronic Signature (UES) fuses and the Product Term Disable (PTD) fuses, are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## REGISTERED MODE LOGIC DIAGRAM

## DIP (PLCC) Package Pinouts




## COMPLEX MODE

In the Complex mode, macrocells are configured as output only or I/O functions.

Architecture configurations available in this mode are similar to the common 20L8 and 20P8 devices with programmable polarity in each macrocell.

Up to six I/O's are possible in this mode. Dedicated inputs or outputs can be implemented as subsets of the I/O function. The two outer most macrocells (pins 15 \& 22) do not have input ca-
pability. Designs requiring eight I/O's can be implemented in the Registered mode.

All macrocells have seven product terms per output. One product term is used for programmable output enable control. Pins 1 and 13 are always available as data inputs into the AND array.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## COMPLEX MODE LOGIC DIAGRAM

## Specifications GAL20V8

## DIP (PLCC) Package Pinouts



## Specifications GAL20V8

## SIMPLE MODE

In the Simple mode, pins are configured as dedicated inputs or as dedicated, always active, combinatorial outputs.

Architecture configurations available in this mode are similar to the common 14L8 and 16P6 devices with many permutations of generic output polarity or input choices.

All outputs in the simple mode have a maximum of eight product terms that can control the logic. In addition, each output has programmable polarity.

Pins 1 and 13 are always available as data inputs into the AND array. The "center" two macrocells (pins 18 \& 19) cannot be used in the input configuration.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## SIMPLE MODE LOGIC DIAGRAM

## Specifications GAL2OV8

## DIP (PLCC) Package Pinouts



## 64-USER ELECTRONIC SIGNATURE FUSES


-0.5 to +7 V -65 to $150^{\circ} \mathrm{C}$

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$ $\qquad$
Input voltage applied $\qquad$ -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$

## Ambient Temperature with

Power Applied .-55 to $125^{\circ} \mathrm{C}$
1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications). prong

## Specifications GAL20V8C

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) .............................. 0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.75 to +5.25 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | $\mathrm{Vcc}+1$ | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{VCc}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage |  | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I O H}=$ MAX. Vin $=$ VIL or $\mathrm{V}_{\text {IH }}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| lOS ${ }^{2}$ | Output Short Circuit Current | $\mathrm{Vcc}=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -150 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V I L}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-5$ | - | 75 | 115 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :---: | :---: |

1) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

Specifications GAL20V8C

AC SWITCHING CHARACTERISTICS
Over Recommended Operating Conditions

|  |  | Over Recommended Operat | CO |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | EST |  | -5 |  |  |
| PAR | COND ${ }^{1}$. | DES | MIN. | MAX. | UNITS |
| tpd | A | Input or I/O to Combinational Output | 1 | 5 | ns |
| tco | A | Clock to Output Delay | 1 | 4 | ns |
| $\mathbf{t c} f^{2}$ | - | Clock to Feedback Delay | - | 3 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 3 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco) | 142.8 | - | MHz |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 166 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 166 | - | MHz |
| twh | - | Clock Pulse Duration, High | 3 | - | ns |
| twl | - | Clock Pulse Duration, Low | 3 | - | ns |
| ten | B | Input or I/O to Output Enabled | 1 | 6 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | 1 | 6 | ns |
| tdis | C | Input or I/O to Output Disabled | 1 | 5 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | 1 | 5 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Descriptions section.
3) Refer to fmax Descriptions section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 \mathrm{O}}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / 0}=2.0 \mathrm{~V}$ |

[^27]
## Specifications GAL20V8B

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}} \ldots \ldots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ~-~ 0.5 ~ t o ~+7 V ~$
Input voltage applied -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ . 65 to $150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied $\qquad$
1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) .............................. 0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{CC}}$ )
with Respect to Ground $\qquad$ +4.75 to +5.25 V

## Industrial Devices:

Ambient Temperature ( $T_{A}$ ) ........................... 40 to $85^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground
+4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | $\mathrm{Vcc}+1$ | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{VIL}^{\text {( }}$ MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{VCC}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | Iol $=$ MAX. $\quad \mathbf{V i n}=\mathbf{V I L}_{\text {IL }}$ or $\mathrm{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I O H}=$ MAX. $\quad \mathbf{V i n}=\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{H}}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 24 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| $1 \mathrm{OS}^{2}$ | Output Short Circuit Current | $\mathrm{Vcc}=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -150 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\begin{aligned} & \mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {toggle }}=15 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ | L -7/-10 | - | 75 | 115 | mA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | L-15/-25 | - | 75 | 90 | mA |
|  |  |  | Q-15/-25 | - | 45 | 55 | mA |

## INDUSTRIAL

| IcC | Operating Power <br> Supply Current | $\begin{aligned} & \mathbf{V}_{\mathrm{LL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V} \\ & \text { ftoggle }^{=15 \mathrm{MHz} \text { Outputs Open }} \end{aligned}$ | L-10/-15/-25 | - | 75 | 130 | mA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Q -20/-25 | - | 45 | 65 | mA |

[^28]
## Specifications GAL20V8B

## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

| PARAM. | $\begin{array}{c\|} \hline \text { TEST } \\ \text { COND' } \end{array}$ | DESCRIPTION |  | $\begin{gathered} \hline \text { COM } \\ \hline-7 \\ \hline \end{gathered}$ |  | $\begin{array}{c\|} \hline \text { COM / IND } \\ \hline-10 \end{array}$ |  | COM / IND <br> -15 |  | $\begin{array}{\|c\|} \hline \text { IND } \\ \hline-20 \end{array}$ |  | $\begin{gathered} \hline \text { COM / IND } \\ \hline-25 \\ \hline \end{gathered}$ |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | MIN. | MAX. | MIN. | max. | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to | 8 outputs switching | 3 | 7.5 | 3 | 10 | 3 | 15 | 3 | 20 | 3 | 25 | ns |
|  |  | Comb. Output | 1 output switching | - | 7 | - | - | - | - | - | - | - | - | ns |
| tco | A | Clock to Output Delay |  | 2 | 5 | 2 | 7 | 2 | 10 | 2 | 11 | 2 | 12 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay |  | - | 3 | - | 6 | - | 8 | - | 9 | - | 10 | ns |
| tsu | - | Setup Time, Input or Fdbk before $\mathrm{Clk} \uparrow$ |  | 7 | - | 10 | - | 12 | - | 13 | - | 15 | - | ns |
| th | - | Hold Time, Input or Fdbk after CIk $\uparrow$ |  | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco) |  | 83.3 | - | 58.8 | - | 45.5 | - | 41.6 | - | 37 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, 1/(tsu + tcf) |  | 100 | - | 62.5 | - | 50 | - | 45.4 | - | 40 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback |  | 100 | - | 62.5 | - | 62.5 | - | 50 | - | 41.7 | - | MHz |
| twh | - | Clock Pulse Duration, High |  | 5 | - | 8 | - | 8 | - | 10 | - | 12 | - | ns |
| twl | - | Clock Pulse Duration, Low |  | 5 | - | 8 | - | 8 | - | 10 | - | 12 | - | ns |
| ten | B | Input or I/O to Output Enabled |  | 3 | 9 | 3 | 10 | - | 15 | - | 20 | - | 25 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled |  | 2 | 6 | 2 | 10 | - | 15 | - | 18 | - | 20 | ns |
| tdis | C | Input or I/O to Output Disabled |  | 2 | 9 | 2 | 10 | - | 15 | - | 20 | - | 25 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled |  | 1.5 | 6 | 1.5 | 10 | - | 15 | - | 18 | - | 20 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Descriptions section.
3) Refer to fmax Descriptions section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{4}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{10}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / 0}=2.0 \mathrm{~V}$ |

*Guaranteed but not 100\% tested.


## SWITCHING WAVEFORMS



Combinatorial Output

INPUT or I/O FEEDBACK

COMBINATIONAL OUTPUT


Input or I/O to Output Enable/Disable


Clock Width


Registered Output

$\overline{\mathrm{OE}}$ to Output Enable/Disable

fmax with Feedback

Specifications GAL20V8
fmax DESCRIPTIONS

fmax with External Feedback $1 /($ tsu + tco)
Note: fmax with external feedback is calculated from measured tsu and tco.


Note: fmax with no feedback may be less than $1 /(t w h+t w l)$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback $\mathbf{1 / ( t s u + t c f )}$
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback (tcf = $1 /$ fmax - tsu). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to tcf + tpd.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels |  | GND to 3.0V |
| :--- | :---: | :---: |
| Input Rise and | GAL20V8B | $2-3 n s 10 \%-90 \%$ |
|  | GAL20V8C | $1.5 \mathrm{~ns} 10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |  |
| Output Timing Reference Levels | 1.5 V |  |
| Output Load |  | See Figure |

3 -state levels are measured 0.5 V from steady-state active level.

${ }^{\circ} C_{\text {L }}$ includes test fixture and probe capacitance

GAL20V8C Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $200 \Omega$ | $200 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $200 \Omega$ | 50 pF |
|  | Active Low | $200 \Omega$ | $200 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $200 \Omega$ | 5 pF |
|  | Active Low | $200 \Omega$ | $200 \Omega$ | 5 pF |

## ELECTRONIC SIGNATURE

An electronic signature is provided in every GAL20V8 device. It contains 64 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature is included in checksum calculations. Changing the electronic signature will alter the checksum.

## SECURITY CELL

A security cell is provided in the GAL20V8 devices to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell.

## LATCH-UP PROTECTION

GAL20V8 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias minimizes the potential of latch-up caused by negative input undershoots. Additionally, outputs are designed with n-channel pull-ups instead of the traditional p-channel pull-ups in order to eliminate latch-up due to output overshoots.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers. Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because, in system operation, certain events occur that may throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

GAL20V8 devices include circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing text vectors perform output register preload automatically.

## INPUT BUFFERS

GAL20V8 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.

The GAL20V8 input and I/O pins have built-in active pull-ups. As a result, unused inputs and I/O's will float to a TTL "high" (logical "1"). Lattice recommends that all unused inputs and tri-stated I/O pins be connected to another active input, Vcc, or Ground. Doing this will tend to improve noise immunity and reduce Icc for the device.


## POWER-UP RESET



Circuitry within the GAL20V8 provides a reset signal to all registers during power-up. All internal registers will have their $Q$ outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. Because of the asynchronous nature of system power-up, some
conditions must be met to guarantee a valid power-up reset of the device. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

INPUT/OUTPUT EQUIVALENT SCHEMATICS


Typ. $\mathrm{Vref}=3.2 \mathrm{~V}$


Typical Input

Typical Output

## Specifications GAL20V8

## GAL 20V8C-5: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


## Specifications GAL20V8

GAL 20V8C-5: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


## GAL 20V8B-7/10: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



GAL 20V8B-7/10: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS

Vol vs lol


Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)


Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


Voh vs loh


Normalized Icc vs Freq.


## Specifications GAL20V8

## GAL 20V8B-15/25: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


GAL 20V8B-15/25: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS

Voh vs loh


Normalized Icc vs Freq.


Frequency $(\mathrm{MHz})$

Vol vs lol


Normalized Icc vs Vcc


Supply Voltage (V)

lol (mA)

Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


브부붑

Notes

GAL20V8Z GAL20V8ZD

FEATURES

- ZERO POWER E²CMOS TECHNOLOGY
- 100 1 A Standby Current
- Input Transition Detection on GAL20V8Z
— Dedicated Power-down Pin on GAL20V8ZD
- Input and Output Latching During Power Down
- HIGH PERFORMANCE E²CMOS TECHNOLOGY
- 12 ns Maximum Propagation Delay
- Fmax $=83.3 \mathrm{MHz}$
- 8 ns Maximum from Clock Input to Data Output
- TTL Compatible 16 mA Output Drive
- UltraMOS ${ }^{\bullet}$ Advanced CMOS Technology
- E2 CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- EIGHT OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- Programmable Output Polarity
- Architecturally Similar to Standard GAL20V8
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS - 100\% Functional Testability
- APPLICATIONS INCLUDE:
- Battery Powered Systems
- DMA Control
- State Machine Control
- High Speed Graphics Processing
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL20V8Z and GAL20V8ZD, at $100 \mu$ A standby current and 12ns propagation delay provides the highest speed and lowest power combination PLD available in the market. The GAL20V8ZIZD is manufactured using Lattice's advanced zero power $E^{2} C M O S$ process, which combines CMOS with Electrically Erasable ( $E^{2}$ ) floating gate technology.
The GAL20V8Z uses Input Transition Detection (ITD) to put the device in standby mode and is capable of emulating the full functionality of the standard GAL20V8. The GAL20V8ZD utilizes a dedicated power-down pin (DPP) to put the device in standby mode. It has 19 inputs available to the AND array.
Unique test circuitry and reprogrammable cells allow complete AC, DC, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all GAL products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.

FUNCTIONAL BLOCK DIAGRAM


PIN CONFIGURATION
DIP


## Specifications GAL20V8Z <br> GAL20V8ZD

## GAL 20V8Z/ZD ORDERING INFORMATION

GAL20V8Z: Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | ISB ( $\mu \mathrm{A})$ | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- | :---: |
| 12 | 10 | 8 | 55 | 100 | GAL20V8Z-12QP | 24-Pin Plastic DIP |
|  |  |  | 55 | 100 | GAL20V8Z-12QJ | 28-Lead PLCC |
| 15 | 15 | 10 | 55 | 100 | GAL20V8Z-15QP | 24-Pin Plastic DIP |
|  |  |  | 55 | 100 | GAL20V8Z-15QJ | 28-Lead PLCC |

## GAL20V8ZD: Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | ISB $(\mu \mathbf{A})$ | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :--- | :--- |
| 12 | 10 | 8 | 55 | 100 | GAL20V8ZD-12QP | 24-Pin Plastic DIP |
|  |  |  | 55 | 100 | GAL20V8ZD-12QJ | 28-Lead PLCC |
|  | 15 | 15 | 10 | 55 | 100 | GAL20V8ZD-15QP |
|  |  |  | 55 | 100 | GAL20V8ZD-Pin Plastic DIP |  |

## PART NUMBER DESCRIPTION

Device Name
GAL20V8Z (Zero Power ITD)
GAL20V8ZD (Zero Power DPP)
Speed (ns)
Active Power
Q = Quarter Power

## Grade

Blank = Commercial
Package
P = Plastic DIP
$J=P L C C$

## Specifications GAL20V8Z GAL20V8ZD

## OUTPUT LOGIC MACROCELL (OLMC)

The following discussion pertains to configuring the output logic macrocell. It should be noted that actual implementation is accomplished by development software/hardware and is completely transparent to the user.

There are three global OLMC configuration modes possible: simple, complex, and registered. Details of each of these modes is illustrated in the following pages. Two global bits, SYN and ACO, control the mode configuration for all macrocells. The

XOR bit of each macrocell controls the polarity of the output in any of the three modes, while the AC1 bit of each of the macrocells controls the input/output configuration. These two global and 16 individual architecture bits define all possible configurations in a GAL20V8Z/ZD. The information given on these architecture bits is only to give a better understanding of the device. Compiler software will transparently set these architecture bits from the pin definitions, so the user should not need to directly manipulate these architecture bits.

## COMPILER SUPPORT FOR OLMC

Software compilers support the three different global OLMC modes as different device types. Most compilers also have the ability to automatically select the device type, generally based on the register usage and output enable (OE) usage. Register usage on the device forces the software to choose the registered mode. All combinatorial outputs with OE controlled by the product term will force the software to choose the complex mode. The software will choose the simple mode only when all outputs are dedicated combinatorial without OE control. For further details, refer to the compiler software manuals.

When using compiler software to configure the device, the user must pay special attention to the following restrictions in each mode.

In registered mode pin 1(2) and pin 13(16) are permanently configured as clock and output enable, respectively. These pins cannot be configured as dedicated inputs in the registered mode.

In complex mode pin 1(2) and pin 13(16) become dedicated inputs and use the feedback paths of pin 22(26) and pin 15(18) respectively. Because of this feedback path usage, pin 22(26) and pin 15(18) do not have the feedback option in this mode.

In simple mode all feedback paths of the output pins are routed via the adjacent pins. In doing so, the two inner most pins ( pins 18(21) and 19(23)) will not have the feedback option as these pins are always configured as dedicated combinatorial output.

When using the standard GAL20V8 JEDEC fuse pattern generated by the logic compilers for the GAL20V8ZD, special attention must be given to pin 4(5) (DPP) to make sure that it is not used as one of the functional inputs.

## Specifications GAL20V8Z GAL20V8ZD

## REGISTERED MODE

In the Registered mode, macrocells are configured as dedicated registered outputs or as I/O functions.

Architecture configurations available in this mode are similar to the common 20R8 and 20RP4 devices with various permutations of polarity, I/O and register placement.

All registered macrocells share common clock and output enable control pins. Any macrocell can be configured as registered or I/O. Up to eight registers or up to eight I/O's are possible in this mode. Dedicated input or output functions can be implemented as subsets of the I/O function.

Registered outputs have eight product terms per output. I/O's have seven product terms per output.

Pin 4(5) is used as dedicated power-down pin on GAL20V8ZD. It cannot be used as functional input.

The JEDEC fuse numbers, including the User Electronic Signature (UES) fuses and the Product Term Disable (PTD) fuses, are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## REGISTERED MODE LOGIC DIAGRAM




## Specifications GAL20V8Z GAL20V8ZD

## COMPLEX MODE

In the Complex mode, macrocells are configured as output only or I/O functions.

Architecture configurations available in this mode are similar to the common 20L8 and 20P8 devices with programmable polarity in each macrocell.

Up to six I/O's are possible in this mode. Dedicated inputs or outputs can be implemented as subsets of the I/O function. The two outer most macrocells (pins 15(18) \& 22(26)) do not have input capability. Designs requiring eight I/O's can be implemented in the Registered mode.

All macrocells have seven product terms per output. One product term is used for programmable output enable control. Pins 1(2) and 13(16) are always available as data inputs into the AND array.

Pin 4(5) is used as dedicated power-down pin on GAL20V8ZD. It cannot be used as functional input.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

COMPLEX MODE LOGIC DIAGRAM


## SIMPLE MODE

In the Simple mode, macrocells are configured as dedicated inputs or as dedicated, always active, combinatorial outputs.

Architecture configurations available in this mode are similar to the common 14L8 and 16P6 devices with many permutations of generic output polarity or input choices.

All outputs in the simple mode have a maximum of eight product terms that can control the logic. In addition, each output has programmable polarity.

Pins 1(2) and 13(16) are always available as data inputs into the AND array. The center two macrocells (pins 18(21) \& 19(23)) cannot be used in the input configuration.

Pin 4(5) is used as dedicated power-down pin on GAL20V8ZD. It cannot be used as functional input.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## SIMPLE MODE LOGIC DIAGRAM



## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$. ... -.5 to +7 V
Input voltage applied ......................... -2.5 to $\mathrm{V}_{\mathrm{Cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cC}}+1.0 \mathrm{~V}$
Storage Temperature -65 to $150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) .............................. 0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ )
with Respect to Ground $\qquad$ +4.75 to +5.25 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION |  | MIN. | TYP. ${ }^{2}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  |  | Vss -0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  |  | 2.0 | - | Vcc+1 | V |
| IIL | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{V}_{\text {IL }}$ (MAX. ) |  | - | - | -10 | $\mu \mathrm{A}$ |
| lıH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{Vin}^{\text {S }}$ Vcc |  | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | Iol $=$ MAX. $\mathrm{Vin}_{\text {in }}=\mathrm{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ |  | - | - | 0.5 | V |
| VOH | Output High Voltage |  |  | 2.4 | - | - | V |
|  |  | $\mathrm{IOH}=-100 \mu \mathrm{~A} \quad \mathrm{Vin}=\mathrm{V}_{\text {IL }}$ | - ViH | Vcc-1 | - | - | V |
| IOL | Low Level Output Current |  |  | - | - | 16 | mA |
| IOH | High Level Output Current |  |  | - | - | -3.2 | mA |
| IOS ${ }^{1}$ | Output Short Circuit Current | $\mathrm{Vcc}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {out }}=0.5 \mathrm{~V}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -150 | mA |

## COMMERCIAL

| ISB | Stand-by Power <br> Supply Current | $V_{\mathrm{IL}}=\mathrm{GND}$ VIH = Vcc Outputs Open | Z-12/-15 <br> ZD-12/-15 | - | 50 | 100 | $\mu \mathrm{~A}$ |
| :---: | :--- | :--- | :--- | :--- | :--- | :---: | :---: |
| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ <br> ftoggle $=15 \mathrm{MHz}$ Outputs Open | Z-12/-15 <br> ZD-12/-15 | - | - | 55 | mA |

1) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
2) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{lo}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / 0}=2.0 \mathrm{~V}$ |

[^29]Specifications GAL2OV8Z

## AC SWITCHING CHARACTERISTICS

## Over Recommended Operating Conditions

|  |  |  |  | M |  | M |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TEST | D |  | 12 |  | 15 |  |
| PARAMETER | COND ${ }^{1}$. | DESCRIPTION | MIN. | MAX. | MIN. | MAX. | UNITS |
| tpd | A | Input or I/O to Combinational Output | 3 | 12 | 3 | 15 | ns |
| tco | A | Clock to Output Delay | 2 | 8 | 2 | 10 | ns |
| $\mathbf{t c} \mathbf{f}^{2}$ | - | Clock to Feedback Delay | - | 6 | - | 7 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 10 | - | 15 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, 1/(tsu + tco) | 55 | - | 40 | - | MHz |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with Internal Feedback, 1/(tsu + tcf) | 62.5 | - | 45.5 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 83.3 | - | 62.5 | - | MHz |
| twh | - | Clock Pulse Duration, High | 6 | - | 8 | - | ns |
| twl | - | Clock Pulse Duration, Low | 6 | - | 8 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 12 | - | 15 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 12 | - | 15 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 15 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | - | 12 | - | 15 | ns |
| tas | - | Last Active Input to Standby | 60 | 140 | 50 | 150 | ns |
| tsa ${ }^{4}$ | - | Standby to Active Output | 6 | 13 | 5 | 15 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Specification section.
3) Refer to fmax Specification section.
4) Add tsa to tpd, tsu, ten and tdis when the device is coming out of standby state.

## STANDBY POWER TIMING WAVEFORMS



* Note: Rising clock edges are allowed during tsa but outputs are not guaranteed.


## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

|  |  |  | CO | M | CO | OM |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TEST | D | -1 | 12 | -1 | 15 |  |
| PARAMETER | COND ${ }^{1}$. | DESCRIPTION | MIN. | MAX. | MIN. | MAX. | S |
| tpd | A | Input or I/O to Combinational Output | 3 | 12 | 3 | 15 | ns |
| tco | A | Clock to Output Delay | 2 | 8 | 2 | 10 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay | - | 6 | - | 7 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 10 | - | 15 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco) | 55 | - | 40 | - | MHz |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 62.5 | - | 45.5 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 83.3 | - | 62.5 | - | MHz |
| twh | - | Clock Pulse Duration, High | 6 | - | 8 | - | ns |
| twl | - | Clock Pulse Duration, Low | 6 | - | 8 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 12 | - | 15 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 12 | - | 15 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 15 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | - | 12 | - | 15 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Specification section.
3) Refer to fmax Specification section.

Specifications GAL20V8ZD

DEDICATED POWER-DOWN PIN SPECIFICATIONS

## Over Recommended Operating Conditions

|  |  |  | $\frac{\mathrm{COM}}{-12}$ |  | COM |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PARAMETER | $\begin{aligned} & \text { TEST } \\ & \text { COND }{ }^{1} . \end{aligned}$ | DESCRIPTION |  |  | -15 |  | UNITS |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| twhd | - | DPP Pulse Duration High | 12 | - | 15 | - | ns |
| twld | - | DPP Pulse Duration Low | 25 | - | 30 | - | ns |

## ACTIVE TO STANDBY

| tivdh | - | Valid Input before DPP High | 5 | - | 8 | - | ns |
| :---: | :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| tgvdh | - | Valid OE before DPP High | 0 | - | 0 | - | ns |
| tcvdh | - | Valid Clock Before DPP High | 0 | - | 0 | - | ns |
| tdhix | - | Input Don't Care after DPP High | - | 2 | - | 5 | ns |
| tdhgx | - | $\overline{\text { OE Don't Care after DPP High }}$ | - | 6 | - | 9 | ns |
| tdhcx | - | Clock Don't Care after DPP High | - | 8 | - | 11 | ns |

## STANDBY TO ACTIVE

| tdliv | - | DPP Low to Valid Input | 12 | - | 15 | - | ns |
| :---: | :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| tdlgv | - | DPP Low to Valid $\overline{\text { OE }}$ | 16 | - | 20 | - | ns |
| tdicv | - | DPP Low to Valid Clock | 18 | - | 20 | - | ns |
| tdlov | A | DPP Low to Valid Output | 5 | 24 | 5 | 30 | ns |

1) Refer to Switching Test Conditions section.

## DEDICATED POWER-DOWN PIN (DPP) TIMING WAVEFORMS

DPP

INPUT or I/O FEEDBACK
$\overline{O E}$

CLK

OUTPUT


## Specifications GAL20V8Z GAL20V8ZD

## SWITCHING WAVEFORMS



Combinatorial Output


Input or I/O to Output Enable/Disable


Clock Width


## Registered Output



OE to Output Enable/Disable

fmax with Feedback

## fmax SPECIFICATIONS


fmax with External Feedback 1/(tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.

fmax with No Feedback
Note: fmax with no feedback may be less than $1 /($ twh $+\mathbf{t w l})$. This is to allow for a clock duty cycle of other than $50 \%$.


## fmax with Internal Feedback $\mathbf{1 / ( t s u + t c f )}$

Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback (tcf = $1 / \mathrm{fmax}-\mathrm{tsu}$ ). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to $\mathbf{t c f}+\mathbf{t p d}$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3-state levels are measured 0.5 V from steady-state active level.
Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R 2}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :---: | :---: | :---: | :---: |
| A |  | $300 \Omega$ | $390 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 50 pF |
|  | Active High | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 5 pF |

FROM OUTPUT (O/Q) UNDER TEST

*C ${ }_{L}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

## ELECTRONIC SIGNATURE

An electronic signature word is provided in every GAL20V8Z/ZD device. It contains 64 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature is included in checksum calculations. Changing the electronic signature will alter checksum.

## SECURITY CELL

A security cell is provided in the GAL20V8Z/ZD devices to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. The electronic signature data is always available to the user, regardless of the state of this security cell.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers (see the GAL Development Tools Section of the Data Book). Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle

## INPUT TRANSITION DETECTION (ITD)

The GAL20V8Z relies on its internal input detection circuitry to put the device in power down mode. If there is no input transition for the specified period of time, the device will go into the power down state. Any valid input transition will put the device back into active state. The first rising clock transition from power-down state only acts as a wake up signal into the device and will not clock the data input through to the output (refer to standby power timing waveform for more detail). Any input pulse widths greater than 5 ns at input voltage level of 1.5 V will be detected as input transition. The device will not detect any input pulse widths less than 1 ns measured at input voltage level of 1.5 V as input transition.

## DEDICATED POWER-DOWN PIN (DPP)

The GAL20V8ZD uses pin 4 (pin 5 on PLCC) as the dedicated power-down signal to put the device in power-down state. DPP is an active high signal where logic high driven on this signal puts the device into power-down state. Input pin 4 (5) cannot be used as a functional input on this device.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because, in system operation, certain events occur that may throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

The GAL20V8Z/ZD devices includes circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing text vectors perform output register preload automatically.

## INPUT BUFFERS

GAL20V8Z/ZD devices are designed with TTL level compatible input buffers. These buffers, with their characteristically high impedance, load driving logic much less than traditional bipolar devices. This allows for a greater fan out from the driving logic.

GAL20V8Z/ZD input buffers have latches within the buffers. As a result, when the device goes into standby mode the inputs will be latched to its values prior to standby. In order to overcome the input latches, they will have to be driven by an external source. Lattice recommends that all unused inputs and tri-stated I/O pins for both devices be connected to another active input, $\mathrm{V}_{\mathrm{cc}}$, or GND. Doing this will tend to improve noise immunity and reduce $I_{c c}$ for the device.

## Typical Input Characteristic



POWER-UP RESET


Circuitry within the GAL20V8Z/ZD provides a reset signal to all registers during power-up. All internal registers will have their $Q$ outputs set low after a specified time (tpr, $1 \mu \mathrm{~s} \mathrm{MAX}$ ). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown below. Because of the
asynchronous nature of system power-up, some conditions must be met to guarantee a valid power-up reset of the GAL20V8Z/ZD. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

## INPUT/OUTPUT EQUIVALENT SCHEMATICS



Typical Input


Typical Output

## Specifications GAL20V8Z <br> GAL20V8ZD

## TYPICAL AC AND DC CHARACTERISTICS



Normalized Tpd vs Temp


Normalized Tco vs Vcc


Normalized Tco vs Temp


Normalized Tsu vs Vcc


Normalized Tsu vs Temp


Delta Tpd vs \＃of Outputs Switching

Delta Tco vs \＃of Outputs Switching


Delta Tco vs Output Loading


TYPICAL AC AND DC CHARACTERISTICS

Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


Vik (V)


Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)


Vin (V)

Voh vs loh


Normalized Icc vs Freq. (DPP
\& ITD $>10 \mathrm{MHz}$ )


Normalized lcc vs Freq. (ITD)


Frequency ( KHz )

Notes

GAL20VP8
High-Speed E²CMOS PLD Generic Array Logic ${ }^{\text {TM }}$

## FEATURES

- HIGH DRIVE E²CMOS ${ }^{\circledR}$ GAL®$^{\circledR}$ DEVICE
- TTL Compatible 64 mA Output Drive
- 15 ns Maximum Propagation Delay
- Fmax $=80 \mathrm{MHz}$
- 10 ns Maximum from Clock Input to Data Output
- UltraMOS ${ }^{\circledR}$ Advanced CMOS Technology
- ENHANCED INPUT AND OUTPUT FEATURES
- Schmitt Trigger Inputs
- Programmable Open-Drain or Totem-Pole Outputs
- Active Pull-Ups on All Inputs and I/O pins
- E ${ }^{2}$ CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure (<100ms)
- 20 Year Data Retention


## - EIGHT OUTPUT LOGIC MACROCELLS

- Maximum Flexibility for Complex Logic Designs
- Programmable Output Polarity
- Architecturally Compatible with Standard GAL20V8
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS - 100\% Functional Testability


## - APPLICATIONS INCLUDE:

- Ideal for Bus Control \& Bus Arbitration Logic
- Bus Address Decode Logic
- Memory Address, Data and Control Circuits
- DMA Control


## - ELECTRONIC SIGNATURE FOR IDENTIFICATION

## DESCRIPTION

The GAL20VP8, with 64 mA drive capability and 15 ns maximum propagation delay time is ideal for Bus and Memory control applications. The GAL20VP8 is manufactured using Lattice's advanced $\mathrm{E}^{2} \mathrm{CMOS}$ process which combines CMOS with Electrically Erasable ( $E^{2}$ ) floating gate technology. High speed erase times ( $<100 \mathrm{~ms}$ ) allow the devices to be reprogrammed quickly and efficiently.
System bus and memory interfaces require control logic before driving the bus or memory interface signals. The GAL20VP8 combines the familiar GAL20V8 architecture with bus drivers as its outputs. The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The 64 mA output drive eliminates the need for additional devices to provide bus-driving capability.

Unique test circuitry and reprogrammable cells allow complete AC, DC, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all GAL products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.

## FUNCTIONAL BLOCK DIAGRAM




[^30]Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

## GAL20VP8 ORDERING INFORMATION

## Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 15 | 8 | 10 | 115 | GAL20VP8B-15LP | 24-Pin Plastic DIP |
|  |  |  | 115 | GAL20VP8B-15LJ | 28-Lead PLCC |
| 25 | 10 | 15 | 115 | GAL20VP8B-25LP | 24-Pin Plastic DIP |
|  |  |  | 115 | GAL20VP8B-25LJ | 28-Lead PLCC |

## PART NUMBER DESCRIPTION



## OUTPUT LOGIC MACROCELL (OLMC)

The following discussion pertains to configuring the output logic macrocell. It should be noted that actual implementation is accomplished by development software/hardware and is completely transparent to the user.

There are three global OLMC configuration modes possible: simple, complex, and registered. Details of each of these modes is illustrated in the following pages. Two global bits, SYN and ACO, control the mode configuration for all macrocells. The XOR bit of each macrocell controls the polarity of the output in any
of the three modes, while the AC1 and AC2 bit of each of the macrocells controls the input/output and totem-pole/open-drain configuration. These two global and 24 individual architecture bits define all possible configurations in a GAL20VP8. The information given on these architecture bits is only to give a better understanding of the device. Compiler software will transparently set these architecture bits from the pin definitions, so the user should not need to directly manipulate these architecture bits.

## COMPILER SUPPORT FOR OLMC

Software compilers support the three different global OLMC modes as different device types. Most compilers also have the ability to automatically select the device type, generally based on the register usage and output enable (OE) usage. Register usage on the device forces the software to choose the registered mode. All combinatorial outputs with OE controlled by the product term will force the software to choose the complex mode. The software will choose the simple mode only when all outputs are dedicated combinatorial without OE control. For further details, refer to the compiler software manuals.

When using compiler software to configure the device, the user must pay special attention to the following restrictions in each mode.
In registered mode pin 1(2) and pin 12(14) are permanently configured as clock and output enable, respectively. These pins cannot be configured as dedicated inputs in the registered mode.

In complex mode pin 1(2) and pin 12(14) become dedicated inputs and use the feedback paths of pin 22(26) and pin 14(17) respectively. Because of this feedback path usage, pin 22(26) and pin 14(17) do not have the feedback option in this mode.

In simple mode all feedback paths of the output pins are routed via the adjacent pins. In doing so, the two inner most pins (pins 17(20) and 19(23)) will not have the feedback option as these pins are always configured as dedicated combinatorial output.

In addition to the architecture configurations, the logic compiler software also supports configuration of either totem-pole or opendrain outputs. The actual architecture bit configuration, again, is transparent to the user with the default configuration being the standard totem-pole output.

Specifications GAL20VP8

## REGISTERED MODE

In the Registered mode, macrocells are configured as dedicated registered outputs or as I/O functions.

All registered macrocells share common clock and output enable control pins. Any macrocell can be configured as registered or I/O. Up to eight registers or up to eight I/O's are possible in this mode. Dedicated input or output functions can be implemented as subsets of the I/O function.

Registered outputs have eight product terms per output. I/O's have seven product terms per output.

The JEDEC fuse numbers, including the User Electronic Signature (UES) fuses and the Product Term Disable (PTD) fuses, are shown on the logic diagram on the following page.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

Specifications GAL20VP8

REGISTERED MODE LOGIC DIAGRAM


## Specifications GAL20VP8

## COMPLEX MODE

In the Complex mode, macrocells are configured as output only or I/O functions.

Up to six I/O's are possible in this mode. Dedicated inputs or outputs can be implemented as subsets of the I/O function. The two outer most macrocells (pins 14(17) \& 22(26)) do not have input capability. Designs requiring eight I/O's can be implemented in the Registered mode.

All macrocells have seven product terms per output. One product term is used for programmable output enable control. Pins 1(2) and 12(14) are always available as data inputs into the AND array.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram on the following page.

|  | Combinatorial I/O Configuration for Complex Mode <br> $-\mathrm{SYN}=1$. <br> - $\mathrm{ACO}=1$. <br> - XOR=0 defines Active Low Output. <br> - XOR=1 defines Active High Output. <br> - AC1 has no effect on this mode. <br> - AC2=1 defines totem pole output. <br> - AC2=0 defines open-drain output. <br> - Pin 15(18) through Pin 21(25) are configured to this function. |
| :---: | :---: |
|  | Combinatorial Output Configuration for Complex Mode <br> $-\mathrm{SYN}=1$. <br> - $A C O=1$. <br> - XOR=0 defines Active Low Output. <br> - XOR=1 defines Active High Output. <br> - AC1 has no effect on this mode. <br> - AC2=1 defines totem pole output. <br> - AC2=0 defines open-drain output. <br> - Pin 14(17) and Pin 22(26) are configured to this function. |

Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## Specifications GAL20VP8

## COMPLEX MODE LOGIC DIAGRAM



## SIMPLE MODE

In the Simple mode, macrocells are configured as dedicated inputs
or as dedicated, always active, combinatorial outputs.

All outputs in the simple mode have a maximum of eight product terms that can control the logic. In addition, each output has programmable polarity.

Pins 1(2) and 12(14) are always available as data inputs into the AND array. The center two macrocells (pins 17(20) \& 19(23)) cannot be used in the input configuration.

The JEDEC fuse numbers including the UES fuses and PTD fuses are shown on the logic diagram.


Note: The development software configures all of the architecture control bits and checks for proper pin usage automatically.

## SIMPLE MODE LOGIC DIAGRAM



## Specifications GAL20VP8

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

## Supply voltage $\mathrm{V}_{\mathrm{cc}}$ <br> $\qquad$ <br> Input voltage applied ......................... -2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ <br> Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cC}}+1.0 \mathrm{~V}$ <br> Storage Temperature ................................. 65 to $150^{\circ} \mathrm{C}$ <br> Ambient Temperature with <br> Power Applied <br> $\qquad$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) $\qquad$ 0 to $75^{\circ} \mathrm{C}$ Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.75 to +5.25 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{4}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss - 0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| $\mathrm{V}_{1}{ }^{1}$ | Input Clamp Voltage | Vcc $=$ Min. $\quad \mathrm{lin}=-32 \mathrm{~mA}$ | - |  | -1.2 | V |
| IIL2 ${ }^{\text {2 }}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{VIL}^{\text {(MAX. }}$ ) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {cc }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage |  | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}_{\text {= }}$ MAX. $\quad$ Vin $=\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 64 | mA |
| IOH | High Level Output Current |  | - | - | -32 | mA |
| $\mathrm{lOS}^{3}$ | Output Short Circuit Current | V cc $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -60 | - | -400 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-15 /-25$ | - | 90 | 115 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :---: | :---: |

[^31]
## AC SWITCHING CHARACTERISTICS

## Over Recommended Operating Conditions

|  |  |  |  | M |  | M |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TEST | DESCRIPTION |  | 5 |  | 5 |  |
| PARAMETER | COND ${ }^{1}$. |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinational Output | 3 | 15 | 3 | 25 | ns |
| tco | A | Clock to Output Delay | 2 | 10 | 2 | 15 | ns |
| $\mathbf{t c} f^{2}$ | - | Clock to Feedback Delay | - | 4.5 | - | 10 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 8 | - | 10 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
|  | A | Maximum Clock Frequency with External Feedback, $1 /(\mathrm{tsu}+\mathrm{tco})$ | 55.5 | - | 40 | - | MHz |
| $\mathbf{f m a x}^{3}$ | A | Maximum Clock Frequency with Internal Feedback, $1 /(\mathrm{tsu}+\mathrm{tcf})$ | 80 | - | 50 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 80 | - | 50 | - | MHz |
| twh | - | Clock Pulse Duration, High | 6 | - | 10 | - | ns |
| twl | - | Clock Pulse Duration, Low | 6 | - | 10 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 15 | - | 20 | ns |
|  | B | $\overline{\text { OE }}$ to Output Enabled | - | 12 | - | 15 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 20 | ns |
|  | C | $\overline{\text { OE }}$ to Output Disabled | - | 12 | - | 15 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Specification section.
3) Refer to fmax Specification section.

## CAPACITANCE ( $\mathrm{T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{IO}}$ | I/O Capacitance | 15 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IO}}=2.0 \mathrm{~V}$ |

[^32]
Specifications GAL20VP8


## SWITCHING WAVEFORMS



## Combinatorial Output

INPUT or I/O FEEDBACK


Input or I/O to Output Enable/Disable


Clock Width

INPUT or I/O FEEDBACK

CLK

REGISTERED OUTPUT


OE to Output Enable/Disable

fmax with Feedback

## fmax DESCRIPTIONS


fmax with External Feedback 1/(tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.


Note: fmax with no feedback may be less than $1 /(\mathrm{twh}+\mathrm{twl})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback $\mathbf{1 / ( t s u + t c f )}$
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback (tcf = $1 / \mathrm{fmax}-\mathrm{tsu}$ ). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to tcf + tpd.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3 -state levels are measured 0.5 V from steady-state active level.
Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{1}$ | $\mathbf{R 2}_{\mathbf{2}}$ | $\mathbf{C L}^{2}$ |
| :---: | :---: | :---: | :---: | :---: |
| A |  | $500 \Omega$ | $500 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $500 \Omega$ | 50 pF |
|  | Active Low | $500 \Omega$ | $500 \Omega$ | 50 pF |
|  | Active High | $\infty$ | $500 \Omega$ | 5 pF |
|  | Active Low | $500 \Omega$ | $500 \Omega$ | 5 pF |


*C ${ }^{\text {L }}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

## ELECTRONIC SIGNATURE

An electronic signature word is provided in every GAL20VP8 device. It contains 64 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature is included in checksum calculations. Changing the electronic signature will alter the checksum.

## SECURITY CELL

The security cell is provided on all GAL20VP8 devices to prevent unauthorized copying of the array patterns. Once programmed, the circuitry enabling array is disabled, preventing further programming or verification of the array. The cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. Signature data is always available to the user.

## LATCH-UP PROTECTION

GAL20VP8 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with n-channel pullups instead of the traditional p-channel pull-ups to eliminate any possibility of SCR induced latching.

## BULK ERASE MODE

During a programming cycle, a clear function performs a bulk erase of the array and the architecture word. In addition, the electronic signature word and the security cell are erased. This mode resets a previously configured device back to its original state, which is all JEDEC ones.

## SCHMITT TRIGGER INPUTS

One of the enhancements of the GAL20VP8 for bus interface logic implementation is input hysteresis. The threshold of the positive going edge is 1.5 V , while the threshold of the negative going edge is 1.3 V . This provides a typical hysteresis of 200 mV between positive and negative transitions of the inputs.

## HIGH DRIVE OUTPUTS

All eight outputs of the GAL20VP8 are capable of driving 64 mA loads when driving low and 32 mA loads when driving high. Near symmetrical high and low output drive capability provides small skews between high-to-low and low-to-high output transitions.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because, in system operation, certain events occur that may throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

The GAL20VP8 device includes circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing test vectors can perform output register preload automatically.

## INPUT BUFFERS

The GAL20VP8 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.

GAL20VP8 input buffers have active pull-ups within their input structure. As a result, unused inputs and I/O's will float to a TTL "high" (logical "1"). Lattice recommends that all unused inputs and tri-stated I/O pins for both devices be connected to another active input, $\mathrm{V}_{\mathrm{cc}}$, or GND . Doing this will tend to improve noise immunity and reduce $I_{c c}$ for the device.

## Typical Input Pull-up Characteristic



## PROGRAMMABLE OPEN-DRAIN OUTPUTS

In addition to the standard GAL20V8 type configuration, the outputs of the GAL20VP8 are individually programmable either as a standard totempole output or an open-drain output. The totempole output drives the specified $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ levels whereas the open-drain output drives only the specified $\mathrm{V}_{\mathrm{OL}}$. The $\mathrm{V}_{\mathrm{OH}}$ level on the open-drain ouput depends on the external loading and pullup. This output configuration is controlled by the AC2 fuse. When AC2 cell is erased (JEDEC "1") the output is configured as a totempole output and when AC2 cell is programmed (JEDEC "0") the output is configured as an open-drain. The default configuration when the device is in bulk erased state is totempole configuration. The AC2 fuses associated with each of the outputs is included in all of the logic diagrams.

POWER-UP RESET


Circuitry within the GAL20VP8 provides a reset signal to all registers during power-up. All internal registers will have their $Q$ outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown above. Because of the asynchro-
nous nature of system power-up, some conditions must be met to guarantee a valid power-up reset of the GAL20VP8. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

INPUT/OUTPUT EQUIVALENT SCHEMATICS


TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching



## Specifications GAL20VP8

## TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)


Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


Voh vs loh


Normalized Icc vs Freq.


High-Speed E²CMOS PLD Generic Array Logic ${ }^{\text {TM }}$

## FEATURES

- HIGH PERFORMANCE E²CMOS ${ }^{\circledR}$ TECHNOLOGY
- 10 ns Maximum Propagation Delay
- Fmax $=100 \mathrm{MHz}$
- 7 ns Maximum from Clock Input to Data Output
- TTL Compatible 16 mA Outputs
- UltraMOS ${ }^{\circledR}$ Advanced CMOS Technology
- 50\% to 75\% REDUCTION IN POWER FROM BIPOLAR - 90mA Max Icc
- 75mA Typ Icc
- ACTIVE PULL-UPS ON ALL PINS
- E ${ }^{2}$ CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- TEN OUTPUT LOGIC MACROCELLS
- XOR Gate Capability on all Outputs
- Full Function and Parametric Compatibility with

PAL12L10, 20L10, 20X10, 20X8, 20X4

- Registered or Combinatorial with Polarity


## - PRELOAD AND POWER-ON RESET OF ALL REGISTERS

- APPLICATIONS INCLUDE:
- High Speed Counters
- Graphics Processing
- Comparators


## - ELECTRONIC SIGNATURE FOR IDENTIFICATION

## DESCRIPTION

The GAL20XV10 combines a high performance CMOS process with electrically erasable ( $E^{2}$ ) floating gate technology to provide the highest speed Exclusive-OR PLD available in the market. At 90 mA maximum Icc ( 75 mA typical Icc), the GAL20XV10 provides a substantial savings in power when compared to bipolar counterparts. $E^{2} C M O S$ technology offers high speed ( $<100 \mathrm{~ms}$ ) erase times providing the ability to reprogram, reconfigure or test the devices quickly and efficiently.
The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. An important subset of the many architecture configurations possible with the GAL20XV10 are the $\mathrm{PAL}^{\circledR}$ architectures listed in the macrocell description section of this document. The GAL20XV10 is capable of emulating these PAL architectures with full function and parametric compatibility.
Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacturing. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all $\mathrm{GAL}^{\circledR}$ products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.


PACKAGE DIAGRAMS


DIP


[^33]
## Specifications GAL20XV10

GAL20XV10 ORDERING INFORMATION

## Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 10 | 6 | 7 | 90 | GAL20XV10B-10LP | 24-Pin Plastic DIP |
|  |  |  |  | GAL20XV10B-10LJ | 28-Lead PLCC |
| 15 | 8 | 8 | 90 | GAL20XV10B-15LP | 24-Pin Plastic DIP |
|  |  |  |  | GAL20XV10B-15LJ | 28 -Lead PLCC |
| 20 | 10 | 10 | 90 | GAL20XV10B-20LP | 24-Pin Plastic DIP |
|  |  |  |  | GAL20XV10B-20LJ | 28-Lead PLCC |

## PART NUMBER DESCRIPTION



## OUTPUT LOGIC MACROCELL (OLMC)

The following discussion pertains to configuring the Output Logic Macrocell. It should be noted that actual implementation is accomplished by development software/hardware and is completely transparent to the user.

The GAL20XV10 has two global architecture configurations that allow it to emulate PAL architectures. The Input mode emulates combinatorial PAL devices, with the I/CLK and I/OE pins used as inputs. The Feedback mode emulates registered PAL devices with the I/CLK pin used as the register clock and the I/OE pin as an output enable for all registers. The following is a list of PAL architectures that the GAL20XV10 can emulate. It also shows the global architecture mode used to emulate the PAL architecture.

| PAL Architectures Emulated by <br> GAL20XV10 | GAL20XV10 Global <br> OLMC Mode |
| :---: | :---: |
| PAL12L10 | Input Mode |
| PAL20L10 | Input Mode |
| PAL20X10 | Feedback Mode |
| PAL20X8 | Feedback Mode |
| PAL20X4 | Feedback Mode |

## INPUT MODE

The Input mode architecture is defined when the global architecture bit SYN=1. In this mode, the I/CLK pin becomes an input to the AND array and also provides the clock source for all registers. The I/OE pin becomes an input into the AND array and provides the output enable control for any macrocell configured as an Exclusive-OR function. Feedback into the AND array is provided from macrocells 2 through 9 only. In this mode, macrocells 1 and 10 have no feedback into the AND array.

## FEEDBACK MODE

The Feedback mode architecture is defined when the global architecture bit SYN = 0 . In this mode the I/CLK pin becomes a dedicated clock source for all registers. The I/OE pin is a dedicated output enable control for any macrocell configured as an Exclusive-OR function. The I/CLK and I/OE pins are not available to the AND array in this mode. Feedback into the AND array is provided on all macrocells 1 through 10.

## FEATURES

Each Output Logic Macrocell has four possible logic function configurations controlled by architecture control bits ACO and AC1. Four product terms are fed into each macrocell.

## XOR REGISTERED CONFIGURATION

The Macrocell is set to the Exclusive-OR Registered configuration when $A C 0=0$ and $A C 1=0$. The four product terms are segmented into two OR-sums of two product terms each, which are then combined by an Exclusive-OR gate and fed into a D-type register. The register is clocked by the low-to-high transition of the I/CLK pin. The inverting output buffer is enabled by the $\mathrm{I} / \overline{\mathrm{OE}}$ pin, which is an active low output enable common to all

Exclusive-OR macrocells. In Feedback mode, the state of the register is available to the AND array via an internal feedback path on all macrocells. In Input mode, the state of the register is available to the AND array via an internal feedback path on macrocells 2 through 9 only, macrocells 1 and 10 have no feedback into the AND array.

## REGISTERED CONFIGURATION

The Macrocell is set to Registered configuration when $\mathrm{ACO}=1$ and $A C 1=0$. Three of the four product terms are used as sum-of-product terms for the D input of the register. The inverting output buffer is enabled by the fourth product term. The output is enabled while this product term is true. The XOR bit controls the polarity of the output. The register is clocked by the low-to-high transition of the I/CLK. In Feedback mode, the state of the register is available to the AND array via an internal feedback path on all macrocells. In Input mode, the state of the register is available to the AND array via an internal feedback path on macrocells 2 through 9 only, macrocells 1 and 10 have no feedback into the AND array.

## XOR COMBINATORIAL CONFIGURATION

The Macrocell is set to the Exclusive-OR Combinatorial configuration when $A C 0=0$ and $A C 1=1$. The four product terms are segmented into two OR-sums of two product terms each, which are then combined by an Exclusive-OR gate and fed to an output buffer. The inverting output buffer is enabled by the I/ $\overline{O E}$ pin, which is an active low output enable that is common to all XOR macrocells. In Feedback mode, the state of the I/O pin is available to the AND array via an internal feedback path on all macrocells. In Input mode, the state of the I/O pin is available to the AND array via an input buffer path on macrocells 2 through 9 only, macrocells 1 and 10 have no input into the AND array.

## COMBINATORIAL CONFIGURATION

The Macrocell is set to Combinatorial mode when $A C O=1$ and $A C 1=1$. Three of the four product terms are used as sum-of-product terms for the combinatorial output. The XOR bit controls the polarity of the output. The inverting output buffer is enabled by the fourth product term. The output is enabled while this product term is true. In Feedback mode, the state of the I/O pin is available to the AND array via an internal feedback path on all macrocells. In Input mode, the state of the I/O pin is available to the AND array via an input buffer path on macrocells 2 through 9 only, macrocells 1 and 10 have no input into the AND array.

## XOR Registered Configuration

- SYN $=1$.
$-\mathrm{ACO}=0$.
$-\mathrm{AC} 1=0$.
- OLMC 1 and OLMC10 do not have the feedback path.
- Pin 1(2) can be CLK and/or Input.
- Pin 13(16) can be $\overline{\mathrm{OE}}$ and/or Input.



## Registered Configuration

$-S Y N=1$.
$-A C O=1$.
$-\mathrm{AC} 1=0$.

- XOR = 1 defines Active Low Output.
- XOR $=0$ defines Active High Output.
- OLMC 1 and OLMC10 do not have the feedback path.
- Pin 1(2) can be CLK and/or Input.
- OE controlled by product term.


XOR Combinatorial Configuration

- SYN = 1 .
$-\mathrm{ACO}=0$.
$-\mathrm{AC} 1=1$.
- OLMC 1 and OLMC10 do not have the feedback path.
- Pin 13(16) can be $\overline{\mathrm{OE}}$ and/or Input.


Combinatorial Configuration

- SYN $=1$.
$-\mathrm{ACO}=1$.
$-\mathrm{AC} 1=1$.
- XOR = 1 defines Active Low Output.
- XOR = 0 defines Active High Output.
- OLMC 1 and OLMC10 do not have the feedback path.
- OE controlled by product term.


## Specifications GAL20XV10

## INPUT MODE LOGIC DIAGRAM

DIP (PLCC) Package Pinout


## FEEDBACK MODE

|  | XOR Registered Configuration $\begin{aligned} & -S Y N=0 . \\ & -A C O=0 . \\ & -A C 1=0 . \end{aligned}$ <br> - Dedicated CLK input on Pin 1(2). <br> - Dedicated $\overline{O E}$ input on Pin 13(16). |
| :---: | :---: |
|  | Registered Configuration <br> - SYN $=0$. <br> $-\mathrm{ACO}=1$. <br> $-\mathrm{AC} 1=0$. <br> - XOR = 1 defines Active Low Output. <br> - XOR = 0 defines Active High Output. <br> - Dedicated CLK input on Pin 1(2). <br> - OE controlled by product term. <br> - Pin 13(16) is not connected to this configuration. |
|  | XOR Combinatorial Configuration <br> - SYN $=0$. <br> $-\mathrm{ACO}=0$. <br> $-\mathrm{AC} 1=1$. <br> - Dedicated $\overline{\mathrm{OE}}$ input on Pin 13(16). <br> - Pin 1 (2) is not connected to this configuration. |
|  | Combinatorial Configuration <br> - SYN $=0$. <br> $-\mathrm{ACO}=1$. <br> $-\mathrm{AC}=1$. <br> - XOR = 1 defines Active Low Output. <br> - XOR = 0 defines Active High Output. <br> - OE controlled by product term. <br> - Both pin1(2) and pin 13(16) are not connected to this configuration. |

## Specifications GAL20XV10

## FEEDBACK MODE LOGIC DIAGRAM

## DIP (PLCC) Package Pinout



40-USER ELECTRONIC SIGNATURE FUSES

| 1631, $1632, \ldots$ |  | $\ldots .1669,1670$ |
| :--- | :--- | :--- |
| Byte4 | Byte3 .... | .... Byte1 |
| Byte0 |  |  |

SYN - 1630

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage Vcc $\qquad$ -0.5 to +7 V
Input voltage applied -2.5 to $\mathrm{Vcc}+1.0 \mathrm{~V}$
Off-state output voltage applied ......... -2.5 to $\mathbf{V} \mathrm{cc}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ -65 to $150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) ............................ 0 to $+75^{\circ} \mathrm{C}$
Supply voltage (Vcc) with Respect to Ground +4.75 to +5.25 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss - 0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | $\mathbf{V} \mathrm{c}+1$ | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or l/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{VIN}^{\text {S }} \mathrm{V}$ cc | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathbf{l o L}=$ MAX. Vin $=\mathbf{V I L}_{\text {L }}$ or $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=$ MAX. $\quad \mathbf{V i n}=\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| $\mathrm{lOS}^{2}$ | Output Short Circuit Current | $\mathrm{Vcc}=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -50 | - | -150 | mA |

COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-10 /-15 /-20$ | - | 75 | 90 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :---: | :---: |

1) The leakage current is due to the internal pull-up on all input and I/O pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

|  |  |  | CO | M | CO | M |  | M |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | EST |  | -1 | 0 | -1 | 5 |  | 20 |  |
| PARAMETER | COND. ${ }^{1}$ | DESCRIPTION | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | S |
| tpd | A | Input or I/O to Combinatorial Output | 3 | 10 | 3 | 15 | 3 | 20 | ns |
| tco | A | Clock to Output Delay | 2 | 7 | 2 | 8 | 2 | 10 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay | - | 4 | - | 4 | - | 4 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 6 | - | 8 | - | 10 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco) | 76.9 | - | 62.5 | - | 50 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 100 | - | 83.3 | - | 71.4 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 100 | - | 83.3 | - | 71.4 | - | MHz |
| twh | - | Clock Pulse Duration, High | 4 | - | 6 | - | 7 | - | ns |
| twl | - | Clock Pulse Duration, Low | 4 | - | 6 | - | 7 | - | ns |
| ten | B | Input or I/O to Output Enabled | 3 | 10 | 3 | 15 | 3 | 20 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | 2 | 9 | 2 | 10 | 2 | 15 | ns |
| tdis | C | Input or I/O to Output Disabled | 3 | 9 | 3 | 15 | 3 | 20 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | 2 | 9 | 2 | 10 | 2 | 15 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Description section.
3) Refer to fmax Description section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathbf{C}_{\mathrm{I}}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathbf{V}_{1}=2.0 \mathrm{~V}$ |
| $\mathbf{C}_{/ / \mathrm{O}}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / 0}=2.0 \mathrm{~V}$ |

*Guaranteed but not 100\% tested.

## Specifications GAL20XV10

## SWITCHING WAVEFORMS



INPUT or I/O FEEDBACK

OUTPUT


Input or I/O Feedback to Enable/Disable

CLK


Clock Width

INPUT or I/O FEEDBACK

CLK

REGISTERED OUTPUT

$\overline{O E}$

OUTPUT


OE to Output Enable/Disable

fmax with Feedback

## INPUT/OUTPUT EQUIVALENT SCHEMATICS



Typical Input



Typical Output

## fmax DESCRIPTIONS

Specifications GAL20XV10
fmax with External Feedback $1 /($ tsu + tco)
Note: fmax with external feedback is calculated from measured tsu and tco.


Note: fmax with no feedback may be less than $1 /(\mathrm{twh}+\mathrm{twl})$. This is to allow for a clock duty cycle of other than $50 \%$.


SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3-state levels are measured 0.5 V from steady-state active level.
Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :---: | :---: | :---: | :---: |
| A | Active High | $300 \Omega$ | $390 \Omega$ | 50 pF |
|  | Active Low | $\infty$ | $390 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 5 pF |



## fmax with Internal Feedback $\mathbf{1 / ( t s u + t c f )}$

Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback ( $\mathrm{tcf}=1 / \mathrm{fmax}-\mathrm{tsu}$ ). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to $\mathrm{tcf}+\mathrm{tpd}$.


## ELECTRONIC SIGNATURE

An electronic signature word is provided in every GAL20XV10 device. It contains 40 bits of reprogrammable memory that contains user defined data. Some uses include user ID codes, revision numbers, pattern identification or inventory control codes. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature bits, if programmed to any value other then zero(0) will alter the checksum of the device.

## SECURITY CELL

A security cell is provided in every GAL20XV10 device as a deterrent to unauthorized copying of the device pattern. Once programmed, this cell prevents further read access of the device pattern information. This cell can be only be reset by reprogramming the device. The original pattern can never be examined once this cell is programmed. The Electronic Signature is always available regardless of the security cell state.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers. Complete programming of the device takes less than a second. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle.

## LATCH-UP PROTECTION

GAL20XV10 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with $n$-channel pullups instead of the traditional $p$-channel pullups to eliminate any possibility of SCR induced latching.

## INPUT BUFFERS

GAL20XV10 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.
GAL20XV10 input buffers have active pull-ups within their input structure. This pull-up will cause any un-terminated input or I/O to float to a TTL high (logical 1). Lattice recommends that all unused inputs and tri-stated I/O pins be connected to another active input, Vcc, or GND. Doing this will tend to improve noise immunity and reduce Icc for the device.


## POWER-UP RESET

Circuitry within the GAL20XV10 provides a reset signal to all registers during power-up. All internal registers will have their $Q$ outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown below. Because of the asynchronous nature of system power-up, some conditions must be met to guarantee a valid power-up reset of the GAL20XV10. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.


## TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


## TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Normalized Icc vs Vcc



Voh vs loh


Normalized lcc vs Temp


Input Clamp (Vik)


Voh vs loh


Normalized Icc vs Freq.


GAL22V10

## FEATURES

- HIGH PERFORMANCE E² ${ }^{2}$ OS $^{\oplus}$ TECHNOLOGY
- 5 ns Maximum Propagation Delay
- Fmax $=200 \mathrm{MHz}$
- 4 ns Maximum from Clock Input to Data Output
- UltraMOS ${ }^{\oplus}$ Advanced CMOS Technology


## - ACTIVE PULL-UPS ON ALL PINS

- COMPATIBLE WITH STANDARD 22V10 DEVICES
- Fully Function/Fuse-Map/Parametric Compatible with Bipolar and UVCMOS 22V10 Devices
- 50\% to 75\% REDUCTION IN POWER VERSUS BIPOLAR
- 90mA Typ Icc on Low Power Device
- 45mA Typ Icc on Quarter Power Device
- E² CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- TEN OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- PRELOAD AND POWER-ON RESET OF REGISTERS
- 100\% Functional Testability
- APPLICATIONS INCLUDE:
- DMA Control
- State Machine Control
- High Speed Graphics Processing
- Standard Logic Speed Upgrade
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL22V10C, at 5ns maximum propagation delay time, combines a high performance CMOS process with Electrically Erasable $\left(\mathrm{E}^{2}\right)$ floating gate technology to provide the highest performance available of any 22 V 10 device on the market. CMOS circuitry allows the GAL22V10 to consume much less power when compared to bipolar 22V10 devices. $\mathrm{E}^{2}$ technology offers high speed ( $<100 \mathrm{~ms}$ ) erase times, providing the ability to reprogram or reconfigure the device quickly and efficiently.
The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The GAL22V10 is fully function/fuse map/parametric compatible with standard bipolar and CMOS 22V10 devices.
Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all GAL ${ }^{\circledR}$ products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.

FUNCTIONAL BLOCK DIAGRAM


## PACKAGE DIAGRAMS



[^34]
## GAL22V10 ORDERING INFORMATION

## Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 5 | 3 | 4 | 150 | GAL22V10C-5LJ | 28-Lead PLCC |
| 6 | 4 | 4 | 140 | GAL22V10C-6LJ | 28-Lead PLCC |
| 7.5 | 4.5 | 4.5 | 140 | GAL22V10C-7LJ | 28-Lead PLCC |
|  | 5 | 4.5 | 140 | GAL22V10C-7LP | 24-Pin Plastic DIP |
|  | 6.5 | 5 | 140 | GAL22V10B-7LP | 24-Pin Plastic DIP |
|  |  |  | 140 | GAL22V10B-7LJ | 28-Lead PLCC |
| 10 | 7 | 7 | 130 | GAL22V10B-10LP | 24-Pin Plastic DIP |
|  |  |  | 130 | GAL22V10B-10LJ | 28-Lead PLCC |
| 15 | 10 | 8 | 55 | GAL22V10B-15QP | 24-Pin Plastic DIP |
|  |  |  | 55 | GAL22V10B-15QJ | 28-Lead PLCC |
|  |  |  | 130 | GAL22V10B-15LP | 24-Pin Plastic DIP |
|  |  |  | 130 | GAL22V10B-15LJ | 28-Lead PLCC |
| 25 | 15 | 15 | 55 | GAL22V10B-25QP | 24-Pin Plastic DIP |
|  |  |  | 55 | GAL22V10B-25QJ | 28-Lead PLCC |
|  |  |  | 90 | GAL22V10B-25LP | 24-Pin Plastic DIP |
|  |  |  | 90 | GAL22V10B-25LJ | 28-Lead PLCC |

Industrial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 10 | 7 | 7 | 160 | GAL22V10C-10LPI | 24-Pin Plastic DIP |
|  |  |  | 160 | GAL22V10C-10LJI | 28-Lead PLCC |
| 15 | 10 | 8 | 150 | GAL22V10B-15LPI | 24-Pin Plastic DIP |
|  |  |  | 150 | GAL22V10B-15LJI | 28-Lead PLCC |
| 20 | 14 | 10 | 150 | GAL22V10B-20LPI | 24-Pin Plastic DIP |
|  |  |  | 150 | GAL22V10B-20LJI | 28-Lead PLCC |
| 25 | 15 | 15 | 150 | GAL22V10B-25LPI | 24-Pin Plastic DIP |
|  |  |  | 150 | GAL22V10B-25LJI | 28-Lead PLCC |

## PART NUMBER DESCRIPTION



## Specifications GAL22V10



## OUTPUT LOGIC MACROCELL (OLMC)

The GAL22V10 has a variable number of product terms per OLMC. Of the ten available OLMCs, two OLMCs have access to eight product terms (pins 14 and 23), two have ten product terms (pins 15 and 22), two have twelve product terms (pins 16 and 21), two have fourteen product terms (pins 17 and 20), and two OLMCs have sixteen product terms (pins 18 and 19). In addition to the product terms available for logic, each OLMC has an additional product-term dedicated to output enable control.

The output polarity of each OLMC can be individually programmed to be true or inverting, in either combinatorial or registered mode. This allows each output to be individually configured as either active high or active low.

The GAL22V10 has a product term for Asynchronous Reset (AR) and a product term for Synchronous Preset (SP). These two product terms are common to all registered OLMCs. The Asynchronous Reset sets all registers to zero any time this dedicated product term is asserted. The Synchronous Preset sets all registers to a logic one on the rising edge of the next clock pulse after this product term is asserted.

NOTE: The AR and SP product terms will force the Q output of the flip-flop into the same state regardless of the polarity of the output. Therefore, a reset operation, which sets the register output to a zero, may result in either a high or low at the output pin, depending on the pin polarity chosen.

## OUTPUT LOGIC MACROCELL CONFIGURATIONS

Each of the Macrocells of the GAL22V10 has two primary functional modes: registered, and combinatorial I/O. The modes and the output polarity are set by two bits (SO and S1), which are normally controlled by the logic compiler. Each of these two primary modes, and the bit settings required to enable them, are described below and on the following page.

## REGISTERED

In registered mode the output pin associated with an individual OLMC is driven by the Q output of that OLMC's D-type flip-flop. Logic polarity of the output signal at the pin may be selected by specifying that the output buffer drive either true (active high) or inverted (active low). Output tri-state control is available as an individual product-term for each OLMC, and can therefore be defined by a logic equation. The D flip-flop's /Q output is fed back into the AND array, with both the true and complement of the feedback available as inputs to the AND array.

NOTE: In registered mode, the feedback is from the /Q output of the register, and not from the pin; therefore, a pin defined as registered is an output only, and cannot be used for dynamic $\mathrm{I} / \mathrm{O}$, as can the combinatorial pins.

## COMBINATORIAL I/O

In combinatorial mode the pin associated with an individual OLMC is driven by the output of the sum term gate. Logic polarity of the output signal at the pin may be selected by specifying that the output buffer drive either true (active high) or inverted (active low). Output tri-state control is available as an individual product-term for each output, and may be individually set by the compiler as either "on" (dedicated output), "off" (dedicated input), or "productterm driven" (dynamic I/O). Feedback into the AND array is from the pin side of the output enable buffer. Both polarities (true and inverted) of the pin are fed back into the AND array.


ACTIVE LOW
$S_{0}=0$
$S_{1}=0$ .

## COMBINATORIAL MODE



## GAL22V10 LOGIC DIAGRAM / JEDEC FUSE MAP

DIP (PLCC) Package Pinouts


## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$ -0.5 to +7 V
Input voltage applied $\qquad$ -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cC}}+1.0 \mathrm{~V}$
Storage Temperature -65 to $150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied -55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature $\left(T_{A}\right)$........................... 0 to $+75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) with Respect to Ground $\qquad$ +4.75 to +5.25 V

## Industrial Devices:

Ambient Temperature $\left(T_{A}\right)$ -40 to $85^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground $\qquad$ +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{VCc}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | lol $=$ MAX. $\mathbf{V i n}=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I O H}=$ MAX. $\quad$ Vin $=\mathbf{V I L}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| $1 \mathrm{OS}^{2}$ | Output Short Circuit Current | $\mathrm{Vcc}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {out }}=0.5 \mathrm{~V}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -130 | mA |

## COMMERCIAL

| Icc | Operating Power Supply Current | $\begin{aligned} & \mathbf{V}_{\mathrm{LL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V} \\ & \mathbf{f}_{\text {toggle }}=15 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ | L-5 | - | 90 | 150 | mA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | L-6/-7 | - | 90 | 140 | mA |

## INDUSTRIAL

| ICC | Operating Power Supply Current | $\mathbf{V}_{\mathrm{LL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-10$ | - | 90 | 160 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

[^35]
## Specifications GAL22V10C

## AC SWITCHING CHARACTERISTICS

## Over Recommended Operating Conditions

| PARAM | $\begin{array}{\|c\|} \text { TEST } \\ \text { COND. } \end{array}$ | DESCRIPTION | COM |  | COM |  | COM |  | COM |  | IND |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | -5 (PLCC) |  | -6 (PLCC) |  | -7 (PLCC) |  | -7 (PDIP) |  | -10 |  | UNITS |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinatorial Output | 1 | 5 | 1 | \% | 1 | 7.5 | 1 | 7.5 | 1 | 10 | ns |
| tco | A | Clock to Output Delay | 1 | 4 | 1 | \% $\%$ | 1 | 4.5 | 1 | 4.5 | 1 | 7 | ns |
| tct ${ }^{2}$ | - | Clock to Feedback Delay | - | 3 | - | *3 | - | 3 | - | 3 | - | 2.5 | ns |
| tsu | - | Setup Time, Input or Fdbk before CIk $\uparrow$ | 3 | - | 4 | \% | 4.5 | - | 5 | - | 7 | - | ns |
| th | - | Hold Time, Input or Fdbk after Clk $\uparrow$ | 0 | - |  | 为 | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{\mathbf{3}}$ | A | Maximum Clock Frequency with External Feedback, $1 /(\mathrm{tsu}+$ tco) | 142.8 | - | $125$ |  | 111 | - | 105 | - | 71.4 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 166 | - | 142.8 |  | 133 | - | 125 | - | 105 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 200 | - | $\begin{gathered} 1668 \\ \gtrless+8 \end{gathered}$ | \% | 166 | - | 142.8 | - | 105 | - | MHz |
| twh | - | Clock Pulse Duration, High | 2.5 | - | $3 *$ | - | 3 | - | 3.5 | - | 4 | - | ns |
| twl | - | Clock Pulse Duration, Low | 2.5 | - | ${ }^{\text {3 }}$, | - | 3 | - | 3.5 | - | 4 | - | ns |
| ten | B | Input or I/O to Output Enabled | 1 | 6 | , \% | 6 | 1 | 7.5 | 1 | 7.5 | 1 | 10 | ns |
| tdis | C | Input or I/O to Output Disabled | 1 | 6 | \% ${ }^{\text {\% }}$ | 6 | 1 | 7.5 | 1 | 7.5 | 1 | 9 | ns |
| tar | A | Input or I/O to Asynch. Reset of Reg. | 1 | 5.5 | 产 | 7.5 | 1 | 9 | 1 | 9 | 1 | 13 | ns |
| tarw | - | Asynch. Reset Pulse Duration | 5.5 | - | \%*5 | - | 7 | - | 7 | - | 8 | - | ns |
| tarr | - | Asynch. Reset to CIk $\uparrow$ Recovery Time | 4 | - |  | - | 5 | - | 5 | - | 8 | - | ns |
| tspr | - | Synch. Preset to Clk $\uparrow$ Recovery Time | 4 | - | \% | - | 5 | - | 5 | - | 10 | - | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Description section.
3) Refer to fmax Description section. Characterized initially and after any design or process changes that may affect these parameters.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{10}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{10}=2.0 \mathrm{~V}$ |

[^36]
## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$...................................... -0.5 to +7 V
Input voltage applied ........................... -2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature -65 to $150^{\circ} \mathrm{C}$

## Ambient Temperature with

Power Applied -55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## Specifications GAL22V10B

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss - 0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{IL}}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{V}_{\text {in }} \leq \mathbf{V}$ cc | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathbf{I o l}=$ MAX. $\quad$ Vin $=\mathbf{V I L}_{\text {IL }}$ or $\mathbf{V I H}^{\text {I }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I O H}=$ MAX. $\mathbf{V i n}=\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{H}}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| los ${ }^{2}$ | Output Short Circuit Current | Vcc = 5V Vout $=0.5 \mathrm{~V}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -130 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathbf{f}_{\text {toggle }}=15 \mathrm{MHz}$ Outputs Open |  | $\mathrm{L}-7$ | - | 90 | 140 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  | $\mathrm{~L}-10 /-15$ | - | 90 | 130 | mA |
|  |  |  | $\mathrm{~L}-25$ | - | 75 | 90 | mA |
|  |  | $\mathrm{Q}-15 /-25$ | - | 45 | 55 | mA |  |

## INDUSTRIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-15 /-20 /-25$ | - | 90 | 150 |
| :---: | :--- | :--- | :--- | :--- | :--- | :---: | mA |  |
| :--- |

[^37]3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

## Specifications GAL22V10B

## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions


1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Description section.
3) Refer to fmax Description section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / \mathrm{O}}=2.0 \mathrm{~V}$ |

[^38]
## SWITCHING WAVEFORMS



## Combinatorial Output

INPUT or I/O FEEDBACK

OUTPUT


Input or VO to Output Enable/Disable
CLK


Clock Width

INPUT or I/O FEEDBACK DRIVING SP

CLK

REGISTERED OUTPUT


Synchronous Preset


Registered Output

CLK

REGISTERED
FEEDBACK

fmax with Feedback


Asynchronous Reset

## fmax DESCRIPTIONS


fmax with External Feedback $\mathbf{1} /($ tsu $+\mathbf{t c o}$ )
Note: fmax with external feedback is calculated from measured tsu and tco.

fmax with No Feedback
Note: fmax with no feedback may be less than $1 /(\mathbf{t w h}+\mathbf{t w l})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback 1/(tsu+tcf)
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback ( $\mathbf{t c f}=1 / \mathrm{fmax}-\mathbf{t s u}$ ). The value of $\mathbf{t c f}$ is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to $\mathbf{t c f}+$ tpd.

SWITCHING TEST CONDITIONS

| Input Pulse Levels |  | GND to 3.0V |
| :--- | ---: | :---: |
| Input Rise and | $-5 /-6$ | $1.5 \mathrm{~ns} 10 \%-90 \%$ |
|  | $-7 /-10$ | $2.0 \mathrm{~ns} 10 \%-90 \%$ |
|  | $-15 /-20 /-25$ | $3 n \mathrm{nimes} 10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |  |
| Output Timing Reference Levels | 1.5 V |  |
| Output Load | See Figure |  |

3-state levels are measured 0.5V from steady-state active level.

Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :---: | :---: | :---: | :---: |
| A |  | $300 \Omega$ | $390 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 5 pF |


${ }^{*} C_{L}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

## ELECTRONIC SIGNATURE

An electronic signature (ES) is provided in every GAL22V10 device. It contains 64 bits of reprogrammable memory that can contain user-defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

The electronic signature is an additional feature not present in other manufacturers' 22 V 10 devices. To use the extra feature of the user-programmable electronic signature it is necessary to choose a Lattice 22V10 device type when compiling a set of logic equations. In addition, many device programmers have two separate selections for the device, typically a GAL22V10 and a GAL22V10-UES (UES = User Electronic Signature) or GAL22V10-ES. This allows users to maintain compatibility with existing 22 V 10 designs, while still having the option to use the GAL device's extra feature.

The JEDEC map for the GAL22V10 contains the 64 extra fuses for the electronic signature, for a total of 5892 fuses. However, the GAL22V10 device can still be programmed with a standard 22V10 JEDEC map (5828 fuses) with any qualified device programmer.

## SECURITY CELL

A security cell is provided in every GAL22V10 device to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell.

## LATCH-UP PROTECTION

GAL22V10 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with n-channel pullups instead of the traditional p-channel pullups to eliminate any possibility of SCR induced latching.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers (see the the GAL Development Tools section). Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because certain events may occur during system operation that throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

The GAL22V10 device includes circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing test vectors perform output register preload automatically.

## INPUT BUFFERS

GAL22V10 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.

The input and I/O pins also have built-in active pull-ups. As a result, floating inputs will float to a TTL high (logic 1). However, Lattice recommends that all unused inputs and tri-stated I/O pins be connected to an adjacent active input, Vcc, or ground. Doing so will tend to improve noise immunity and reduce Icc for the device. (See equivalent input and I/O schematics on the following page.)

## Typical Input Current



## POWER-UP RESET



Circuitry within the GAL22V10 provides a reset signal to all registers during power-up. All internal registers will have their Q outputs set low after a specified time (tpr, $1 \mu \mathrm{~s} \mathrm{MAX}$ ). As a result, the state on the registered output pins (if they are enabled) will always be high or low on power-up, depending on the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. Because of the asynchronous nature of system power-
up, some conditions must be met to guarantee a valid power-up reset of the device. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

## INPUT/OUTPUT EQUIVALENT SCHEMATICS



Specifications GAL22V10

## GAL22V10C-6/-7: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading



Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)


Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


Voh ve loh


Normalized Icc vs Freq.


## Specifications GAL22V10

## GAL22V10B-7/-10/-15/-25L: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching



Specifications GAL22V10

## GAL22V10B-7/-10/-15/-25L: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)
 Vin (V)

Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


Vik (V)

Voh vs loh


Normalized Icc vs Freq.


## Specifications GAL22V10

GAL22V10B-15/-25Q: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Normalized Tpd vs Temp


Normalized Tco vs Vcc


Normalized Tco vs Temp


Normalized Tsu vs Vce


Normalized Tsu vs Temp


Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


## Specifications GAL22V10

GAL22V10B-15/-25Q: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Normalized Icc vs Vcc

Delta Icc vs Vin (1 input)

Vin (V)



Normalized Icc vs Freq.


Voh vs loh


Normalized Icc vs Temp



Notes
ispGAL22V10
In-System Programmable $\mathrm{E}^{2}$ CMOS PLD
Generic Array Logic ${ }^{T M}$

## FEATURES

- IN-SYSTEM PROGRAMMABLE (5-V ONLY)
- 4-Wire Serial Programming Interface
- Minimum 10,000 Program/Erase Cycles


## - HIGH PERFORMANCE E ${ }^{2} \mathrm{CMOS}^{\oplus}$ TECHNOLOGY

- 7.5 ns Maximum Propagation Delay
- Fmax $=111 \mathrm{MHz}$
- 5 ns Maximum from Clock Input to Data Output
- UltraMOS ${ }^{\star}$ Advanced CMOS Technology
- ACTIVE PULL-UPS ON ALL PINS
- COMPATIBLE WITH STANDARD 22V10 DEVICES
- Fully Function/Fuse-Map/Parametric Compatible with Bipolar and CMOS 22V10 Devices
- E ${ }^{2}$ CELL TECHNOLOGY
- In-System Programmable Logic
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure (<100ms)
- 20 Year Data Retention
- TEN OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- APPLICATIONS INCLUDE:
- DMA Control
- State Machine Control
- High Speed Graphics Processing
- Software-Driven Hardware Configuration


## - ELECTRONIC SIGNATURE FOR IDENTIFICATION

## DESCRIPTION

The ispGAL22V10, at 7.5 ns maximum propagation delay time, combines a high performance CMOS process with Electrically Erasable ( $E^{2}$ ) floating gate technology to provide the industry's first in-system programmable 22 V 10 device. $\mathrm{E}^{2}$ technology offers high speed ( $<100 \mathrm{~ms}$ ) erase times, providing the ability to reprogram or reconfigure the device quickly and efficiently.

The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The ispGAL22V10 is fully function/fuse map/parametric compatible with standard bipolar and CMOS 22V10 devices. The standard PLCC package provides the same functional pinout as the standard 22V10 PLCC package with No-Connect pins being used for ISP interface signals.
Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all products. LATTICE also guarantees 10,000 erase/rewrite cycles and data retention in excess of 20 years.

FUNCTIONAL BLOCK DIAGRAM



Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
1994 Data Book
Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

## Specifications ispGAL22V10

## ispGAL22V10 ORDERING INFORMATION

## Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 7.5 | 6.5 | 5 | 140 | ispGAL22V10B-7LJ | 28-Lead PLCC |
| 10 | 7 | 7 | 140 | ispGAL22V10B-10LJ | 28-Lead PLCC |
| 15 | 10 | 8 | 140 | ispGAL22V10B-15LJ | 28-Lead PLCC |

PART NUMBER DESCRIPTION
ispGAL22V10B Device Name

## Specifications ispGAL22V10

## OUTPUT LOGIC MACROCELL (OLMC)

The ispGAL22V10 has a variable number of product terms per OLMC. Of the ten available OLMCs, two OLMCs have access to eight product terms (OLMC 1 and 10), two have ten product terms (OLMC 2 and 9), two have twelve product terms (OLMC 3 and 8), two have fourteen product terms (OLMC 4 and 7), and two OLMCs have sixteen product terms (OLMC 5 and 6). In addition to the product terms available for logic, each OLMC has an additional product-term dedicated to output enable control.

The output polarity of each OLMC can be individually programmed to be true or inverting, in either combinatorial or registered mode. This allows each output to be individually configured as either active high or active low.

The ispGAL22V10 has a product term for Asynchronous Reset (AR) and a product term for Synchronous Preset (SP). These two product terms are common to all registered OLMCs. The Asynchronous Reset sets all registers to zero any time this dedicated product term is asserted. The Synchronous Preset sets all registers to a logic one on the rising edge of the next clock pulse after this product term is asserted.

NOTE: The AR and SP product terms will force the Q output of the flip-flop into the same state regardless of the polarity of the output. Therefore, a reset operation, which sets the register output to a zero, may result in either a high or low at the output pin, depending on the pin polarity chosen.

ispGAL22V10 OUTPUT LOGIC MACROCELL (OLMC)

## OUTPUT LOGIC MACROCELL CONFIGURATIONS

Each of the Macrocells of the ispGAL22V10 has two primary functional modes: registered, and combinatorial I/O. The modes and the output polarity are set by two bits (SO and S 1 ), which are normally controlled by the logic compiler. Each of these two primary modes, and the bit settings required to enable them, are described below and on the following page.

## REGISTERED

In registered mode the output pin associated with an individual OLMC is driven by the Q output of that OLMC's D-type flip-flop. Logic polarity of the output signal at the pin may be selected by specifying that the output buffer drive either true (active high) or inverted (active low). Output tri-state control is available as an individual product-term for each OLMC, and can therefore be defined by a logic equation. The D flip-flop's /Q output is fed back into the AND array, with both the true and complement of the feedback available as inputs to the AND array.

NOTE: In registered mode, the feedback is from the /Q output of the register, and not from the pin; therefore, a pin defined as registered is an output only, and cannot be used for dynamic I/O, as can the combinatorial pins.

## COMBINATORIAL I/O

In combinatorial mode the pin associated with an individual OLMC is driven by the output of the sum term gate. Logic polarity of the output signal at the pin may be selected by specifying that the output buffer drive either true (active high) or inverted (active low). Output tri-state control is available as an individual product-term for each output, and may be individually set by the compiler as either "on" (dedicated output), "off" (dedicated input), or "productterm driven" (dynamic I/O). Feedback into the AND array is from the pin side of the output enable buffer. Both polarities (true and inverted) of the pin are fed back into the AND array.

REGISTERED MODE


ACTIVE LOW
$S_{0}=0$
$S_{1}=0$


ACTIVE HIGH
$S_{0}=1$
$S_{1}=0$

## COMBINATORIAL MODE



Specifications ispGAL22V10

## ispGAL22V10 LOGIC DIAGRAM / JEDEC FUSE MAP

PLCC Package Pinouts


## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}} \ldots \ldots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ~-~ 0.5 ~ t o ~+7 V ~$
Input voltage applied ............................ -2.5 to $\mathrm{V}_{\mathrm{cC}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature ................................. 65 to $150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{VIN}^{\text {c }}$ V $\mathrm{VIL}^{\text {( MAX. }}$ ) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{Vin} \leq \mathbf{V c c}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VoL | Output Low Voltage | Iol = MAX. Vin $=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I o h}=$ MAX. Vin $=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| IOS ${ }^{2}$ | Output Short Circuit Current | V cc $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -130 | mA |

COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{LL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-7 /-10 /-15$ | - | 90 | 140 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :---: | :---: |

1) The leakage current is due to the internal pull-up on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

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

| SYMBOL | PARAMETER | MAXIMUM* | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{lo}}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{V} / \mathrm{O}}=2.0 \mathrm{~V}$ |

*Guaranteed but not 100\% tested. Specifications ispGAL22V10

## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions


1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Description section.
3) Refer to fmax Description section.

Specifications ispGAL22V10

## SWITCHING WAVEFORMS



Combinatorial Output

INPUT or VO FEEDBACK

OUTPUT


Input or VO to Output Enable/Disable

CLK


Clock Width

INPUT or VO FEEDBACK DRIVING SP

CLK

REGISTERED OUTPUT


Synchronous Preset

INPUT or VO FEEDBACK

CLK

REGISTERED OUTPUT


Registered Output

CLK

REGISTERED FEEDBACK

INPUT or /V FEEDBACK DRIVING AR

CLK

REGISTERED OUTPUT


Asynchronous Reset
fmax DESCRIPTIONS

fmax with External Feedback 1/(tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.


Note: fmax with no feedback may be less than $1 / \mathrm{twh}+\mathrm{twl}$. This is to allow for a clock duty cycle of other than $50 \%$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3-state levels are measured 0.5 V from steady-state active level.

Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $300 \Omega$ | $390 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 5 pF |

FROM OUTPUT (O/Q) UNDER TEST


* ${ }^{\text {L }}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE


## ELECTRONIC SIGNATURE

An electronic signature (ES) is provided in every ispGAL22V10 device. It contains 64 bits of reprogrammable memory that can contain user-defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

The electronic signature is an additional feature not present in other manufacturers' 22 V 10 devices. To use the extra feature of the user-programmable electronic signature it is necessary to choose a Lattice 22V10 device type when compiling a set of logic equations. In addition, many device programmers have two separate selections for the device, typically an ispGAL22V10 and a ispGAL22V10-UES (UES = User Electronic Signature) or ispGAL22V10-ES. This allows users to maintain compatibility with existing 22 V 10 designs, while still having the option to use the GAL device's extra feature.

The JEDEC map for the ispGAL22V10 contains the 64 extra fuses for the electronic signature, for a total of 5892 fuses. However, the ispGAL22V10 device can still be programmed with a standard 22 V 10 JEDEC map ( 5828 fuses) with any qualified device programmer.

## SECURITY CELL

A security cell is provided in every ispGAL22V10 device to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell.

## LATCH-UP PROTECTION

ispGAL22V10 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with n-channel pullups instead of the traditional p-channel pullups to eliminate any possibility of SCR induced latching.

## DEVICE PROGRAMMING

The ispGAL22V10 device uses a standard 22V10 JEDEC fusemap file to describe the device programming information. Any third party logic compiler can produce the JEDEC file for this device.

The JEDEC file can be used to program the device using a standard PLD programmer or the in-system programming methods described later in this data sheet.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in the normal machine operations. This is because certain events may occur during system operation that throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

The ispGAL22V10 device includes circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing test vectors perform output register preload automatically.

## INPUT BUFFERS

ispGAL22V10 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.

The input and I/O pins also have built-in active pull-ups. As a result, floating inputs will float to a TTL high (logic 1). However, Lattice recommends that all unused inputs and tri-stated I/O pins be connected to an adjacent active input, Vcc, or ground. Doing so will tend to improve noise immunity and reduce Icc for the device. (See equivalent input and I/O schematics on the following page.)

Typical Input Current


Specifications ispGAL22V10

## POWER-UP RESET

Circuitry within the ispGAL22V10 provides a reset signal to all registers during power-up. All internal registers will have their Q outputs set low after a specified time (tpr, $1 \mu \mathrm{~s} M A X$ ). As a result, the state on the registered output pins (if they are enabled) will be either high or low on power-up, depending on the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown below. Because of the asynchronous nature of system power-up, some conditions must be met to guarantee a valid power-up reset of the ispGAL22V10. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.



INPUT/OUTPUT EQUIVALENT SCHEMATICS


Input


Output

## IN-SYSTEM PROGRAMMING OVERVIEW

The ispGAL22V10 device can be programmed in a number of ways. Two options are to build a custom cable to program devices on your board directly from the parallel port of a PC, or to build the programming capability right into your system. To support the software side of either of these solutions, Lattice provides the ispGAL Download library of programming routines. These routines are written in ANSI-standard C language, which can be used either to serve as detailed examples or to be integrated directly into your system. These routines include such common operations as Program, Read, and Verify. The routines are structured so that any hardware-dependent code is contained in a few well-documented functions, which can be easily modified for virtually any system. Example programs are included which use the parallel printer port of an IBM PC or compatible.

In addition, popular third-party programmers provide the ability to program the devices in a socket, just like conventionally programmed devices. This is especially useful for engineering
debug of programming circuitry you build into your own system. Many of the best applications for the ispGAL device use their ability to reconfigure a system in the field. In any system that uses a microprocessor, the microprocessor can often be used to program the ispGAL devices right in the system. The Lattice ispGAL Download software routines can be used to easily integrate ispGAL programming capability into your system software, or allow you to quickly create a custom program for configuring the system. A typical system is shown below in Figure 1. Note that the pattern information is normally stored in the Lattice ispSTREAM ${ }^{\text {TM }}$ format, which is a bit-packed format providing device pattern storage in less than $1 / 8$ that of a standard JEDEC file. The pattern information may reside either on-board in an EPROM or EEPROM, or be loaded from an external source such as a disk or across a network.


Figure 1. In-System Programming Using ispGAL Download Routines

## Specifications ispGAL22V10




## IN-SYSTEM PROGRAMMING OVERVIEW

Another possibility is to use an external system, such as a portable PC, to change the configuration of a board by reprogramming an on-board ispGAL device (see figure 2 below). This can be useful for field service personnel to re-configure a board for testing or to enable optional features. The same method can be used during the design, test or manufacturing phase, before the board is put into a working system capable of reprogramming the devices.

Lattice provides a stand-alone utility program that uses the PC parallel port to program ispGAL devices through a cable. Also, the ispGAL software library can be used to easily create custom programs for programming the ispGAL devices through your own interface. Example programs using the PC parallel port are included in the ispGAL Download software.

When programming multiple ispGAL devices, the ISP serial interface allows the user to cascade multiple ISP devices in a serial daisy chain (see figure 3). This serial daisy chain interface provides the flexibility to program all daisy chained devices at once or one at a time through a 4 -wire interface. To program the serial devices one at a time, the Lattice ISP FLOWTHRU instruction is provided to bypass the serial devices that are not to be programmed.

If you have any questions about programming the ispGAL devices, please contact Lattice Application Engineering at 800-327-8425 or 503-693-0201.


Figure 2. Configuring the ispGAL Device from a Remote System


Figure 3. ISP Serial Daisy Chain

The ispGAL uses a similar programming algorithm and programming parameters to other Lattice ISP devices. The devices generate their own internal supervoltage for programming, and only require standardTTL signals to program. Programmingthe ispGAL device is centered around a 3-state state machine, with its state transitions controlled by two control signals. One of the states is the normal operation state, with the other two states controlling the programming process. The ISP programming state machine is controlled by four dedicated programming pins on each device, which are described below. During normal device operation the SDI, MODE and SCLK pins should be tied low.

## SERIAL PROGRAMMING INTERFACE

The ispGAL devices are programmed using the four dedicated programming interface pins: SDI, MODE, SDO and SCLK.

Serial Data $\ln$ (SDI) performs two different functions. First as the input to the serial shift register, and second as one of the two control pins for the programming state machine. Because of this dual role, the function of SDI is controlled by the MODE pin. When MODE is low, SDI is the serial input to the shift registers and when MODE is high, SDI becomes a control signal. Internal to the device, the SDI is multiplexed to various shift registers in the device. The different shift instructions of the state machine determine which of these shift registers gets the input from SDI.

The MODE signal, combined with the SDI signal, controls the programming state machine, as described in this section.

Serial Clock (SCLK) is the serial shift register clock used to clock
the internal serial shift registers and to clock the state machine between states. State changes and shifting data in is done on a low-to-high transition. When shifting data out, the data is available on SDO only after a subsequent high-to-low transition. When MODE is high, SCLK controls the programming state machine, and when MODE is low, SCLK acts as a shift register clock to shift data in or out or to start an operation.

Serial Data Out (SDO) is the output of the serial shift registers. The selection of shift register is again determined by the state machine's shift instruction. When MODE is driven high, SDO connects directly to the SDI, bypassingthe device's shift registers.

## PROGRAMMING STATE MACHINE OPERATION

The programming state machine controls which mode the device is in, and provides the means to read and write data to the device (see figure 4). The four dedicated control pins are used to load and unload data, and to control the state machine. The state machine is a 2 bit state machine, with three defined states: IDLE (00), SHIFT (01) and EXECUTE (10). Instruction codes are shifted into the device in the SHIFT state, and control which instruction is to be executed in the EXECUTE state. In the SHIFT and EXECUTE states all the I/O pins are tri-stated. To transition between states MODE is held high, SDI is set to the appropriate level, and SCLK is clocked.

The IDLE state is the default state of the state machine. In this state the device is in normal operation, and programming operations are disabled. Each device contains a hardwired eight bit ID code, which can be read from this state. The IDLE state may be reached from any other state by setting MODE high, SDI low, and clocking SCLK.


Figure 4. Programming State Machine


The SHIFT state provides the means to load an instruction into the state machine. A five bit instruction is loaded into the state machine by holding MODE low and clocking in the instruction, via SDI. The entire Instruction Set is shown below in Table 1. Once an instruction is loaded into the state machine, it may be executed in the EXECUTE state. The SHIFT state is reached from either of the other two states by setting MODE and SDI high, and clocking SCLK.

The EXECUTE state is where the instruction that was shifted in during the SHIFT state is actually executed. An individual instruction execution is started by taking MODE low and clocking SCLK.

| Instruction | Operation | Description |
| :--- | :--- | :--- |
| 00000 | NOP | No operation performed. |
| 00010 | SHIFT_DATA | Clocks data into, or out of, <br> the Data Shift Register. |
| 00011 | BULK_ERASE | Erases the entire device. |
| 00101 | ERASE_ARRAY | Erases everything except <br> the Architecture rows. |
| 00110 | ERASE_ARCH | Erases the Architecture <br> rows only |
| 00111 | PROGRAM | Programs the Serial Shift <br> Register data into the <br> addressed row |
| 01010 | VERIFY | Load data from the <br> selected row into the <br> Serial Shift Register. |
| 01101 | IOPRLD | Preload the I/O register <br> with given data. |
| 01110 | FLOWTHRU | Disables the Shift Register <br> (SDI=SDO). |
| 10100 | ARCH SHIFT | Enables the Architecture <br> shift register for shifting <br> data into or out of the <br> register. |

Table 1. Instruction Codes

## SHIFT REGISTERS

The ispGAL device has four shift registers, the Device ID shift register, the Instruction shift register, the Data shift register, and the Architecture shift register. All shift registers operate on a First in First Out (FIFO) basis, and are chosen by which state the programming state machine is in.

## Specifications ispGAL22V10

The Device ID shift register is only accessible in the IDLE state. It is eight bits long, and is only used to shift out the device ID. For ispGAL22V10, the ID is defined to be 08 (hex). The Instruction shift register is only accessible in the SHIFT state. It is five bits long, and is only used to shift the Instruction Codes into the device. The Data and Instruction shift registers expect the LSB shifted in first. The Data shift register is 138 bits long, and is used to shift all addresses and data into or out of the device. The Data shift register is only accessible in the EXECUTE state when executing a SHIFT_DATA instruction. The architecture shift register is 20 bits long and the OLMC 1's S1 architecture bit is shifted in first and OLMC 10's S0 architecture bit is shifted in last. The architecture shift register is accessed during EXECUTE state when ARCH_SHIFT instruction is executed.

To program an ispGAL device, data is read from a serial bit stream and shifted into the shift registers. The data is read 138 bits at a time, shifted into the device, and then a programming operation is performed. The exact sequence, and the methods for converting a JEDEC map into a serial bit stream is explained in the Device Architecture section.

## TIMING

Programming the ispGAL devices properly requires that a number of timing specifications be met. Most critical are the specifications relating to programming and erasing the $\mathrm{E}^{2} \mathrm{CMOS}$ cells. In addition to a minimum pulse width, there is also a maximum specification for these parameters. Table 2 lists the programming mode specifications for the ispGAL device. Diagrams for the programming mode specifications are shown in Figures 5, 6, and 7 on the following page.

## INTERNAL ARCHITECTURE

This section explains the internal architecture of the device as it relates to programming. This section is not strictly necessary to the programming of the device if you are using the Lattice software tools provided.

The key to easy programming of the ispGAL device is the use of a bit-stream of all the data that needs to be shifted into a device to program it. Lattice calls this bit-stream format an ispSTREAM ${ }^{\text {TM }}$ format. The ispSTREAM format uses one bit to represent the state of each of the programmable cells, instead of the byte value used in a JEDEC file. Considering the additional characters in a JEDEC file, this means a space savings of more than a factor of eight. In addition, the ispSTREAM does not require any parsing. The bits are simply read from the file and shifted into the device. Since 804 bytes are required to store the pattern for an ispGAL device, multiple patterns can be stored in a small space.

This section mainly concerns the details of constructing the ispSTREAM format. If you are using the supplied software tools, a conversion utility (complete with source code) is included to convert an industry-standard JEDEC file to an ispSTREAM format. All of the Lattice software routines read from and write to this ispSTREAM format.

## Specifications ispGAL22V10

The ispGAL device have three basic sections to their programming architecture (see figure 8). There are 44, 132-bit wide rows of AND array section, one 64-bit wide row of User Electronic Signature (UES) section and one 20-bit wide row of architecture information.

The AND array section of the physical layout is organized so that each column of JEDEC fuse numbers shown in the logic diagram of ispGAL22V10 corresponds to one row of shift register for the device layout. This translates to each physical row being 132 bits long. With each row of AND array data, there is a 6-bit row address associated with it. Including the row address bits makes the shift registers 138 bits long. These row
address bits must also be shifted into the shift register along with the AND array data. Executing a PROGRAM command following the combination of data and row address shift programs the row that is specified by the shift instruction. The UES row is unique from the AND array data rows in that it is only 64 bits long. When the row address bits are added to the row the total shift register length required to fully specify the UES row is 70 bits long. In other words only 70 bits out of 132 bit shift register is used for UES. The 20-bit long architecture shift register is selected when ARCH_SHIFT instruction is executed. The OLMC $0, \mathrm{~S} 1$ : OLMC 0, S0; OLMC 1, S1: OLMC1, S0: etc. are shifted in order with the last bit of the shift register being OLMC 10, S0.

| Param. | Description | Min. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| trst | Time from power-up of device to any progamming operation. | 1 | - | $\mu \mathrm{s}$ |
| tisp | Time from leaving IDLE state to I/O pins tri-state, or entering IDLE state to I/O pins active. | - | 10 | $\mu \mathrm{~s}$ |
| tsu | Setup time, from either MODE or SDI to rising edge of SCLK. | 100 | - | ns |
| th | Hold time, from rising edge of SCLK to MODE or SDI changing level. | 100 |  | ns |
| tco | Time from falling edge of SCLK to data out on SDO. |  | 150 | ns |
| tclkh | Clock pulse width of SCLK while high. | 0.5 |  | $\mu \mathrm{~s}$ |
| tclkl | Clock pulse width of SCLK while low. | 0.5 |  | $\mu \mathrm{~s}$ |
| tpwp | Time for a programming operation. | 40 | 100 | ms |
| tpwe | Time for an erase operation. | 200 |  | ms |
| tpwv | Time for a verify operation. | 5 |  | $\mu \mathrm{~s}$ |

Table 2. Programming Mode Timing Specifications


Figure 5. Programming Mode Timing


Figure 7. Program, Verify, \& Erase Timing

## Specifications ispGAL22V10

ispStream Format
To convert the information in a standard JEDEC file into the ispSTREAM format, all of the addressing information is added, as well as the place-holding bits to fill to the next byte boundary. The objective is to have every bit that is shifted into the device for programming included in the ispSTREAM format. For the AND array rows, this means simply adding six bits to the end of each row. For the UES row, there are 2 bits to add. And for the architecture row 4 bits are added. These additional bits must be properly handled when data is shifted into the shift register. The proper number of bits must be incremented to forward the ispSTREAM bits to point to the next correct address bit.

The ispSTREAM uses one bit for each programmable cell. This means that each AND array row will take 138 bits. Similarly, 64 bits for the UES and 20 bits for the architecture. One extra byte is used at the front of the file to store the device ID code. This ID code is the same as the one hardwired into the device. The purpose of including this ID code is to be sure the ispSTREAM type matches that of the device to be programmed. All ispSTREAM formats, regardless of which Lattice In-System Programmable device they are for, will contain this ID code as the first byte. By reading this ID code, you can tell which device the ispSTREAM is for. If the ispSTREAMs are stored in EPROM for instance, they will be stacked end to end, and the ID code will help to determine not only which device type it belongs with, but how long it is, and thus where the next pattern starts.



Figure 8. ispGAL Device Shift Register Layout

## ISP PROGRAMMING TOOLS SUPPORT

To assist users in implementing ISP programming, Lattice provides ispGAL C language routines included with the ispGAL Download software which implement the basic ISP functions for programming through the PC parallel port. This section provides the details of the PC parallel port definition needed to program the ispGAL.

## PC PARALLEL PORT DEFINITION

The PC parallel port must be properly defined in order to use the ispGAL software to program the devices. After defining the port, ispGAL Download software controls the read and write of data through the parallel port. To guarantee the signal integrity and drive capability, a 74 HC 367 (or equivalent) buffer should be directly connected at the parallel port's DB25 connector. Figure

9 below defines the parallel port DB25 pins and the associated programming signals. This hardware definition is identical to the Lattice ispLSI programming hardware with the exception of the ispEN and RESET signals which are defined only for the ispLSI devices.

The buffer at the parallel port drives the cable that connects the output of the buffer to the ISP programming signals of the device. It is important to keep the cable length to a minimum to reduce the loading on the signal drivers. The SDI, SCLK and MODE inputs to the ispGAL are driven by the buffer connected at the parallel port. The SDO output signal from the ispGAL is driven from the device back to the parallel port. If the load on the SDO signal is more than a minimum cable length and the parallel port input, it is recommended that the user provide a buffer on the circuit board to ensure good signal integrity.


Figure 9. PC Parallel Port Buffer \& RJ45 Connector Definition

## Specifications ispGAL22V10

## ispGAL22V10B: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs
Switching

Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading

ispGAL22V10B: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Normalized Icc vs Vcc


Delta Icc vs Vcc


Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


Voh vs loh


Normalized Icc vs Freq.


## FEATURES

- HIGH PERFORMANCE E ${ }^{2}$ CMOS $^{\circledR}$ TECHNOLOGY
- 7.5 ns Maximum Propagation Delay
- Fmax $=142.8 \mathrm{MHz}$
- 4.5ns Maximum from Clock Input to Data Output
- TTL Compatible 16 mA Outputs
- UltraMOS ${ }^{\oplus}$ Advanced CMOS Technology
- ACTIVE PULL-UPS ON ALL PINS
- LOW POWER CMOS
- 90 mA Typical Icc
- E² CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure (<100ms)
- 20 Year Data Retention
- TWELVE OUTPUT LOGIC MACROCELLS
- Uses Standard 22V10 Macrocells
- Maximum Flexibility for Complex Logic Designs
- PRELOAD AND POWER-ON RESET OF REGISTERS - 100\% Functional Testability
- APPLICATIONS INCLUDE:
- DMA Control
- State Machine Control
- High Speed Graphics Processing
- Standard Logic Speed Upgrade
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL26CV12, at 7.5 ns maximum propagation delay time, combines a high performance CMOS process with Electrically Erasable ( $\mathrm{E}^{2}$ ) floating gate technology to provide the highest performance 28 -pin PLD available on the market. $E^{2}$ technology offers high speed ( $<100 \mathrm{~ms}$ ) erase times, providing the ability to reprogram or reconfigure the device quickly and efficiently.

Expanding upon the industry standard 22 V 10 architecture, the GAL26CV12 eliminates the learning curve typically associated with using a new device architecture. The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The GAL26CV12 OLMC is fully compatible with the OLMC in standard bipolar and CMOS 22V10 devices.

Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all GAL ${ }^{\circledR}$ products. LATTICE also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.

FUNCTIONAL BLOCK DIAGRAM



[^39]
## GAL26CV12 ORDERING INFORMATION

## Commercial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 7.5 | 6 | 4.5 | 130 | GAL26CV12C-7LP | 28-Pin Plastic DIP |
|  |  |  | 130 | GAL26CV12C-7LJ | 28-Lead PLCC |
| 10 | 7 | 7 | 130 | GAL26CV12B-10LP | 28-Pin Plastic DIP |
|  |  |  | 130 | GAL26CV12B-10LJ | 28-Lead PLCC |
| 15 | 10 | 8 | 130 | GAL26CV12B-15LP | 28-Pin Plastic DIP |
|  |  |  | 130 | GAL26CV12B-15LJ | 28-Lead PLCC |
| 20 | 12 | 12 | 130 | GAL26CV12B-20LP | 28-Pin Plastic DIP |
|  |  |  | 130 | GAL26CV12B-20LJ | 28-Lead PLCC |

Industrial Grade Specifications

| Tpd (ns) | Tsu (ns) | Tco (ns) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 10 | 7 | 7 | 150 | GAL26CV12C-10LPI | 28-Pin Plastic DIP |
|  |  |  | 150 | GAL26CV12C-10LJI | 28-Lead PLCC |
| 15 | 10 | 8 | 150 | GAL26CV12B-15LPI | 28-Pin Plastic DIP |
|  |  |  | 150 | GAL26CV12B-15LJI | 28-Lead PLCC |
| 20 | 20 | 12 | 150 | GAL26CV12B-20LPI | 28-Pin Plastic DIP |
|  |  |  | 150 | GAL26CV12B-20LJI | 28-Lead PLCC |

## PART NUMBER DESCRIPTION



## Specifications GAL26CV12

## OUTPUT LOGIC MACROCELL (OLMC)

The GAL26CV12 has a variable number of product terms per OLMC. Of the twelve available OLMCs, two OLMCs have access to twelve product terms (pins 20 and 22), two have access to ten product terms (pins 19 and 23), and the other eight OLMCs have eight product terms each. In addition to the product terms available for logic, each OLMC has an additional product term dedicated to output enable control.

The output polarity of each OLMC can be individually programmed to be true or inverting, in either combinatorial or registered mode. This allows each output to be individually configured as either active high or active low.

The GAL26CV12 has a product term for Asynchronous Reset (AR) and a product term for Synchronous Preset (SP). These two product terms are common to all registered OLMCs. The Asynchronous Reset sets all registered outputs to zero any time this dedicated product term is asserted. The Synchronous Preset sets all registers to a logic one on the rising edge of the next clock pulse after this product term is asserted.

NOTE: The AR and SP product terms will force the Q output of the flip-flop into the same state regardless of the polarity of the output. Therefore, a reset operation, which sets the register output to a zero, may result in either a high or low at the output pin, depending on the pin polarity chosen.


GAL26CV12 OUTPUT LOGIC MACROCELL (OLMC)

## OUTPUT LOGIC MACROCELL CONFIGURATIONS

Each of the Macrocells of the GAL26CV12 has two primary functional modes: registered, and combinatorial I/O. The modes and the output polarity are set by two bits (SO and S1), which are normally controlled by the logic compiler. Each of these two primary modes, and the bit settings required to enable them, are described below and on the the following page.

## REGISTERED

In registered mode the output pin associated with an individual OLMC is driven by the Q output of that OLMC's D-type flip-flop. Logic polarity of the output signal at the pin may be selected by specifying that the output buffer drive either true (active high) or inverted (active low). Output tri-state control is available as an individual product term for each OLMC, and can therefore be defined by a logic equation. The $D$ flip-flop's /Q output is fed back into the AND array, with both the true and complement of the feedback available as inputs to the AND array.

NOTE: In registered mode, the feedback is from the /Q output of the register, and not from the pin; therefore, a pin defined as registered is an output only, and cannot be used for dynamic $\mathrm{I} / \mathrm{O}$, as can the combinatorial pins.

## COMBINATORIAL I/O

In combinatorial mode the pin associated with an individual OLMC is driven by the output of the sum term gate. Logic polarity of the output signal at the pin may be selected by specifying that the output buffer drive either true (active high) or inverted (active low). Output tri-state control is available as an individual product term for each output, and may be individually set by the compiler as either "on" (dedicated output), "off" (dedicated input), or "product term driven" (dynamic I/O). Feedback into the AND array is from the pin side of the output enable buffer. Both polarities (true and inverted) of the pin are fed back into the AND array.

## Specifications GAL26CV12

## REGISTERED MODE



ACTIVE LOW
$S_{0}=0$
$S_{1}=0$

COMBINATORIAL MODE


Specifications GAL26CV12

## GAL26CV12 LOGIC DIAGRAM / JEDEC FUSE MAP



Specifications GAL26CV12C

## ABSOLUTE MAXIMUM RATINGS()

Supply voltage $\mathrm{V}_{\mathrm{cc}}$ Input voltage applied $\qquad$ -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied $\qquad$ -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ -65 to $150^{\circ} \mathrm{C}$

## Ambient Temperature with

Power Applied $\qquad$ .-55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature $\left(T_{A}\right)$........................... 0 to $+75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground +4.75 to +5.25 V

Industrial Devices:
Ambient Temperature $\left(T_{A}\right)$.......................... -40 to $85^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground +4.5 to +5.5 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss - 0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | $\mathrm{Vcc}+1$ | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{VIL}^{\text {(MAX. }}$ ) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{VCC}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | lol $=$ MAX. $\quad$ Vin $=\mathbf{V}_{\text {IL }}$ or V $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| $1 \mathrm{OS}^{2}$ | Output Short Circuit Current | Vcc $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -130 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{LL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V}$ ftoggle $=15 \mathrm{MHz}$ <br> Outputs Open | $\mathrm{L}-7$ | - | 90 | 130 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## INDUSTRIAL

| ICC | Operating Power <br> Supply Current | $V_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{H}}=3.0 \mathrm{~V}$ foggle $=15 \mathrm{MHz}$ <br> Outputs Open | $\mathrm{L}-10$ | - | 90 | 150 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

1) The leakage current is due to the internal pull-up on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

| PARAMETER | TESTCOND. ${ }^{1}$ | DESCRIPTION | $\begin{gathered} \hline \text { COM } \\ \hline-7 \end{gathered}$ |  | $\begin{gathered} \hline \text { IND } \\ \hline-10 \end{gathered}$ |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinatorial Output | 1 | 7.5 | 1 | 10 | ns |
| tco | A | Clock to Output Delay | 1 | 4.5 | 1 | 7 | ns |
| tcf ${ }^{2}$ | - | Clock to Feedback Delay | - | 2.5 | - | 2.5 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 6 | - | 7 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, 1/(tsu + tco) | 95.2 | - | 71.4 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 117.6 | - | 105 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 142.8 | - | 105 | - | MHz |
| twh | - | Clock Pulse Duration, High | 3.5 | - | 4 | - | ns |
| $t_{w l}$ | - | Clock Pulse Duration, Low | 3.5 | - | 4 | - | ns |
| ten | B | Input or I/O to Output Enabled | 1 | 7.5 | 1 | 10 | ns |
| tdis | C | Input or I/O to Output Disabled | 1 | 7.5 | 1 | 9 | ns |
| tar | A | Input or I/O to Asynchronous Reset of Register | 1 | 9 | 1 | 13 | ns |
| tarw | - | Asynchronous Reset Pulse Duration | 7 | - | 8 | - | ns |
| tarr | - | Asynchronous Reset to Clock $\uparrow$ Recovery Time | 5 | - | 8 | - | ns |
| tspr | - | Synchronous Preset to Clock $\uparrow$ Recovery Time | 5 | - | 10 | - | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Specification section.
3) Refer to fmax Specification section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{\star}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{10}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / \mathrm{O}}=2.0 \mathrm{~V}$ |

[^40]
## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

| Supply voltage $\mathrm{V}_{\mathrm{cc}} \ldots \ldots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .-0.5 ~ t o ~+7 V ~$ Input voltage applied ......................... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$ <br> Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$ Storage Temperature ................................. 65 to $150^{\circ} \mathrm{C}$ <br> Ambient Temperature with <br> Power Applied .......................................... 55 to $125^{\circ} \mathrm{C}$ <br> 1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications). |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |

## Specifications GAL26CV12B

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) ............................ 0 to $+75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground +4.75 to +5.25 V

## Industrial Devices:

Ambient Temperature ( $T_{A}$ ) ........................... -40 to $85^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ )
with Respect to Ground .......................... +4.5 to +5.5 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.0 | - | $\mathrm{Vcc}+1$ | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{V}_{\text {cc }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | Iol $=$ MAX. $\quad$ Vin $=\mathrm{V}_{\text {IL }}$ or $\mathrm{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I O H}=$ MAX. $\quad$ Vin $=$ VIL or $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| $1 \mathrm{OS}^{2}$ | Output Short Circuit Current | V cc $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -130 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V I L}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ foggle $=15 \mathrm{MHz}$ <br> Outputs Open | $\mathrm{L}-10 /-15 /-20$ | - | 90 | 130 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :---: |

## INDUSTRIAL

| ICC | Operating Power <br> Supply Current | $\mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{H}}=3.0 \mathrm{~V}$ ftoggle $=15 \mathrm{MHz}$ <br> Outputs Open | $\mathrm{L}-15 /-20$ | - | 90 | 150 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :---: |

1) The leakage current is due to the internal pull-up on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{VCC}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## Specifications GAL26CV12B

AC SWITCHING CHARACTERISTICS
Over Recommended Operating Conditions


1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Specification section.
3) Refer to fmax Specification section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{10}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{II}}=2.0 \mathrm{~V}$ |

[^41]
## Specifications GAL26CV12

SWITCHING WAVEFORMS


## Registered Output

INPUT or I/O FEEDBACK

OUTPUT


Input or VO to Output Enable/Disable

CLK


Clock Width


Synchronous Preset


Asynchronous Reset

## fmax SPECIFICATIONS


fmax with External Feedback $\mathbf{1 / ( t s u + t c o )}$
Note: fmax with external feedback is calculated from measured tsu and tco.


Note: fmax with no feedback may be less than $1 /(t w h+t w l)$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback $1 /$ (tsu+tcf)
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback ( $\mathrm{tcf}=1 / \mathrm{fmax}-\mathrm{tsu}$ ). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to $\mathbf{t c f}+\mathrm{tpd}$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels |  | GND to 3.0V |
| :--- | ---: | :---: |
| Input Rise and | C-7/-10 | $1.5 \mathrm{~ns} \mathrm{10} \mathrm{\%-90} \mathrm{\%}$ |
| Fall Times | B-10/-15/-20 | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |  |
| Output Timing Reference Levels | 1.5 V |  |
| Output Load |  | See Figure |

3-state levels are measured 0.5V from steady-state active level.

GAL26CV12 Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :--- | :---: | :---: | :---: |
| A |  | $300 \Omega$ | $390 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 50 pF |
|  | Active High | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 5 pF |

FROM OUTPUT (O/Q) UNDER TEST


[^42]
## Specifications GAL26CV12

## ELECTRONIC SIGNATURE

An electronic signature is provided in every GAL26CV12 device. It contains 64 bits of reprogrammable memory that can contain user-defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

## SECURITY CELL

A security cell is provided in every GAL26CV12 device to prevent unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the functional bits in the device. This cell can only be erased by re-programming the device, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell.

## LATCH-UP PROTECTION

GAL26CV12 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias minimizes the potential for latch-up caused by negative input undershoots. Additionally, outputs are designed with n-channel pull-ups instead of the traditional p-channel pull-ups in order to eliminate latch-up due to output overshoots.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers (see the the GAL Development Tools section). Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle.

## OUTPUT REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified in the design, not just those required in normal machine operation. This is because certain events may occur during system operation that throw the logic into an illegal state (power-up, line voltage glitches, brown-outs, etc.). To test a design for proper treatment of these conditions, a way must be provided to break the feedback paths, and force any desired (i.e., illegal) state into the registers. Then the machine can be sequenced and the outputs tested for correct next state conditions.

The GAL26CV12 device includes circuitry that allows each registered output to be synchronously set either high or low. Thus, any present state condition can be forced for test sequencing. If necessary, approved GAL programmers capable of executing test vectors perform output register preload automatically.

## INPUT BUFFERS

GAL26CV12 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL logic.

The input and I/O pins also have built-in active pull-ups. As a result, floating inputs will float to a TTL high (logic 1). However, Lattice recommends that all unused inputs and tri-stated I/O pins be connected to an adjacent active input, Vcc, or ground. Doing so will tend to improve noise immunity and reduce Icc for the device.


## Specifications GAL26CV12

## POWER-UP RESET



Circuitry within the GAL26CV12 provides a reset signal to all registers during power-up. All internal registers will have their $Q$ outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will be either high or low on power-up, depending on the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. Because of the asynchronous nature of system power-up, some
conditions must be met to guarantee a valid power-up reset of the device. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

## INPUT/OUTPUT EQUIVALENT SCHEMATICS



Typical Input



Typical Output

## GAL26CV12C: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


## Specifications GAL26CV12

## GAL26CV12C:TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Normalized Icc vs Vcc


## Delta Icc vs Vin (1 input)




Voh vs loh


Normalized Icc vs Temp



Normalized Icc vs Freq.


GAL26CV12B: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS


Delta Tpd vs \# of Outputs
Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading




## GAL26CV12B: TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Normalized Icc vs Vcc


## Delta Icc vs Vin (1 input)



Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


## FEATURES

- HIGH PERFORMANCE E ${ }^{2}$ CMOS $^{\circledR}$ TECHNOLOGY
- 30ns Maximum Propagation Delay
- 27MHz Maximum Frequency
- 12ns Max. Clock to Output Delay
- TTL Compatible 16mA Outputs
- UltraMOS ${ }^{\circledR}$ Advanced CMOS Technology
- LOW POWER CMOS
- 90mA Typical Icc
- E ${ }^{2}$ CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- UNPRECEDENTED FUNCTIONAL DENSITY
- $78 \times 64 \times 36$ FPLA Architecture
- 10 Output Logic Macrocells
- 8 Buried Logic Macrocells
- 20 Input and I/O Logic Macrocells
- HIGH-LEVEL DESIGN FLEXIBILITY
- Asynchronous or Synchronous Clocking
- Separate State Register and Input Clock Pins
- Functional Superset of Existing 24-pin PAL ${ }^{\circledR}$ and FPLA Devices
- APPLICATIONS INCLUDE:
- Sequencers
- State Machine Control
- Multiple PLD Device Integration


## DESCRIPTION

Using a high performance $\mathrm{E}^{2} \mathrm{CMOS}$ technology, Lattice Semiconductor has produced a next-generation programmable logic device, the GAL6001. Having an FPLA architecture, known for its superior flexibility in state-machine design, the GAL6001 offers a high degree of functional integration and flexibility in a 24pin, 300-mil package.
The GAL6001 has 10 programmable Output Logic Macrocells (OLMC) and 8 programmable Buried Logic Macrocells (BLMC). In addition, there are 10 Input Logic Macrocells (ILMC) and 10 I/O Logic Macrocells (IOLMC). Two clock inputs are provided for independent control of the input and output macrocells.
Advanced features that simplify programming and reduce test time, coupled with $\mathrm{E}^{2} \mathrm{CMOS}$ reprogrammable cells, enable $100 \%$ $A C, D C$, programmability, and functionality testing of each GAL6001 during manufacture. This allows Lattice to guarantee $100 \%$ performance to specifications. In addition, data retention of 20 years and a minimum of 100 erase/write cycles are guaranteed.


MACROCELL NAMES

| ILMC | INPUT LOGIC MACROCELL |
| :--- | :--- |
| IOLMC | I/O LOGIC MACROCELL |
| BLMC | BURIED LOGIC MACROCELL |
| OLMC | OUTPUT LOGIC MACROCELL |

## PIN NAMES

| $I_{0}-I_{10}$ | INPUT | I/O/Q | BIDIRECTIONAL |
| :--- | :--- | :--- | :--- |
| ICLK | INPUT CLOCK | $V_{C C}$ | POWER (+5) |
| OCLK | OUTPUT CLOCK | GND | GROUND |

## PIN CONFIGURATION


DIP

## GAL6001 ORDERING INFORMATION

## Commercial Grade Specifications

| Tpd (ns) | Fclk (MHz) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :--- | :--- |
| 30 | 27 | 150 | GAL6001B-30LP | 24-Pin Plastic DIP |
|  |  | 150 | GAL6001B-30LJ | 28 -Lead PLCC |

## PART NUMBER DESCRIPTION



## INPUT LOGIC MACROCELL (ILMC) AND I/O LOGIC MACROCELL (IOLMC)

The GAL6001 features two configurable input sections. The ILMC section corresponds to the dedicated input pins (2-11) and the IOLMC to the I/O pins (14-23). Each input section is configurable as a block for asynchronous, latched, or registered inputs. Pin 1 (ICLK) is used as an enable input for latched macrocells or as a clock input for registered macrocells. Configurable input blocks provide system designers with unparalleled design flexibility. With
the GAL6001, external registers and latches are not necessary.
Both the ILMC and the IOLMC are block configurable. However, the ILMC can be configured independently of the IOLMC. The three valid macrocell configurations are shown in the macrocell equivalent diagrams on the following pages.

## OUTPUT LOGIC MACROCELL (OLMC) AND BURIED LOGIC MACROCELL (BLMC)

The outputs of the OR array feed two groups of macrocells. One group of eight macrocells is buried; its outputs feed back directly into the AND array rather than to device pins. These cells are called the Buried Logic Macrocells (BLMC), and are useful for building state machines. The second group of macrocells consists of 10 cells whose outputs, in addition to feeding back into the AND array, are available at the device pins. Cells in this group are known as Output Logic Macrocells (OLMC).

The Output and Buried Logic Macrocells are configurable on a macrocell by macrocell basis. Buried and Output Logic Macrocells may be set to one of three configurations: combinatorial, D-type register with sum term (asynchronous) clock, or D/E-type register. Output macrocells always have I/O capability, with directional control provided by the 10 output enable (OE) product terms. Additionally, the polarity of each OLMC output is selected through the "D" XOR. Polarity selection is available for BLMCs, since both the true and complemented forms of their outputs are available in the AND array. Polarity of all "E" sum terms is selected through the "E" XOR.

When the macrocell is configured as a D/E type register, it is clocked from the common OCLK and the register clock enable input is controlled by the associated " $E$ " sum term. This configuration is useful for building counters and state-machines with state hold functions.

When the macrocell is configured as a D-type register with a sum term clock, the register is always enabled and its "E" sum term is routed directly to the clock input. This permits asynchronous programmable clocking, selected on a register-by-register basis.

Registers in both the Output and Buried Logic Macrocells feature a common RESET product term. This active high product term allows the registers to be asynchronously reset. Registers are reset to a logic zero. If connected to an output pin, a logic one will occur because of the inverting output buffer.

There are two possible feedback paths from each OLMC. The first path is directly from the OLMC (this feedback is before the output buffer and always present). When the OLMC is used as an output, the second feedback path is through the IOLMC. With this dual feedback arrangement, the OLMC can be permanently buried (the associated OLMC pin is an input), or dynamically buried with the use of the output enable product term.

The D/E registers used in this device offer the designer the ultimate in flexibility and utility. The D/E register architecture can emulate RS-, JK-, and T-type registers with the same efficiency as a dedicated RS-, JK-, or T-register.

The three macrocell configurations are shown in the macrocell equivalent diagrams on the following pages.

ILMC AND IOLMC CONFIGURATIONS


## ILMC/IOLMC

Generic Logic Block Diagram

ILMC (Input Logic Macrocell) JEDEC Fuse Numbers

| ISYN | LATCH |
| :---: | :---: |
| 8218 | 8219 |

IOLMC (I/O Logic Macrocell)
JEDEC Fuse Numbers

| ISYN | LATCH |
| :---: | :---: |
| 8220 | 8221 |



## Specifications GAL6001

ILMC AND IOLMC CONFIGURATIONS


Asynchronous Input
Latched Input

| ISYN | LATCH |
| :---: | :---: |
| 1 | 1 |


| ISYN | LATCH |
| :---: | :---: |
| 0 | 0 |



Registered Input

| ISYN | LATCH |
| :---: | :---: |
| 0 | 1 |

## OLMC AND BLMC CONFIGURATIONS



## OLMC/BLMC

Generic Logic Block Diagram

## OLMC (Output Logic Macrocell)

JEDEC Fuse Numbers

| OLMC | OCLK | OSYN | XORE | XORD |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 8178 | 8179 | 8180 | 8181 |
| 1 | 8182 | 8183 | 8184 | 8185 |
| 2 | 8186 | 8187 | 8188 | 8189 |
| 3 | 8190 | 8191 | 8192 | 8193 |
| 4 | 8194 | 8195 | 8196 | 8197 |
| 5 | 8198 | 8199 | 8200 | 8201 |
| 6 | 8202 | 8203 | 8204 | 8205 |
| 7 | 8206 | 8207 | 8208 | 8209 |
| 8 | 8210 | 8211 | 8212 | 8213 |
| 9 | 8214 | 8215 | 8216 | 8217 |

븝․․․․․․


## Specifications GAL6001

OLMC AND BLMC CONFIGURATIONS


D/E Type Registered


Combinatorial

| OSYN(i) | OCKS(i) |
| :---: | :---: |
| 1 | 0 |



D Type Register
with Sum Term
Asynchronous Clock

| OSYN(i) | OCKS(i) |
| :---: | :---: |
| 0 | 0 |

GAL6001 LOGIC DIAGRAM



## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$ -0.5 to +7 V Input voltage applied -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature -65 to $150^{\circ} \mathrm{C}$

## Ambient Temperature with

Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$
1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) .0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ )
with Respect to Ground $\qquad$ +4.75 to +5.25 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{IL}}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V}_{\mathrm{IH}} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {cC }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | $\mathbf{I o L}=$ MAX. $\mathbf{V i n}=\mathbf{V I L L}^{\text {or }} \mathbf{V}_{\mathrm{IH}}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I O H}=$ MAX. Vin $=\mathbf{V I L}$ or $\mathbf{V I H}^{\text {I }}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| lOS ${ }^{2}$ | Output Short Circuit Current | $\mathrm{Vcc}=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V}$ | -30 | - | -130 | mA |

## COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-30$ | - | 90 | 150 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | mA |  |
| :--- |

1) The leakage current is due to the internal pull-up on all pins.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{uo}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{lo}}=2.0 \mathrm{~V}$ |

[^43]AC SWITCHING CHARACTERISTICS
Over Recommended Operating Conditions

|  |  |  |  | OM |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | EST | D |  | 0 |  |
| PARAMETER | COND ${ }^{1}$. |  | MIN. | MAX. | UNTS |
| tpd1 | A | Combinatorial Input to Combinatorial Output | - | 30 | ns |
| tpd2 | A | Feedback or I/O to Combinatorial Output | - | 30 | ns |
| tpd3 | A | Transparent Latch Input to Combinatorial Output | - | 35 | ns |
| tco1 | A | Input Latch ICLK to Combinatorial Output Delay | - | 35 | ns |
| tco2 | A | Input Reg. ICLK to Combinatorial Output Delay | - | 35 | ns |
| tco3 | A | Output D/E Reg. OCLK to Output Delay | - | 12 | ns |
| tco4 | A | Output D Reg. Sum Term CLK to Output Delay | - | 35 | ns |
| tsu1 | - | Setup Time, Input before Input Latch ICLK | 2.5 | - | ns |
| tsu2 | - | Setup Time, Input before Input Reg. ICLK | 2.5 | - | ns |
| tsu3 | - | Setup Time, Input or Feedback before D/E Reg. OCLK | 25 | - | ns |
| tsu4 | - | Setup Time, Input or Feedback before D Reg. Sum Term CLK | 7.5 | - | ns |
| tsu5 | - | Setup Time, Input Reg. ICLK before D/E Reg. OCLK | 30 | - | ns |
| tsu6 | - | Setup Time, Input Reg. ICLK before D Reg. Sum Term CLK | 15 | - | ns |
| th1 | - | Hold Time, Input after Input Latch ICLK | 5 | - | ns |
| th2 | - | Hold Time, Input after Input Reg. ICLK | 5 | - | ns |
| th3 | - | Hold Time, Input or Feedback after D/E Reg. OCLK | 0 | - | ns |
| th4 | - | Hold Time, Input or Feedback after D Reg. Sum Term CLK | 10 | - | ns |
| $\mathrm{fmax}^{\text {max }}$ | - | Maximum Clock Frequency, OCLK | 27 | - | MHz |
| twh1 | - | ICLK or OCLK Pulse Duration, High | 10 | - | ns |
| twh2 | - | Sum Term CLK Pulse Duration, High | 15 | - | ns |
| twl1 | - | ICLK or OCLK Pulse Duration, Low | 10 | - | ns |
| twl2 | - | Sum Term CLK Pulse Duration, Low | 15 | - | ns |
| tarw | - | Reset Pulse Duration | 15 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 25 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 25 | ns |
| tar | A | Input or I/O to Asynchronous Reg. Reset | - | 35 | ns |
| tarr1 | - | Asynchronous Reset to OCLK Recovery Time | 20 | - | ns |
| tarr2 | - | Asynchronous Reset to Sum Term CLK Recovery Time | 10 | - | ns |

1) Refer to Switching Test Conditions section.


## Specifications GAL6001

## SWITCHING WAVEFORMS



Combinatorial Output

INPUT or I/O FEEDBACK

ICLK (LATCH)

COMBINATORIAL OUTPUT


Latched Input


Input or I/O to Output Enable/Disable


Clock Width


Registered Input

INPUT or I/O FEEDBACK

OCLK

REGISTERED OUTPUT


Registered Output (OCLK)


Asynchronous Reset

## fmax DESCRIPTIONS


fmax with External Feedback 1/(tsu+tco)

Note: fmax with external feedback is calculated from measured tsu and tco.


## fmax with No Feedback

Note: fmax with no feedback may be less than $1 /(\mathrm{twh}+\mathrm{twl})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback $\mathbf{1 / ( t s u + t c f )}$

Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback ( $\mathbf{t c f}=1 / \mathrm{fmax}-\mathrm{tsu}$ ). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to tcf $+\mathbf{t p d}$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3 -state levels are measured 0.5 V from steady-state active level.

## Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R 1}_{1}$ | $\mathbf{R 2}_{\mathbf{2}}$ | CL |
| :---: | :---: | :---: | :---: | :---: |
| A |  | $300 \Omega$ | $390 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 5 pF |

FROM OUTPUT (O/Q) UNDER TEST

CL INCLUDES JIG AND PROBE TOTAL CAPACITANCE

## Specifications GAL6001

## ARRAY DESCRIPTION

The GAL6001 contains two $\mathrm{E}^{2}$ reprogrammable arrays. The first is an AND array and the second is an OR array. These arrays are described in detail below.

## AND ARRAY

The AND array is organized as 78 inputs by 75 product term outputs. The 10 ILMCs, 10 IOLMCs, 8 BLMC feedbacks, 10 OLMC feedbacks, and ICLK comprise the 39 inputs to this array (each available in true and complement forms). 64 product terms serve as inputs to the OR array. The RESET product term generates the RESET signal described in the Output and Buried Logic Macrocells section. There are 10 output enable product terms which allow device pins 14-23 to be bi-directional or tri-state.

## OR ARRAY

The OR array is organized as 64 inputs by 36 sum term outputs. 64 product terms from the AND array serve as the inputs to the OR array. Of the 36 sum term outputs, 18 are data ("D") terms and 18 are enable/clock (" $E$ ") terms. These terms feed into the 10 OLMCs and 8 BLMCs, one "D" term and one "E" term to each.

The programmable OR array offers unparalleled versatility in product term usage. This programmability allows from 1 to 64 product terms to be connected to a single sum term. A programmable OR array is more flexible than a fixed, shared, or variable product term architecture.

## ELECTRONIC SIGNATURE

An electronic signature (ES) is provided in every GAL6001 device. It contains 72 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

NOTE: The ES is included in checksum calculations. Changing the ES will alter the checksum.

## SECURITY CELL

A security cell is provided in every GAL6001 device as a deterrent to unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the AND and OR arrays. This cell can be erased only during a bulk erase cycle, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell.

## BULK ERASE

Before writing a new pattern into a previously programmed part, the old pattern must first be erased. This erasure is done automatically by the programming hardware as part of the programming cycle and takes only 50 milliseconds.

## REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified, not just those required during normal operations. This is because in system operation, certain events may occur that cause the logic to assume an illegal state: powerup, brown out, line voltage glitches, etc. To test a design for proper treatment of these conditions, a method must be provided to break the feedback paths and force any desired state (i.e., illegal) into the registers. Then the machine can be sequenced and the outputs tested for correct next state generation.

All of the registers in the GAL6001 can be preloaded, including the ILMC, IOLMC, OLMC, and BLMC registers. In addition, the contents of the state and output registers can be examined in a special diagnostics mode. Programming hardware takes care of all preload timing and voltage requirements.

## LATCH-UP PROTECTION

GAL6001 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with n-channel pullups instead of the traditional p-channel pull-ups to eliminate any possibility of SCR induced latching.

## INPUT BUFFERS

GAL devices are designed with TTL level compatible input buffers. These buffers, with their characteristically high impedance, load driving logic much less than traditional bipolar devices. This allows for a greater fan out from the driving logic.

GAL6001 input buffers have active pull-ups within their input structure. This pull-up will cause any unterminated input or I/O to float to a TTL high (logical 1). Lattice recommends that all unused inputs and tri-stated I/O pins be connected to another active input, Vcc, or GND. Doing this will tend to improve noise immunity and reduce Icc for the device.

## Typical Input Pull-up Characteristic





## POWER-UP RESET

Circuitry within the GAL6001 provides a reset signal to all registers during power-up. All internal registers will have their Q outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown below. Because of the asynchronous nature of system power-up, some conditions must be met to guarantee a valid power-up reset of the GAL6001. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.


## DIFFERENTIAL PRODUCT TERM SWITCHING (DPTS) APPLICATIONS

The number of Differential Product Term Switching (DPTS ) for a given design is calculated by subtracting the total number of product terms that are switching from a Logical HI to a Logical LO from those switching from a Logical LO to a Logical HI within a 5 ns period. After subtracting take the absolute value.

$$
\text { DPTS }=\mid(P-\text { Terms })_{L H}-(P-\text { Terms })_{H L} \mid
$$

DPTS restricts the number of product terms that can be switched
simultaneously - there is no limit on the number of product terms that can be used.

A software utility is available from Lattice Applications Engineering that will perform this calculation on any GAL6001 JEDEC file. This program, DPTS, and additional information may be obtained from your local Lattice representative or by contacting Lattice Applications Engineering Dept. (Tel: 503-681-0118 or 800FASTGAL; FAX: 681-3037).

## Specifications GAL6001

TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Normalized Tsu vs Vcc



Normalized Tco vs Temp


Normalized Tsu vs Temp


Delta Tpd vs \# of Outputs Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading



TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS

## Specifications GAL6001



Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)


Voh vs loh


Normalized Icc vs Temp



Voh vs loh


Normalized Icc vs Freq.


## GAL6002

## FEATURES

- HIGH PERFORMANCE E ${ }^{2}$ CMOS $^{\circledR}$ TECHNOLOGY
- 15ns Maximum Propagation Delay
- 75MHz Maximum Frequency
- 6.5 ns Max. Clock to Output Delay
- TTL Compatible 16 mA Outputs
- UltraMOS ${ }^{\text {® }}$ Advanced CMOS Technology
- ACTIVE PULL-UPS ON ALL PINS
- LOW POWER CMOS
- 90mA Typical Icc
- E ${ }^{2}$ CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure (<100ms)
- 20 Year Data Retention
- UNPRECEDENTED FUNCTIONAL DENSITY
- $78 \times 64 \times 36$ FPLA Architecture
- 10 Output Logic Macrocells
- 8 Buried Logic Macrocells
- 20 Input and I/O Logic Macrocells
- HIGH-LEVEL DESIGN FLEXIBILITY
- Asynchronous or Synchronous Clocking
- Separate State Register and Input Clock Pins
- Functional Superset of Existing 24-pin PAL ${ }^{\circledR}$ and FPLA Devices
- APPLICATIONS INCLUDE:
- Sequencers
- State Machine Control
- Multiple PLD Device Integration


## DESCRIPTION

Having an FPLA architecture, the GAL6002 provides superior flexibility in state-machine design. The GAL6002 offers the highest degree of functional integration, flexibility, and speed currently available in a 24 -pin, 300 -mil package. $E^{2} \mathrm{CMOS}$ technology offers high speed ( $<100 \mathrm{~ms}$ ) erase times, providing the ability to reprogram or reconfigure the device quickly and efficiently.

The GAL6002 has 10 programmable Output Logic Macrocells (OLMC) and 8 programmable Buried Logic Macrocells (BLMC). In addition, there are 10 Input Logic Macrocells (ILMC) and 10 I/O Logic Macrocells (IOLMC). Two clock inputs are provided for independent control of the input and output macrocells.

Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacturing. As a result, Lattice is able to guarantee $100 \%$ field programmability and functionality of all GAL products. Lattice also guarantees 100 erase/rewrite cycles and data retention in excess of 20 years.

FUNCTIONAL BLOCK DIAGRAM


MACROCELL NAMES

| ILMC | INPUT LOGIC MACROCELL |
| :--- | :--- |
| IOLMC | I/O LOGIC MACROCELL |
| BLMC | BURIED LOGIC MACROCELL |
| OLMC | OUTPUT LOGIC MACROCELL |

PIN NAMES

| $I_{0}-I_{10}$ | INPUT | $I / O / Q$ | BIDIRECTIONAL |
| :--- | :--- | :--- | :--- |
| ICLK | INPUT CLOCK | $V_{C C}$ | POWER $(+5 \mathrm{~V})$ |
| OCLK | OUTPUT CLOCK | GND | GROUND |

PIN CONFIGURATION


[^44]
## Specifications GAL6002

## GAL6002 COMMERCIAL DEVICE ORDERING INFORMATION

Commercial Grade Specifications

| Tpd (ns) | Fclk (MHz) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :--- | :--- |
| 15 | 75 | 135 | GAL6002B-15LP | 24-Pin Plastic DIP |
|  |  | 135 | GAL6002B-15LJ | 28-Lead PLCC |
| 20 | 60 | 135 | GAL6002B-20LP | 24-Pin Plastic DIP |
|  |  | 135 | GAL6002B-20LJ | 28-Lead PLCC |

## PART NUMBER DESCRIPTION



Specifications GAL6002

## INPUT LOGIC MACROCELL (ILMC) AND I/O LOGIC MACROCELL (IOLMC)

The GAL6002 features two configurable input sections. The ILMC section corresponds to the dedicated input pins (2-11) and the IOLMC to the I/O pins (14-23). Each input section is individually configurable as asynchronous, latched, or registered inputs. Pin 1 (ICLK) is used as an enable input for latched macrocells or as a clock input for registered macrocells. Individually configurable inputs provide system designers with unparalleled design flexibility. With the GAL6002, external input registers and latches are not necessary.

Both the ILMC and the IOLMC are individually configurable and the ILMC can be configured independently of the IOLMC. The three valid macrocell configurations and its associated fuse numbers are shown in the diagrams on the following pages. Note that these programmable cells are configured by the logic compiler software. The user does not need to manually manipulate these architecture bits.

## OUTPUT LOGIC MACROCELL (OLMC) AND BURIED LOGIC MACROCELL (BLMC)

The outputs of the OR array feed two groups of macrocells. One group of eight macrocells is buried; its outputs feed back directly into the AND array rather than to device pins. These cells are called the Buried Logic Macrocells (BLMC), and are useful for building state machines. The second group of macrocells consists of 10 cells whose outputs, in addition to feeding back into the AND array, are available at the device pins. Cells in this group are known as Output Logic Macrocells (OLMC).

The Output and Buried Logic Macrocells are configurable on a macrocell by macrocell basis. Buried and Output Logic Macrocells may be set to one of three configurations: combinational, D-type register with sum term (asynchronous) clock, or D/E-type register. Output macrocells always have I/O capability, with directional control provided by the 10 output enable (OE) product terms. Additionally, the polarity of each OLMC output is selected through the programmable polarity control cell called XORD. Polarity selection for BLMCs is selected through the true and complement forms of their feedbacks to the AND array. Polarity of all E (Enable) sum terms is selected through the XORE programmable cells.

When the output or buried logic macrocell is configured as a D/E type register, the register is clocked from the common OCLK and the register clock enable input is controlled by the associated " $E$ " sum term. This configuration is useful for building counters and state-machines with count hold and state hold functions.

When the macrocell is configured as a $D$ type register with a sum term clock, the register is always enabled and the associated " $E$ "
sum term is routed directly to the clock input. This permits asynchronous programmable clocking, selected on a register-byregister basis.

Registers in both the Output and Buried Logic Macrocells feature a common RESET product term. This active high product term allows the registers to be asynchronously reset. All registers reset to logic zero. With the inverting output buffers, the output pins will reset to logic one.

There are two possible feedback paths from each OLMC. The first path is directly from the OLMC (this feedback is before the output buffer). When the OLMC is used as an output, the second feedback path is through the IOLMC. With this dual feedback arrangement, the OLMC can be permanently buried without losing the use of the associated OLMC pin as an input, or dynamically buried with the use of the output enable product term.

The D/E registers used in this device offer the designer the ultimate in flexibility and utility. The D/E register architecture can emulate RS, JK, and T registers with the same efficiency as a dedicated RS, JK, or T registers.

The three macrocell configurations are shown in the diagrams on the following pages. These programmable cells are also configured by the logic compiler software. The user does not need to manually manipulate these architecture bits.

ILMC AND IOLMC CONFIGURATIONS

## Specifications GAL6002



Input Macrocell JEDEC Fuse Numbers

| INSYNC | INLATCH | ILMC |
| :---: | :---: | :---: |
| 8218 | 8219 | 0 |
| 8220 | 8221 | 1 |
| 8222 | 8223 | 2 |
| 8224 | 8225 | 3 |
| 8226 | 8227 | 4 |
| 8228 | 8229 | 5 |
| 8230 | 8231 | 6 |
| 8232 | 8233 | 7 |
| 8234 | 8235 | 8 |
| 8236 | 8237 | 9 |


| IOSYNC | IOLATCH | IOLMC |
| :---: | :---: | :---: |
| 8238 | 8239 | 9 |
| 8240 | 8241 | 8 |
| 8242 | 8243 | 7 |
| 8244 | 8245 | 6 |
| 8246 | 8247 | 5 |
| 8248 | 8249 | 4 |
| 8250 | 8251 | 3 |
| 8252 | 8253 | 2 |
| 8254 | 8255 | 1 |
| 8256 | 8257 | 0 |



## OLMC AND BLMC CONFIGURATIONS



## OLMC/BLMC

Generic Logic Block Diagram

OLMC JEDEC Fuse Numbers

| OLMC | CKS | OUTSYNC | XORE | XORD |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 8178 | 8179 | 8180 | 8181 |
| 1 | 8182 | 8183 | 8184 | 8185 |
| 2 | 8186 | 8187 | 8188 | 8189 |
| 3 | 8190 | 8191 | 8192 | 8193 |
| 4 | 8194 | 8195 | 8196 | 8197 |
| 5 | 8198 | 8199 | 8200 | 8201 |
| 6 | 8202 | 8203 | 8204 | 8205 |
| 7 | 8206 | 8207 | 8208 | 8209 |
| 8 | 8210 | 8211 | 8212 | 8213 |
| 9 | 8214 | 8215 | 8216 | 8217 |

## BLMC JEDEC Fuse Numbers

| BLMC | CKS | OUTSYNC | XORE |
| :---: | :---: | :---: | :---: |
| 7 | 8175 | 8176 | 8177 |
| 6 | 8172 | 8173 | 8174 |
| 5 | 8169 | 8170 | 8171 |
| 4 | 8166 | 8167 | 8168 |
| 3 | 8163 | 8164 | 8165 |
| 2 | 8160 | 8161 | 8162 |
| 1 | 8157 | 8158 | 8159 |
| 0 | 8154 | 8155 | 8156 |



Z0097甘ט suo！！eo！！！oəds
әวบทบำ
（INOכ）WVધכVIG ગ1כOา

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$


#### Abstract

Supply voltage $\mathrm{V}_{\mathrm{cc}}$ $\qquad$ -0.5 to +7 V Input voltage applied ..........................-2.5 to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$ Storage Temperature -65 to $150^{\circ} \mathrm{C}$

\section*{Ambient Temperature with}

Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$ 1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).


## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss-0.5 | - | 0.8 | V |
| $\mathrm{V}_{\mathbf{I H}}$ | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (MAX.) | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathbf{V i N} \leq \mathbf{V C C}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | Iol $=$ MAX. Vin $=\mathbf{V I L}_{\text {IL }}$ or $\mathbf{V I H}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I o H}=$ MAX. Vin $=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 16 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| los ${ }^{2}$ | Output Short Circuit Current | V cc $=5 \mathrm{~V}$ Vout $=0.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -130 | mA |

COMMERCIAL

| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathbf{V}_{\mathrm{H}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-15 /-20$ | - | 90 | 135 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :---: |

1) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 /}$ | I/O Capacitance | 8 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / \mathrm{O}}=2.0 \mathrm{~V}$ |

[^45]
## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

|  |  |  | CO | OM | CO | OM |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ST | DESCRIPTION | -1 | 15 | -20 | 0 |  |
| PARAM. | COND'. |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd 1 | A | Combinatorial Input to Combinatorial Output | - | 15 | - | 20 | ns |
| tpd2 | A | Feedback or I/O to Combinational Output | - | 15 | - | 20 | ns |
| tpd3 | A | Transparent Latch Input to Combinatorial Output | - | 18 | - | 23 | ns |
| tcol | A | Input Latch ICLK to Combinatorial Output Delay | - | 20 | - | 25 | ns |
| tco2 | A | Input Reg. ICLK to Combinatorial Output Delay | - | 20 | - | 25 | ns |
| tco3 | A | Output D/E Reg. OCLK to Output Delay | - | 6.5 | - | 8 | ns |
| tco4 | A | Output D Reg. Sum Term CLK to Output Delay | - | 18 | - | 20 | ns |
| tcf1 ${ }^{2}$ | - | Output D/E Reg. OCLK to Buried Feedback Delay | - | 3.6 | - | 7 | ns |
| tcf2 ${ }^{2}$ | - | Output D Reg. STCLK to Buried Feedback Delay | - | 10.1 | - | 13 | ns |
| tsu1 | - | Setup Time, Input before Input Latch ICLK | 1.5 | - | 2 | - | ns |
| tsu2 | - | Setup Time, Input before Input Reg. ICLK | 1.5 | - | 2 | - | ns |
| tsu3 | - | Setup Time, Input or Fdbk before D/E Reg. OCLK | 11.5 | - | 13 | - | ns |
| tsu4 | - | Setup Time, Input or Fdbk before D Reg. Sum Term CLK | 5 | - | 7 | - | ns |
| tsu5 | - | Setup Time, Input Reg. ICLK before D/E Reg. OCLK | 15 | - | 20 | - | ns |
| tsu6 | - | Setup Time, Input Reg. ICLK before D Reg. Sum Term CLK | 7 | - | 9 | - | ns |
| th1 | - | Hold Time, Input after Input Latch ICLK | 3 | - | 4 | - | ns |
| th2 | - | Hold Time, Input after Input Reg. ICLK | 3 | - | 4 | - | ns |
| th3 | - | Hold Time, Input or Feedback after D/E Reg. OCLK | 0 | - | 0 | - | ns |
| th4 | - | Hold Time, Input or Feedback after D Reg. Sum Term CLK | 4 | - | 6 | - | ns |
| $\mathrm{fmax}^{13}$ | - | Max. Clock Frequency w/External Feedback, 1/(tsu3+tco3) | 55.5 | - | 47.6 | , | MHz |
| $\mathrm{fmax}^{3}$ | - | Max. Clock Frequency w/External Feedback, 1/(tsu4+tco4) | 43.4 | - | 37 | - | MHz |
| $\mathrm{fmax}^{3}$ | - | Max. Clock Frequency w/Internal Feedback, 1/(tsu3+tcf1) | 66 | - | 50 | - | MHz |
| $\mathrm{fmax}^{\text {a }}$ | - | Max. Clock Frequency w/Internal Feedback, 1/(tsu4+tcf2) | 66 | - | 50 | - | MHz |
| $\mathbf{f m a x}^{3}$ | - | Max. Clock Frequency w/No Feedback, OCLK | 75 | - | 60 | - | MHz |
| fmax6 ${ }^{3}$ | - | Max. Clock Frequency w/No Feedback, STCLK | 70 | - | 60 | - | MHz |
| twh1 | - | ICLK Pulse Duration, High | 6 | - | 7 | - | ns |
| twh2 | - | OCLK Pulse Duration, High | 6 | - | 7 | - | ns |
| twh3 | - | STCLK Pulse Duration, High | 7 | - | 8 | - | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Desciption section.
3) Refer to fmax Desciption section.

## AC SWITCHING CHARACTERISTICS (CONT.)

Over Recommended Operating Conditions

| PARAMETER | $\begin{array}{\|c\|} \hline \text { TEST } \\ \text { COND }^{1} . \end{array}$ |  | COM |  | COM |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | DESCRIPTION | -15 |  | -20 |  | UNITS |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| twl1 | - | ICLK Pulse Duration, Low | 6 | - | 7 | - | ns |
| twl2 | - | OCLK Pulse Duration, Low | 6 | - | 7 | - | ns |
| twl3 | - | STCLK Pulse Duration, Low | 7 | - | 8 | - | ns |
| tarw | - | Reset Pulse Duration | 12 | - | 15 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 15 | - | 20 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 20 | ns |
| tar | A | Input or I/O to Asynchronous Reg. Reset | - | 16 | - | 20 | ns |
| tarr1 | - | Asynchronous Reset to OCLK Recovery Time | 11 | - | 14 | - | ns |
| tarr2 | - | Asynchronous Reset to Sum Term CLK Recovery Time | 4 | - | 6 | - | ns |

1) Refer to Switching Test Conditions section.

## SWITCHING WAVEFORMS



## Combinatorial Output

INPUT or I/O FEEDBACK

ICLK (LATCH)

COMBINATORIAL OUTPUT


Registered Output (Sum Term CLK)


Input or I/O to Output Enable/Disable

ICLK or
OCLK

Sum Term CLK


## Clock Width



INPUT or
I/O FEEDBACK

ICLK (REGISTER)

COMBINATORIAL OUTPUT

OCLK

Sum Term CLK


Registered Input

INPUT or I/O FEEDBACK

OCLK

REGISTERED OUTPUT


Registered Output (OCLK)


Asynchronous Reset

## Specifications GAL6002

## fmax DESCRIPTIONS


fmax with External Feedback $1 /($ tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.


## fmax with No Feedback

Note: fmax with no feedback may be less than $1 /(\mathrm{twh}+\mathrm{twl})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback 1/(tsu+tcf)
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback (tcf = 1/fmax - tsu). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to $\mathbf{t c f}+\mathrm{tpd}$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns 10\%-90\% |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3 -state levels are measured 0.5 V from steady-state active level.

Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | CL |
| :---: | :---: | :---: | :---: | :---: |
| A |  | $300 \Omega$ | $390 \Omega$ | 50 pF |
| B | Active High | $\infty$ | $390 \Omega$ | 50 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $390 \Omega$ | 5 pF |
|  | Active Low | $300 \Omega$ | $390 \Omega$ | 5 pF |



* $C_{L}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE


## ARRAY DESCRIPTION

The GAL6002 contains two $E^{2}$ reprogrammable arrays. The first is an AND array and the second is an OR array. These arrays are described in detail below.

## AND ARRAY

The AND array is organized as 78 inputs by 75 product term outputs. The 10 ILMCs, 10 IOLMCs, 8 BLMC feedbacks, 10 OLMC feedbacks, and ICLK comprise the 39 inputs to this array (each available in true and complement forms). 64 product terms serve as inputs to the OR array. The RESET product term generates the RESET signal described in the Output and Buried Logic Macrocells section. There are 10 output enable product terms which allow device I/O pins to be bi-directional or tri-state.

## OR ARRAY

The OR array is organized as 64 inputs by 36 sum term outputs. 64 product terms from the AND array serve as the inputs to the OR array. Of the 36 sum term outputs, 18 are data ("D") terms and 18 are enable/clock (" $E$ ") terms. These terms feed into the 10 OLMCs and 8 BLMCs, one " $D$ " term and one " $E$ " term to each.

The programmable OR array offers unparalleled versatility in product term usage. This programmability allows from 1 to 64 product terms to be connected to a single sum term. A programmable OR array is more flexible than a fixed, shared, or variable product term architecture.

## ELECTRONIC SIGNATURE

An electronic signature is provided with every GAL6002 device. It contains 72 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell.

NOTE: The electronic signature is included in checksum calculations. Changing the electronic signature will alter the checksum.

## SECURITY CELL

A security cell is provided with every GAL6002 device as a deterrent to unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the AND array. This cell can be erased only during a bulk erase cycle, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell.

## DEVICE PROGRAMMING

GAL devices are programmed using a Lattice-approved Logic Programmer, available from a number of manufacturers. Complete programming of the device takes only a few seconds. Erasing of the device is transparent to the user, and is done automatically as part of the programming cycle.

## REGISTER PRELOAD

When testing state machine designs, all possible states and state transitions must be verified, not just those required during normal operations. This is because certain events may occur during system operation that cause the logic to be in an illegal state (power-up, line voltage glitches, brown-out, etc.). To test a design for proper treatment of these conditions, a method must be provided to break the feedback paths and force any desired state (i.e., illegal) into the registers. Then the machine can be sequenced and the outputs tested for correct next state generation.

All of the registers in the GAL6002 can be preloaded, including the ILMC, IOLMC, OLMC, and BLMC registers. In addition, the contents of the state and output registers can be examined in a special diagnostics mode. Programming hardware takes care of all preload timing and voltage requirements.

## LATCH-UP PROTECTION

GAL6002 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with n-channel pull-ups instead of the traditional p-channel pull-ups to eliminate any possibility of SCR induced latching.

## INPUT BUFFERS

GAL6002 devices are designed with TTL level compatible input buffers. These buffers have a characteristically high impedance, and present a much lighter load to the driving logic than bipolar TTL devices.

GAL6002 input buffers have active pull-ups within their input structure. This pull-up will cause any un-terminated input or I/O to float to a TTL high (logical 1). Lattice recommends that all unused inputs and tri-stated I/O pins be connected to another active input, Vcc, or GND. Doing this will tend to improve noise immunity and reduce Icc for the device.


Specifications GAL6002

## POWER-UP RESET



Circuitry within the GAL6002 provides a reset signal to all registers during power-up. All internal registers will have their $Q$ outputs set low after a specified time (tpr, $1 \mu \mathrm{~s}$ MAX). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown below. Because of the asynchronous nature
of system power-up, some conditions must be met to guarantee a valid power-up reset of the GAL6002. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation, avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements.

## DIFFERENTIAL PRODUCT TERM SWITCHING (DPTS) APPLICATIONS

The number of Differential Product Term Switching (DPTS ) for a given design is calculated by subtracting the total number of product terms that are switching from a Logical HI to a Logical LO from those switching from a Logical LO to a Logical HI within a 5 ns period. After subtracting take the absolute value.

$$
\text { DPTS }=\mid(P-\text { Terms })_{\mathrm{LH}}-(\mathrm{P}-\text { Terms })_{\mathrm{HL}} \mid
$$

DPTS restricts the number of product terms that can be switched simultaneously - there is no limit on the number of product terms that can be used.

The majority of designs fall below 15 DPTS, with the upper limit being approximately 25 DPTS. Lattice guarantees and tests the commercial grade GAL6002 for functionality at DPTS $\leq 30$.

A software utility is available from Lattice Applications Engineering that will perform this calculation on any GAL6002 JEDEC file. This program, DPTS, and additional information may be obtained from your local Lattice representative or by contacting Lattice Applications Engineering Dept. (Tel: 503-681-0118 or 1-800FASTGAL; FAX: 681-3037)

## TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS



Normalized Tco vs Vcc


Normalized Tco vs Temp


Normalized Tsu vs Vcc


Normalized Tsu vs Temp


Delta Tpd vs \# of Outputs
Switching


Delta Tpd vs Output Loading


Delta Tco vs \# of Outputs Switching


Delta Tco vs Output Loading


## TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS

Vol vs Iol


Normalized Icc vs Vcc


Delta Icc vs Vin (1 input)


Voh vs loh


Normalized Icc vs Temp


Input Clamp (Vik)


Voh vs loh


Normalized Icc vs Freq.

Section 1: Introduction
Section 2: High-Density Programmable Logic
Section 3: Low-Density Programmable Logic
Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices Introduction to ispGDS ..... 4-1
ispGDS22/18/14 Datasheet ..... 4-5
Section 5: Military Program
Section 6: Development Tools
Section 7: Quality and Reliability
Section 8: General Information

# Introduction to ispGDS ${ }^{\text {T }}$ 

Lattice, the pioneer of non-volatile in-system programmable (ISP ${ }^{\text {TM }}$ ) logic has now expanded the application of ISP to include programmable system interconnect. The new ispGDS (Generic Digital Switch) family combines the in-system programmability, high performance and low power of Lattice's GAL programmable logic technology with a switch matrix architecture, resulting in an innovative programmable signal router. The ispGDS is a configurable switch matrix which provides the ability to quickly implement and change p.c. board connections without changing mechanical switches or other system hardware. ISP allows the connections to be reprogrammed without removal from the p . c . board via a simple $5 \mathrm{~V}, 4$ wire serial interface. This capability allows the system designer to define hardware which can be reconfigured in-system to meet a variety of applications. The ispGDS also conserves board real estate, providing up to 22 I/Os in about a quarter square inch of board space.

With today's demand for user-friendly systems, there is an increasing need for hardware which is easily reconfigured under software control without manual intervention. The Lattice ispGDS family is an ideal solution for end-system feature reconfiguration and signal routing applications. The fast 7.5 ns propagation delay through the devices supports high-performance signal routing applications. Easiersystem upgrades, userfeature selection and system manufacturing are the results.

The ispGDS also provides higher quality and reliability than other switch solutions due to the nature of $\mathrm{E}^{2} \mathrm{CMOS}$ technology. $E^{2} \mathrm{CMOS}$ technology supports $100 \%$ testability which guarantees you $100 \%$ in-system programmability and functionality.

There are three members of the ispGDS family: the ispGDS22, ispGDS18, and ispGDS14. Each of the devices operate identically with the only difference being the number of I/O cells available.


## ispGDS Applications

With the ispGDS, designs can be reconfigured without mechanical devices or user intervention. Provision for easier system upgrades and feature selection can now
be included in the system's original design. A few examples of actual ispGDS applications demonstrate the possibilities.


One board design can support two different microprocessor speeds with the ispGDS.

Based on the motherboard processor configuration, the software directs the ispGDS to set the clock speed and the hardware for the correct configuration. The ispGDS eliminates the need to manually reconfigure the hardware to support manufacturing motherboards with different processors.


Create a cross point switch with the ispGDS

A crosspoint switch enables the MSB and LSB bytes on a bus to be swapped. The ispGDS acts as a crosspoint switch and swaps MSB and LSB bytes of the data for the different microprocessors.



## Introduction to ispGDS

## In-System Programming

The ispGDS devices can be programmed in-system using 5 volt only signals through a simple 4 -wire programming interface using TTL level signals. Programming and erasure of the entire device can be done in less than one second.

In addition to third party programmers, the ispGDS can be programmed from your automatic test equipment (ATE) or even from a PC on your manufacturing line. For more flexibility, you can have your product's embedded microprocessor configure the ispGDS devices though one of its I/O ports, making a field upgrade a snap.

Lattice provides free compiler support and "ISP Download Software" to support the software side of these programming options. The ispGDS Download routines are written in ANSI-standard C language which can be integrated directly into your system.

Designing with the ispGDS will provide you with the flexibility to reconfigure your design while in-system. It will revolutionize the way systems are designed and maintained. Call 1-800-327-8425 for a data sheet and begin designing today!


Figure 2. In-System Programming Using ispGDS Download Routines


Figure 3. Configuring an ispGDS Device from a Remote System
ispGDS22/18/14

FEATURES

- HIGH-SPEED SWITCH MATRIX
- 7.5 ns Maximum Propagation Delay
- Typical Icc $=25 \mathrm{~mA}$
— UltraMOS ${ }^{\circledR}$ Advanced CMOS Technology
- FLEXIBLE I/O MACROCELL
- Any I/O Pin Can be Input, Output, or Fixed TTL High or Low
- Programmable Output Polarity
- Multiple Outputs Can be Driven by One Input
- IN-SYSTEM PROGRAMMABLE (5-VOLT ONLY)
- Programming Time of Less Than One Second
- 4-Wire Programming Interface
- Minimum 10,000 Program/Erase Cycles
- E² CELL TECHNOLOGY
- Non-Volatile Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure (<100ms)
- 20 Year Data Retention
- APPLICATIONS INCLUDE:
- Software-Driven Hardware Configuration
- Multiple DIP Switch Replacement
- Software Configuration of Add-In Boards
- Configurable Addressing of I/O Boards
- Multiple Clock Source Selection
- Cross-Matrix Switch
- ELECTRONIC SIGNATURE FOR IDENTIFICATION

FUNCTIONAL BLOCK DIAGRAM (ispGDS22)



The Lattice ispGDST™ family is an ideal solution for reconfiguring system signal routing or replacing DIP switches used for feature selection. With today's demands for customer ease of use, there is a need for hardware which is easily reconfigured electronically without dismantling the system. The ispGDS devices address this challenge by replacing conventional switches with a software configurable solution. Since each I/O pin can be set to an independent logic level, the ispGDS devices can replace most DIP switch functions with about half the pin count, and without the need for additional pull-up resistors. In addition to DIP switch replacement, the ispGDS devices are useful as signal routing cross-matrix switches. This is the only non-volatile device on the market which can provide this flexibility.

With a maximum tpd of 7.5 ns , and a typical active Icc of only 25 mA , these devices provide maximum performance at very low power levels. The ispGDS devices may be programmed in-system, using 5 volt only signals, through a simple 4 -wire programming interface. The ispGDS devices are manufactured
using Lattice's advanced non-volatile $\mathrm{E}^{2} \mathrm{CMOS}$ process which combines CMOS with Electrically Erasable ( $\mathrm{E}^{2}$ ) floating gate technology. High speed erase times ( $<100 \mathrm{~ms}$ ) allow the devices to be reprogrammed quickly and efficiently.

Each I/O macrocell can be configured as an input, an inverting or non-inverting output, or a fixed TTL high or low output. Any I/O pin can be driven by any other I/O pin in the opposite bank. A single input can drive one or more outputs in the opposite bank, allowing a signal (such as a clock) to be distributed to multiple destinations on the board, under software control. The I/Os accept and drive TTL voltage levels.
Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all LATTICE products. LATTICE also guarantees 10,000 erase/rewrite cycles and data retention in excess of 20 years.

[^46]
## Specifications ispGDS

ispGDS ORDERING INFORMATION

## Commercial Grade Specifications

| Matrix Size | I/O Pins | Tpd (ns) | Isb (mA) | Icc (mA) | Ordering \# | Package |
| :---: | :---: | :---: | :---: | :---: | :--- | :--- |
| $11 \times 11$ | 22 | 7.5 | 25 | 40 | ispGDS22-7P | 28 -Pin Plastic DIP |
|  |  |  |  |  | 28 -Lead PLCC |  |
| $9 \times 9$ | 18 | 7.5 | 25 | 40 | ispGDS18-7P | 24 -Pin Plastic DIP |
| $7 \times 7$ | 14 | 7.5 | 25 | 40 | ispGDS14-7P | $20-$ Pin Plastic DIP |
|  |  |  |  |  | 20 -Lead PLCC |  |

## PART NUMBER DESCRIPTION



PACKAGE DIAGRAMS

## Specifications ispGDS



## 28-Pin PLCC



20-Pin DIP


## 20-Pin PLCC



## ispGDS FAMILY OVERVIEW

There are three members of the ispGDS family, the ispGDS22, ispGDS18, and ispGSD14. The numerical portion of the part name indicates the number of I/O cells available. All of the devices are available in a DIP package, with the ispGDS22 and ispGDS14 also available in a PLCC package. Each of the devices operate identically, with the only difference being the number of I/O cells available.

The ispGDS devices are all programmed through a four-pin interface, using TTL level signals. The four dedicated programming pins are named MODE, SDI, SDO, and SCLK. No high-voltage is needed, as the voltages needed for programming are generated internally. Programming of the entire device, including erasure, can be done in less than one second. During the programming operation, all I/O pins will be tri-stated. Further
details of the programming process can be found in the InSystem Programming section later in this datasheet.

The I/O cells in each device are divided equally into two banks (Bank A and Bank B). Each I/O cell can be configured as an input, an inverting output, a non-inverting output, or set to a fixed TTL high or low. A switch matrix connects the I/O banks, allowing an I/O cell in one bank to be connected to any of the I/O cells in the other bank. A single I/O cell configured as an input can drive one or more I/O cells in the other bank. The full I/O macrocell, which is identical for each of the I/O pins, is shown below. The allowable configurations are shown on the following page.

## I/O MACROCELL



## DEVICE PROGRAMMING

The ispGDS family of devices uses a standard JEDEC file, as used for programmable logic devices, to describe device programming information. Popular logic compilers, such as ABEL and CUPL, can produce the JEDEC files for these devices.

The JEDEC files can be used to program the ispGDS devices in a number of ways, which are shown in the In -System Programming Overview section later in this datasheet.

## ELECTRONIC SIGNATURE

An electronic signature word is provided with every ispGDS device. It contains 32 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control.

NOTE: The electronic signature is included in checksum calculations. Changing the electronic signature will alter the fuse checksum in the JEDEC fusemap.

I/O MACROCELL CONFIGURATIONS


Note 1: The development software configures all of the architecture control bits and checks for proper pin usage automatically. Note 2: The default configuration for unused pins is for all configuration bits set to one, which produces a tri-stated output.

## IN-SYSTEM PROGRAMMING OVERVIEW

The ispGDS family of devices can be programmed in a number of ways. Two options are to build a custom cable to program devices on your board directly from the parallel port of a PC, or to build the programming capability right into your system. To support the software side of either of these solutions, Lattice provides ispGDS Download programming routines. These routines are written in ANSI-standard C language, which can be used either to serve as detailed examples or to be integrated directly into your system. These routines include such common operations as Program, Read, and Verify. The routines are structured so that any hardware-dependent code is contained in a few well-documented functions, which can be easily modified for virtually any system. Example programs are included which use the parallel printer port of an IBM PC or compatible.
In addition, popular third-party programmers provide the ability to program the devices in a socket, just like conventionally programmed devices. This is especially useful for engineering debug of programming circuitry you build into your own system.

Many of the best uses for the ispGDS devices are to use them to reconfigure a system in the field. In any system that uses a microprocessor, the microprocessor can often be usedto program the ispGDS devices right in the system. The Lattice ispGDS Download software routines can be used to easily integrate ispGDS programming capability into your system software, or allow you to quickly create a custom program for configuring the system. A typical system is shown below in Figure 1. Note that the pattern information is normally stored in the Lattice ispSTREAM ${ }^{\text {TM }}$ format, which is a bit-packed format providing device pattern storage in less than $1 / 8$ that of a standard JEDEC file. The pattern information may reside either on-board in an EPROM or EEPROM, or be loaded from an external source such as a disk or across a network.


Figure 1 - In-System Programming Using ispGDS Download Software

## Specifications ispGDS

## IN-SYSTEM PROGRAMMING OVERVIEW

Another possibility is to use an external system, such as a portable PC, to change the configuration of a board by reprogramming an on-board ispGDS device (see figure 2 below). This can be useful for field service personnel to re-configure a board for testing or to enable optional features. The same method can be used during the design, test or manufacturing phase, before the board is put into a working system capable of reprogramming the devices.

Lattice provides a standalone utility program that uses the PC parallel port to program ispGDS devices through a cable. Also, the ispGDS Download software can be used to easily create custom programs for programming the ispGDS devices through your own interface. Example programs using the PC parallel port are included in the ispGDS Download software.
If you have any questions about programming the ispGDS devices, please contact Lattice Application Engineering at 800-327-8425 or 503-693-0201.


Figure 2 - Configuring the ispGDS from a Remote System

## Specifications ispGDS

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}} \ldots \ldots \ldots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ~ . ~ 5 ~ t o ~+7 V ~$
Input voltage applied ......................... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature ................................. -65 to $150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied $\qquad$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

## Commercial Devices:

Ambient Temperature ( $T_{A}$ ) .............................. 0 to $75^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground .................... +4.75 to +5.25 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER | CONDITION | MIN. | TYP. ${ }^{2}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  | Vss - 0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  | 2.0 | - | Vcc+1 | V |
| IIL | Input or I/O Low Leakage Current | $0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{IL}}$ (MAX.) | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current | $3.5 \mathrm{~V} \leq \mathrm{VIN}^{\text {S }} \mathrm{VCc}$ | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage | Iol $=$ MAX. Vin $=\mathbf{V}$ IL or $\mathbf{V}_{\text {IH }}$ | - | - | 0.5 | V |
| VOH | Output High Voltage | $\mathbf{I O H}=$ MAX. $\quad \mathbf{V i n}=\mathbf{V}$ IL or $\mathbf{V}_{\text {IH }}$ | 2.4 | - | - | V |
| IOL | Low Level Output Current |  | - | - | 8 | mA |
| IOH | High Level Output Current |  | - | - | -3.2 | mA |
| los ${ }^{1}$ | Output Short Circuit Current | $\mathbf{V c c}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {out }}=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | -30 | - | -130 | mA |

## COMMERCIAL

| ISB | Standby Power <br> Supply Current | Inputs = OV Outputs open | L-7 | - | 15 | 25 | mA |
| :---: | :--- | :--- | :--- | :--- | :--- | :---: | :---: |
| ICC | Operating Power <br> Supply Current | $\mathbf{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ <br> $\mathbf{f t o g g l e}=15 \mathrm{MHz}$ Outputs Open | $\mathrm{L}-7$ | - | 25 | 40 | mA |

1) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
2) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

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

| SYMBOL | PARAMETER | MAXIMUM* $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{1 / 0}$ | I/O Capacitance (as input or output) | 8 | pF | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |

[^47]
## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

|  |  |  |  | COM |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PARAMETER | TEST COND. | DESCRIPTION |  | MIN. | MAX. | UNITS |
| tpd | A | Input to Output Delay | One Input Driving One Output | 1 | 7.5 | ns |
| $f_{\text {max }}$ | A | Maximum Input Frequency | One Output Switching | - | 50 | MHz |
| twh | A | Input Pulse Duration, High |  | 10 | - | ns |
| twl | A | Input Pulse Duration, Low |  | 10 | - | ns |

SWITCHING WAVEFORMS


Input to Output Delay

INPUT


Input Pulse Width/ Fmax

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 2ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3 -state levels are measured 0.5 V from steady-state active level.

Output Load Conditions (see figure)

| Test Condition | $\mathbf{R 1}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}_{\mathbf{L}}$ |
| :--- | :---: | :---: | :---: |
| A | $470 \Omega$ | $390 \Omega$ | 50 pF |


${ }^{*} C_{\llcorner }$INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

泰Lattice"

## IN-SYSTEM PROGRAMMING

Each device in the ispGDS family uses the same programming algorithm and programming parameters. The devices generate their own internal supervoltage for programming, and only require standard TTL signals to program. Programming the ispGDS devices is centered around a 3 -state state machine, with its state transitions controlled by two control signals. One of the states is the normal operation state, with the other two states controlling the programming process. The ISP programming state machine is controlled by four dedicated programming pins on each device, which are described below. During normal device operation the SDI, MODE and SCLK pins should be tied low.

## SERIAL PROGRAMMING INTERFACE

The ispGDS devices are programmed using the four dedicated programming interface pins: SDI, MODE, SDO and SCLK.
Serial Data In (SDI) performs two different functions. First as the input to the serial shift register, and second as one of the two control pins for the programming state machine. Because of this dual role, the function of SDI is controlled by the MODE pin. When MODE is low, SDI is the serial input to the shift registers and when MODE is high, SDI becomes a control signal. Internal to the device, the SDI is multiplexed to various shift registers in the device. The different shift instructions of the state machine determine which of these shift registers gets the input from SDI.
The MODE signal, combined with the SDI signal, controls the programming state machine, as described in this section.
Serial Clock (SCLK) is the serial shift register clock used to clock the internal serial shift registers and to clock the state machine between states. State changes and shifting data in is done on
a low-to-high transition. When shifting data out, the data is available on SDO only after a subsequent high-to-low transition. When MODE is high, SCLK controls the programming state machine, and when MODE is low, SCLK acts as a shift register clock to shift data in or out or to start an operation.
Serial Data Out (SDO) is the output of the serial shift registers. The selection of shift register is again determined by the state machine's shift instruction. When MODE is driven high, SDO connects directly to the SDI, bypassing the device's shift registers.

## PROGRAMMING STATE MACHINE OPERATION

The programming state machine controls which mode the device is in, and provides the means to read and write data to the device (see figure 3). The four dedicated control pins are used to load and unload data, and to control the state machine. The state machine is a 2 bit state machine, with three defined states: IDLE (00), SHIFT (01) and EXECUTE (10). Instruction codes are shifted into the device in the SHIFT state, and control which instruction is to be executed in the EXECUTE state. In the SHIFT and EXECUTE states all the I/O pins are tri-stated. To transition between states MODE is held high, SDI is set to the appropriate level, and SCLK is clocked.

The IDLE state is the default state of the state machine. In this state the device is in normal operation, and programming operations are disabled. Each device contains a hardwired eight bit ID code, which can be read from this state. The IDLE state may be reached from any other state by setting MODE high, SDI low, and clocking SCLK.

Note:


Figure 3. Programming State Machine


## Specifications ispGDS

The SHIFT state provides the means to load an instruction into the state machine. A five bit instruction is loaded into the state machine by holding MODE low and clocking in the instruction, via SDI. The entire Instruction Set is shown below in Table 1. Once an instruction is loaded into the state machine, it may be executed in the EXECUTE state. The SHIFT state is reached from either of the other two states by setting MODE and SDI high, and clocking SCLK.

The EXECUTE state is where the instruction that was shifted in during the SHIFT state is actually executed. An individual instruction execution is started by taking MODE low and clocking SCLK.

| Instruction | Operation | Description |
| :--- | :--- | :--- |
| 00000 | NOP | No operation performed. |
| 00010 | SHIFT_DATA | Clocks data into, or out of, <br> the Data Shift Register. |
| 00011 | BULK_ERASE | Erases the entire device. |
| 00101 | ERASE_ARRAY | Erases everything except <br> the Architecture rows. |
| 00110 | ERASE_ARCH | Erases the Architecture <br> rows only |
| 00111 | PROGRAM | Programs the Shift <br> Register data into the <br> addressed row |
| 01010 | VERIFY | Load data from the <br> selected row into the <br> Serial Shift Register. |
| 01110 | FLOWTHRU | Disables the Shift Register <br> (SDI=SDO). |

Table 1. Instruction Codes

## SHIFT REGISTERS

The ispGDS devices have three shift registers, the Device ID shift register, the Instruction shift register and the Data shift register. All shift registers operate on a First In First Out (FIFO) basis, and are chosen by which state the programming state machine is in.

The Device ID shift register is only accessible in the IDLE state. It is eight bits long, and is only used to shift out the device ID. The Instruction shift register is only accessible in the SHIFT state. It is five bits long, and is only used to shift the Instruction Codes
into the device. The Device ID and Instruction shift registers expect the LSB shifted in first. The Data shift register is 24 bits long, and is used to shift all addresses and data into or out of the device. The Data shift register is only accessible in the EXECUTE state when executing a SHIFT_DATA instruction.
To program an ispGDS device, data is read from a serial bit stream and shifted into the shift registers. Twenty four bits are read at a time, shifted into the device, and then a programming operation is performed. The exact sequence, and the methods for converting a JEDEC map into a serial bit stream is explained in the Device Architecture section.

## TIMING

Programming the ispGDS devices properly requires that a number of timing specifications be met. Most critical are the specifications relating to programming and erasing the $\mathrm{E}^{2} \mathrm{CMOS}$ cells. In addtion to a minimum pulse width, there is also a maximum specification for these parameters. Table 2 lists the programming mode specifications for the ispGDS family of devices. Diagrams for the programming mode specifications are shown in Figures 4, 5, and 6 on the following page.

## INTERNAL ARCHITECTURE

This section explains the internal architecture of the device as it relates to programming. This section is not strictly necessary to the programming of the device if you are using the Lattice software tools provided.
The key to easy programming of the ispGDS device is the use of a bit-stream of all the data that needs to be shifted into a device to program it. Lattice calls this bit-stream format an ispStream format. The ispStream format uses one bit to represent the state of each of the programmable cells, instead of the byte value used in a JEDEC file. Considering the additional characters in a JEDEC file, this means a space savings of more than a factor of eight. In addition, the ispStream does not require any parsing. The bits are simply read from the file and shifted into the device. Since only 49 bytes are required to store the pattern for an ispGDS device, many different patterns can be stored in a small space.
This section mainly concerns the details of constructing the ispStream format. If you are using the supplied software tools, a conversion utility (complete with source code) is included to convert an industry-standard JEDEC file to an ispStream format. All of the Lattice software routines read from and write to this ispStream format.
The ispGDS devices have two basic sections to their programming architecture (see figure 7). There are three rows of architecture information, which contain the three bits that control the function of each I/O cell. The rows are 24 bits long; one bit for each I/O cell. ( the ispGDS18 and ispGDS14 do not use all the bits) The other major area contains the cell data for the switch

## Specifications ispGDS

Table 1. Programming Mode Timing Specifications

| Param. | Description | Min. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| trst | Time from power-up of device to any progamming operation. | 1 | - | $\mu \mathrm{s}$ |
| tisp | Time from leaving IDLE state to I/O pins tri-state, or entering IDLE state to I/O pins active. | - | 10 | $\mu \mathrm{~s}$ |
| $\mathbf{t s u}$ | Setup time, from either MODE or SDI to rising edge of SCLK. | 100 | - | ns |
| th | Hold time, from rising edge of SCLK to MODE or SDI changing level. | 100 | - | ns |
| $\mathbf{t c o}$ | Time from falling edge of SCLK to data out on SDO. | - | 150 | ns |
| $\mathbf{t c l k h}$ | Clock pulse width of SCLK while high. | 0.5 | - | $\mu \mathrm{s}$ |
| $\mathbf{t c l k I}$ | Clock pulse width of SCLK while low. | 0.5 | - | $\mu \mathrm{s}$ |
| tpwp | Time for a programming operation. | 40 | 100 | ms |
| tpwe | Time for an erase operation. | 200 | - | ms |
| tpwv | Time for a verify operation. | 5 | - | $\mu \mathrm{s}$ |



Figure 4. Programming Mode Timing


Figure 5. Shift Register Timing


Figure 6. Program, Verify, \& Erase Timing

## Specifications ispGDS

matrix area of the device, and the User Electronic Signature (UES) data area. There are two UES rows of 24 bits each, and 11 switch matrix rows of 24 bits each.

Even though the shift register lengths are 24 bits long, all of the area is not a data area. In the Architecture section, two bits are used for addressing. In the matrix/UES area, there are six bits for addressing. In the switch matrix area, there are only 11 bits of actual data, and 7 dummy bits to make all the shift registers the same length. These 5 bits will always read as a one, or a logic High on SDO. For the UES, there are 16 bits of actual data in each row, and two dummy bits.

## STREAM FORMAT

To convert the information in a standard JEDEC file into the ispStream format, all of the addressing information is added, as well as the place-holding bits (dummy bits). The objective is to
have every bit that is shifted into the device for programming included in the ispStream format. For the three architecture rows, this means simply adding the two bits for the addresses. For the UES and Switch Matrix rows, there are 8 bits to add. The first two bits are always 00 to distinguish this area from the Architecture row. Then there are 4 bits to address the specific row, and 2 bits as placeholders. In the Switch Matrix rows, there are also 5 bits for place-holding at the end of the rows. The various placeholding bits are built into the device so that all rows appear to be the same length, thus simplifying the programming operations.
The ispStream uses one bit for each programmable cell. This means that each row will take 24 bits, or 3 bytes of storage. With 3 bytes per row, and 16 rows per device, the ispStream would then take only 48 bytes of storage area. However, there is one extra byte used at the front of the file to store the device ID code,

| Address bits |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Dummy bits <br> 11 bits of Matrix Data | $\nabla$ |
| 00 | 0000 | 11 | Switch Matrix Data | 11111 |
| 00 | 0001 | 11 |  | 11111 |
| 00 | 0010 | 11 |  | 11111 |
| 00 | 0011 | 11 |  | 11111 |
| 00 | 0100 | 11 |  | 11111 |
| 00 | 0101 | 11 |  | 11111 |
| 00 | 0110 | 11 |  | 11111 |
| 00 | 0111 | 11 |  | 11111 |
| 00 | 1000 | 11 |  | 11111 |
| 00 | 1001 | 11 |  | 11111 |
| 00 | 1010 | 11 | $\nabla$ | 11111 |


| 00 | 1011 | 11 | UES Data |
| :--- | :--- | :--- | :--- |
| 00 | 1100 | 11 | UES Dats of UES data |


| 01 | Architecture Control Bit:C0 |
| :--- | :--- |
| 10 | Architecture Control Bit:C1 |
| 11 | Architecture Control Bit:C2 |

SDI $\rightarrow$ Shift Register (24 bits) $\rightarrow$ SDO

Figure 7. ispGDS Architecture
and a 32-bit checksum. This ID code is the same as the one hardwired into the device. The purpose of including this ID code is to be sure the ispStream type is the same as the device is to be programmed into. All ispStream formats, regardless of which Lattice In-System Programmable device they are for, will contain this ID code as the first byte. By reading this ID code, you can tell which device the ispStream is for. If the ispStreams are stored in EPROM for instance, they will be stacked end to end, and the ID code will help to determine not only which device type it belongs with, but how long it is, and thus where the next pattern starts. See Figure 8 for details of the ispStream format, and Figure 9 for the JEDEC map.

## Specifications ispGDS

## ALGORITHMS

The programming of the ispGDS devices will be described as a hierarchical set of algorithms and functions. This section contains the high level algorithms for erasing, programming, verifying and loading an ispGDS device. A universal set of functions is used to make up all the algorithms, and enable each of them to be written in a modular format. The individual functions are explained in the next section. Note that most procedures leave the device in the SHIFT state. These algorithms and functions closely follow the ispCODE source code library that Lattice provides.

ispStream 4-bit \# 8

Figure 8. ispStream Format

Specifications ispGDS


| ispGDS22: | B10 | B9 | B8 | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| ispGDS18: | B8 | B7 | B6 | B5 |  |  | B4 | B3 | B2 | B1 | B0 |
| ispGDS14: | B6 | B5 | B4 |  |  |  |  | B3 | B2 | B1 | B0 |

User Electronic Signature
121, 122... ... 151, 152

| Byte 3 | Byte 2 | Byte 1 | Byte 0 |
| :--- | :--- | :--- | :--- |


| M | L |
| :--- | :--- |
| $S$ | $S$ |
| $B$ | $B$ |

Figure 9. ispGDS JEDEC Fuse Map

To simplify the algorithms, all operations use an ispStream format as the data structure from which to read from and write to. The ispStream contains all the address information, and simplifies all the operations considerably. Working from the ispStream, the device appears as an array of 16 rows by 24 bits long.

## Program Algorithm

Before programming a device, it must first be erased. Cells can be programmed (set to a JEDEC zero) using the programming command, but only an Erase procedure erase a cell (set a cell back to a JEDEC one). In this algorithm, the entire device is erased (Bulk Erased), and then the entire device is programmed.
To program a device:

- Call procedure: Get_ID ( to check device type)
- Call procedure: Change_State ( from IDLE to SHIFT state)
(Erase entire device)
- Call procedure: Shift_Command, with command: ERASE
- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Execute_Command (starts operation)
- Call procedure: Wait (Erase_Time)
- Call procedure: Change_State ( to SHIFT state)
- Set row_count $=0$
- Loop until row_count $=15$
(Program one row on each loop)
- Call procedure: Shift_Command, with command:

SHIFT_DATA

- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Shift_Data_In, with data location in ispStream at (row_count x 24)
- Call procedure: Change_State ( to SHIFT state)
- Call procedure: Shift_Command, with command: PROGRAM
- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Execute_Command (starts operation)
- Call procedure: Wait (Program_Time)
- Call procedure: Change_State ( to SHIFT state)
- End Loop


## Load Algorithm

The load algorithm below is the same for all ispGDS devices. First the 13 rows of array data (11 rows for the array matrix, and 2 for the UES) is read, and then the 3 rows of Architecture information is read. After each row is read, it is stored in an ispStream format.
In order to load each row's data into the shift register, it is necessary to load the address of the row into the appropriate area of the shift register. Because of the unique way the different areas of the device are addressed, the simplest way to get the addresses into the device in the proper order is to use an existing ispStream to supply those addresses. In other words, the full data for each row is loaded from the ispStream into the device. When a VERIFY command is executed, the device's data for that same row is then loaded into the shift register to be shifted out. This method will be used in this algorithm.
When using an existing ispStream to supply the addresses, the data should not be the same as the expected data, or a failure to verify may not be detected. To cover this possibility, a pattern that contains all ones for data can be used (and is supplied with the software tools provided by Lattice). This ispStream still has the addresses intact, but all programmable cell data is set to a one (erased state).
To load a device:

- Call procedure: Get_ID ( to check device)
- Call procedure: Change_State ( from IDLE to SHIFT state)
- Set row_count $=0$
- Loop until row_count = 15
- Call procedure: Shift_Command, with command:

SHIFT_DATA

- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Shift_Data_In, with data location in

Source ispStream at (row_count x 24)

- Call procedure: Change_State ( to SHIFT state)
- Call procedure: Shift_Command, with command: VERIFY
- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Execute_Command (starts operation)
- Call procedure: Wait (Verify_Time)
- Call procedure: Change_State ( to SHIFT state)
- Call procedure: Shift_Command, with command: SHIFT_DATA
- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Shift_Data_Out, with data location in

Target ispStream at (row_count x 24)

- Call procedure: Change_State ( to SHIFT state)
- End Loop

Specifications ispGDS

## Verify Algorithm

A row by row verification procedure is used to verify the ispGDS device, and is basically the same as the verify algorithm, except that each row is compared with (instead of stored in) an ispStream as the data is shifted out of the device. Note that the special pattern used for verifying is used to load the addresses, the same as in the Load algorithm. The
To load a device:

- Call procedure: Get_ID (to check device type)
- Call procedure: Change_State ( from IDLE to SHIFT state)
- Set row_count =0
- Loop until row_count $=15$
- Call procedure: Shift_Command, with command:

SHIFT_DATA

- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Shift_Data_In, with data location in

Source ispStream at (row_count x 24)

- Call procedure: Change_State ( to SHIFT state)
-Call procedure: Shift_Command, with command: VERIFY
- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Execute_Command (starts operation)
- Call procedure: Wait (Verify_Time)
- Call procedure: Change_State ( to SHIFT state)
- Call procedure: Shift_Command, with command: SHIFT_DATA
- Call procedure: Change_State (to EXECUTE State)
- Call procedure: Shift_Data_Out, with data location a 24 bit temporary buffer
- Compare temp row buffer with data location in ispStream to be verified against, at (row_count x 24)
- Verify Error if the 24 bits don't match
- Call procedure: Change_State ( to SHIFT state)
- End Loop


## PROCEDURES

This section describes the procedures that make up the program, verify and load algorithms for the ispGDS family of devices. The procedures are written so each algorithm may be written in a high-level modular format, calling one of the following procedures to actually change pin levels and handle timing.
Important: Notice that most of the procedures are written so the state machine is left in the Shift State ready to perform the next operation. This point is important in keeping all the routines compatible.

## Goto_IDLE Procedure

The Goto_IDLE procedure resets the programming state machine to the IDLE state, regardless of which state it is in.
Procedure Steps:
set MODE pin High, and SDI pin Low
wait Tsu
bring SCLK pin High
wait Tclkh
bring SCLK pin Low
(END Procedure)

## Get_ID Procedure

The 8 bit device ID code provides the means to identify the three different ispGDS devices. The ID is read in the IDLE state by first loading the ID into the shift register and then clocking the data out. The ID is loaded by holding MODE high and SDI low and clocking the device. The ID is clocked out of the device by holding MODE low and clocking DCLK. Only seven clock cycles are required, since the first bit is available at SDO after the ID is loaded.

8 bit ID codes:

| Device | Pins | Device ID |
| :--- | :--- | :--- |
| ispGDS22 | 28 | 01110010 (72 hex) |
| ispGDS18 | 24 | 01110001 (71 hex) |
| ispGDS14 | 20 | 01110000 (70 hex) |

## Procedure Steps:

set MODE pin High, and SDI pin Low
wait Tsu
Set SCLK pin High
wait Tclkh
Set SCLK pin Low
set count =0
get value from SDO and store in temp_buffer[0]
set count = 1
loop until count $==7$
bring SCLK pin High
wait Twh
bring SCLK pin Low
wait Twl
get value from SDO and store in temp_buffer[count]
End loop
( Device ID code is now stored in the temp_buffer array )
(END procedure)

Specifications ispGDS

## Change_State Procedure

The Change_State procedure changes the programming state machine to the next state, according to the state diagram.
Procedure Steps:
set MODE pin High, and SDI pin High
wait Tsu
bring SCLK pin High
wait Th
set MODE pin Low, and SDI pin Low
wait Tclkh
bring SCLK pin Low
(END Procedure)

## Shift_Command Procedure

The Shift_Command procedure shifts a five bit command into the device's shift register. The various commands should be coded so the procedure can use a mnemonic (such as PROGRAM), and the controlling software will use the appropriate five bit sequence for that command.

## Procedure Steps:

set MODE pin Low
set count $=0$
loop until count $==4$
get next bit of command code (count = bit number)
set SDI pin to bit value
wait Tsu
bring SCLK pin High
wait Tclkh
bring SCLK pin Low
count $=$ count +1
End loop
(END Procedure)

## Shift_Data_In Procedure

The Shift_Data_In procedure explains the steps to clock a row of data into the device, reading the data from an ispStream. This procedure shifts in 22 bits of data, and is used for all 16 rows.
Procedure Steps:
set MODE pin Low
set count $=0$
loop until count $==23$
get next bit from ispStream (bit number $=$ count x row_number)
set SDI pin to bit value
wait Tsu
bring SCLK pin High

wait Tclkh<br>bring SCLK pin Low

End loop
(END Procedure)

## Shift_Data_Out Procedure

The Shift_Data_In procedure explains the steps to clock a row of data out of the device and store it in an ispStream. This procedure shifts out 22 bits of data, and is used for all 16 rows.
Procedure Steps:
set MODE pin Low
wait Tsu
set count $=0$
loop until count $==23$
bring SCLK pin High
wait Tclkh
bring SCLK pin Low
get value of SDO pin and store as next bit in ispStream ( bit number = count x row_number)
End loop
(END Procedure)

## Execute_Command Procedure

The Execute_Command procedure causes many of the commands to begin executing after the state machine is in the EXECUTE state.

## Procedure Steps:

set MODE pin Low, and SDI pin Low
wait Tsu
bring SCLK pin High
wait Twh
bring SCLK pin Low
(END Procedure)

## Wait Procedure

The Wait procedure simply waits the indicated time period, to make sure various timing parameters are met. This procedure is most likely to be used when executing the PROGRAM and ERASE procedures, which need a long delay (tens of milliseconds). The other timing parameters may be able to be guaranteed by the system timing, although the wait procedure can also be used. The various timing parameters should be coded so that a mnemonic (such as PROGRAM_TIME) may be passed to the procedure. This procedure will be system (hardware) specific.
Procedure Steps:
wait the indicated time
(END Procedure)

## ISP PROGRAMMING TOOLS SUPPORT

To assist users in implementing the ISP programming, Lattice provides ispGDS Download software C language routines which implement the basic ISP functions for programming through the PC parallel port. This section provides the details of the ispGDS C code and the PC parallel port definition needed to program the ispGDS.

## PC PARALLEL PORT DEFINITION

The PC parallel port must be properly defined in order to use the ispGDS software to program the devices. After defining the port, it is just a matter of using the ispGDS software to read and write from the parallel port. To guarantee the signal integrity and drive capability, a 74 HC 367 (or equivalent) buffer should be directly connected at the parallel port's DB25 connector. Figure 10 below defines the parallel port DB25 pins and the associated programming signals. This hardware definition is identical to the Lattice ispLSI programming hardware with the exception of the ispEN and RESET signals which are defined only for the ispLSI devices.

The buffer at the parallel port drives the cable that connects the output of the buffer to the ISP programming signals of the
device. It is important to keep the cable length to a minimum to reduce the loading on the signal drivers. The SDI, SCLK and MODE inputs to the ispGDS are driven by the buffer connected at the parallel port. SDO output signal from the ispGDS is driven from the device back to the parallel port. If the load on the SDO signal is more than a minimum cable length and the parallel port input, it is recommended that the user provide a buffer on the circuit board to ensure signal integrity.

## ISP SOFTWARE INTERFACE

In addition to the hardware interface, the ispGDS Download C language routines take care of the ispGDS programming software interface. The software interface must implement routines to read and write from the parallel port, to translate JEDEC fusemap to and from the stream file format, and to toggle the ISP hardware signals connected at the output port. Predefined routines for these functions such as gds_program, gds_read, gds_verify, etc. are provided with the ispGDS download software which is available on the Lattice BBS at (503) 693-0215 under the file name GDSPKG.ZIP.

Also available within the GDSPKG.ZIP file is a compiler that supports all the ispGDS devices. These utilities can also be obtained from your local Lattice sales representative.


Figure 10. PC Parallel Port Buffer \& RJ45 Connector Definition

TYPICAL AC AND DC CHARACTERISTIC DIAGRAMS

Section 1: Introduction
Section 2: High-Density Programmable Logic
Section 3: Low-Density Programmable Logic
Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices
Section 5: Military Program
Military Program Overview ..... 5-1
Military Ordering Information ..... 5-3
Military Product Datasheets GAL16V8 ..... 5-5
GAL20V8 ..... 5-13
GAL22V10 ..... 5-21pLSI and ispLSI 1016 (See Commercial Datasheet)pLSI and ispLSI 1024 (See Commercial Datasheet)pLSI and ispLSI 1032 (See Commercial Datasheet)
Section 6: Development Tools

## Section 7: Quality and Reliability

## Section 8: General Information

## Military Program Overview

## CORPORATE PHILOSOPHY

Lattice Semiconductor is committed to leadership in device performance and quality. Our family of Military GAL devices is a reflection of this philosophy. Lattice manufactures all devices under strict Quality Assurance guidelines. All grades, Commercial through Military 883, are monitored under a quality program conformant to MIL-I-38535 Appendix C with inspections conformant to MIL-I-45208.

Complete reviews of Lattice's procedures, documentation and technical data are welcomed and can be arranged at the Company's facility near Portland, Oregon.

## QUALITY AND TESTABILITY

Lattice Semiconductor processes its devices to strict conformance with MIL-STD-883 Class B. In conjunction with the military flow, the inherent testability of $\mathrm{E}^{2} \mathrm{CMOS}$ technology allows Lattice to achieve a quality level superior to other PLD technologies.

All devices are patterned and tested dozens of times throughout the manufacturing flow. Every device is tested under worst case configurations to assure customers achieve $100 \%$ yields. Tests are performed using the same $E^{2}$ cell array that will be used for the final patterning of the devices. This $100 \%$ "actual test" philosophy does away with the correlated and simulated testing that is necessary with bipolar and UV (EPROM) based PLD devices.

## RELIABILITY

Lattice Semiconductor performs extensive reliability testing prior to product release. This testing continues in the form of Reliability Monitors that are run on an ongoing basis to assure continued process integrity. A formal, written report of these test results is updated regularly and can be obtained from your local Lattice Sales Representative.

The reliability testing performed includes extensive analysis of fundamental design and process integrity. The reprogrammable nature of Lattice devices allows for an inherently more thorough reliability evaluation than other programmable alternatives.

## MIL-STD-883 COMPLIANCE

MIL-STD-883 defines a uniform and precise method for environmental, mechanical and electrical testing which ensures the suitability of microelectronic devices for use in military and aerospace systems. Table I summarizes the MIL-STD-883, Class B flow. Table II summarizes the conformance testing required by MIL-STD-883, Method 5005, for quality conformance testing of Lattice military microcircuits.

## MIL-I-38535

MIL-I-38535 Appendix A and C, when used in conjunction with MIL-STD-883, define design, packaging, material, marking, sampling, qualification and quality system requirements for Lattice military devices.

## GROUP DATA

Group $A$ and $B$ data is taken on every inspection lot per MIL-STD-883, Class B requirements. This data, along with Generic Group C and D data can be supplied, upon written request, with your device shipment. Your Lattice sales representative can advise you of charges and leadtime necessary for providing this data.

## STANDARD MILITARY DRAWINGS

Lattice actively supports the DESC Standard Military Drawing (SMD) Program. The SMD Program offers a cost effective alternative to source control drawings and provides standardized MIL-STD-883 product specifications to simplify military procurement.

A list of currently available SMD qualified devices is provided (see Military Ordering Information).

## MILITARY SCREENING FLOW (TABLE I)

| Screen | Method | Requirement |
| :--- | :--- | :---: |
| Internal Visual | 2010 Cond. B | $100 \%$ |
| Temp. Cycling | 1010 Cond. C | $100 \%$ |
| Constant Acceleration | 2001 Cond. E | $100 \%$ |
| $\begin{array}{l}\text { Hermeticity } \\ \text { Fine } \\ \text { Gross }\end{array}$ | $\begin{array}{l}1014 \\ \text { Cond. A or B } \\ \text { Cond. C }\end{array}$ | $100 \%$ |
| Endurance Test | 1033 |  |
| Retention Test | $\begin{array}{l}\text { Unbiased Bake } \\ 24 ~ H R S . ~ \\ \text { TA }=180^{\circ} \mathrm{C}\end{array}$ | $100 \%$ |
| Pre Burn-In Electrical | $\begin{array}{l}\text { Applicable Device } \\ \text { Specification } \\ \text { Tc }=25^{\circ} \mathrm{C}\end{array}$ | $100 \%$ |
| Dynamic Burn-In | 1015 Cond. D |  |
| Post Burn-In Electrical | $\begin{array}{l}\text { Applicable Device } \\ \text { Specification } \\ \text { Tc }=25^{\circ} \mathrm{C}\end{array}$ | $100 \%$ |
| PDA $=5 \%$ |  |  |$]$

MILITARY QUALITY CONFORMANCE INSPECTIONS (TABLE II)

| Subgroup | Method | Sample |
| :---: | :---: | :---: |
| GROUP A: Electrical Tests |  |  |
| $\begin{gathered} \text { Subgroups } 1,7,9 \\ \text { Electrical Test } \end{gathered}$ | Applicable Device Spec. $25^{\circ} \mathrm{C}$ | LTPD $=2$ |
| Subgroups 2, 8A, 10 Electrical Test | Applicable Device Spec. Max. Operating Temp. | LTPD $=2$ |
| Subgroups 3, 8B, 11 Electrical Test | Applicable Device Spec. Min. Operating Temp. | LTPD $=2$ |
| GROUP B: Mechanical Tests |  |  |
| Subgroup 2 |  | 4(0) |
| Solvent Resistance | 2015 |  |
| Subgroup 3 |  | LTPD $=10$ |
| Solderability | 2003 |  |
| Subgroup 5 |  | LTPD $=15$ |
| Bond Strength | 2011 |  |
| GROUP C: Chip Integrity Tests |  |  |
| Subgroup 1 |  |  |
| Dynamic Life Test End Point Electrical | $1005,1,000$ HRS. $125^{\circ} \mathrm{C}$ <br> Applicable Device Spec. | LTPD $=5$ |
| Subgroup 2 |  |  |
| Unbiased Retention | 1,000 HRS. $150^{\circ} \mathrm{C}$ | LTPD $=5$ |
| End Point Electrical | Applicable Device Spec. |  |
| GROUP D: Environmental Integrity |  |  |
| Subgroup 1 |  | LTPD $=15$ |
| Physical Dimensions | 2016 |  |
| Subgroup 2 |  | LTPD $=5$ |
| Lead Integrity | 2004, Cond. B |  |
| Hermeticity | 1014 |  |
| Subgroup 3 |  | LTPD $=15$ |
| Thermal Shock | 1011, Cond. B, 15 Cycles |  |
| Temp. Cycle | 1010, Cond. C, 100 Cycles |  |
| Moisture Resistance | 1004 |  |
| Hermeticity | 1014 |  |
| Visual Examination | 1004, 1010 |  |
| Endpoint Electrical | Applicable Device Spec. |  |
| Subgroup 4 |  | LTPD $=15$ |
| Mechanical Shock | 2002, Cond. B |  |
| Vibration | 2007, Cond. A |  |
| Constant Acceleration | 2001, Cond. E |  |
| Hermeticity | 1014 |  |
| Visual Examination | 1010, 1011 |  |
| Endpoint Electrical | Applicable Device Spec. |  |
| Subgroup 5 |  | LTPD $=15$ |
| Salt Atmosphere | 1009, Cond. A |  |
| Hermeticity | 1014 |  |
| Visual Examination | 1009 |  |
| Subgroup 6 |  | 3(0) |
| Internal Water Vapor | 1018 < 5,000 PPM, $100^{\circ} \mathrm{C}$ |  |
| Subgroup 7 |  | LTPD $=15$ |
| Lead Finish Adhesion | 2025 |  |
| Subgroup 8 |  | 5(0) |
| Lid Torque | 2024 |  |

## Military Ordering Information

Lattice offers the most comprehensive line of military $E^{2}$ CMOS Programmable Logic Devices. Lattice recognizes the trendin military device procurementtowards using SMD compliant devices and encouragescustomers
to use the SMD number where it exists, when ordering parts. Listed below are Lattice's military qualified devices and their corresponding SMD numbers. Please contact your local Lattice representative for the latest product listing.

## Military Products Selector Guide

| Family | Part* | SMD \# | Tpd (ns) | Fmax (MHz) | lce |  | Package |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{aligned} & \text { Typ } \\ & \text { (mA) } \end{aligned}$ | $\begin{aligned} & \text { Max } \\ & (\mathrm{mA}) \end{aligned}$ |  |
| pLSI | pLSI 1016-60LHU883 | Contact Factory | 20 | 60 | 100 | 170 | 44-Pin JLCC |
|  | pLSI 1024-60LH8883 | Contact Factory | 20 | 60 | 130 | 215 | 68-Pin JLCC |
|  | pLSI 1032-60LG/883 | 5962-9466801MXC | 20 | 60 | 135 | 220 | 84-Pin CPGA |
| ispLSI | ispLSI 1016-60LH/883 | Contact Factory | 20 | 60 | 100 | 170 | 44-Pin JLCC |
|  | ispLSI 1024-60LH/883 | Contact Factory | 20 | 60 | 130 | 215 | 68-Pin JLCC |
|  | ispLSI 1032-60LG/883 | 5962-9308501MXC | 20 | 60 | 135 | 220 | 84-Pin CPGA |
| GAL16V8 | GAL16V8B-10LD/883 | 5962-8983904RA | 10 | 62.5 | 75 | 130 | 20-Pin CERDIP |
|  | GAL16V8B-10LP/883 | 5962-89839042A | 10 | 62.5 | 75 | 130 | 20-Pin LCC |
|  | GAL16V8B-15LD/883 | 5962-8983903RA | 15 | 50 | 75 | 130 | 20-Pin CERDIP |
|  | GAL16V8B-15LR/883 | 5962-89839032A | 15 | 50 | 75 | 130 | 20-Pin LCC |
|  | GAL16V8A-20LD/883 | 5962-8983902RA | 20 | 41.6 | 75 | 130 | 20-Pin CERDIP |
|  | GAL16V8A-20LR/883 | 5962-89839022A | 20 | 41.6 | 75 | 130 | 20-Pin LCC |
|  | GAL16V8A-30LD/883 | 5962-8983901RA | 30 | 33.3 | 75 | 130 | 20-Pin CERDIP |
| GAL20V8 | GAL20V8B-10LD/883 | 5962-8984004LA | 10 | 62.5 | 75 | 130 | 24-Pin CERDIP |
|  | GAL20V8B-10LP/883 | 5962-89840043A | 10 | 62.5 | 75 | 130 | 28-Pin LCC |
|  | GAL20V8B-15LD/883 | 5962-8984003LA | 15 | 50 | 75 | 130 | 24-Pin CERDIP |
|  | GAL20V8A-15LR/883 | 5962-89840033A | 15 | 50 | 75 | 130 | 28-Pin LCC |
|  | GAL20V8B-20LD/883 | 5962-8984002LA | 20 | 41.6 | 75 | 130 | 24-Pin CERDIP |
|  | GAL20V8A-20LR/883 | 5962-89840023A | 20 | 41.6 | 75 | 130 | 28-Pin LCC |
| GAL22V10 | GAL22V10B-15LD/883 | 5962-8984103LA | 15 | 62.5 | 90 | 150 | 24-Pin CERDIP |
|  | GAL22V10B-15LR/883 | 5962-89841033A | 15 | 62.5 | 90 | 150 | 28-Pin LCC |
|  | GAL22V10B-20LD/883 | 5962-8984102LA | 20 | 33 | 90 | 150 | 24-Pin CERDIP |
|  | GAL22V10B-20LR/883 | 5962-89841023A | 20 | 33 | 90 | 150 | 28-Pin LCC |
|  | GAL22V10B-25LD/883 | 5962-8984104LA | 25 | 33 | 90 | 150 | 24-Pin CERDIP |
|  | GAL22V10B-30LD/883 | 5962-8984101LA | 30 | 25 | 90 | 150 | 24-Pin CERDIP |

## Military Ordering Information

## DESC Standard Military Drawing Listing

| SMD \# | LATTICE PART \# |
| :--- | :--- |
| $5962-8983901 R A$ | GAL16V8A-30LD/883 |
| $5962-89839022 A$ | GAL16V8A-20LR/883 |
| $5962-8983902 R A$ | GAL16V8A-20LD/883 |
| $5962-89839032 A$ | GAL16V8B-15LR/883 |
| $5962-8983903 R A$ | GAL16V8B-15LD/883 |
| $5962-89839042 A$ | GAL16V8B-10LR/883 |
| $5962-8983904 R A$ | GAL16V8B-10LD/883 |
| $5962-89840023 A$ | GAL20V8A-20LR/883 |
| $5962-8984002 L A$ | GAL20V8A-20LD/883 |
| $5962-89840033 A$ | GAL20V8A-15LR/883 |
| $5962-8984003 L A$ | GAL20V8A-15LD/883 |


| SMD * | LATTICE PART * |
| :--- | :--- |
| $5962-89840043 A$ | GAL20V8B-10LR/883 |
| $5962-8984004 \mathrm{LA}$ | GAL20V8B-10LD/883 |
| $5962-8984101$ LA | GAL22V10B-30LD/883 |
| $5962-89841023 \mathrm{~A}$ | GAL22V10B-20LR/883 |
| $5962-8984102 \mathrm{LA}$ | GAL22V10B-20LD/883 |
| $5962-89841033 A$ | GAL22V10B-15LR/883 |
| $5962-8984103 \mathrm{LA}$ | GAL22V10B-15LD/883 |
| $5962-8984104 \mathrm{LA}$ | GAL22V10B-25LD/883 |
| $5962-9308501$ MXC | ispLSI 1032-60LG/883 |
| $5962-9466801$ MXC | pLSI 1032-60LG/883 |

## Standard Military Drawing Number Description



## FEATURES

- HIGH PERFORMANCE E²CMOS ${ }^{\circledR}$ TECHNOLOGY
- 10 ns Maximum Propagation Delay
- Fmax $=62.5 \mathrm{MHz}$
- 7 ns Maximum from Clock Input to Data Output
- TTL Compatible 12 mA Outputs
- UltraMOS ${ }^{\circledR}$ Advanced CMOS Technology
- 50\% REDUCTION IN POWER FROM BIPOLAR - 75mA Typ Icc
- ACTIVE PULL-UPS ON ALL PINS (GAL16V8B-10)
- E ${ }^{2}$ CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- EIGHT OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- Programmable Output Polarity
- Also Emulates 20-pin PAL ${ }^{\text {® }}$ Devices with Full Function/Fuse Map/Parametric Compatibility
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS
- 100\% Functional Testability
- APPLICATIONS INCLUDE:
- DMA Control
- State Machine Control
- High Speed Graphics Processing
- Standard Logic Speed Upgrade
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL16V8/883 is a high performance $\mathrm{E}^{2} \mathrm{CMOS}$ programmable logic device processed in full compliance to MIL-STD883. This military grade device combines a high performance CMOS process with Electrically Erasable ( $\mathrm{E}^{2}$ ) floating gate technology to provide the highest speed/power performance available in the 883 qualified PLD market. The GAL16V8B/883, at $10 n$ s maximum propagation delay time, is the world's fastest military qualified CMOS PLD.
The generic GAL architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The GAL16V8/883 is capable of emulating all standard 20-pin $\mathrm{PAL}^{\oplus}$ devices with full function/fuse map/parametric compatibility.
Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. Therefore, Lattice guarantees 100\% field programmability and functionality of all GAL products. Lattice also guarantees 100 erase/rewrite cycles and that data retention exceeds 20 years.

## FUNCTIONAL BLOCK DIAGRAM




[^48]Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$
Input voltage applied -0.5 to +7 V

Off-state output voltage applied $\quad-25$ to V
Storage Temperature -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$

## Case Temperature with

Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$
1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

Case Temperature ( $T_{C}$ )<br>$\qquad$ -55 to $125^{\circ} \mathrm{C}$ Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER |  | CONDITION |  | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  |  |  | Vss -0.5 | - | 0.8 | V |
| $\mathrm{V}_{1} \mathrm{H}$ | Input High Voltage |  |  |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current |  | $\mathrm{O} \mathrm{V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{I}}$ | L-10 | - | - | -100 | $\mu \mathrm{A}$ |
|  |  |  | L-15 | - | - | -10 | $\mu \mathrm{A}$ |
| lıH | Input or l/O High Leakage Current |  |  | $3.5 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{V}_{\text {cc }}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage |  | Iol $=$ MAX. Vin $=\mathbf{V I L}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ |  | - | - | 0.5 | V |
| VOH | Output High Voltage |  |  |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  |  |  | - | - | 12 | mA |
| IOH | High Level Output Current |  |  |  | - | - | -2 | mA |
| $1 \mathrm{OS}^{2}$ | Output Short Circuit Current |  | $\mathrm{Vcc}=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | -30 | - | -150 | mA |
| ICC | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{HH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {toggle }}=15 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ |  | L-10/-15 | - | 75 | 130 | mA |

1) The leakage current is due to the internal pull-up on all pins. See Input Buffer section for more information.
2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

AC SWITCHING CHARACTERISTICS
Over Recommended Operating Conditions

| PARAMETER | TEST COND ${ }^{1}$. | DESCRIPTION | -10 |  | -15 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinational Output | 2 | 10 | 3 | 15 | ns |
| tco | A | Clock to Output Delay | 1 | 7 | 2 | 12 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay | - | 7 | - | 12 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 10 | - | 12 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, $1 /(\mathrm{tsu}+$ tco) | 58.8 | - | 41.6 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, 1/(tsu + tcf) | 58.8 | - | 41.6 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 62.5 | - | 50 | - | MHz |
| twh | - | Clock Pulse Duration, High | 8 | - | 10 | - | ns |
| twl | - | Clock Pulse Duration, Low | 8 | - | 10 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 10 | - | 15 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 10 | - | 15 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 10 | - | 15 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | - | 10 | - | 15 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Descriptions section.
3) Refer to fmax Descriptions section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{yo}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{vo}}=2.0 \mathrm{~V}$ |

[^49]
## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}} \ldots \ldots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .-0.5 ~ t o ~+7 V ~$ Input voltage applied .......................... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$ Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ -65 to $150^{\circ} \mathrm{C}$

## Case Temperature with

Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$
1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## Specifications GAL16V8A/883

## RECOMMENDED OPERATING COND.

## CaseTemperature ( $\mathrm{T}_{\mathrm{c}}$ )

 -55 to $125^{\circ} \mathrm{C}$Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ )
with Respect to Ground $\qquad$ +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER |  | CONDITION |  | MIN. | TYP. ${ }^{2}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  |  |  | Vss-0.5 | - | 0.8 | V |
| $\mathrm{V}_{1} \mathrm{H}$ | Input High Voltage |  |  |  | 2.0 | - | Vcc+1 | V |
| IIL | Input or I/O Low Leakage Current |  | $0 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current |  | $\mathbf{V}_{\text {IH }} \leq \mathbf{V}_{\text {IN }} \leq \mathbf{V}_{\text {cc }}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage |  | lol $=$ MAX. $\quad$ Vin $=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\text {IH }}$ |  | - | - | 0.5 | V |
| VOH | Output High Voltage |  |  |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  |  |  | - | - | 12 | mA |
| IOH | High Level Output Current |  |  |  | - | - | -2.0 | mA |
| $1 \mathrm{OS}^{1}$ | Output Short Circuit Current |  | VCC $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | -30 | - | -150 | mA |
| ICC | Operating Power <br> Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{H}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {toggle }}=25 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ |  | L -20/-30 | - | 75 | 130 | mA |

[^50]AC SWITCHING CHARACTERISTICS

## Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST } \\ & \text { COND. } \end{aligned}$ | DESCRIPTION | -20 |  | -30 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinational Output | 3 | 20 | 3 | 30 | ns |
| $\mathbf{t c o}^{\text {c }}$ | A | Clock to Output Delay | 2 | 15 | 2 | 20 | ns |
| tcf ${ }^{2}$ | - | Clock to Feedback Delay | - | 15 | - | 20 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 15 | - | 25 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco) | 33.3 | - | 22.2 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, 1/(tsu + tcf) | 33.3 | - | 22.2 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 41.6 | - | 33.3 | - | MHz |
| twh | - | Clock Pulse Duration, High | 12 | - | 15 | - | ns |
| $t w l$ | - | Clock Pulse Duration, Low | 12 | - | 15 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 20 | - | 30 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 18 | - | 25 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 20 | - | 30 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | - | 18 | - | 25 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Descriptions section.
3) Refer to fmax Descriptions section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 / 0}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / 0}=2.0 \mathrm{~V}$ |

*Guaranteed but not 100\% tested.

## SWITCHING WAVEFORMS



## Combinatorial Output

INPUT or I/O FEEDBACK

COMBINATIONAL
OUTPUT


Input or I/O to Output Enable/Disable



Registered Output

$\overline{\mathrm{OE}}$ to Output Enable/Disable

fmax with Feedback

## Specifications GAL16V8/883

## fmax DESCRIPTIONS



## fmax with External Feedback 1/(tsu+tco)

Note: fmax with external feedback is calculated from measured tsu and tco.

fmax with No Feedback

Note: fmax with no feedback may be less than $1 /(\mathbf{t w h}+\mathbf{t w l})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback 1/(tsu+tcf)
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback (tcf = $1 / \mathrm{fmax}-\mathrm{tsu}$ ). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to tcf + tpd.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns 10\% -90\% |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3-state levels are measured 0.5 V from steady-state active level.
Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :--- | :---: | :---: | :---: |
| A | $390 \Omega$ | $750 \Omega$ | 50 pF |  |
| B | Active High | $\infty$ | $750 \Omega$ | 50 pF |
|  | Active Low | $390 \Omega$ | $750 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $750 \Omega$ | 5 pF |
|  | Active Low | $390 \Omega$ | $750 \Omega$ | 5 pF |


${ }^{*} \mathrm{C}_{\mathrm{L}}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

## Specifications GAL16V8/883

GAL16V8 ORDERING INFORMATION (MIL-STD-883 and SMD)


Note: Lattice recognizes the trend in military device procurement towards using SMD compliant devices, as such, ordering by this number where it exists is recommended.

## PART NUMBER DESCRIPTION



GAL20V8/883
High Performance $\mathrm{E}^{2}$ CMOS PLD
Generic Array Logic ${ }^{\top \mathrm{M}}$

FEATURES

- HIGH PERFORMANCE E²CMOS ${ }^{\circledR}$ TECHNOLOGY
- 10 ns Maximum Propagation Delay
- Fmax $=62.5 \mathrm{MHz}$
- 7 ns Maximum from Clock Input to Data Output
— TTL Compatible 12 mA Outputs
- UltraMOS ${ }^{\oplus}$ Advanced CMOS Technology
- 50\% REDUCTION IN POWER FROM BIPOLAR
- 75mA Typ Icc on Low Power Device
- E ${ }^{2}$ CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention


## - EIGHT OUTPUT LOGIC MACROCELLS

- Maximum Flexibility for Complex Logic Designs
- Programmable Output Polarity
- Also Emulates 24-pin PAL ${ }^{\otimes}$ Devices with Full Function/Fuse Map/Parametric Compatibility
- PRELOAD AND POWER-ON RESET OF ALL REGISTERS - 100\% Functional Testability


## - APPLICATIONS INCLUDE:

## - DMA Contro

- State Machine Control
- High Speed Graphics Processing
- Standard Logic Speed Upgrade
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL20V8/883 is a high performance $\mathrm{E}^{2} \mathrm{CMOS}$ programmable logic devices processed in full compliance to MIL-STD883. This military grade device combines a high performance CMOS process with Electrically Erasable ( $E^{2}$ ) floating gate technology to provide the highest speed/power performance available in the 883 qualified PLD market.
The generic GAL architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The GAL20V8/883 is capable of emulating all standard 24-pin $\mathrm{PAL}^{\oplus}$ devices with full function/fuse map/parametric compatibility.
Unique test circuitry and reprogrammable cells allow complete AC, DC, and functional testing during manufacture. Therefore, Lattice guarantees $100 \%$ field programmability and functionality of all GAL products. Lattice also guarantees 100 erase/rewrite cycles and that data retention exceeds 20 years.


CERDIP



[^51]
## Specifications GAL20V8B/883

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $V_{c c}$ $\qquad$ .-0.5 to +7 V
Input voltage applied -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ -65 to $150^{\circ} \mathrm{C}$

## Case Temperature with

Power Applied $\qquad$ .-55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

CaseTemperature $\left(T_{C}\right)$.............................. -55 to $125^{\circ} \mathrm{C}$
Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER |  | CONDITION |  | MIN. | TYP. ${ }^{2}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  |  |  | Vss -0.5 | - | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  |  |  | 2.0 | - | Vcc+1 | V |
| IIL | Input or l/O Low Leakage Current |  | $\mathrm{OV} \leq \mathrm{VIN} \leq \mathrm{V}_{\mathrm{LL}}$ (MA |  | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current |  | $3.5 \mathrm{~V}_{\mathrm{IH}} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{C}}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage |  | $\mathrm{loL}=$ MAX. Vin |  | - | - | 0.5 | V |
| VOH | Output High Voltage |  | $\mathrm{IOH}=$ MAX. Vin |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  |  |  | - | - | 12 | mA |
| IOH | High Level Output Current |  |  |  | - | - | -2.0 | mA |
| los ${ }^{1}$ | Output Short Circuit Current |  | $\mathrm{Vcc}=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | -30 | - | -150 | mA |
| ICC | Operating Power <br> Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{HH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {toggle }}=15 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ |  | L-10 | - | 75 | 130 | mA |

1) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
2) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{TA}=25^{\circ} \mathrm{C}$

## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST } \\ & \text { COND } \end{aligned}$ | DESCRIPTION | -10 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinational Output | 2 | 10 | ns |
| $\mathbf{t c o}$ | A | Clock to Output Delay | 1 | 7 | ns |
| $\mathbf{t c f}{ }^{2}$ | - | Clock to Feedback Delay | - | 7 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 10 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, $1 /(\mathrm{tsu}+$ tco) | 58.8 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 58.8 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 62.5 | - | MHz |
| twh | - | Clock Pulse Duration, High | 8 | - | ns |
| twl | - | Clock Pulse Duration, Low | 8 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 10 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 10 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 10 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | - | 10 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Descriptions section.
3) Refer to fmax Descriptions section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{I} / \mathrm{O}}=2.0 \mathrm{~V}$ |

[^52]
## Specifications GAL20V8A/883

## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$ -0.5 to +7 V
Input voltage applied $\qquad$ -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Storage Temperature -65 to $150^{\circ} \mathrm{C}$
Case Temperature with Power Applied -55 to $125^{\circ} \mathrm{C}$
1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

CaseTemperature $\left(T_{c}\right)$
-55 to $125^{\circ} \mathrm{C}$

Supply voltage ( $\mathrm{V}_{\mathrm{cc}}$ ) with Respect to Ground +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER |  | CONDITION |  | MIN. | TYP. ${ }^{2}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  |  |  | Vss -0.5 | - | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  |  |  | 2.0 | - | $\mathrm{Vcc}+1$ | V |
| IIL | Input or I/O Low Leakage Current |  | OV $\leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IL }}$ (M |  | - | - | -10 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current |  | $\mathbf{V}_{\text {IH }} \leq \mathbf{V}_{\text {IN }} \leq \mathbf{V}_{\text {cC }}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage |  | $\mathrm{loL}=\mathrm{MAX} . \quad \mathrm{V}$ in |  | - | - | 0.5 | V |
| VOH | Output High Voltage |  | $\mathrm{IOH}=\mathrm{MAX} . \quad \mathrm{Vin}$ |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  |  |  | - | - | 12 | mA |
| IOH | High Level Output Current |  |  |  | - | - | -2.0 | mA |
| los ${ }^{1}$ | Output Short Circuit Current |  | VCC $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \quad \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | -30 | - | -150 | mA |
| Icc | Operating Power Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{HH}}=3.0 \mathrm{~V} \\ & \text { ftoggle }=25 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ |  | L-15/-20 | - | 75 | 130 | mA |

1) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
2) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{TA}=25^{\circ} \mathrm{C}$

Specifications GAL20V8A/883

## AC SWITCHING CHARACTERISTICS

## Over Recommended Operating Conditions

| PARAMETER | $\begin{aligned} & \text { TEST } \\ & \text { COND } \end{aligned}$ | DESCRIPTION | -15 |  | -20 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinational Output | 3 | 15 | 3 | 20 | ns |
| tco | A | Clock to Output Delay | 2 | 12 | 2 | 15 | ns |
| tcf ${ }^{2}$ | - | Clock to Feedback Delay | - | 12 | - | 15 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock | 12 | - | 15 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock | 0 | - | 0 | - | ns |
| $\mathrm{fmax}^{3}$ | A | Maximum Clock Frequency with External Feedback, $1 /($ tsu + tco) | 41.6 | - | 33.3 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, $1 /(\mathrm{tsu}+$ tcf) | 41.6 | - | 33.3 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 50 | - | 41.6 | - | MHz |
| twh | - | Clock Pulse Duration, High | 10 | - | 12 | - | ns |
| twl | - | Clock Pulse Duration, Low | 10 | - | 12 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 15 | - | 20 | ns |
|  | B | $\overline{\mathrm{OE}}$ to Output Enabled | - | 15 | - | 18 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 20 | ns |
|  | C | $\overline{\mathrm{OE}}$ to Output Disabled | - | 15 | - | 18 | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Descriptions section.
3) Refer to fmax Descriptions section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 \mathrm{o}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{o}}=2.0 \mathrm{~V}$ |

*Guaranteed but not $100 \%$ tested.

## Specifications GAL20V8/883

## SWITCHING WAVEFORMS



Combinatorial Output

INPUT or I/O FEEDBACK

COMBINATIONAL OUTPUT


Input or I/O to Output Enable/Disable


Clock Width


Registered Output

$\overline{\mathrm{OE}}$ to Output Enable/Disable

fmax with Feedback

## fmax DESCRIPTIONS


fmax with External Feedback 1/(tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.

fmax with No Feedback

Note: fmax with no feedback may be less than $1 /(\mathbf{t w h}+\mathbf{t w l})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback 1/(tsu+tcf)
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback ( $\mathbf{t c f}=1 / \mathrm{fmax}-\mathrm{tsu}$ ). The value of tcf is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to $\mathbf{t c f}+\mathbf{t p d}$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3-state levels are measured 0.5 V from steady-state active level.

## Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | CL |
| :---: | :---: | :---: | :---: | :---: |
| A | $390 \Omega$ | $750 \Omega$ | 50 pF |  |
| B | Active High | $\infty$ | $750 \Omega$ | 50 pF |
|  | Active Low | $390 \Omega$ | $750 \Omega$ | 50 pF |
| C | Active High | $\infty$ | $750 \Omega$ | 5 pF |
|  | Active Low | $390 \Omega$ | $750 \Omega$ | 5 pF |



[^53]
## GAL20V8 ORDERING INFORMATION (MIL-STD-883 and SMD)


*Preliminary
Note: Lattice recognizes the trend in military device procurement towards using SMD compliant devices, as such, ordering by this number where it exists is recommended.

## PART NUMBER DESCRIPTION



GAL22V10/883
High Performance E2CMOS PLD Generic Array Logic ${ }^{\text {TM }}$

## FEATURES

- HIGH PERFORMANCE E²CMOS ${ }^{\circledR}$ TECHNOLOGY
- 15 ns Maximum Propagation Delay
- Fmax $=62.5 \mathrm{MHz}$
- 8ns Maximum from Clock Input to Data Output
- TTL Compatible 12 mA Outputs
- UltraMOS ${ }^{\circledR}$ Advanced CMOS Technology
- ACTIVE PULL-UPS ON ALL PINS
- COMPATIBLE WITH STANDARD 22V10 DEVICES
- Fully Function/Fuse-Map/Parametric Compatible with Bipolar and UVCMOS 22V10 Devices
- 50\% REDUCTION IN POWER VERSUS BIPOLAR
- E² CELL TECHNOLOGY
- Reconfigurable Logic
- Reprogrammable Cells
- 100\% Tested/Guaranteed 100\% Yields
- High Speed Electrical Erasure ( $<100 \mathrm{~ms}$ )
- 20 Year Data Retention
- TEN OUTPUT LOGIC MACROCELLS
- Maximum Flexibility for Complex Logic Designs
- PRELOAD AND POWER-ON RESET OF REGISTERS
- 100\% Functional Testability
- APPLICATIONS INCLUDE:
- DMA Control
- State Machine Control
- High Speed Graphics Processing
- Standard Logic Speed Upgrade
- ELECTRONIC SIGNATURE FOR IDENTIFICATION


## DESCRIPTION

The GAL22V10/883 is a high performance $\mathrm{E}^{2} \mathrm{CMOS}$ programmable logic device processed in full compliance to MIL-STD-883. This military grade device combines a high performance CMOS process with Electrically Erasable ( $\mathrm{E}^{2}$ ) floating gate technology to provide the highest speed performance available of any military qualified 22V10 device. CMOS circuitry allows the GAL22V10 to consume much less power when compared to bipolar 22V10 devices. $E^{2}$ technology offers high speed ( $<100 \mathrm{~ms}$ ) erase times, providing the ability to reprogram or reconfigure the device quickly and efficiently.

The generic architecture provides maximum design flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The GAL22V10 is fully function/fuse map/parametric compatible with standard bipolar and CMOS 22V10 devices.

Unique test circuitry and reprogrammable cells allow complete $A C, D C$, and functional testing during manufacture. As a result, LATTICE is able to guarantee $100 \%$ field programmability and functionality of all GAL ${ }^{\circledR}$ products.

FUNCTIONAL BLOCK DIAGRAM


PACKAGE DIAGRAMS


## ABSOLUTE MAXIMUM RATINGS ${ }^{(1)}$

Supply voltage $\mathrm{V}_{\mathrm{cc}}$. -0.5 to +7 V
Input voltage applied $\qquad$ -2.5 to $\mathrm{V}_{\mathrm{cc}}+1.0 \mathrm{~V}$
Off-state output voltage applied .......... -2.5 to $\mathrm{V}_{\mathrm{cC}}+1.0 \mathrm{~V}$
Storage Temperature $\qquad$ -65 to $150^{\circ} \mathrm{C}$
Case Temperature with
Power Applied $\qquad$ -55 to $125^{\circ} \mathrm{C}$

1. Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications).

## RECOMMENDED OPERATING COND.

Case Temperature $\left(T_{C}\right) \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . . . . . . . . . . . . . . . . . . .55$ to $125^{\circ} \mathrm{C}$
Supply Voltage ( $\mathrm{V}_{\mathrm{cc}}$ )
with Respect to Ground ..................... +4.50 to +5.50 V

## DC ELECTRICAL CHARACTERISTICS

Over Recommended Operating Conditions (Unless Otherwise Specified)

| SYMBOL | PARAMETER |  | CONDITION |  | MIN. | TYP. ${ }^{3}$ | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage |  |  |  | Vss-0.5 | - | 0.8 | V |
| VIH | Input High Voltage |  |  |  | 2.0 | - | Vcc+1 | V |
| IIL ${ }^{1}$ | Input or I/O Low Leakage Current |  | $0 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\text {IL }}$ (MAX.) |  | - | - | -100 | $\mu \mathrm{A}$ |
| IIH | Input or I/O High Leakage Current |  | $3.5 \mathrm{~V} \leq \mathrm{VIN} \leq \mathrm{V}_{\text {cc }}$ |  | - | - | 10 | $\mu \mathrm{A}$ |
| VOL | Output Low Voltage |  |  |  | - | - | 0.5 | V |
| VOH | Output High Voltage |  | $\mathbf{I} \mathbf{O H}=$ MAX. $\mathbf{V i n}=\mathbf{V}_{\text {IL }}$ or $\mathbf{V}_{\mathbf{H}}$ |  | 2.4 | - | - | V |
| IOL | Low Level Output Current |  |  |  | - | - | 12 | mA |
| IOH | High Level Output Current |  |  |  | - | - | -2.0 | mA |
| IOS ${ }^{2}$ | Output Short Circuit Current |  | Vcc $=5 \mathrm{~V} \quad$ Vout $=0.5 \mathrm{~V} \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | -50 | - | -135 | mA |
| Icc | Operating Power <br> Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{IH}}=3.0 \mathrm{~V} \\ & \mathrm{f}_{\text {toggle }}=15 \mathrm{MHz} \text { Outputs Open } \end{aligned}$ |  | L -15/-20/-25/-30 | - | 90 | 150 | mA |

[^54]
## AC SWITCHING CHARACTERISTICS

Over Recommended Operating Conditions

| PARAMETER | TEST COND. | DESCRIPTION | -15 |  | -20 |  | -25 |  | -30 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| tpd | A | Input or I/O to Combinatorial Output | - | 15 | - | 20 | - | 25 | - | 30 | ns |
| tco | A | Clock to Output Delay | - | 8 | - | 15 | - | 20 | - | 20 | ns |
| $\mathbf{t c} \mathbf{f}^{2}$ | - | Clock to Feedback Delay | - | 8 | - | 15 | - | 20 | - | 20 | ns |
| tsu | - | Setup Time, Input or Feedback before Clock $\uparrow$ | 12 | - | 17 | - | 20 | - | 25 | - | ns |
| th | - | Hold Time, Input or Feedback after Clock $\uparrow$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $\mathbf{f m a x}^{3}$ | A | Maximum Clock Frequency with External Feedback, 1/(tsu + tco) | 50 | - | 31.2 | - | 25 | - | 22 | - | MHz |
|  | A | Maximum Clock Frequency with Internal Feedback, $1 /($ tsu + tcf) | 50 | - | 31.2 | - | 25 | - | 22 | - | MHz |
|  | A | Maximum Clock Frequency with No Feedback | 62.5 | - | 33 | - | 33 | - | 25 | - | MHz |
| twh | - | Clock Pulse Duration, High | 8 | - | 15 | - | 15 | - | 20 | - | ns |
| twl | - | Clock Pulse Duration, Low | 8 | - | 15 | - | 15 | - | 20 | - | ns |
| ten | B | Input or I/O to Output Enabled | - | 15 | - | 20 | - | 25 | - | 25 | ns |
| tdis | C | Input or I/O to Output Disabled | - | 15 | - | 20 | - | 25 | - | 25 | ns |
| tar | A | Input or I/O to Asynchronous Reset of Register | - | 20 | - | 25 | - | 30 | - | 30 | ns |
| tarw | - | Asynchronous Reset Pulse Duration | 15 | - | 20 | - | 25 | - | 30 | - | ns |
| tarr | - | Asynchronous Reset to Clock Recovery Time | 15 | - | 20 | - | 25 | - | 30 | - | ns |
| tspr | - | Synchronous Preset to Clock Recovery Time | 12 | - | 17 | - | 20 | -- | 25 | - | ns |

1) Refer to Switching Test Conditions section.
2) Calculated from fmax with internal feedback. Refer to fmax Description section.
3) Refer to fmax Description section.

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

| SYMBOL | PARAMETER | MAXIMUM $^{*}$ | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Input Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance | 10 | pF | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}, \mathrm{~V}_{1 / \mathrm{O}}=2.0 \mathrm{~V}$ |

[^55]Specifications GAL22V10/883

## SWITCHING WAVEFORMS


Combinatorial Output

NPUT or //O FEEDBACK

OUTPUT


Input or V/O to Output Enable/Disable

CLK


## Clock Width

INPUT or I/O FEEDBACK DRIVING SP

CLK

REGISTERED OUTPUT


Synchronous Preset

INPUT or VO FEEDBACK

CLK

REGISTERED OUTPUT

Registered Output

CLK

REGISTERED FEEDBACK
fmax with Feedback

INPUT or //O FEEDBACK DRIVING AR

CLK

REGISTERED OUTPUT

Specifications GAL22V10/883

## fmax DESCRIPTIONS


fmax with External Feedback 1/(tsu+tco)
Note: fmax with external feedback is calculated from measured tsu and tco.


Note: fmax with no feedback may be less than $1 /(\mathbf{t w h}+\mathbf{t w l})$. This is to allow for a clock duty cycle of other than $50 \%$.

fmax with Internal Feedback $\mathbf{1 / ( t s u + t c f )}$
Note: tcf is a calculated value, derived by subtracting tsu from the period of fmax w/internal feedback ( $\mathbf{t c f}=1 / \mathrm{fmax}-\mathbf{t s u}$ ). The value of $\mathbf{t c f}$ is used primarily when calculating the delay from clocking a register to a combinatorial output (through registered feedback), as shown above. For example, the timing from clock to a combinatorial output is equal to $t c f+t p d$.

## SWITCHING TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise and Fall Times | 3ns $10 \%-90 \%$ |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | 1.5 V |
| Output Load | See Figure |

3 -state levels are measured 0.5 V from steady-state active level.

## Output Load Conditions (see figure)

| Test Condition |  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C L}$ |
| :---: | :--- | :---: | :---: | :---: |
| A | $390 \Omega$ | $750 \Omega$ | 50 pF |  |
|  | Active High | $\infty$ | $750 \Omega$ | 50 pF |
|  | Active Low | Active High | $\infty$ | $750 \Omega$ |
| $750 \Omega$ | 50 pF |  |  |  |
|  | Active Low | $390 \Omega$ | $750 \Omega$ | 5 pF |

FROM OUTPUT (O/Q) UNDER TEST

${ }^{*} C_{L}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

## Specifications GAL22V10/883

GAL22V10 ORDERING INFORMATION (MIL-STD-883 and SMD )


Note: Lattice recognizes the trend in military device procurement towards using SMD compliant devices, as such, ordering by this number where it exists is recommended.

## PART NUMBER DESCRIPTION


Section 1: Introduction
Section 2: High-Density Programmable Logic
Section 3: Low-Density Programmable Logic
Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices
Section 5: Military Program
Section 6: Development Tools
Lattice Design Tool Strategy ..... 6-1
System Design Process ..... 6-3
pLSI and ispLSI Design Flow ..... 6-5
Lattice Development Tool Datasheets pDS Software ..... 6-9
pDS+ ABEL Software ..... 6-15
pDS+ Viewlogic Software ..... 6-19
pDS+ LOG/iC Software ..... 6-25
isp Starter Kit ..... 6-31
ispCODE ..... 6-33
isp Engineering Kit - Model 100 ..... 6-39
isp Engineering Kit - Model 200 ..... 6-43
ispDOWNLOAD Cable ..... 6-49
pLSI and ispLSI Design Tool Selector Guide ..... 6-51
GAL Development Support ..... 6-55
ispGDS Compiler Support ..... 6-57
Section 7: Quality and Reliability
Section 8: General Information

## Lattice Design Tool Strategy

## Introduction

The Lattice design tool strategy for the pLSI and ispLSI families is to support a wide range of design environments. Lattice provides both a proprietary PC-based solution ( $\mathrm{pDS}{ }^{\circledR}$ ) as well as third-party compatibleCAE tools ( $\mathrm{pDS}+{ }^{\mathrm{TM}}$ Fitters) that run on PC and Sun workstation platforms.

The Lattice pDS (pLSI and ispLSI Development System) software provides a comprehensive, high-performance, low-cost package for logic development. Developed and supported by Lattice, pDS provides an easy-to-use Win-dows-based graphical interface using a mouse and pull-down menus. Design entry includes Boolean equations and macros. Forsimulation, timing tables are included as a standard offering. Additionally, pDS interfaces with Viewlogic's Viewsim simulation package for full functional and timing simulation. pDS software generates industry standard JEDEC programming files and supports direct download into ispLSI devices.

Lattice's pDS+ (pDS Plus) solution supports multiple thirdparty CAE tools, providing designers with the capability to design in familiar CAE environments. These third-party CAE tools offer schematic capture, hardware description language(such as VHDL), state machine language, Boolean equation, and macro design entry as well as functional and timing simulators for design verification.

Lattice's pDS and pDS+ solutions give designers powerful, easy to use, cost-effective design tools to meet their development needs. Each third-party vendor must adhere to strict quality and certification requirements before becoming qualified, thus ensuring superior support. Additional support for popular third-party CAE tools is scheduled. Contact your local Lattice Sales Representative for availability.

Figure 1. pDS and pDS+ Design Flows


## Lattice Design Tool Strategy

## Lattice Design Flow

There are three steps in the Lattice pLSI and ispLSI design flow: design entry, device fitting (logic partitioning, place and route), and design verification. (See the pDS and pDS+ Design Flow). This section outlines the design flow of the pDS and pDS+ solutions.

## Lattice pDS

Lattice's pDS solution is a comprehensive, self-contained design solution which operates on a PC under Microsoft Windows. pDS uses familiar ABEL-like Boolean equation and macro design entry, and provides manual partitioning, high speed automatic place and route, and simulation timing tables for design verification. Viewlogic's Viewsim simulation package is compatible with pDS for functional and timing simulation.

After the development work has been completed, the design is ready to be programmed into a device. For thirdparty programming support, the pDS package generates a JEDEC fusemap. Alternatively, the ispLSI devices can be programmed directly from the PC or Sun workstation with the Lattice isp Engineering Kit.

ThepDS development systems are ideal for designers who desire a cost-effective, user friendly approach to pLSI and ispLSI design.

## Lattice pDS+

The pDS+ solution combines third-party CAE tools for design entry and verification with the LatticepDS+Fitter for device fitting to offer a powerful and complete development solution. Initial Fitter products include the pDS+ ABEL Fitter, pDS+ Viewlogic Fitter, and pDS+ LOG/iC Fitter which interface with their respective third party design tools.

The design entry step is typically performed with schematic capture, Boolean equations, state machines, truth tables or a Hardware Description Language (HDL). Once design entry is complete, the design is ready to be implemented into a Lattice pLSI or ispLSI device.

The Lattice pDS+ Fitter uses architecture-specific algorithms to synthesize a logic description into a pLSI or ispLSI device. Steps in the device fitting process include logic optimization and minimization, automatic logic partitioning, and automatic place and route.
pDS+also supports design verification. Design verification options include both functional and timing simulation. Various combinations of graphical and text-based functional and timing simulators are supported by third-party CAE vendors.

Following design verification, the Lattice pDS+ Fitter generates a JEDEC fusemap for device programming. The design can be programmed into a pLSI device using thirdparty programmers. In addition, the ispLSI devices can be programmed directly from the PC or Sun workstation system using Lattice's isp Engineering Kit, or from dedicated logic designed into the end-system.

## System Design Process

## Introduction

Conceptually, system definition is the first step in the design process. This involves visualizing the PLD's interaction with the rest of the electronic system and defining a general flow diagram to determine the design's basic sequential behavior. This organizational flow, used to integrate an entire subsystem into high density devices, is described in the following topics and shown in figure 1.

Figure 1. System Design Flow


## Partitioning

After completing the conceptual design, the designer partitions the system into modules or functional blocks. These blocks can be a few components or multiple circuit boards with numerous components. The designer organizes these functional blocks to match the capabilities of the devices being targeted, for example, the number of I/O pins, flip-flops and gates needed. The user should also consider the frequency at which the targeted device must operate, the number of clocks required, and the timing relationships of signals (AC specifications).

## Specifying Components

After the partitioning is defined, the designer chooses the components which will be used to implement the desired functions. The design should meet the system specifications using the least number of components in order to keep the system cost as low as possible while keeping the system reliability as high as possible.

System specifications calling for low weight, low power and reduced size also drive designers to higher levels of logic integration. These added requirements can adversely affect the design schedule and project completion. The pLSI and ispLSI high-density devices can meet such design requirements while delivering excellent performance. The pLSI and ispLSI family of high-speed, high-density PLDs supported by easy-to-use effective software for fast design implementation and verification.

## Design Entry and Optimization

After the functional partitioning and component specifications are completed, the logic necessary to implement the functions is defined block by block. The logic may include standard TTL functions, CMOS logic functions, or functions from a library, such as the Lattice Macro Library. The implementation of logic into a highdensity device is optimized for the targeted device by the design software. The partitioning also affects the optimization. Optimization can be for speed, utilization or a combination of both.

Logic entry for a Lattice high density device is done with the pLSI/ispLSI Development System or with any of Lattice's pDS+ Fitter products (pDS+ Viewlogic, pDS+ ABEL, pDS + LOG/iC, etc.). The pDS software utilizes the Graphical User Interface (GUI) of Microsoft's Windows ${ }^{\text {TM }}$ to provide a complete design flow from logic entry to program-

## System Design Process

ming pLSI/ispLSI devices within hours. The pDS + ABEL software supports textual design entry using a Hardware Description Language (HDL). Standard CAE schematic design entry is supported by the pDS+ Viewlogic software. pDS+ LOG/iC supports Boolean, truth table and state machine entry.

## Test and Debug

When designing a system, or a portion of a system, it is easier to test and debug pieces or modules rather than the entire system. In this manner, the designer can confirm module designs, or functional blocks, and find problems earlier in the design cycle.

Logic can be verified by either timing simulation or actual testing of the programmed device. Simulation can be accomplished using the Viewlogic Viewsim logic simulator (available from Lattice). Design errors detected by software simulation can be corrected by the designer before the printed circuit board is laid out and manufactured, which saves time and reduces cost. Board and system level simulation can be accomplished through behavioral simulation using Logic Modeling Corporation's models.

Reprogrammable devices allow the designertotest, debug, and modify logic right on the p.c. board. pLSI and ispLSI devices can be reprogrammed multiple times. This reprogrammability further assists the designers by allowing them to temporarily program the devices with diagnostic and design verification logic.

The designer should always attempt to design logic with testability in mind. Testability means different things to different designers. Key guidelines to be aware of are:

- Large counters should be segmented for quick and easy testing.
- Logic should be designed for controllability and observability.
- There should be no floating nets.
- All nets should be at a known state or are able to be set or reset.

To assistsystem testability, the ispLSI devices offer preload and verification features. These features allow register contents to be verified without using logic analyzers or other debugging tools.

## Printed Circuit Board Layout

Once the logic has been verified, the Printed Circuit Board (PCB) is laid out and manufactured. Since the logic may be changed during design, this phase of the system design is usually executed after the logic has been validated. It is recommended that board design and layout be done after verifying designs using pLSI and ispLSI parts.

## System Test and Debug

System test and debug is the final stage of the design process. The logic and the PCB are tested as a system and minor enhancements or bug fixes are implemented. Because of the flexibility of the pLSI and ispLSI devices, minor changes can be made without affecting the layout of the PCB or the pinout of the device.

## pLSI and ispLSI Design Flow

## Introduction

Once the system design has been organized into functional components, and the logic functions which need to be incorporated in the selected components defined, the logic design phase begins. The general design flow is shown in figure 1. A pLSI or ispLSI design may be implemented from a number of design environments: including pLSI/ispLSI Development System (pDS), pDS + ABEL, pDS + Viewlogic and pDS+ LOG/iC
Figure 1. General Design Flow


These design environments offer various levels of design implementation from logic entry through programming the device. They support a variety of user interfaces and entry methods including: MS Windows GUI, Data I/O ABEL HDL or VHDL, Viewlogic Viewdraw/Viewsynthesis and the ISDATA LOG/iC Design System. The design flows using these development software systems are shown in figures $2,2 \mathrm{a}, 2 \mathrm{~b}$ and 2 c .

## Design Entry

The pDS software allows the user to manually partition the logic to control design fit and performance. Using the MS Windows environment, logic functions are placed into Generic Logic Blocks (GLBs) and I/O Cells. This can be done by using the Edit, Cut, Copy, and Paste functions to enter Boolean equations and/or pre-defined functions from the Lattice Macro or user libraries.

In addition to Boolean design entry, the pDS+ABEL HDL format allows high-level descriptions of counters, adders, comparators, etc. The ABEL language also supports state machines, truth tables and case constructs for behavioral
design implementations. ABEL also accepts VHDL aas a high level language input. The Lattice-ABEL interface allows many existing PLD designs to be easily integrated and converted into a pLSI or ispLSI devices.

For standard CAE schematic designs, the pDS+Viewlogic software provides support for graphical and hierarchical logic implementations using the Lattice library of primitives and macros. The Viewlogic interface also allows easy integration of system or user-created functions into a hierarchical schematic using a top-down or bottom-up design methodology. Additonally, Viewsynthesis offers VHDL capability to round out the design entry process.

## Design Verification

Verification using the pDS software is accomplished in two steps after logic has been placed. First, each cell may be individually verified to ensure that the minimized logic will fit into the GLB architecture. After all GLB and I/O cells are incrementally checked, the entire design is then verified to ensure that all nets have proper sources and destinations.

Because the advanced pDS+ tools perform automatic partitioning, design verification is done at a higher-level (pre-partitioned). In the ABEL environment, the Compile (ahdl2pla) function performs the syntax and design rule checks. After the Compile phase, the Optimize (plaopt) function (optionally) minimizes the design.

In the pDS+Viewlogic environment, pre-partitioned design verification is performed by the Design Analyzer which ensures the logic conforms to the Lattice design rules.

## Partitioning

Partitioning using the pDS software is done by the user as partof the design entry process. The advancedpDS+ABEL, pDS+ Viewlogic and pDS+ LOG/iC tools incorporate Lattice's automatic partitioner which accepts converted data from designs entered in ABEL, Viewlogic and LOG/iC respectively. Lattice specific attributes for design entry are available to guide the partitioner in order to optimize usage of device features and performance.

## Place and Route

All Lattice design tools offer automatic place and route. This entails placement of GLB and IOC logic and then routing (or interconnecting) the source signals to their

## pLSI and ispLSI Design Flow

destinations. In the pLSI and ispLSI devices, the Global Routing Pool (GRP) provides fast interconnects from external inputs and GLB feedbacks to the GLB inputs. The Output Routing Pool (ORP) provides flexible interconnects from GLB outputs to external pins. To take advantage of the architectural features, Lattice offers two differentrouters, Fast and Strong. The Fast router utilizes quick algorithms to route most designs. The more comprehensive Strong router is used to route more complex designs.

## Post-route Simulation

After place and route, a netlist for full timing and function simulation may be passed to the Viewsim simulator. Viewsim supports simulation using both textual and graphical input and interfaces. Board and system level simulation models are also available from Logic Modeling Corporation.

## Documentation

Report files, containing partitioned equations and pin-out information, may be generated for routed or un-routed designs. The pDS software can also generate reports with post-route maximum timing delays. In addition, the design can be exported in an Electronic Design Interchange Format(EDIF). This supports design interfaces to standard third-party CAE tools.

## Device Programming

Programming information is generated on a routed design by the FuseMap Generator for a specific pLSI and ispLSI device. It is an ASCII file written in the JEDEC format. Using the pDS + ABEL software, the user may optionally append test vectors onto the JEDEC file. This allows postprogramming functional test on the actual device.

Two programming methods are used to program the pLSI and ispLSI devices. The first method uses the Device Programming Mode for both types of devices. This method facilitates device programming support from thirdparty vendors. The second method uses the Lattice In-System Programming Mode and applies to the ispLSI family of devices.

Both methods of device programming allow the user to program and read back the fuesmap from the programmed device for verification (if the security cell has not been set).

Figure 2. pDS Design Flow


Figure 2a. pDS+ ABEL Design Flow


Figure 2b. pDS+ Viewlogic Design Flow


Figure 2c. pDS+ LOG/iC Design Flow


## Notes

## pDS ${ }^{\ominus}$ Software

## Features

- pLSI ${ }^{\oplus}$ and ispLSI ${ }^{\text {"w }}$ Development System
—Supports pLSI and ispLSI 1000, 2000 and 3000 Families
- Design Entry with Easy-to-Use Windows ${ }^{\text {™ }}$ Environment
- ABEL-Like Boolean Equation Entry
- Logic Macro Entry with over 275 "TTL-Like" Macros
- Manual Device Partitioning Ensures Tight Control of Performance and Utilization
- Fast Design Compilation
- Efficient Design Optimization \& Minimization
- "Hands Free" Automatic Place and Route
- Fast Route Option for Quick Turnaround
- Strong Route Option for Comprehensive and Optimized Routing
- Predictable Performance
- Complete Design Verification
- Functional and Timing Simulation Option Using Viewsim
- Industry Standard JEDEC Programming File Generation
- Standard JEDEC Device Fusemap
- Optional isp Engineering Kit (Model 100)*
- PC Compatible Programmer for Engineering Use
- Supports Entire ispLSI Device Family
- Download to Programmer Circuit Board
- Runs on 386/486/Pentium IBM-Compatible PC Under Windows ${ }^{\text {TM }}$ Environment
*Not intended for production programming


## Introduction

The pDS software is a comprehensive design package for the Lattice PLSI and ispLSI device families giving full design entry and device implementation capabilities under the Windows design environment. The pDS software provides the best solution for high performance designs which require direct control of the logic implementation. It offers designers complete control over the performance and utilization of the device. The pDS software allows designers to quickly move from concept to a programmed logic device.
The pDS software also offers a simulation option for full functional and timing simulation of designs using Viewlogic's Viewsim software.

## pDS Software

Using the pDS software, designs can be defined completely using simple Boolean equations and "TTL-like" logic macros. Automated design capabilities shorten design cycles allowing designers to explore several design solutions before deciding on the one that provides the best solution.
Designs can be entered in two ways: either through the integrated edit windows within the pDS software, or by using a standard ASCII text editor to create a design file that can be imported into the pDS environment. The Lattice Place and Route software automatically places the logic and routes the interconnections. The Fusemap program generates a fuse file which can then be downloaded into a device programmer or directly to a Lattice ispLSI device (see figure 1).
Figure 1. pDS Design Flow


## Design Entry

pDS software offers an easy to use interface as shown in figure 2. Designers can quickly enter the design into

GLBs and I/O cells through this interface. An example of an edit window is shown in figure 3. Tables 1, 2 and 3 provide a condensed list of the different operations which are supported in the pDS software.

Figure 2. User Interface


Figure 3. Sample Edit Window Illustrating Boolean Equations and Macros

The following summarizes the pDS software keywords, operators and dot extensions used.

Table 1. Keywords

| Keyword | Description |
| :--- | :--- |
| CONSTANT | Assigns a value to a signal |
| SET | Assigns a label to a group of signals |
| SIGTYPE | Assigns specific attributes to a GLB <br> output |
| CRIT | Used for the 4 product term bypass |
| XPIN | Identifies external signal in the I/O <br> cell |
| LOCK | Locks an I/O cell to a pin <br> EQUATIONS |
| Beginning of the Boolean description <br> of the logic in a GLB |  |
| The text that follows is a comment |  | pDS Software

## Table 2. Operators

| Operator | Description |
| :---: | :--- |
| $=$ | Assignment |
| $!$ | Inversion |
| $\$ \$$ | Hardware exclusive OR |
| $\&$ | AND |
| $\#$ | OR |
| $\$$ | Exclusive OR |
| $1 \$$ | Exclusive NOR |

Table 3. Dot Extensions

| Extension | Description |
| :---: | :---: |
| D | Identifies the signal as the D input |
| Q | Identifies the signal as the Q output |
| .RE | Identifies the product term reset signal for the GLB |
| .CLK | Identifies the system clock for the GLB |
| .PTCLK | Identifies the product term clock for the GLB |
| . OE | Identifies the output enable signal for the I/O cells within the megablock |

The pDS software offers an extensive selection (over 275) of TTL-like macros. These macros enable the design engineer to use familiar pre-defined functions to build a design. Table 4 shows a summary of the available macros in the pDS software.

## Table 4. Macro Summary

| Macro Type | Quantity |
| :--- | :---: |
| AND/NAND | 29 |
| OR/NOR | 24 |
| XOR/XNOR | 11 |
| I/Os | 31 |
| Flip-Flops | 25 |
| Arithmetic | 28 |
| Counters | 66 |
| Shift Registers | 15 |
| MUX/DEMUX | 34 |
| Miscellaneous | 25 |

## Logic Optimization

The pDS software provides extensive design rule checking during the optimization and fitting process. After the design has been checked, the software initiates logic minimization to reduce the number of product terms needed.

## Automatic Place and Route

The pDS software provides an automatic place and route routine which eliminates the need for manual routing and provides a quicker design cycle time. The router automatically generates pinouts based on an optimal design implementation or it can use a user defined pinout. There are two routing options:

\author{

- Fast Route <br> - Strong Route
}

The Fast Route option performs quick place and route to reach the debugging stage sooner. The Strong Route option performs a comprehensive routing search to maximize device resource utilization and ensures efficient design implementation. With the Strong Route option, small design changes can generally be performed without expensive PC board rework.

Incremental place-and-route capability allows last-minute logic updates to be implemented without design pin-out changes.

## Post Route Simulation

Complete post route design verification can be peformed using the optional Viewsim timing simulator.

## Fusemap Generation

The Lattice Fusemap generation module outputs the file containing the fuse pattern used to implement the logic in the device. A security feature offers protection of proprietary designs from unauthorized duplication.

## Device Programming

The pDS software supports two ways of programming devices. The designer can program the parts themselves through the In-System Programming option or download the file to a third-party device programmer (shown in table 5).

In-System Programming allows the devices to be programmed without removing them from the system board. A download cable is used to transfer the bit stream and programming instructions (called ispSTREAM) from the pDS software to the target system.

Table 5. Programming Support

| Programmer Vendor | Model |
| :---: | :--- |
| Advin Systems | Pilot-U84 |
|  | Pilot-U40 |
|  | Pilot-GL/GCE |
| BP Microsystems | PLD-1128 |
|  | CP-1128 |
| Data I/O | 2900 |
|  | 3900 |
|  | Unisite 40/48 |
| Logical Devices | Allpro 40 |
|  | Allpro 88 |
| SMS Micro Systems | Sprint Expert |
| Stag | System 3000 |
|  | ZL30/A |
| System General | TURPRO-1 |

High pin-count socket adapters are available from Emulation Technology, EDI Corporation and PROCON.

## System Requirements

- 386/486/Pentium IBM Compatible PC
- MS DOS Version 3.3 or Later
- MS Windows Version 3.1 or Later
- 4 MB RAM and 10 MB Hard Disk Space
- Parallel Printer Port for Software Key
- VGA or Higher Resolution Display
- Mouse (Windows Compatible)


## isp Engineering Kit Ordering Information

- Kit Contains Programming Module (Base Unit), Download Cable, A/C Adapter, Socket Adapters and
- One ispLSI Device Sample Included per Adapter

For more information on specific devices, please refer to the isp Engineering Kit data sheet.

## Product Code Description

pDS4102-PM Model 100 Universal Programming Module

## Technical Support Assistance

| Lattice Hotline: | $1-800-$ LATTICE (Domestic) |
| ---: | :--- |
| Lattice Hotline: | $1-408-428-6414$ (International) |
| Lattice BBS: | $1-408-980-9814$ |
| email: | applications@lattice.com |

## Warranty/Update Service

- 90 Day Warranty on Disk Media
- One year of Maintenance Support Included
- Annual Maintenance Agreement Available
- 90 Day Warranty on isp Engineering Kit


## pDS Ordering Information

## Product Code

 pDS1101-STD/PC1 pDS1101-3UP/PC1 pDS1101-ULT/PC1 pDS1101M-STD/PC1 pDS1101M-ULT/PC1 pDS3302-PC1 pDS1102-PC1
## Description

pLSI and ispLSI Development System supports 1000 and 2000 Family devices pLSI and ispLSI Development System Upgrade to add support fo 3000 Family devices pLSI and ispLSI Development System supports 1000, 2000 and 3000 Family devices pDS1101-STD/PC1Annual Maintenance Renewal pDS1101-ULT/PC1 Annual Maintenance Renewal
Viewlogic Viewsim Timing \& Functional Simulator
Viewlogic Viewsim Simulation Libraries and Interface Files
pDS+"ABEL Software

## Features

- pLSI ${ }^{\circledR}$ and ispLSI'" Development System
-Supports All pLSI and ispLSI 1000, 2000 and 3000 Families
- Design Entry Using ABEL and VHDL-Direct ${ }^{\text {M }}$
- Design Verification Using ABEL Functional Simulation
- Lattice Fitter for Design Synthesis
- Optional Timing Simulation Using Viewlogic Viewsim
- Supports Viewlogic ViewPLD
- Integrated Development Environment for MixedMode Design Entry
- ABEL Hardware Description Language (AHDL) or VHDL Syntax Including Boolean Equations, Truth Tables and State Machines
- Graphical Menu Driven User Interface
- Lattice pDS+ ABEL Fitter
- Automatic Device Fitter Ensures High Utilization and Performance
- Efficient Design Optimization \& Minimization
- Automatic Partitioning with High Utilization
- "Hands Free" Automatic Place and Route
- Fast Route Option for Quick Turnaround
- Strong Route Option for Comprehensive and Optimized Routing
- Predictable Performance
- Industry Standard Programming File Generation
- Standard JEDEC Device Fusemap
- Standard JEDEC Device Test Vectors
- Optional isp Engineering Kit*
- Programmer for Engineering Use
- Model 100 for PC
- Model 200 for Sun Workstation
- Supports All ispLSI Device Families
- Download to Programmer or Circuit Board
- PC and Sun Workstation Design Platforms
- PC - 386/486/Pentium IBM Compatible PC
- Sun Workstation - Sun SPARC 4
*Not intended for production programming


## Introduction

The pDS+ ABEL software from Lattice Semiconductor offers a powerful solution to fit high-density logic designs into Lattice's pLSI and ispLSI devices.

Design entry is made simple by using ABEL software from Data I/O together with the pDS + ABEL Fitter for design implementation. The Lattice pDS+ ABEL software offers high-level, device independent design entry with efficient logic compilation, delivering unprecedented performance for the most complex designs.

## Data I/O ABEL

The easy-to-use, menu-driven ABEL software packages provide a complete pre-fit design environment. Using the ABEL Hardware Description Language (AHDL) from DATA I/O Corporation or the IEEE standard VHDL, complex designs can be quickly and efficiently described using a combination of Boolean Equations, Truth Tables, State Machine syntax or other HDL descriptions. The HDL syntax allows design creation without regard to any specific device dependencies. The built-in functional simulator allows designs to be fully verified before device fitting. The menu driven environment makes design implementation as easy as clicking a mouse button. Synario will support schematic entry and additional features.

## pDS+ ABEL Software

The Lattice pDS + ABEL Fitter for pLSI and ispLSI devices is completely integrated within the ABELSoftware environment. The Lattice Fitter provides hands-off design implementation through intelligent design optimization, logic partitioning, automatic place \& route and fusemap generation with optional test vectors, in standard JEDEC format. Extensive top level design control is provided to optimize design implementation for speed and/or high device resource utilization. The pDS + ABEL Fitter performs the following functions during design synthesis:

> - Design Optimization and Logic Minimization
> - Automatic Partitioning
> - Automatic Place and Route
> - Design Parameter Control
> - Fusemap Generation

Figure 3. pDS+ ABEL Fully Integrated Design Environment


## Design Optimization and Logic Minimization

The pDS+ ABEL Fitter uses proprietary algorithms targeted for device specific features. The Fitter optimizes the design thoroughly, compressing multiple level logic into two level logic, and utilizing logic minimization, product term sharing and XOR functions wherever necessary. In addition, the pDS + ABEL Fitter supports multiple fitting strategies to obtain the best device utilization and performance.

## Automatic Partitioning

The pDS+ ABEL Fitter incorporates a powerful Automatic Partitioner for hands-free synthesis of a design into Generic Logic Blocks (GLBs). The partitioner takes full advantage of the device's powerful features such as the hard XOR function and product term sharing. The internal XOR can be utilized for Arithmetic functions, T-Type flip-flops, and on \& off set optimization functions. The partitioner also makes extensive use of product term sharing. Product term sharing allows the fitter to efficiently use device resources by sharing product terms across multiple logic functions. These features combine to maximize device resource utilization and increase design performance.

## Automatic Place and Route

Automatic place and route eliminates the need for manual editing and accelerates the design cycle. The Router automatically generates pinouts based on the optimal design implementation or uses user assigned pinouts. It offers two routing options:

> — Fast Route
> - Strong Route

The Fast Route option allows quick place and route for fast debugging of designs. The Strong Route option performs a comprehensive route to maximize device resource utilization and ensure efficient design implementation. The result is small design changes don't result in expensive PC Board rework.

## Design Parameter Control

Extensive design parameter control at the design entry level is possible with the pDS+ ABEL Fitter giving the user the option to optimize the design for maximum utilization and speed. Controls are specified using "Property" statements in the ABEL design file. These controls fall into two categories:

- Performance and Utilization Control
- Design Implementation Control pDS+ ABEL Software


## Performance and Utilization Control

Special properties can be passed to the pDS+ ABEL Fitter providing complete control over critical design considerations. Fitter control over design partitioning and routing optimizes the design for speed and/or device utilization. Here are a few of the powerful features:

MAX_DELAY Specifies maximum level of (GLB's) delay

PRESERVE Maintains a net as GLB output
SCP/ECP Defines critical paths to reduce delays
EFFORT Runs four optimization strategies and uses the best to implement the design

CRIT Instructs router to use the faster Output Routing Pool Bypass

SNP/ENP Defines logic paths for no logic minimization

SAP/EAP Defines asynchronous paths to prevent signal duplication

LXOR2 Defines nets to use the internal hard XOR for speed (Macro library element)

## Design Implementation Control

pDS + ABEL Design implementation controls are used for changing such design parameters as security, clocking, etc. Some of the implementation controls are:

| MAX_GLB_IN | Controls maximum number of inputs to a <br> GLB |
| :--- | :--- |
| AVG_GLB_IN | Specifies average number of inputs to a <br> GLB |
| FASTCLK | Lets you assign a product term clock to <br> use the Fast Clock Distribution network <br> to clock all or desired sets of registers |
| REGTYPE | Specifies register placement either in an <br> I/O Cell or GLB |
| PULLUP | Specifies internal pull-up resistors on all <br> or unused I/Os |
| SECURITY | Sets the device security cell to prevent <br> unauthorized fusemap read back |
| ISP | Instructs Router to reserve in-system <br> programming pins |

ISP_EXCEPT_Y2 Reserves all ISP pins except Y2

Y1_AS_RESET<br>LOCK

## Parameter File

The pDS+ ABEL Fitter provides a parameter file feature which helps designers eliminate guesswork and optimizes the design for the right device. It allows the user to try a number of design implementation options using the design implementation controls in batch mode. The parameter file instructs the partitioner and the router on how to maximize both device utilization and performance.

ThepDS+ABELFitter also provides post-route equations showing exactly how the design is implemented in the selected device.

## Fusemap Generation

The pDS+ ABEL Fitter generates a device fusemap in standard JEDEC format. A security feature gives protection of proprietary designs from unauthorized duplication. The fitter also appends any design test vectors in JEDEC format to the device fusemap thus facilitating a quick, easy functional verification of a programmed device.

## Design Verification

The pDS + ABEL software provides functional simulation of all pLSI and ispLSI designs using the built-in ABEL functional simulator. The simulation test vectors can be combined into the JEDEC file for device testing in a programmer.

Complete post route design verification can also be performed using the optional Viewsim timing simulator. The pDS+ ABEL software generates the "sim" file required for Viewsim simulation. Simulation libraries are available from Lattice for both PC and Sun platforms. The Viewlogic Viewsim simulation is available from Lattice for the PC platform.
pDS+ ABEL Software

## System Requirements (PC Platform)

- 386/486/Pentium IBM Compatible PC
- MSDOS Version 3.3 or Later
- 16 MB RAM with 10MB Hard Disk Space
- ABEL 4.1 or Later
- Parallel Printer Port for Software Key

System Requirements (Sun Platform)

- Sun Sparc 4
- Sun OS Version 4.x
- Open Windows 3.0
- ABEL 4.1 or Later
- 16 MG RAM with 100 MB Hard Disk Space
- 3 Button Mouse


## Technical Support Assistance

Lattice Hotline: 1-800-LATTICE (Domestic)
Lattice Hotline: 1-408-428-6414 (International)
Lattice BBS: 1-408-980-9814
email: applications@lattice.com

## pDS+ ABEL Ordering Information

```
Product Code Description
pDS2102-PC1 pDS+ ABEL Fitter for PC
pDS2102-SN1 pDS+ ABEL Fitter for Sun
    Workstation
pDS2102M-PC1 pDS+ ABEL Fitter Maintenance
pDS2102M-SN1 pDS+ ABEL Fitter Maintenance
pDS3302-PC1 Viewlogic Viewsim Timing and
    Functional Simulator
pDS1102-PC1 Viewlogic Viewsim Timing and
    Functional Simulation Libraries and
    Interface Files (For customers who
    already own Viewlogic Viewsim)
```

Note: Contact Lattice for availability of pDS+ ABEL support for Synario and pLSI \& ispLSI 2000 and 3000 Families.

## Programmer Support

All devices in the Lattice ispLSI device families can be programmed while installed on the target circuit board. Insystem programming can be performed either via the isp Engineering Kit or by an on-board microprocessor.
All Lattice ispLSI and pLSI devices can be programmed using third-party PLD programmers. These devices are
currently supported by programmers from the following vendors:

| Programmer Vendor | Model |
| :---: | :--- |
| Advin Systems | Pilot-U84 |
|  | Pilot-U40 |
|  | Pilot-GL/GCE |
| BP Microsystems | PLD-1128 |
|  | CP-1128 |
| Data I/O | 2900 |
|  | 3900 |
|  | Unisite 40/48 |
| Logical Devices | Allpro 40 |
|  | Allpro 88 |
|  | Sprint Expert |
| Stag | System 3000 |
|  | ZL30/A |

High Pin-count socket adapters are available from Emulation Technology, EDI Corporation and PROCON.

## isp Engineering Kit Ordering Information

- Kit Contains Programming Module (Base Unit), Download Cable, A/C Adapter, Socket Adapters and
- One ispLSI Device Sample Included per Adapter


## Product Code

pDS4102-PM Model 100 Universal Programming Module (for PC)
pDS4102-WS Model 200 Universal Programming Module (for Sun)

## Warranty/Update Service

- 90 Day Warranty on Disk Media
- One year Maintenance Support Included with Purchase
- Annual Maintenance Agreement Available
- 90 Day Warranty on isp Engineering Kit
pDS+"Viewlogic Software


## Features

- pLSI ${ }^{\oplus}$ and ispLSI'm Development System
- Supports All pLSI and ispLSI 1000 Devices
- Support for 2000 and 3000 Families Under Development
- Integrated Workview 4.x, Pro Series, Workview Plus or Powerview Development Environment for Design Entry
- Schematic Entry
— Over 300 "TTL-like" Macros
- Viewsynthesis VHDL Language Entry
- Graphical Menu Driven User Interface
- Command Line Driven User Interface
- Lattice pDS+ Viewlogic Fitter
- Automatic Device Fitter Ensures High Utilization and Performance
- Efficient Design Optimization \& Minimization
- Automatic Partitioning
- "Hands Free" Automatic Place and Route
- Fast Route Option for Quick Turnaround
- Strong Route Options for Comprehensive and Optimized Routing
- Predictable Performance
- Complete Design Verification
— Using Viewsim Timing Simulator
- Industry Standard Programming File Generation
- Standard JEDEC Device Fusemap
- Optional isp Engineering Kit*
- Programmer for Engineering Use
- Model 100 for PC
- Model 200 for Sun Workstation
- Supports All ispLSI Device Families
- Download to Programmer or Circuit Board
- PC and Sun Workstation Design Platforms
- PC - 386/486/Pentium IBM Compatible PC
- Sun Workstation - Sun Sparc 4


## Introduction

The pDS+ Viewlogic Software from Lattice Semiconductor now offers a powerful solution to fit high density logic designs into Lattice's pLSI and ispLSI devices.

Design entry and implementation is made simple using the software environments from Viewlogic Corporation. Viewlogic has a number of software products of various names. The new Pro Series of products will be supported by Lattice in 1994. For simplicity the tools are referred to as Viewdraw, Viewsim and Viewsynthesis. The Lattice pDS+ Viewlogic software supports high level, device independent design entry together with efficient logic compilation, delivering the most complex designs in the shortest time possible.

## Viewlogic's Software

Viewlogic supports schematic entry using Viewdraw. Viewdraw lets you create designs without regard to any specific device dependencies. Viewdraw offers advanced features such as cut and paste, unlimited zoom and pan functions, automatic symbol generation as well as many other features to streamline and speed-up the design and verification process. Viewsynthesis supports VHDL language entry as well. The integrated design environment supports an optional timing simulator (Viewsim) so designs can be fully simulated before device programming. The Menu-driven environment makes design implementations as easy as a single click of the mouse button. The pDS+ Viewlogic design environment also offers the user multi-window operation, allowing schematic, simulator and waveform (Viewwave) windows to be opened concurrently. Results can also be dynamically back annotated to the schematic for design verification.

The Viewwave software is a graphical editor for creating simulation input stimulus as well as analyzing waveforms. This graphical editor/analyzer also increases designer productivity through its speed and ease-of-use.

## pDS+ Viewlogic Software

The Lattice pDS+ Viewlogic Fitter for pLSI and ispLSI devices is completely integrated within the Viewlogic
*Not intended for production programming

[^56]environment. The LatticepDS+Viewlogic Fitter provides hands-off design implementation through intelligent design optimization, logic partitioning, automatic place and route and fusemap generation. The pDS+ Viewlogic software comes complete with a library of over 300 TTLlike macros to simplify design entry. Extensive top level design control is provided for design implementation optimized for speed and/or high device resource utilization. The pDS+ Viewlogic Fitter performs the following functions during design synthesis:

- Design Optimization and Logic Minimization
- Automatic Partitioning
- Automatic Place and Route
- Design Parameter Control
- Fusemap Generation


## pDS+ Viewlogic Macro Library

The pDS+ Viewlogic software offers an extensive selection (over 300) of TTL-like macros. These macros enable the design engineer to use familiar predefined functions to build a design. Table 1 shows a summary of the available macros in the pDS+ software.

Table 1. Macro Summary

| Macro Type | Quantity |
| :--- | :---: |
| AND/NAND | 29 |
| OR/NOR | 24 |
| XOR/XNOR | 12 |
| I/Os | 89 |
| Flip-Flops | 39 |
| Latches | 30 |
| Arithmetic | 22 |
| Counters | 65 |
| Shift Registers | 15 |
| Miscellaneous | 45 |

Figure 1. pDS+ Viewlogic PC Design Interface

| Window <br> View <br> Add <br> Level <br> Buffer <br> File <br> Change <br> Export <br> Lattice <br> Xform <br> Select <br> Delete <br> Move <br> Copy <br> Plot <br> Undo <br> Info <br> Bye | Design Analyzer <br> Symbol <br> Select Device <br> Compile <br> Export Timing <br> Free Pins <br> View Reports <br> Download <br> Command File | pLSI ispLSI Functional Simulation | pLSI1048_70LQ pLSI1048_50LQ pLSI1032_80LJ pLSI1032_60LJ pLSI2032_135LJ pLSI3256_70LG |
| :---: | :---: | :---: | :---: |

Figure 2. pDS+ Viewlogic Integrated Design Environment


Figure 3. pDS+ Viewlogic Multi-Window PC Design Environment


## Design Optimization and Logic Minimization

The pDS+ Viewlogic Fitter uses proprietary logic synthesis algorithms targeted for device-specific features. The fitter performs a thorough design optimization, compressing multiple level logic into two level logic, and utilizing logic minimization, product term sharing and XOR functions wherever necessary. In addition, the pDS+ Viewlogic Fitter supports multiple fitting strategies to obtain the best device utilization and performance.

## Automatic Partitioning

The pDS+ Viewlogic Fitter incorporates a powerful Automatic Partitioner for hands-free synthesis of a design into Generic Logic Blocks (GLBs). The partitioner takes full advantage of the device's powerful features such as the hard XOR and product term sharing. The internal XOR can be utilized for Arithmetic functions, T-Type flip-flops, and on \& off set optimization functions. The partitioner also makes extensive use of product term sharing. Product term sharing allows the Fitter to efficiently use device resources by sharing product terms across multiple logic functions. These features combine to maximize device resource utilization and increase design performance.

## Automatic Place and Route

Automatic place and route eliminates the need for manual editing and accelerates the design cycle. The Router automatically generates pinouts based on optimal design implementation or uses user-assigned pinouts. It offers two routing options:

- Fast Route
- Strong Route

The Fast Route option allows quick place and route for fast debugging of designs. The Strong Route option performs comprehensive routing to maximize device resource utilization and ensures efficient design implementation. The result is small design changes do not result in expensive PCB rework.

## Design Parameter Control

The pDS+ Viewlogic Fitter offers extensive design parameter control at the design entry level, letting the user optimize the design for maximum utilization and/or speed. All of the controls are specified using "Attributes" in the

Viewdraw design file. These controls fall into two categories:

- Performance and Utilization Control
- Design Implementation Control


## Performance and Utilization Control

Special attributes can be passed to the pDS+ Viewlogic Fitter providing complete control over critical design considerations. Fitter control over design partitioning and routing optimizes the design for speed and/or device utilization. Here are a few of the powerful features:

| MAX_DELAY | Specifies maximum levels of (GLBs) <br> delay |
| :--- | :--- |
| PRESERVE | Maintains a net as GLB output |
| SCP/ECP | Defines critical paths to reduce delays |
| EFFORT | Runsfouroptimization strategies and uses <br> the best to implement the design. |
| CRIT | Instructs router to use the faster Output <br> Routing Pool Bypass |
| SNP/ENP | Defines logic paths for no logic minimiza- <br> tion |
| SAP/EAP | Defines asynchronous paths to prevent <br> signal duplication |
| LXOR2 | Defines nets to use the internal hard XOR <br> for speed (This is a macro library element) |

## Design Implementation Control

pDS+ Viewlogic Design implementation controls are used for changing such design parameters as security, clocking and pin locking. Some of the powerful implementation controls are:

MAX_GLB_IN Controls maximum number of inputs to a GLB

AVG_GLB_IN Specifies average number of inputs to a GLB

FASTCLK Assigns a clock to the Fast Clock Distribution network to clock all or desired sets of registers

REGTYPE Specifies register placement either in an I/O Cell or GLB

PULLUP Specifies internal pull-up resistors on all or unused I/Os

SECURITY Sets the device security cell to prevent unauthorized fusemap read back

ISP
Instructs Router to reserve device insystem programming pins

ISP_EXCEPT_Y2Reserves all ISP pins except Y2
Y1_AS_RESET Uses Y1 clock pin on ispLSI and pLSI 1016 as a global reset pin

LOCK Lets you lock I/O signals to specific device pins

## Parameter File

The pDS+ Viewlogic Fitter provides a parameter file feature which helps designers eliminate the guesswork and optimizes the design for the right device. It allows the user to try a number of design implementation options using all of the design implementation controls in a batch mode. The parameter file instructs the partitioner and the router to maximize both device utilization and performance.

The pDS+ Viewlogic Fitter also provides a post route design file for optional timing simulation.

## Design Verification

The pDS+Viewlogic software offers complete post route design verification using the optional Viewsim timing simulator. The pDS+ Viewlogic Fitter generates the "wire" file required for Viewsim simulations, and generates a "sim" file which can be used in the Viewsim simulator, or other design platforms. The Viewlogic simulation libraries and the Viewsim simulator are available from Lattice.

## Fusemap Generation

ThepDS+Viewlogic software generates a device fusemap in standard JEDEC format. A security feature offers protection of proprietary designs from unauthorized duplication. The Fitter also appends any design test vectors in JEDEC format to the device fusemap thus facilitating a quick, easy functional verification of a programmed device.

## System Requirements (PC Platform)

- 386/486/Pentium IBM Compatible PC
- MS DOS Version 3.3 or Later
- 16 MB RAM with 40 MB Hard Disk Space
- Workview 4.1 or Later
- Serial Port for Mouse
- 3 Button Mouse (Mouse Systems Compatible)
- Parallel Printer Port for Software Key


## System Requirements (Sun Platform)

- Sun Sparc 4
- Sun OS Version 4.x
- Open Windows 3.0
- Workview 4.1 or Powerview 5.0 or Later
- 16 MB RAM with 100 MB Hard Disk Space
- 3 Button Mouse


## Technical Support Assistance

Lattice Hotline 1-800-LATTICE (Domestic)
Lattice Hotline 1-408-428-6414 (International)
Lattice BBS 1-408-980-9814

## Programmer Support

All devices in the Lattice ispLSI device family can be programmed while installed on the target circuit board. In-system programming can be performed either via the isp Engineering Kit or by an on-board microprocessor.

All Lattice ispLSI and pLSI devices can be programmed using third-party programmers. These devices are currently supported by programmers from the following vendors:

| Programmer Vendor | Model |
| :---: | :--- |
| Advin Systems | Pilot-U84 |
|  | Pilot-U40 |
|  | Pilot-GL/GCE |
| BP Microsystems | PLD-1128 |
|  | CP-1128 |
| Data I/O | 2900 |
|  | 3900 |
|  | Unisite 40/48 |
|  | Allpro 40 |
|  | Allpro 88 |
|  | Sprint Expert |
| System General | System 3000 |

High pin-count socket adapters are available from Emulation Technology, EDI Corporation and PROCON.

## pDS+ Viewlogic Software

## pDS+ Viewlogic Ordering Information

## Software Products

| pDS1102-PC1 | Viewlogic Viewsim and Viewdraw Libraries and Interface Files (Direct Viewlogic Customers on the PC) |
| :--- | :--- |
| pDS1102-SN1 | Viewlogic Viewsim and Viewdraw Libraries and Interface Files (Direct Viewlogic Customers on the Sun) |
| pDS1103-PC1 | Viewlogic Viewsim and Viewdraw Libraries and Interface Files (Customers of Actel or Other FPGA |
|  | Suppliers on the PC) |
| pDS1104-PC1 | Viewlogic Viewsim and Viewdraw Libraries and Interface Files (Xilinx Customers on the PC) |
| pDS1301-PC1 | Viewlogic Viewdraw Schematic Editor |
| pDS2101-PC1 | pDS+ Viewlogic Fitter for (PC) |
| pDS2101-SN1 | pDS+ Viewlogic Fitter for (Sun) |
| pDS3302A-PC1 | pDS+ Viewlogic Viewsim Functional and Timing Simulator (PC) for Current Viewlogic Users |
| pDS3302-PC1 | pDS+ Viewlogic Viewsim Functional and Timing Simulator (PC) for New Viewlogic Users |

## Maintenance Agreements

| pDS1102M-PC1 | Viewlogic Viewsim and Viewdraw Libraries and Interface Files (Lattice Viewsim Library Products) <br> (pDS1102-PC1) |
| :--- | :--- |
| pDS1102M-SN1 | Viewlogic Viewsim and Viewdraw Libraries and Interface files (pDS1102-SN1) |
| pDS1301M-PC1 | Viewlogic Viewdraw Schematic Editor (pDS1301-PC1) <br> pDS2101M-PC1 |
| pDS+ Viewlogic Fitter (pDS2101-PC1) |  |
| pDS2101M-SN1 | pDS+ Viewlogic Fitter (pDS2101-SN1) |
| pDS3302M-PC1 | pDS+ Viewlogic Viewsim Functional and Timing Simulator (For all Lattice Viewsim Simulation Products) <br> (pDS3302-PC1) |

## isp Engineering Kit

| pDS4102-PM | Model 100 Universal Programming Module for the PC: <br> Universal Programming Module,(2) 8 wire Download cables, AC/DC Power Supply Converter, 25-Pin <br> Parallel Port Adapter |
| :--- | :--- |
| pDS4102-WS | Model 200 Universal Programming Module for the Sun |

## Warranty / Update Service

- 90 Day Warranty on Disk Media
- One year of Maintenance Support Included with Purchase
- Annual Maintenance Agreement Available
- 90 Day Warranty on isp Engineering Kit pDS+"LOG/iC Software


## Features

- pLS ${ }^{\circledR}$ and ispLSI ${ }^{m}{ }^{m}$ Development System Support
— pLSI 1016, 1024, 1032
— ispLSI 1016, 1024, 1032
- Support for 2000 Family Under Development
- Design Entry Using ISDATA LOG/iC PLUS or PERFECT and LOG/iC ODC
- Design Verification Using LOG/iC Functional Simulation
- Lattice Fitter for Design Synthesis
- Optional Timing Simulator
- Integrated Development Environment for MixedMode Design Entry
- ISDATA LOG/iC Syntax Including Boolean Equations, Truth Tables and State Machines, Optional VHDL, Schematics or Graphical State Machine Entry
- Graphical Menu Driven User Interface
- Lattice pDS+ LOG/iC Fitter
- Automatic Device Fitter Ensures High Utilization and Performance
- Efficient Design Optimization \& Minimization
- Automatic Partitioning with High Utilization
- "Hands Free" Automatic Place and Route
- Fast Route Option for Quick Turnaround
- Strong Route Option for Comprehensive and Optimized Routing
- Predictable Performance
- Industry Standard Programming File Generation
- Standard JEDEC Device Fusemap
- Optional isp Engineering Kit*
- Programmer for Engineering Use
- Supports ispLSI 1016, 1024, \& 1032
- Model 100 for PC
- Download to Programmer or Circuit Board
- Runs on 386/486/Pentium IBM Compatible PC
*Not intended for production programming


## Introduction

The pDS+ LOG/iC software from Lattice Semiconductor offers a powerful solution to fit high density logic designs into Lattice's pLSI and ispLSI devices.
Design entry is made simple by using LOG/iC software from ISDATA GmbH together with the pDS+ LOG/iC Fitter for design implementation. The Lattice pDS+ LOG/iC software offers high-level, device independent design entry with efficient logic compilation, delivering unprecedented performance for the most complex designs.

## ISDATA LOG/IC

The easy to use, menu driven ISDATA LOG/iC software package provides a complete design environment. Using the LOG/iC program package, complex designs can be quickly and efficiently described using a combination of Boolean Equations, Truth Tables, State Machine syntax or other LOG/iC design. The LOG/iC syntax creates designs without regard to any specific device dependencies. The built-in functional simulator allows designs to be fully verified before device fitting. The menu driven environment makes design implementation simple to use.

## pDS+ LOG/iC Software

The Lattice pDS+ LOG/iC Fitter for pLSI and ispLSI devices is completely integrated within the LOG/iC software environment. The Lattice Fitter provides hands-off design implementation through intelligent design optimization, logic partitioning, automatic place \& route and fusemap generation with optional test vectors in standard JEDEC format. Extensive top level design control is provided to optimize design implementation for speed and/or high device resource utilization. The pDS+ LOG/iC Fitter performs the following functions during design synthesis:

- Design Optimization and Logic Minimization
- Automatic Partitioning
- Automatic Place and Route
- Design Parameter Control
- Fusemap Generation

[^57]Figure 1. pDS+ LOG/iC Design Interface


Figure 2. pDS+ LOG/iC Fully Integrated Design Environment
 pDS+ LOG/iC Software

## Design Optimization and Logic Minimization

The pDS+ LOG/iC Fitter uses proprietary algorithms targeted for device specific features. The Fitter optimizes the design thoroughly, compressing multiple level logic into two level logic, and utilizing logic minimization, product term sharing and XOR functions wherever necessary. In addition, the pDS+ LOG/iC Fitter supports multiple fitting strategies to obtain the best device utilization and performance.

## Automatic Partitioning

The pDS+ LOG/iC Fitter incorporates a powerful Automatic Partitioner for hands-free synthesis of a design into Generic Logic Blocks (GLBs). The partitioner takes full advantage of the device's powerful features, such as the hard XOR function and product term sharing. The internal XOR can be utilized for Arithmetic functions, T-Type flip-flops, and on \& off set optimization functions. Common sub-expressions are extracted, and unused registers are eliminated. These features combine to maximize device resource utilization and increase design performance.

## Automatic Place and Route

Automatic place and route eliminates the need for manual editing and accelerates the design cycle. The Router automatically generates pinouts based on the optimal design implementation or uses user assigned pinouts. It offers two routing options:

## - Fast Route

- Strong Route

The Fast Route option allows quick place and route for fast debugging of designs. The Strong Route option performs a comprehensive route to maximize device resource utilization and ensure efficient design implementation. The result is small design changes don't result in expensive p.c. board rework.

## Design Parameter Control

Extensive design parameter control at the design entry level is possible with the pDS+ LOG/iC Fitter giving the user the option to optimize the design for maximum utilization and speed. Controls are specified using "Property" statements in the Lattice Property file (.IPR). These controls fall into five categories:

- Fitter Statements
- Option Statements
- Net Statements
- Path Statements
- Sym Statements


## Fitter Statements

Special properties can be passed to the pDS+ LOG/iC Fitter providing complete control over critical design considerations. Fitter control over design partitioning and routing optimizes the design for speed and/or device utilization. Here are a few of the powerful features:
PART Determines device type to be used
EFFORT/TRY Runs four optimization strategies and uses the best to implement the design. TRY uses only one of the four strategies, and overrides EFFORT if both are specified

LOCK Lets you lock I/O signals to specific device pins

MAX_DELAY $\begin{aligned} & \text { Specifies maximum level of (GLBs) de- } \\ & \text { lay }\end{aligned}$
AVG_GLB_IN Specifies average number of inputs to a GLB. Default is 16

MAX_GLB_IN Controls maximum number of inputs to a GLB. Default is 16

FAST/STRONG Method of routing. Default is STRONG ROUTE Fixed

## Option Statements

pDS+ LOG/iC Design implementation controls are used for changing such design parameters as security, pullups etc. Some of the implementation controls are:
ISP Instructs Router to reserve in-system programming pins

ISP_EXCEPT_Y2Reserves all ISP pins except Y2 (ispLSI and pLSI 1016 only)

Y1_AS_RESETUses Y1 clock pin on ispLSI and pLSI 1016 as a global reset pin

SECURITY Sets the device security cell to prevent unauthorized fusemap read back

PULLUP Specifies internal pull-up resistors on all (ON) or unused I/Os

## Net Statements

These properties control how the design is mapped into the specified features of the target device:

CLK 0-2 Assigns GLB clock signals
IOCLK 0-1 Assigns I/O cell clock signals
FASTCLK Assigns a product term clock to use any one of the dedicated clock inputs to clock all or desired sets of registers

SLOWCLK Designate clock to use a product term clock within a GLB

PRESERVE Prevents logic minimization on specified nodes

CRIT Specifies Output Routing Pool Bypass Modes for selected duplication

## Path Statements

The following properties specify paths in the design that have special fitting requirements:

SAP/EAP Defines asynchronous paths to prevent signal duplication

SCP/ECP Defines critical paths to reduce delays
SNP/ENP Defines logic paths for no logic minimization

## Sym Statements

These allow you to choose to place a register in a specific GLB or an I/O cell:

$$
\begin{array}{ll}
\text { SYM IOC } & \text { Register in the I/O cell } \\
\text { SYM GLB } & \text { Register in the GLB } \\
\text { Parameter File }
\end{array}
$$

The pDS+ LOG/iC Fitter uses a parameter file (IPR file) feature to help designers optimize the design for the right device. It allows the user to try a number of design implementation options using the design implementation controls in batch mode. The parameter file instructs the partitioner and the router on how to maximize both device utilization and performance.

The pDS+ LOG/iC Fitter also provides post route equations showing exactly how the design is implemented in the selected device. An optional timing simulator is also available for detailed post route timing simulation of designs using the VERIFY section of the menu.

## Fusemap Generation

The pDS+ LOG/iC Fitter generates a device fusemap in standard JEDEC format. The fusemap is automatically produced and inserted in the JEDEC file after a successful route. A security feature gives protection of proprietary designs from unauthorized duplication.

## Design Verification

The pDS+ LOG/iC software provides functional simulation of pLSI and ispLSI designs using the optional LOG/iC Functional Design Verifier (FDV). The simulation test program file (.DTP) can be created for device simulation in the VERIFY menu, but the FDV can also be stimulated interactively on the screen.
Full timing simulation is also available using Viewlogic's Viewsim Simulation (available from Lattice).

## System Requirements

386/486/Pentium IBM Compatible PC

- MSDOS Version 3.3 or Later
- 16 MB RAM with 40MB Hard Disk Space
- 3 1/2" Floppy Disk Drive
- ISDATA's LOG/iC PLUS or PERFECT and LOG/iC ODC SOFTWARE
- Parallel Printer Port for Software Key
- EGA Graphics Monitor or higher


## Technical Support Assistance

| Lattice Hotline: | $1-800-$ LATTICE (Domestic) |
| :--- | :--- |
| Lattice Hotline: | $1-408-428-6414$ (International) |
| Lattice BBS: | $1-408-980-9814$ |
| email: | applications@lattice.com |
| ISDATA Inc. | $1-510-531-8553$ |
|  | $1-800-777-1202$ |

ISDATA GmbH: 49-721-751087

## Programmer Support

All devices in the Lattice ispLSI device family can be programmed while installed on the target circuit board. In-system programming can be performed either via the isp Engineering Kit or by an on-board microprocessor.
All Lattice ispLSI and pLSI devices can be programmed using third-party PLD programmers. These devices are currently supported by programmers from the following vendors:

| Programmer Vendor | Model |
| :---: | :--- |
| Advin Systems | Pilot-U84 |
|  | Pilot-U40 |
|  | Pilot-GL/GCE |
| BP Microsystems | PLD-1128 |
|  | CP-1128 |
| Data I/O | 2900 |
|  | 3900 |
|  | Unisite 40/48 |
| Logical Devices | Allpro 40 |
|  | Allpro 88 |
| SMS Micro Systems | Sprint Expert |
| Stag | System 3000 |
|  | ZL30/A |
|  | TURPRO-1 |

High Pin-count socket adapters are available from Emulation Technology, EDI Corporation and PROCON.

## pDS+ LOG/iC Ordering Information

## Product Code Description

pDS2103-PC1 pDS+LOG/iC Fitter for PC pDS2103M-PC1 pDS+LOG/iC Fitter Maintenance pDS3302-PC1 Viewlogic Viewsim Simulator pDS3302M-PC1 Viewsim Maintenance pDS1102-PC1 Viewsim Library

## isp Engineering Kit Ordering Information

- Kit Contains Programming Module (Base Unit), Download Cable and A/C Adapter
- One ispLSI Device Sample Included per Adapter

Product Code
pDS4102-PM

## Description

Model 100 Universal Programming Module

## Warranty/Update Service

- 90 Day Warranty on Disk Media
- One year Maintenance Support Included with Purchase
- Annual Maintenance Agreement Available
- 90 Day Warranty on isp Engineering Kit

Notes

 isp ${ }^{\text {m'S }}$ Starter Kit Starter Set of Software, Hardware, Datasheets and Samples for Lattice ISP Products

## Includes

- Software
— pDS1016-PC1 Design Development System for ispLSI 1016 Device
- ispGAL ${ }^{\circledR}$ Download Software
- ispGDS ${ }^{\text {Tu }}$ (Generic Digital Switch) Compiler and Download Software
- ispCODE ${ }^{\text {mw }}$ ANSI C Compiled and Source Programming Software
- Datasheets
- ispLSI 1016 Device Datasheet
- ispGAL22V10 Device Datasheet
- ispGDS22/18/14 Device Datasheet
- Samples
— ispLSI 1016-60LJ Device in 44 pin PLCC Package
— ispGAL22V10B-15LJ Device in 28 pin PLCC Package
- ispGDS14-7J Device in 20 pin PLCC Package
- Hardware
— ispDOWNLOAD" ${ }^{\text {T" }}$ Cable


## Features

- Easy to Use Kit Contains Everything Needed for In-System Programmable Device Design-in
- Supports Lattice's ispLSI 1016 Device - the Industry's Fastest High Density Programmable Device at 110 MHz
- Supports Industry Standard 22V10 Architecture Coupled with Lattice's Innovative In-System Programmable Design Capability
- Supports Lattice's New isp Generic Digital Switch for Applications such as Software Driven Hardware Configuration and Multiple DIP Switch Replacement
- E ${ }^{2}$ CMOS Technology


## Introduction

The isp Starter Kit is designed to make Lattice's innovative in-system programmable device technology available in a single, complete package. The isp Starter Kit contains all the software, hardware, device samples, and information you need to begin designing with Lattice's ISP products. The ispLSI devices are the fastest High Density Programmable Logic devices in the industry, at 110 MHz , as certified by PREP ${ }^{\text {TM }}$ Benchmarks. Lattice's new 7.5ns ispGAL22V10 device has all the advantages of In-System Programmability and maintains the familiar 22 V 10 architecture and 28 -pin PLCC pinout. The ispGDS is Lattice's latest in-system programmable innovation. This new family of devices offers the ability to configure its programmable switch matrix to connect signals arbitrarily between two banks of I/O pins or to force pins to fixed high or low logic states.

## In-System Programmability (ISP)

ISP is a Lattice innovation that supports device function programming and reprogramming on the printed circuit board at 5 volts. There are several advantages to in-system programmability: First, it accelerates the system and board level debug process and enables you to define your board layout earlier in the design process. Second, ISP eliminates bent leads caused by extra handling and socket insertions made during the device programming process. Third, systems incorporating ISP are reconfigurable with the devices already soldered to the p.c. board, minimizing board rework time and expense. With this capability your system options are boundless and easier field updates are made possible by downloading a new configuration file via a floppy disk or modem.

## ispLSI 1016 and pDS 1016 Software

The ispLSI 1016 device is a fast, high density programmable logic device containing 64 logic registers, 32 Universal I/O pins with input registers, four dedicated input pins, three dedicated clock input pins, and a programmable Global Routing Pool (GRP). The basic logic element of the device is the Generic Logic Block (GLB) which has 18 inputs, a programmable AND/OR/ XOR array, and four outputs that may be configured as

[^58]either combinatorial or registered. Lattice's pDS1016 Design Software is a high performance development environment that runs on IBM compatible 386/486/ Pentium PCs. The software has a friendly, efficient, Microsoft Windows Interface which supports familiar Boolean equation entry. pDS1016 features automatic logic Place and Route for quick design implementation. To make designing even easier there is a library of over 200 Logic Macros for fast design entry.

## ispGAL22V10 and Download Software

The ispGAL22V10 is the industry's first in-system programmable 22 V 10 device and offers a fast 7.5 ns maximum propagation delay time. The generic architecture provides maximum flexibility by allowing the Output Logic Macrocell (OLMC) to be configured by the user. The logic functionality, fusemap, and AC and DC parameters of the ispGAL22V10 are fully compatible with standard bipolar and CMOS 22V10 devices. The 28-pin PLCC package provides the same functional pinout as the standard 22V10 by using thefour "No Connect" pins on the 28 pin PLCC for the ISP interface signals.

Designs for the ispGAL22V10 can be compiled by any logic compiler supporting the 22V10 architecture. The ispGAL Download Software takes any 22V10 JEDEC file as input and programs the device in-system, quickly and easily.

## ispGDS and Compiler/Download Software

The Lattice ispGDS family is an ideal solution for reconfiguring system signal routing and replacing DIP switches used for feature selection. Each I/O cell can be configured as an input, an inverting or noninverting output, or a fixed TTL high or low output. Any I/O pin in the one bank can be driven by any I/O pin in the opposite bank. A single input can also drive one or more outputs in the opposite bank, allowing a signal, such as a clock, to be distributed to multiple destinations on the board.

The ispGDS Compiler and Download Software is a simple text entry and compilation design tool that produces a standard JEDEC file for device programming.

## Ordering Information

Part Number
isp-SK

Description
Lattice isp Starter Kit

## Source Code for In-System Programming of the Lattice ispLSI ${ }^{\text {TM }}$ Family

## Features

- C-LANGUAGE SOURCE CODE FOR IN-SYSTEM PROGRAMMING OF THE ispLSI FAMILY
- Simplifies In-System Programming
- Pre-Defined Routines for Common Programming Functions
- Extensively Commented Code Provides Complete Reference
- Easy Modification Saves Valuable Time
- Supports Programming of Multiple ispLSI Devices on Individual Boards
- ACCEPTS PROGRAMMING FILES FROM THE pLSI AND ispLSI DEVELOPMENT SYSTEM (pDS®)
- Supports pDS and pDS+ ${ }^{\text {TM }}$ Software
-Supports ispLSI 1000, 2000, and 3000 Families
- PORTABLE TO ANY HARDWARE PLATFORM
- Adaptable to Any Hardware Interface
— UNIX Systems, PCs, Testers, Embedded Systems
- ANSI-Standard C for Portability
- GENERATES ispSTREAM ${ }^{\text {TM }}$ FORMAT FOR GREATER EFFICIENCY
- Bit-packed File Format for Storing JEDEC Fusemap
- Requires Less Than $1 / 8$ the Storage Space of a Standard JEDEC File
- Ideal for Use in Embedded Systems, PROMs and EPROMs
- Includes Checksum To Assure Data Integrity
- USER ELECTRONIC SIGNATURE (UES) SUPPORTED
- Provides Data Storage Area In Device
- Facilitates User Identification of Program for Secured Devices
- Automatic Counter Records Number of Programming Cycles
- EXTENSIVE EXAMPLE FILES
- Fast Learning Curve
- 100\% of Library Functions Demonstrated


## Introduction

The ispCODE software from Lattice is designed to facilitate in-system programming of ispLSI devices on customer-specific hardware platforms. The ispCODE works with Lattice's pLSI and ispLSI Development System software to give users a powerful, fully integrated tool kit for developing logic designs and programming ispLSI devices "on-the-fly."

After completion of the logic design and creation of a JEDEC file by the pDS or pDS+ software (see figure 1), in-system programming can be accomplished on cus-tomer-specific hardware: UNIX systems, PCs, testers, embedded systems (see figure 2). The ispCODE software package supplies specific routines, with extensively commented code, for incorporation into user application programs. These routines provide users with flexible, easy-to-use program modules which support the programming of a single device or multiple devices on a board.

## ispCODE Software

The ispCODE software consists of source files containing subroutines for performing all the functions needed to control the programming of Lattice in-system programmable devices (see Table 1). These routines are provided as fully-commented source code for easy inclusion with any software written in the industry-standard C language. This source code library was designed from the ground up to be easily portable to any system that has an ANSIstandard C compiler. The majority of the code is completely independent of the hardware platform and rarely requires modification. All hardware dependent portions of the code are in a separate file, and are easily modified for any hardware system. The code supports the programming of multiple ispLSI devices by controlling the ispEN pins of each device separately, or in a daisy chain configuration.

Example programs are provided to demonstrate the use of each routine. These example programs are designed to enhance readability and understanding. In addition, they provide a practical method of immediately programming devices. By making small changes to the hardware-specific source files and re-compiling the example programs, a complete set of command-line oriented

[^59]
붑․․․․․

utilities are created that program, verify, read, and secure devices.

All of the example programs and the hardware-specific code are written to run on IBM PC or compatible microcomputers. The programs use the standard PC parallel printer port to provide the interface to the Lattice device's insystem programming pins (see figure 3). The pinout is compatible with the Lattice isp Engineering Kit Model 100.

## Fusemap Storage

All of the ispCODE routines use a bit-packed file format for storing the device pattern information. This bit stream is called an ispSTREAM, and consists of one bit for each of the programmable cells in the devices, plus one byte at the front of the file for a device ID code, and four bytes at the end of the file for a 32 -bit checksum. This format provides the most compact means possible for storing the pattern information, requiring less than $1 / 8$ the storage space of a standard JEDEC file. This format is ideal for use in embedded systems, and the storage of ispLSI pattem information in PROMs or EPROMs. Also, using the ispSTREAM format simplifies the programming code, thus reducing the possibility of errors. The following are the ispSTREAM storage requirements for ispLSI 1000 family devices:

## Device

ispLSI 1016
ispLSI 1024
ispLSI 1032
ispLSI 1048

## Storage Requirement

1933 bytes
3078 bytes
4343 bytes
7233 bytes

Figure 1. Using the ispCODE Software
There are ispCODE routines for converting JEDEC files to ispSTREAM files, and for converting back to JEDEC files. In addition, ispCODE software includes stand-alone programs called "jedtoisp" and "isptojed" which can be used for converting files. When using the ispCODE routines and the example programs, the JEDEC files are first converted to ispSTREAM format. The ispSTREAM files are then used to do the programming.

## User Electronic Signature

The ispCODE library provides routines for accessing the UES (User Electronic Signature), which is a user-accesUES (User Electronic Signature), which is a user-acces-
sible data storage area present in all Lattice in-system programmable devices. This area can be used to store information relating to the current configuration of the device or system, and is always readable, even when the functional portions of the devices are secured.

The ispLSI 1000 family devices have the following UES areas available:

Device
ispLSI 1016
ispLSI 1024
ispLSI 1032
ispLSI 1048

辟

## UES Area

$\frac{\text { UES Area }}{8 \text { bytes }}$
13 bytes
18 bytes
28 bytes




Figure 2. Configuring an ispLSI Device from an On-board Microprocessor


Figure 3. Configuring an ispLSI Device from a Remote System


## Automatic Program Count

Another useful feature of ispCODE is the implementation of a program counter. A section of the same area in which the UES is stored is reserved for a 16-bit count of programming cycles. When the ispCODE routines are used exclusively for programming the device, an accurate count of programming cycles will be available to the user. The programming routine automatically increments the count after each programming cycle. There is also a routine which reads the count value from the device.

Table 1. High Level Routines

| Routine | Purpose |
| :--- | :--- |
| isp_program() | program the entire device |
| isp_read() | read the entire device |
| isp_verify() | verify the entire device |
| isp_secure() | secure the device |
| isp_jedtoisp() | convert JEDEC file to ispSTREAM format |
| isp_isptojed() | convert ispSTREAM format to JEDEC file <br> pattern data and address |
| isp_new() | delete device data structure |
| isp_delete() | read the User Electronic Signature (UES) <br> from the device |
| isp_read_ues() | convert an array of UES bits to a standard <br> C string |
| isp_ues_to_string() | convert a standard C string to an array of <br> UES bits |
| isp_string_to_ues() | compare two arrays of UES bits |
| isp_compare_ues() | get the programming count |
| isp_get_count() | get the device ID from a device |
| isp_get_id() | calculate and add/update an ispSTREAM <br> checksum |
| isp_add_checksum( | verify the checksum of an ispSTREAM |
| isp_check_stream() | calculate the checksum of an ispSTREAM |
| isp_calc_checksum() | indac\| |

## Using the Routines

All the user-accessible routines use a data structure (isp_STRUCT) to hold all the data needed to do any ISP operation on a given device. This structure is defined in a header file, which must be included in any program that calls the Lattice routines. There are two routines, isp_new() and isp_delete(), which handle the memory allocation and freeing, as well as the data initialization for isp_STRUCT items.

Multiple isp_STRUCT structures may be allocated at once, since all the routines take a pointer to a single isp_STRUCT, and don't depend on any global variables. Each structure created holds a pointer to an ispSTREAM, as well as the I/O port address, for the device (and other device-specific data). Different devices could be located at different addresses and easily programmed by sequential calls to the isp_program() routine with a different isp_STRUCT pointer each time.

## Devices Supported

The ispCODE library of routines will support all Lattice insystem programmable devices. As new devices are developed and released, the ispCODE library will be updated to include them.

## Hardware Requirements

The ispCODE routines are designed to be portable to any hardware platform with an ANSI C compiler available. The code is written such that accessing the pins of the Lattice device is done by writing to a memory or I/O port address.

In addition to driving the pins, a method of controlling timing in the millisecond range is required. The best approach for this is a hardware-based method, such as a timer chip that can be read. Most micro controllers have a timer built in, and most other systems have some way of keeping time that may be used. The ispCODE source files include an example of reading the timer chip on a PC to accurately time the programming pulses.

## ispCODE Ordering Information

## Part Number <br> pDS4103

## Description

ispCode Software - ANSI C Compiled and Source Files

Lattice includes a copy of the ispCODE with pDS and pDS+ software purchases.

## Technical Support Assistance

Lattice Hotline: 1-800-LATTICE (Domestic)
Lattice Hotline: 1-408-428-6414 (International)
Lattice BBS: 1-408-980-9814
email: applications@lattice.com



## ispCODE Example Program

Below is a sample program using the Lattice routines to program, verify, and secure a device from an ispSTREAM file. The usual error checking has been omitted for clarity, with the ispCODE specific sections in boldface type. This file would be compiled and linked with the ispCODE routines to produce the executable program.

```
#include <stdio.h>
#include <stdlib.h>
#Include "isplsi.h"
void main(int argc, char *argv[])
{
isp_STRUCT *device;
unsigned inport, outport;
FILE *source_file;
int verified = FALSE;
int i, dev_num;
    /* Program device #1 */
    dev_num = 1;
    /* use LPT1 parallel port on PC */
    inport = PORT1_IN;
    outport = PORT1_OUT;
    /* Initialize isp device structure, allocate memory for the
        ispSTREAM, and set device type and I/O ports */
    device = 1sp_new(1spLSI1032, TRUE, FALSE, inport+1, outport, dev_num);
    /* read file into ispSTREAM buffer allocated by isp_new()*/
    source_file = fopen(argv[1],"rb");
    for( i=0; i<device->stream_bits; i++)
        device->stream[i] = getc(source_file);
    /* print status and program the device */
    printf("Programming.... Please wait. \n");
    1sp_program(device, FALSE);
    /* print status and verify the device */
    printf("Verifying.... Please wait. \n");
    verified = isp_verify(device, TRUE);
    if( verified )
    {
        printf("Device programmed and verified! \n");
        /* secure device if verified properly */
        1sp_secure(device);
    }
    else
        printf("ERROR: Device did not verify \n");
    /* free the memory allocated for the isp_STRUCT */
    isp_delete(device);
/*main()*/
```


## Features

- Supports All ispLSI 1000, 2000 and 3000 Family Members
- Stand-alone Device Programmer
- Download Directly to an ISP ${ }^{\text {TM }}$ Device on System Board
- Only 5 Control/Data Pins Needed
- Quick Device Programming
- Inexpensive, Small and Compact
- Eliminates Need For Expensive, Remote Programmer
- Excellent for Prototyping New Designs
- Not Intended For Production Programming
- Easy to Use
- Connects Directly to Parallel Printer Port of Host PC


## Description

The isp Engineering Kit Model 100 provides designers a quick and inexpensive means of evaluating and prototyping new designs using Lattice in-system programmable Large Scale Integration (ispLSI ${ }^{\text {TM }}$ ) devices. This Kit is designed for engineering purposes only and is not intended for production use. The Kit programs devices from the parallel printer port of a host PC using the Lattice pLSI/ispLSI Development System (pDS ${ }^{\circledR}$ ) or pLSI/ispLSI Development System Plus (pDS $+^{+M}$ ) PCbased designs tools. By connecting a system cable (included) from the host PC to the isp Engineering Kit, or connecting from the host PC to the target device on the system board, a JEDEC file can be easily downloaded into the ispLSI device(s).

## Components

The isp Engineering Kit Model 100 consists of two primary components, each sold separately:

- Universal Programming Module (UPM)
- Socket Adapters

The adapters plug into the UPM base. The adapter provides the appropriate PLCC, PQFP, TQFP, or QFP socket for a particular ispLSI device package.

isp Engineering Kit - Model 100

## UPM Description

The Model 100 Universal Programming Module (UPM) is designed to support all package types available from Lattice. It consists of the following components:

- Universal Programming Module Base Unit
- Power Supply Converter (110VAC/9VDC @ 200 mA )
- Included for North America and Asia Only
- 25-Pin Parallel Port Adapter
- 6'Universal Programming Module Download Cable with Modular Phone connectors (RJ45) on both ends
- 6' System Download Cable with a Modular Phone connector on one end and a AMP 1-87499-3 connector on other end

The connection between the host PC and the UPM base unit is shown in figure 1.

[^60]
## Electrical Characteristics

## Power Supply

$$
\begin{array}{ll}
\text { AC Input Voltage: } & 110 \text { VAC } \\
\text { DC Output Voltage: } & 9 \mathrm{VDC} @ 200 \mathrm{~mA}
\end{array}
$$

## UPM Physical Characteristics

| Length: | 3.75 inches |
| :--- | :--- |
| Width: | 2.625 inches |
| Depth: | 1.375 inchs |

## Download Cables

## Download Cable with RJ-45 Phone Connectors on Both Ends

Length:
Connectors:
6.0 feet ( 192.8 cm )
RJ-45 with eight positions

## System Download Cable with RJ-45 Phone and

 AMP 1-87499-3 Connectors| Length: | 6.0 feet $(192.8 \mathrm{~cm})$ |
| :--- | :--- |
| Connectors: | RJ- 45 with eight positions <br> AMP single in-line 0.100 " <br> center spacing 8 positions |

Figure 1. Universal Programming Module Description


0813A

## Ordering Information

Order Code
pDS4102-PM
pDS4102-J44
pDS4102-T44
pDS4102-J68
pDS4102-J84
pDS4102-T100
pDS4102-Q120
pDS4102-Q128
pDS4102-M160
pDS4102-G167

## Product Description

isp Engineering Kit Model 100 for the PC:
UPM programming module, (2) 8 wire Download cables, AC/DC Power Supply Converter, 25-Pin Parallel Port Adapter

44-pin PLCC socket adapter, (1) ispLSI 1016 Engineering Sample
44-pin TQFP socket adapter, (1) ispLSI 1016 Engineering Sample
68-pin PLCC socket adapter, (1) ispLSI 1024 Engineering Sample
84-pin PLCC socket adapter, (1) ispLSI 1032 Engineering Sample
100-pin TQFP socket adapter, (1) ispLSI 1032 Engineering Sample 120-pin PQFP socket adapter, (1) ispLSI 1048 Engineering Sample 128-pin PQFP socket adapter, (1) ispLSI 1048C Engineering Sample 160-pin MQFP socket adapter, (1) ispLSI 3256 Engineering Sample 167-pin CPGA socket adapter, (1) ispLSI 3256 Engineering Sample

Notes

## isp ${ }^{T M}$ Engineering Kit Model 200

## Features

- Supports All ispLSI 1000, 2000, and 3000 Family Members
- Stand-alone Device Programmer
- Download Directly to an ISP™ Device on System Board - Only 5 Control/Data Pins Needed
- Quick Device Programming
- Inexpensive, Small and Compact
- Eliminates Need For Expensive, Remote Programmer
- All External isp Signals Optically Isolated from Workstation
- Prevents Ground Loop Problems
- Excellent for Prototyping New Designs - Not Intended for Production Programming
- Easy to Use
- Connects Directly to Serial Port of Host Workstation


## Description

The isp Engineering Kit Model 200 provides designers a quick and inexpensive means of evaluating and prototyping new designs using Lattice in-systems programmable Large Scale Integration devices (ispLSI ${ }^{\text {M }}$ ). This Kit is designed for engineering purposes only and is not intended for production use. The Kit programs devices from the RS-232 serial port of a host workstation using the Lattice pLSI/ispLSI Development System Plus ( $\mathrm{pDS}+{ }^{\mathrm{TM}}$ ) workstation based design tools by connecting a system download cable (included) from the host workstation to the isp Engineering Kit.

## Components

The isp Engineering Kit Model 200 consists of two primary components, each sold separately:

- Universal Programming Module (UPM)
- Socket Adapters

The adapters plug into the UPM base. The adapter provides the appropriate PLCC, PQFP, TQFP or QFP socket.

isp Engineering Kit - Model 200

## Model 200 Description

The Model 200 Universal Programming Module (UPM) is designed to support all package types available from Lattice. It consists of the following components:

- Universal Programming Module Base Unit
- Power Supply Converter (110VAC/9VDC at 500 mA )
- Included for North America and Asia Only
- RS-232C (DB25P) Serial Port Adapter and cable
- 6' Universal Programming Module Download Cable with Modular Phone connectors (RJ45) on both ends
- 6' System Download Cable with a Modular Phone connector on one end and a AMP 1-87499-3 connector on other end

A drawing showing the connection between the workstation host and the UPM is shown in figure 1.

[^61]isp Engineering Kit Model 200

## Detailed Functional Description

## Top Panel

The top panel has three status indicator lights:
Power Indicator Light: Green illuminates when the power is turned ON and the correct input voltage is applied to the programming module.

System Indicator Light: Green or Red. When data is transmitted to or read from an isp device on the socket adapter board, the light becomes green. When any type of error is detected during programming, the light blinks red.
isp Indicator Light: Green illuminates when data is transmitted to or read from an isp device that is connected to the isp download cable. If the programming module detects the presence of a supply voltage on the isp download cable, it becomes active and programming to the socket adapter board is bypassed, regardless of the presence of a device on the socket adapter board.

Quick-Connect Interface for Socket Adapter Boards
Located at rear of the top panel are slots for the dual set of quick release contacts and the handles used to activate them. The inner or outer pair of contacts is chosen depending on type of socket adapter board used. The handles are flipped up when a socket adapter board is inserted in the proper contact slots. Push both handles down to lock the socket adapter board in place.

## Left Panel

Power Input Jack

RS-232 RJ-11 Jack

BAUD

## Right Panel

ON/OFF Switch

RJ-45 Jack

This jack is coaxial and accepts the power plug from the Power Supply Converter.

This jack connects the RS-232C flat cable to the workstation's serial port.

An eight position DIP switch that sets the serial port communications parameters. This switch is set at the factory for optimum performance.

This switch controls the input power supplied to the programming module.

If download is to be performed while an isp device is on board, the isp download cable is plugged into the RJ-45 jack.

Figure 2. isp Engineering Kit Model 200


DIP Switch for Serial Port Setup


Figure 1. isp Engineering Kit Model 200


## DIP Switch Settings

DIP switch settings for Model 200 are shown in Tables 1 to 4.

Note: SW1 is not used and asterisk following parameters are default factory settings

Table 1. RS-232C Baud Rate Selection

| Baud Rate | SW2 | SW3 | SW4 |
| :--- | :---: | :---: | :---: |
| $38400^{\star}$ | UP | DOWN | UP |
| 19200 | UP | DOWN | DOWN |
| 9600 | DOWN | UP | UP |
| 2400 | DOWN | UP | DOWN |
| 1200 | DOWN | DOWN | UP |
| 300 | DOWN | DOWN | DOWN |

Table 2. Parity Selection

| Parity | SW5 | SW6 |
| :--- | :---: | :---: |
| None $^{*}$ | DOWN | DOWN |
| Odd | UP | DOWN |
| Even | UP | UP |

## Electrical Characteristics

Power Supply
AC Input Voltage: 110 VAC
DC Output Voltage: 9 VDC @ 500mA
UPM Physical Characteristics
Length:
6.50 inches
Width:
4.125 inches
Depth:
1.50 inches

## Download Cables

Serial Port Cable with RJ-11 Phone Connectors on Both Ends

| Length: | 6.0 feet $(192.8 \mathrm{~cm})$ |
| :--- | :--- |
| Connectors: | RJ- 11 with 6 positions |

System Download Cable with RJ-45 Phone and AMP 1-87499-3 Connectors

| Length: | 6.0 feet $(192.8 \mathrm{~cm})$ |
| :--- | :--- |
| Connectors: | RJ-45 with 8 positions <br> AMP single in-line $0.100 "$ <br>  |
|  | center spacing 8 positions |

Table 3. Word Length Selection

| Word Length | SW7 |
| :---: | :---: |
| 7 Data Bits | DOWN |
| 8 Data Bits | UP |

Table 4. Stop Bit Selection

| Number of Stop Bits | SW8 |
| :---: | :---: |
| $1^{*}$ | DOWN |
| 2 | UP |

## Ordering Information

## Order Code <br> Product Description

pDS4102-WS isp Engineering Kit Model 200 for the Workstation:
M200PM programming module, (1) 8 wire Download cable, (1) 6 wire Download cable, AC/DC Power Supply Converter
pDS4102-J44
pDS4102-T44
pDS4102-J68
pDS4102-J84
pDS4102-T100
pDS4102-Q120
pDS4102-Q128
pDS4102-M160
pDS4102-G167

44-pin PLCC socket adapter, (1) ispLSI 1016 Engineering Sample 44-pin TQFP socket adapter, (1) ispLSI 1016 Engineering Sample 68-pin PLCC socket adapter, (1) ispLSI 1024 Engineering Sample 84-pin PLCC socket adapter, (1) ispLSI 1032 Engineering Sample 100-pin TQFP socket adapter, (1) ispLSI 1032 Engineering Sample 120-pin PQFP socket adapter, (1) ispLSI 1048 Engineering Sample 128-pin PQFP socket adapter, (1) ispLSI 1048C Engineering Sample 160-pin MQFP socket adapter, (1) ispLSI 3256 Engineering Sample 167-pin CPGA socket adapter, (1) ispLSI 3256 Engineering Sample

Notes


#  

 ispDOWNLOAD"' Cable
## Download Cable for In-System Programming

 of the Lattice ISP ${ }^{m ¹}$ Family of Devices
## Features

- CABLE AND PARALLEL PORT ADAPTER FACILITATE IN-SYSTEM PROGRAMMING OF ISP FAMILY OF DEVICES
- Simplifies In-System Programming
- Ideal for Design Prototyping and Debugging


## - SUPPORTS ALL ISPTM FAMILIES

- ispLSI"' Families (1000, 2000 and 3000)
- ispGAL• Family
- ispGDS" ${ }^{\text {" }}$ Family
- EASY-TO-USE CONNECTORS
- 25-Pin Adapter Connects to PC Parallel Printer Port
- Two 6' Cables Offer P.C. Board Interface Options:
- RJ-45 Connector
-AMP Connector (8 Position, 100 Inch Center Spacing)


## Introduction

The ispDOWNLOAD Cable product is designedtofacilitate in-system programming of all Lattice ISP devices on a printed circuit board directly from the parallel port of a PC. With In-System Programming, hardware functions can be programmed and modified in real-time on the system board to give additional product features, shorten system design and debug cycle time, enhance product manufacturability and simplify field upgrades. After completion of the logic design and creation of a JEDEC file by a logic compiler such as the $\mathrm{pDS}^{\circledR}, \mathrm{pDS}+{ }^{\mathrm{TM}}$ Fitter or ispGDS Compiler software, Lattice's ispDOWNLOAD Software programs devices on the end-product p.c. board by generating programming signals directly from the parallel port of a PC which then pass through the ispDOWNLOAD Cable to the device. With this cable and a connector on the p.c. board, no additional components are required to program a device. The ispDOWNLOAD Software automatically generates the appropriate ISP command, programming address and data from the JEDEC fusemap information. ispDOWNLOAD Software is included with all Lattice pDS and pDS+ Fitter products. For the ispGDS, the ispDOWNLOAD Software can be obtained directly from the Lattice Literature Department.

Figure 1. ispDOWNLOAD Cable Offers Two Types of In-System Programming Interfaces


Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
1994 Data Book Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

Figure 2. PC Parallel Port Connector


Figure 3. Configuring In-System Programming from a Remote System


## Ordering Information

## Part Number

pDS4102-DL

Description
ispDOWNLOAD Cable (For PC Only)
Contains: Two 6' Cables with RJ45 and AMP Connectors
Parallel Port Adapter
Documentation

## pLSI and ispLSI Design Tool Selector Guide

| $\begin{aligned} & \text { DESIRED } \\ & \text { DESIGN } \\ & \text { ENVIRONMENT } \end{aligned}$ | $\begin{aligned} & \text { DESIRED } \\ & \text { CAPABILITIES } \end{aligned}$ | pLSI and ispLSI DESIRED FAMILY SUPPORT |  |  | $\begin{aligned} & \text { EXISTING } \\ & \text { TOOLS } \end{aligned}$ | DESIGN TOOL SOLUTION | $\begin{aligned} & \text { PC } \\ & \text { ORDERING } \\ & \text { INFORMATION } \end{aligned}$ | SUN <br> ORDERING <br> INFORMATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 1000 | 2000 | 3000 |  |  |  |  |
| LATTICE <br> pLSI and ispLSI Development System (pDS) | Entry and Fitting | x | x |  | None | pDS-STD (Standard) | pDS1101-STD/PC1 | N/A |
|  |  |  |  | X | pDS1101 | pDS 3000 Family Upgrade | pDS1101-3UP/PC1 | N/A |
|  |  | x | x | x | None | pDS-Ultra | pDS1101-ULT/PC1 | N/A |
|  | Entry, Fitting, and Simulation | x | x |  | None | pDS-STD (Standard) Viewlogic ViewSim Simulator | $\begin{aligned} & \text { pDS1101-STD/PC1 } \\ & \text { pDS3302-PC1 } \end{aligned}$ | $\begin{aligned} & \text { N/A } \\ & \text { N/A } \end{aligned}$ |
|  |  | x | x |  | ViewSim purchased from Viewlogic | pDS-STD (Standard) Viewlogic Interface/Library | $\begin{aligned} & \text { pDS1101-STD/PC1 } \\ & \text { pDS1102-PC1 } \end{aligned}$ | $\begin{aligned} & \mathrm{N} / \mathrm{A} \\ & \mathrm{~N} / \mathrm{A} \end{aligned}$ |
|  |  | x | x |  | ViewSim purchased from Actel/TI/Other | pDS-STD (Standard) <br> Viewlogic Interface/Library Upgrade | $\begin{aligned} & \text { pDS1101-STD/PC1 } \\ & \text { pDS1103-PC1 } \end{aligned}$ | $\begin{aligned} & \mathrm{N} / \mathrm{A} \\ & \mathrm{~N} / \mathrm{A} \end{aligned}$ |
|  |  | x | x |  | ViewSim purchased from Xilinx | pDS-STD (Standard) <br> Viewlogic Interface/Library Upgrade | $\begin{aligned} & \text { pDS1101-STD/PC1 } \\ & \text { pDS1104-PC1 } \end{aligned}$ | $\begin{aligned} & \hline \text { N/A } \\ & \text { N/A } \end{aligned}$ |
|  |  | x | x | x | None | pDS-Ultra <br> Viewlogic ViewSim Simulator | $\begin{aligned} & \text { pDS1101-ULT/PC1 } \\ & \text { pDS3302-PC1 } \end{aligned}$ | $\begin{aligned} & \mathrm{N} / \mathrm{A} \\ & \mathrm{~N} / \mathrm{A} \end{aligned}$ |
|  |  | x | x | x | ViewSim purchased from Viewlogic | pDS-Ultra Viewlogic Interface/Library | pDS1101-ULT/PC1 pDS1102-PC1 | $\begin{aligned} & \text { N/A } \\ & \mathrm{N} / \mathrm{A} \end{aligned}$ |
|  |  | x | x | x | ViewSim purchased from Actel/TI/Other | pDS-Ultra <br> Viewlogic Interface/Library Upgrade | $\begin{aligned} & \text { pDS1101-ULT/PC1 } \\ & \text { pDS1103-PC1 } \end{aligned}$ | $\begin{aligned} & \mathrm{N} / \mathrm{A} \\ & \mathrm{~N} / \mathrm{A} \end{aligned}$ |
|  |  | x | x | x | ViewSim purchased from Xilinx | pDS-Ultra <br> Viewlogic Interface/Library Upgrade | $\begin{aligned} & \text { pDS1101-ULT/PC1 } \\ & \text { pDS1104-PC1 } \end{aligned}$ | $\begin{aligned} & N / A \\ & N / A \end{aligned}$ |
| LATTICE <br> In System Programmable isp-Starter Kit | isp-Starter Kit | and ispGAL22V10 and ispGDS |  |  | None | Lattice pDS Software to Support pLSI1016 and ispLSI1016, ispGDS, ispGAL22V10, Device Samples, Datasheets, and ispDownload Cable | isp-SK | N/A |

pLSI and ispLSI Design Tool Selector Guide (Cont.)

| DESIRED <br> DESIGN <br> ENVIRONMENT | DESIRED CAPABILITIES | pLSI and ispLSI DESIRED FAMILY SUPPORT |  |  | $\begin{aligned} & \text { EXISTING } \\ & \text { TOOLS } \end{aligned}$ | DESIGN TOOL SOLUTION | PC <br> ORDERING <br> INFORMATION | SUN <br> ORDERING <br> INFORMATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 1000 | 2000 | 3000 |  |  |  |  |
| DATA I/O ABEL | Entry and Fitting | x |  |  | None | ABEL 4.3 or Later Lattice pDS+ ABEL Fitter | From Data I/O pDS2102-PC1 | From Data I/O pDS2102-SN1 |
|  |  | X |  |  | ABEL 4.3 or Later | Lattice pDS+ ABEL Fitter | pDS2102-PC1 | pDS2102-SN1 |
|  | Entry, Fitting, and Simulation | X |  |  | None | ABEL 4.3 or Later Lattice pDS+ ABEL Fitter Viewlogic ViewSim Simulator Viewlogic Interface/Library | $\begin{aligned} & \text { From Data I/O } \\ & \text { pDS2102-PC1 } \\ & \text { pDS3302-PC1 } \\ & \text { Included w/pDS3302 } \end{aligned}$ | From Data I/O pDS2102-SN1 <br> From Viewlogic pDS1102-SN1 |
|  |  | X |  |  | ABEL 4.3 or Later | Lattice pDS+ ABEL Fitter Viewlogic ViewSim Simulator Viewlogic Interface/Library | $\begin{aligned} & \text { pDS2102-PC1 } \\ & \text { pDS3302-PC1 } \\ & \text { Included w/pDS3302 } \end{aligned}$ | pDS2102-SN1 <br> From Viewlogic pDS1102-SN1 |
|  |  | x |  |  | ViewSim purchased from Viewlogic | ABEL 4.3 or Later Lattice pDS+ ABEL Fitter Viewlogic Interface/Library | $\begin{aligned} & \text { From Data I/O } \\ & \text { pDS2102-PC1 } \\ & \text { pDS1102-PC1 } \end{aligned}$ | $\begin{aligned} & \text { From Data I/O } \\ & \text { pDS2102-SN1 } \\ & \text { pDS1102-SN1 } \end{aligned}$ |
|  |  | X |  |  | ViewSim purchased from Actel/TI/Other (PC Only) | ABEL 4.3 or Later <br> Lattice pDS+ ABEL Fitter Viewlogic Interface/Library Upgrade | $\begin{aligned} & \text { From Data I/O } \\ & \text { pDS2102-PC1 } \\ & \text { pDS1103-PC1 } \end{aligned}$ | N/A <br> N/A <br> N/A |
|  |  | x |  |  | ViewSim purchased from Xilinx (PC Only) | ABEL 4.3 or Later <br> Lattice pDS+ ABEL Fitter Viewlogic Interface/Library Upgrade | $\begin{aligned} & \text { From Data I/O } \\ & \text { pDS2102-PC1 } \\ & \text { pDS1104-PC1 } \end{aligned}$ | N/A <br> N/A <br> N/A |
| VIEWLOGIC <br> Workview, PRO Series, Workview +, and Powerview | Capture and Fitting | x |  |  | None | Viewlogic ViewDraw Capture Lattice pDS+ Viewlogic Fitter Viewlogic Interface/Library | $\begin{aligned} & \text { pDS1301-PC1 } \\ & \text { pDS2101-PC1 } \\ & \text { included w/pDS1301 } \end{aligned}$ | From Viewlogic pDS2101-SN1 pDS1102-SN1 |
|  |  | x |  |  | ViewDraw purchased from Viewlogic | Lattice pDS+ Viewlogic Fitter Viewlogic Interface/Library | $\begin{aligned} & \text { pDS2101-PC1 } \\ & \text { pDS1102-PC1 } \end{aligned}$ | pDS2101-SN1 pDS1102-SN1 |
|  |  | X |  |  | ViewDraw purchased from Actel/TI/Other (PC Only) | Lattice pDS+ Viewlogic Fitter Viewlogic Interface/Library | $\begin{aligned} & \text { pDS2101-PC1 } \\ & \text { pDS1103-PC1 } \end{aligned}$ | $\begin{aligned} & \mathrm{N} / \mathrm{A} \\ & \mathrm{~N} / \mathrm{A} \end{aligned}$ |
|  |  | X |  |  | ViewDraw purchased | Lattice pDS + Viewlogic Fitter | pDS2101-PC1 | N/A |

pLSI and ispLSI Design Tool Selector Guide (Cont.)


## pLSI and ispLSI Design Tool Selector Guide (Cont.)



## GAL Development Support

Lattice Semiconductor recommends the use of qualified programming equipment when programming Lattice devices. Lattice works with several programming manufacturers to insure that there is cost effective equipment available. We have approved programmers in each of the following catagories:

- Low Cost GAL Only Programmers
- Mid Range 28-pin Programmers
- Full Universal Programmers
- Production Programming Equipment


## QUALIFED PROGRAMMERS

| Vendor | Programmer |
| :---: | :---: |
| Data 1/O | Autosite |
|  | Unisite |
|  | 3900 |
|  | 2900 |
|  | 29B |
|  | 60A/H |
| Logical Devices | Allpro 88 |
|  | Allpro 40 |
| Stag | System 3000 |
|  | ZL30B \& ZL30A |
|  | Quasar-U84 \& Quasar-U40 |
| System General | TURPRO-1 \& TURPRO-1/FX |
|  | SGUP-85A |
| SMS Microcomputer | Sprint Expert |
|  | Sprint Plus |
| BP-Microsystems | BP-1200 |
|  | PLD-1128 \& CP-1128 |
|  | PLD-1100 |
| Advin | Pilot-U84 \& Pilot-U40 |
|  | Pilot-GL \& Pilot-GCE |

Lattice conducts a very stringent qualification procedure, which includes a complete evaluation of the programming, verification and load algorithms; verification of critical pulse widths and voltage levels, along with a complete yield analysis. The result is the best programming yields in the industry and a guarantee of $100 \%$ programming yields to customers using qualified programming equipment. Below are the third-party programmers which are qualified to program Lattice devices.

For a current listing of Lattice qualified programmers, please call Lattice's Literature Distribution Department (Tel: 503-693-0287; FAX: 503-681-3037).

LOGIC COMPILER SUPPORT

| Vendor | Logic Compiler |
| :---: | :--- |
| Accel Tech. | Tango PLD |
| Cadence | PIC Designer Composer |
|  | PIC Designer Concept |
| Data I/O | ABEL |
| ISDATA | LOG/iC |
| Logical Devices | CUPL |
| Mentor Graphics | PLSynthesis II |
| Minc | PLDesigner-XL |
| OrCAD | OrCAD PLD |
| Omation | Schema-PLD |
| Viewlogic | ViewPLD |

## GAL Development Support

## PROGRAMMER/COMPILER VENDORS

Accel Technologies 6825 Flanders Dr.
San Diego, CA 92121
Tel: (619) 554-1000
FAX: (619) 554-1019

## Advin Systems

1050-L Duane Ave
Sunnyvale, CA 94086
Tel: (408) 243-7000
FAX: (408) 736-2503
BP Microsystems
1000 N Post Oak Road
Houston, TX 77055-7237
Tel: (713) 688-4600
1-800-225-2102
FAX: (713) 688-0902
BBS: (713) 688-9283
Cadence Design Systems
555 River Oaks Parkway
San Jose, CA 95134
Tel: (408) 943-1234
FAX: (408) 943-0513
Data I/O Corp.
10525 Willows Road N.E. P.O. Box 97046

Redmond, WA 98073-9746
Tel: (206) 881-6444
Tel: 1-800-247-5700
FAX: (206) 882-1043
In Europe contact:
Data I/O Corp.
Tel: +31 (0) 20-6622866 In Japan contact:
Data I/O Corp.
Tel: (03) 432-6991

## ISDATA GmbH

Haid-und-Neu-Straße 7
7500 Karlsruhe 1
Germany
Tel: 0721-693092
FAX: 0721-174263
In the U.S. contact

## ISDATA Inc.

Tel: (408) 373-7359
FAX: (408) 373-3622

## Logical Devices

692 South Military Trail
Deerfield Beach, FL 33442
Tel: (305) 428-6868
FAX: (305) 428-1181

## Mentor Graphics

8005 S.W. Boeckman Rd.
Wilsonville, OR 97070
Tel: (503) 685-7000
FAX: (503) 685-1204
Minc Incorporated
6755 Earl Dr.
Colorado Springs, CO 80918
Tel: (719) 590-1155
FAX: (719) 590-7330

## Omation

801 Presidential
Richardson, TX 75081
Tel: (214) 231-5167
FAX: (214) 783-9072
OrCAD Systems Corp.
3175 N.W. Aloclek Dr.
Hillsboro, OR 97124
Tel: (503) 690-9881
FAX: (503) 690-9891
SMS Micro Systems
IM Grund 15
D-7988 Wangen
Germany
Tel: (49) 7522-5018
FAX: (49) 7522-8929
In the U.S. contact:
SMS North America, Inc.
16522 N.E. 135th PI.
Redmond, WA 98052
Tel: (206) 883-8447
FAX: (206) 883-8601
Stag Microsystems
Martinfield
Welwyn Garden City
Herts AL7 1JT
United Kingdom
Tel: 011-44-707-332148
FAX: 011-44-707-371503
In the U.S. contact:
Stag Microsystems
1600 Wyatt Dr.
Santa Clara, CA 95054
Tel: (408) 988-1118
FAX: (408) 988-1232

## System General

3FI., No. 1, Alley 8, Lane 45
Bao Shing Rd.
Shin Dian
Taipei, Taiwan R.O.C.
Tel: 886-2-9173005
FAX: 886-2-9111283
In the U.S. contact:
System General
510 S. Park Victoria Dr.
Milpitas, CA 95035
Tel: (408) 263-6667
FAX: (408) 262-9220
Viewlogic Systems
293 Boston Post Rd. West
Marlboro, MA 01752
Tel: (508) 480-0881
FAX: (508) 480-0882

## Compiler Support

## Introduction

To simplify the development of ispGDS devices, Lattice offers an ispGDS assembler which processes the input ASCII files to generate the JEDEC compatible fusemap files required for the ispGDS devices. Free ispGDS assembler software is available from the Lattice BBS at 503-693-0215 under GDSPKG.ZIP file. This software is also available on diskette by calling the Lattice Hotline at 1-800-327-8425 (FASTGAL) For design engineers who are familiar with standard third party compiler software packages, ABEL from Data I/O and CUPL from Logical Devices also support all ispGDS devices.

## Using the GDS Compiler

The compiler will accept an ASCII text file containing the GDS programming instructions, and will create JEDEC and DOC files. Once a JEDEC file has been created, the ispGDS device can be programmed by either downloading the JEDEC file to a programmer, or by using the ispGDS Download utility to program the device using the parallel port of an IBM compatible PC.

## Compiler Syntax

The basic compiler syntax supports inserting comments, title, device type, pin assignments and input/output assignments. The ispGDS compiler source file comment lines are denoted with quote marks at the beginning of the comment lines. The title is defined with the key word "title $=$ ". Any text following the "title $=$ " key word that are within single quotes are defined to be the title of the design. Similarly, the device type is defined by the key word "device =" followed by the three valid device types -ispgds22, ispgds 18 , ispgds14. The compiler syntax also allow the user to assign pin names by typing in a 10 character pin name followed by at least a single space, the "pin" key word and the pin number. This pin assignment is optional since the compiler syntax allows the user to use the "pin" key word and the pin number directly in the input/output assignments.

The output pins are assigned on the left side of the equation and the input pins are assigned on the right side of the equation. To assign an output pin to either high or low, simply assign " H " or "L" respectively on the right side of the equation. If you need to assign an input pin to multiple output pins, use one line for each assignment, as
shown in the following example. In the example below, pin 28 is an input that is routed to three outputs - pin 1, pin 2 and pin 3 . Further, each output's polarity can be individually defined. The example shows pin 3 as an active low polarity whereas pin 1 and pin 2 are defined to be active high polarity. An example source file is appended at the end of this document.
pin $1=\operatorname{pin} 28$
pin $2=\operatorname{pin} 28$
! $\mathrm{pin} 3=\operatorname{pin} 28$

## Assembling a File

To use the assembler, create an ASCII GDS source file, then invoke the assembler from the DOS command line. For example: gasm <test.gds>
where test.gds is the name of the GDS source file. GDS will create a JEDEC file with the same base name, and a .JED extension, like "test.jed," and a doc file with a .DOC extension, like "test.doc."

## Submitting a New Problem Report

If you find problems with the assembler, please ZIP the following files together, and upload to the Lattice BBS at (503)693-0215:

1. the GDS source file
2. the JEDEC file
3. a description of the error

After the files are uploaded, please call the Lattice Hotline at (800) 327-8425 and inform them that the files have been uploaded.

## Programming the ispGDS

You can either program the GDS using a JEDEC file output from the GDS assembler, or by using the GDS_PROG routines included in the GDSPKG software package. To program the GDS using a programmer, follow these steps:

1. Create an ASCII GDS source file
2. Assemble the GDS file using the GDS assembler (GASM).
3. Download the JEDEC file created by the assembler to the programmer and program the device. The

## ispGDS Compiler Support

JEDEC file will have the same name as your GDS source file, but will have a .JED extension (for example, "test.jed").

Alternatively, you may want to program the ispGDS devices either through the parallel port of an IBM compatible PC, or through some custom hardware configuration. The routines included in the ispGDS compiler software package are configured to use the PC parallel port for programming. If you want to use a custom hardware configuration, read through the comments in GDS_PROG for information on which routines need to be modified. If you are programming using the PC, you will need an ispDOWNLOAD Cable and ISP programming interface signals on the circuit board which will plug into the printer port on your PC.

To program using the parallel port of the PC , follow these steps:

1. Create an ASCII GDS source file
2. Assemble the GDS file using the GDS assembler (GASM)
3. Convert the JEDEC file to ISP stream format by running JEDTOISP. See the documentation on JEDTOISP for further information.
4. Run GDS _PROG to program the device using the parallel port.

## GDS Source Format

The following text is an example of a GDS source file.

```
"This is a comment (line begins with quote mark)
title = 'DIP SWITCH REPLACEMENT CONFIGURATION'
" the ispgds device type (ispgds22, ispgds18, ispgds14)
device = ispgds22
" pin names are defined as follows
pin_name pin 28
" pin 1 is an output connected to pin 28
pin 1 = pin_name
pin 2 = pin 27
" pin 3 is another output connected to pin 28
pin 3 = pin 28
" pin 5 is always high
pin 5 = h
"pin 6 is always low
pin 6 = 1
pin 8 = pin 22
"! defines the inverted output for pin 9
!pin 9 = pin 20
pin 10 = pin 19
pin 12 = pin 17
pin 13 = pin 16
pin 14 = pin 15
```


## Notes

If you get an error regarding "pin 0", you may have duplicated an output pin assignment ( by assigning different input signals to the same output pin). Refer to the line number in the assembler error message to locate the source of the problem.

## Section 1: Introduction

Section 2: High-Density Programmable Logic
Section 3: Low-Density Programmable Logic
Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices
Section 5: Military Program
Section 6: Development Tools
Section 7: Quality and Reliability
Quality Assurance Program ..... 7-1
Qualification Program ..... 7-3
E $^{2}$ CMOS Testability Improves Quality ..... 7-5
ISO 9000 Program ..... 7-7
Section 8: General Information

## Quality Assurance Program

## Introduction

Lattice views quality assurance as a corporate responsibility and an integral part of all operational activities. Lattice's Quality Assurance organization is independent from Manufacturing and has directaccess to top management, assuring sufficient authority is afforded to quality issues.

Lattice's quality program is in full compliance to the quality assurance requirements of MIL-M-38510 Appendix A and all inspection system requirements of MIL-I-45208. Lattice is also fully certified to the ISO 9001 standard.

## Reliability

All new products, processes and vendors must pass predefined evaluations before receiving initial qualification release. Major changes to products, processes orvendors require additional qualificaton before implementation. To assure continuing conformance to reliability goals, an ongoing monitor program is maintained on all products.

## In-Process Control

Qualified product must be manufactured under strict quality controls that start with regulated procurement and documented inspection plans for all incoming materials. Sample testing and in-line monitoring as well as statistical process control charts provide constant feedback at each critical step of the manufacturing process.

## Calibration

All equipment involved in determining product conformance to specifications through inspection, measurement or testing must be of the required accuracy. Equipment is calibrated and maintained on a defined interval against a nationally recognized standard. In addition, equipment must exhibit a suitable indicator showing calibration status as well as safeguards to disallow unauthorized adjustments.

## Training

Key manufacturing personnel must complete a formal training program and obtain certification for each operation before they are allowed to perform activities affecting quality. Methods and records identifying the type and extent of training are maintained and recertification required on a yearly basis.

## Subcontractor Control

All subcontracted manufacturing operations must be performed by sources exhibiting a quality program
commensurate to that of Lattice. These suppliers are audited at least once a year to monitor their compliance to Lattice's quality initiatives and goals. Incoming inspection is performed to provide feedback and continuous improvement of subcontractor performance with the main objective being to control quality at the source. Communications and in-line data are continuously exchanged to allow real-time monitoring of subcontractor manufacturing operations.

## Document Control

Every product and process must have adequate written documentation released and available at the point of use before production begins. All information related to the definition, manufacturing, testing and support of Lattice products or services shall be maintained and controlled. Initial release as well as subsequent changes must be properly reviewed and approved before implemented.

## Nonconforming Material

Material found to be nonconforming to specified requirements is identified, segregated, analyzed and dispositioned per documented procedures. Records are maintained denoting the nature of the discrepancy as well as the final disposition. All dispositions involve the applicable engineering section and Quality Assurance. Where applicable, the root cause of the discrepancy will be identified and a corrective action implemented using the CAR (Corrective Action Request) form.

## Failure analysis

Failure modes discovered during qualification testing, inspections, customer returns or in-process screening are processed through Lattice's Failure Analysis group to determine the cause or relevancy of the failure. Verified failure modes are documented and corrective action initiated as required to eliminate the root cause.

## Corrective action

All operational functions utilize a documented corrective action system coordinated, recorded and monitored by Quality Assurance. The system is designed to provide for proactive problem identification and resolution in a timely manner. Inputs include vendor, internal and customer related problems. Emphasis is placed on effective elimination of the root cause to prevent recurrence of the problem.

Management is responsible for ensuring that employees have sufficiently well defined responsibilities, authority and organizational freedom to identify potential quality related problems as well as initiate and implement solutions.

## Quality Assurance Program

## Self Audit

Internal self audits of the entire quality and delivery system are performed per written procedures and to a predefined schedule. The functional audits evaluate actual method to written procedure. The results of these audits are documented on a checklist and any discrepancies are brought to the attention of personnel responsible for the audited area. Deficiencies require corrective actions must be initiated and subsequently verified as to deployment and effectiveness. A periodic review of these functional audit results and corrective actions is performed by Quality Assurance.

## Procurement

All direct materials and services affecting quality or reliability of end product mustbe purchased from qualified sources. Selection of these critical suppliers is based upon one of more of the following: quality system audits, product qualification testing, correlation studies, incoming inspection and demonstrated ability. A qualified supplier list is maintained by Quality Assurance and used by Purchasing to control procurement. Each purchase order must specify the applicable controlling requirements for all such direct materials or services.

## Qualification Program

## Introduction

Lattice has an intensive qualification program for examining and testing new products, processes, and vendors in order to insure the highest levels of quality. Lattice's Quality and Reliability Group is responsible for defining and implementing this qualification program.

The following table outlines the steps which must be performed before a new product, package or process is released. The requirements listed below are general guidelines. Detailed information on Lattice's qualification process is available to customers upon request.

## Qualification Requirements

| Test | \# of Samples | Duration |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | New Product | New Wafer Process | New Package |
| $125^{\circ} \mathrm{C}$ Operating Lifetest $(5.25 \mathrm{~V})$ | 300 | 1,000 Hours | 2,000 Hours | 2,000 Hours ${ }^{1}$ |
| $150^{\circ} \mathrm{C}$ Biased Retention Bake (5.25V) | 450 | 1,000 Hours | 2,000 Hours | 2,000 Hours ${ }^{1}$ |
| Endurance Cycling | 75 | 10,000 Cycles | 10,000 Cycles | N/A |
| ESD (CDM, HBM, MM) | 216 | End of Test | End of Test | N/A |
| Latch-Up Immunity | 27 | End of Test | End of Test | N/A |
| Temperature Cycling (-65 to $150^{\circ} \mathrm{C}$ ) | 150 | 1,000 Cycles | 1,000 Cycles | 1,000 Cycles |
| Biased 85/85 (5V) | 225 | N/A | 1,000 Hours | 1,000 Hours |
| Autoclave ( $121^{\circ} \mathrm{C}, 15 \mathrm{psig}$ ) | 150 | N/A | 336 Hours | 336 Hours |
| Lead Integrity (DIP only) | 9 | N/A | N/A | End of Test |
| Solderability | 9 | N/A | N/A | End of Test |
| Physical Dimensions | 6 | N/A | N/A | End of Test |

1. Required for new assembly technologies only.

## Qualification Program

## Reliability Monitor Program

The Reliability Monitor Program provides for a periodic reliability monitor of Lattice products. The program assures that all Lattice products comply on a continuing basis with established reliability and quality levels.

The Reliability Monitor Program is designed to monitor all fab and assembly facilities as well as each process technology in production. A summary of the program test and sampling plan is shown below.

## Short Term Process Monitor (Bi-Weekly)

| Test | \# of Samples | Duration |
| :--- | :---: | :---: |
| $125^{\circ}$ C Operating Lifetest (6.50V) | 70 | 160 Hours |
| $150^{\circ}$ C Biased Retention Bake (5.25V) | 70 | 160 Hours |
| Autoclave $\left(121^{\circ} \mathrm{C}, 15\right.$ psig) | 35 | 160 Hours |

## Long Term Process Monitor (Monthly)

| Test | \# of Samples | Duration |
| :--- | :---: | :---: |
| $125^{\circ}$ C Operating Lifetest (6.00V) | 100 | 2000 Hours |
| $150^{\circ}$ C Biased Retention Bake (5.25V) | 150 | 2000 Hours |

Ongoing Package Monitor (Monthly)

| Test | \# of Samples | Duration |
| :--- | :---: | :---: |
| Temperature Cycling (-65 to $\left.150^{\circ} \mathrm{C}\right)$ | 50 | 1000 Cycles |
| $85^{\circ} \mathrm{C} / 85 \% \mathrm{RH}$ | 75 | 2000 Hours |

# $E^{2}$ CMOS Testability Improves Quality 

## Introduction

The inherent testability of Lattice's $\mathrm{E}^{2} \mathrm{CMOS}$ PLDs significantly improves their quality and reliability. By using electrically erasable EEPROM technology to produce GAL, pLSI and ispLSI devices, Lattice is able to perform $100 \%$ AC/DC, functional, and parametric testing of every single device. In order to achieve the highest quality levels, Lattice programs and tests each device repeatedly throughout the manufacturing process.

## Actual Test vs. Simulated Test

Why is "actual test" so significant? PLDs, unlike most other semiconductor devices, have a programmable element that determines the final device functionality and AC/DC performance. These programmable elements can be fabricated from metal link fuses, programmable diodes or transistors, volatile static RAM cells, UV EPROM cells or electrically erasable EEPROM cells. Each of these technologies carries a different variability of programming success and a variance in the impact of the programming success on the performance and reliability of the device.

The most common programmable elements are the metal fuse, EPROM cell and EEPROM cell. Of these element types, only the EEPROM cell can be thoroughly tested by the manufacturer prior to shipment to an end user OEM.

## EEPROM Allows Actual Test

Each of the technologies identified above can be programmed. In this manner they are all the same. The differences become apparent when the erase times are analyzed. Metal link and One-Time Programmable (OTP) devices cannot be erased. UV EPROM devices can be erased, however the time required is 20-30 minutes (in an expensive windowed package). EEPROM devices, on the other hand, offer instant erasability on the order of 50 ms (thousandth's of a second). The advantage of this instant erase for manufacturing test is significant. Instant erase allows instant re-patterning for additional testing.

EEPROM technology has been used for PLD manufacturing by Lattice for more than a decade. Lattice refers to their high performance EEPROM technology as $\mathrm{E}^{2} \mathrm{CMOS}$ technology. Extensive reliability studies of the technology have been performed with industry-wide acceptance, including the military.

## Other Methods Are Imprecise

All PLD devices must be tested to some degree to validate functionality and performance. Technologies that are not erasable or require lengthy erase times severely constrain
the test flexibility. Since the normal "user" programmable elements cannot be programmed during manufacture (all elements must be available for end-user programming) the manufacturers of one-time programmable PLDs resort to using simulated and correlated performance of test rows, test columns and phantom or dummy-test arrays. At best, this is a statistical measure of the actual device performance. One need only look at the "normal" programming yield fallout of 0.5 to $3 \%$ or the "acceptable" post-programming test vector and board yield fallout of 0.5 to $2 \%$ to know that this correlation is weak. The quality systems of today are measuring defects in parts per million (PPM). A six sigma program requires less than 3.4 PPM, four orders of magnitude less than that achievable with non-testable PLDs.

## Actual Matrix Patterning

The unique capability of $\mathrm{E}^{2} \mathrm{CMOS}$ devices to be instantly electrically erased allows these devices to be patterned multiple times during Lattice's manufacturing test. Normal array cells in the programmable matrix are patterned, erased and tested again and again. The test rows or columns, phantom arrays, etc., that are used with other technologies are not necessary with $E^{2} C M O S$ devices. Programmability of every cell is checked dozens of times.

Historically, the checking of a successful programming operation consisted of no more than a pass/fail verification step. This digital, go/no go check is not adequate to assure that the cell is programmed properly with sufficient margin to guarantee long-term reliable performance of the device. Lattice $E^{2}$ CMOS devices are processed through a proprietary cell verification step that consists of an analog measure (to millivolt accuracy) of the actual cell threshold. This capability is used for extensive reliability and quality measurements and testing.

## Worst Case AC/DC Testing

A PLD does not have a defined function until the engineer patterns the device with his custom pattern. The manufacturer, when considering the testing of a PLD, must consider the hundreds of different architecture and functional variations that can be created by the enduser. Each configuration of architecture brings on a different set of worst case pattern and stimulus conditions. Quick application of a series of worst case patterns that cover all of the permutations of input combinations, array load and switching, and output configuration is required.
$E^{2}$ CMOS devices offer instant erasability to address this reconfiguration and test problem. Testing each additional

## $E^{2}$ CMOS Testability Improves Quality

worst case configuration takes fractions of a second, allowing multiple patterns to be checked to assure performance to rated speeds. The final result is a device with defects reduced from PPH (parts per hundred) to PPM (parts per million).

## ISO 9000 Program

## Introduction

Lattice is the first major PLD manufacturer to complete ISO 9000 registration. Lattice Quality Systems have been certified, and the company is registered to the ISO 9000 standard. Lattice certification is for ISO 9001, the most comprehensive of the various ISO 9000 levels, covering the design, manufacturing, sales, and service functions.

## ISO 9000 Certification

Certification to the ISO 9000 standard provides a recognized and standardized basis for the continued development of the quality and reliability of Lattice products. This certification assures Lattice's customers that its Quality Systems are well organized and embody a "Quality First" philosophy. It also reaffirms Lattice's promise to provide its customers with the highest quality and most reliable products in the industry.

## What is ISO 9000?

The ISO 9000 series is an international version of British Standard BS 5750, intended to define the quality management systems for a wide range of an organization's
activities. The standard was initiated by the British Standards Institution, which over the last 80 years has certified over 9,000 Quality Systems. Today, both the CEN (European Committee for Standardization), which is commissioned to coordinate quality standards in Europe and remove potential trade restrictions within and outside the European Community, and the USA Standard ANSI/ASQC have adopted the ISO 9000 series.

Four quality standards make up the ISO 9000 series: ISO 9004, ISO 9003, ISO 9002, and ISO 9001. ISO 9004 is an informational document containing guidelines for Quality Management and Quality Systems. ISO 9003 guarantees quality in a product's final testing and inspection. ISO 9002 confirms quality in the production and installation of a product. ISO 9001 assures quality in a product's design, development, production, and installation. ISO 9001 is composed of 20 system sections, including the ISO 9002 and ISO 9003 subsets. Lattice is certified to the most comprehensive quality standard of the series, ISO 9001, and registered with the American Society for Quality Control's Registration Accreditation Board.


Lattice Semiconductor: First PLD Supplier to Achieve ISO 9000 Certification

Notes
Section 1: Introduction
Section 2: High-Density Programmable Logic
Section 3: Low-Density Programmable Logic
Section 4: In-System Programmable Generic Digital Switch (ispGDS) Devices
Section 5: Military Program
Section 6: Development Tools
Section 7: Quality and Reliability
Section 8: General Information
Copying PAL, EPLD \& PEEL Patterns into GAL Devices ..... 8-1
GAL Product Line Cross Reference ..... 8-3
Package Thermal Resistance ..... 8-5
Tape and Reel Specifications ..... 8-6
Package Diagrams ..... 8-7
Sales Offices ..... 8-21

# Copying PAL, EPLD \& PEEL Patterns Into GAL Devices 

## INTRODUCTION

The generic/universal architectures of Lattice GAL devices are able to emulate a wide variety of PAL, EPLD and PEEL devices. GAL devices are direct functional and parametric replacements for most PLD device architectures. To use GAL devices in place of other PLD types, some conversion of the original device pattern may be needed. This conversion is not difficult, and can be accomplished at either the design or manufacturing level. The following sections describe several techniques available to convert PAL, EPLD and PEEL device patterns to Lattice GAL device patterns.

CROSS PROGRAMMING: GAL16V8 AND GAL20V8
The GAL16V8 and GAL20V8 devices replace most standard $20-\mathrm{pin}$ and 24 -pin PAL devices. To simplify the conversion process, Lattice has worked with programmer hardware manufacturers to provide the ability to program GAL devices directly from existing PAL JEDEC files, or master PAL devices. Lattice qualified programmers can automatically configure the architecture of a GAL device to emulate the source PAL device.

To provide a conceptual framework for the conversion from PAL devices to GAL devices, a mythical device known as a RAL device was created. A RAL device is simply a GAL device configured to emulate a PAL. There is a one-to-one correspondence between the name of a PAL device and that of a RAL device. For example, a RAL16L8 is simply a GAL16V8 configured as a PAL16L8. Some programmers list the RAL device types as choices for cross-programming, while others specifically state that a cross-programming operation is to be performed using a PAL device type as the architecture type. Other programmers list devices such as a Lattice 16L8. Even though Lattice does not make a 16L8 device, choosing this selection allows the programmer to accept a 16L8 JEDEC file, and will program a GAL16V8 device to emulate a PAL16L8.

To program a GAL16V8 or GAL20V8 device from an existing PAL JEDEC file, simply select the appropriate device code (either RAL type, or PAL type to crossprogram from), then download the PAL JEDEC file to the programmer. Insert the appropriate GAL device that can directly emulate the PAL device (according to the chart in the GAL16V8 orGAL20V8data sheets). The programmer will automatically configure the GAL device to emulate the PAL device during programming. The resulting GAL device is $100 \%$ compatible with the original PAL device.

A GAL device may also be programmed from a master PAL device by reading the pattern of the master PAL into the programmer memory, then selecting the appropriate RAL device or PAL type to cross-program from. The GAL device can then be programmed from the programmer memory.

## CROSS PROGRAMMING: GAL22V10/GAL20RA10

The GAL22V10 and GAL20RA10 are direct replacements for bipolar PAL devices, and are JEDEC fuse map compatible with these industry standard devices. To program a GAL22V10 or GAL20RA10 device from an existing PAL JEDEC file, simply select the appropriate GAL device code, then download the PAL JEDEC file to the programmer. The resulting GAL device is $100 \%$ compatible with the original PAL.

GAL devices also may be programmed from Master PAL devices by reading the pattern of the Master PAL into the programmermemory, then selecting the appropriate GAL device code. The GAL device can then be programmed from the programmer memory.

The GAL22V10 and GAL20RA10 also can store a User Electronic Signature (seethe data sheets onthese devices for more information). To use this feature, the JEDEC file must contain this information. To add the signature data to the JEDEC map, use the PALtoGAL conversion utility (see next section) or recompile the source equations for a Lattice GAL device instead of a generic 22 V 10 type. Many programmers list two device types to differentiate between the two types of JEDEC files, and list both a GAL22V10 and a name such as GAL22V10-UES or GAL22V10-ES. Other programmers allow both types of JEDEC file s to be accepted, and simply don't program the Signature fuses if they are not present in the file.

## CROSS PROGRAMMING: GAL20XV10

The GAL20XV10 canbe configuredas a directreplacement for bipolar PAL20X10, 20X8, 20X4, and 20L10 devices. Many programmers provide cross-programming support similartothat providedforthe GAL16V8/GAL20V8devices. This allows the use of existing PAL device filesto program the GAL20XV10 to emulate the PAL devices. The PALtoGAL conversion software (described below) also supports conversion of the PAL JEDEC files to a functionally equivalent GAL device file.

## PALTOGAL CONVERSION UTILITY SOFTWARE

Lattice has created a software utility that will convert an existing PAL device JEDEC file to the appropriate GAL

## Copying PAL Patterns Into GAL Devices

device JEDEC format. Called PALtoGAL, this software utility can be used to convert PAL device files to GAL device files, add/or change the User Electronic Signature without changing device functionality, and reformat existing GAL JEDEC files for readability.

Since a few programmable logic devices have features that a GAL device cannot exactly emulate, the PALtoGAL utility will clearly describe the incompatibility but will not create an output file. GAL devices programmed using files converted by PALtoGAL will be 100\% compatible with the original logic device. PALtoGAL is just another method of cross-programming, and should produce the same results as using a programmer. The advantage is that a full GAL device JEDEC map is created, meaning that the appropriate GAL device may then be selected on the programmer, which may simplify the manufacturing flow. Also, the PALtoGAL conversion software provides conversions that programmers do not.

A copy of the PALtoGAL conversion utility software can be obtained through your local Lattice representative, or by
contacting the GAL Applications Hotline at 1-800FASTGAL (327-8425) or (503) 693-0201. The software also may be downloaded from Lattice's Electronic Bulletin Board at (503) 693-0215; the file name is "PALTOGAL.EXE".

## SOFTWARE COMPILER CONVERSION

If the equation source file is available for the PAL device, it can be converted by re-compiling using a suitable logic compiler that supports GAL devices. If there are any device incompatibilities (there shouldn't be in most cases), the compiler will describe the errors. The output of the compiler will be a GAL JEDEC file that can be used to program a GAL device directly. The resulting GAL device will be $100 \%$ functionally compatible with the original device.

Suitable logic compilers are listed in the Development Tools section. If additional questions arise, contact your compiler manufacturer or a Lattice Applications Engineer by calling the GAL Applications Hotline at 1-800-FASTGAL or (503) 693-0201.

## GAL Product Line Cross Reference

| MANUFACTURER | PART \# | LATTICE PART \# | MANUFACTURER | PART \# | LATTICE PART \# |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ALTERA | $\begin{aligned} & \text { EP310 } \\ & \text { EP320 } \\ & \text { EP330 } \end{aligned}$ | GAL16V8Z ${ }^{1}$ GAL16V8 ${ }^{1}$ or... GAL18V10 | AMD | AmPAL20RP10 | GAL22V10 |
|  |  |  |  | PAL20S10 | GAL6002 ${ }^{1}$ |
| AMD | PAL10H8 <br> PAL10L8 <br> PAL12H6 <br> PAL12L6 <br> PAL14H4 <br> PAL14L4 <br> PAL16H2 <br> PAL16L2 | GAL16V8 |  | PAL20RS8 PAL20RS10 |  |
|  |  |  |  | PAL12L10 <br> AmPAL20L10 <br> PAL20L10 <br> PAL20X4 ${ }^{2}$ <br> PAL20X8 ${ }^{2}$ <br> PAL20X10 ${ }^{2}$ | GAL20XV10 |
|  | PAL16L8 <br> PAL16R4 <br> PAL16R6 <br> PAL16R8 <br> PALC16L8 <br> PALC16R4 <br> PALC16R6 <br> PALC16R8 <br> AmPAL16L8 <br> AmPAL16R4 <br> AmPAL16R6 <br> AmPAL16R8 <br> PAL16P8 <br> PAL16RP4 <br> PAL16RP6 <br> PAL16RP8 | GAL16V8 |  | AmPAL22V10 <br> PAL22V10 <br> PALC22V10 <br> PALCE22V10 | GAL22V10 |
|  |  |  |  | PALCE24V10 PALCE26V12 | GAL26CV12 ${ }^{1}$ |
|  |  |  |  | PLS167 <br> PLS168 | GAL6002 ${ }^{1}$ |
|  |  |  | ATMEL | AT22V10 | GAL22V10 |
|  |  |  | CYPRESS | PALC16L8 PALC16R4 | GAL16V8 |
|  | PALCE16V8 | GAL16V8 |  | PALC16R8 |  |
|  | PALCE16V8Z | GAL16V8Z |  | PLDC18G8 | GAL16V8 ${ }^{1}$ or... GAL18V10 |
|  | AmPAL18P8 <br> PALC18U8 | GAL16V8 or... GAL18V10 |  | PALC20CG10 PALC22V10 | GAL16V8 ${ }^{1}$ or... GAL22V10 |
|  | PAL14L8 <br> PAL16L6 <br> PAL18L4 <br> PAL20L2 | GAL20V8 |  | PAL22V10 |  |
|  |  |  |  | PLD20RA10 | GAL20RA10 |
|  | PAL20L8 <br> PAL20R4 <br> PAL20R6 <br> PAL20R8 <br> AmPAL20RP4 <br> AmPAL20RP6 <br> AmPAL20RP8 | GAL20V8 | HARRIS | HPL16LC8 <br> HPL16RC4 <br> HPL16RC6 <br> HPL16RC8 | GAL16V8 |
|  |  |  | ICT | PEEL18CV8 | GAL16V8 ${ }^{1}$ or... GAL18V10 |
|  | PALCE20V8 | GAL20V8 |  | PEEL153 <br> PEEL253 | GAL16V8 ${ }^{1}$ or... GAL18V10 ${ }^{1}$ |
|  | PAL20RA10 | GAL20RA10 |  | PEEL20CG10 <br> PEEL22CV10A | GAL20V8 ${ }^{1}$ or... GAL22V10 |
| 1) Conversion possible but not $100 \%$ compatible with this device. |  |  |  |  |  |

GAL Product Line Cross Reference

| MANUFACTURER | PART \# | LATTICE PART \# | MANUFACTURER | PART \# | LATTICE PART \# |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INTEL | $\begin{aligned} & 5 \mathrm{C} 031 \\ & 5 \mathrm{C} 032 \\ & 85 \mathrm{C} 220 \end{aligned}$ | GAL16V8 ${ }^{1}$ or... GAL16V8Z or... GAL18V10 | SGS-THOMSON | GAL16V8 | GAL16V8 |
|  |  |  |  | GAL20V8 | GAL20V8 |
|  | 85C224 | $\begin{aligned} & \text { GAL20V81 } \\ & \text { or... GAL22V10 } \end{aligned}$ |  | GAL39V18 | $\begin{array}{r} \text { GAL6001 } \\ \text { or... GAL6002 } \end{array}$ |
|  | 85C22V10 | GAL22V10 | SIGNETICS | PLHS16L8 <br> PLUS16L8 <br> PLUS16R4 <br> PLUS16R6 <br> PLUS16R8 | GAL16V8 |
| NATIONAL | PAL10H8 | GAL16V8 |  |  |  |
|  | PAL10L8 <br> PAL12H6 <br> PAL12L6 <br> PAL14H4 <br> PAL14L4 <br> PAL16H2 <br> PAL16L2 | GAL16V8 |  |  |  |
|  |  |  |  | PLHS18P8 | $\begin{array}{r} \text { GAL16V81 } \\ \text { or... GAL18V10 } \end{array}$ |
|  |  |  |  | $\begin{aligned} & \text { PLS153 } \\ & \text { PHD16N8 } \end{aligned}$ | $\begin{gathered} \text { GAL16V81 }^{1} \\ \text { or... GAL18V101 } \end{gathered}$ |
|  | PAL16L8 <br> PAL16R4 <br> PAL16R6 <br> PAL16R8 | GAL16V8 |  | PLUS20L8 <br> PLUS20R4 <br> PLUS20R6 <br> PLUS20R8 | GAL20V8 |
|  | GAL16V8 GAL16V8A | GAL16V8 |  | PLUS168 PLUS173 | GAL6002 ${ }^{1}$ |
|  | GAL18V10 | GAL18V10 | TI | TIBPAL16L8 <br> TIBPAL16R4 <br> TIBPAL16R6 <br> TIBPAL16R8 | GAL16V8 |
|  | PAL14L8 <br> PAL16L6 <br> PAL18L4 | GAL20V8 |  |  |  |
|  | PAL20L2 |  |  | TICPAL16L8 TICPAL16R4 | GAL16V8 |
|  | PAL20L8 <br> PAL20P8 <br> PAL20R4 | GAL20V8 |  | TICPAL16R6 TICPAL16R8 |  |
|  | PAL20RP4 PAL20R6 PAL20RP6 |  |  | $\begin{aligned} & \text { EP330 } \\ & \text { TIBPAD16N8 } \end{aligned}$ | GAL16V81 or... GAL18V10 |
|  | PAL20R8 <br> PAL20RP8 <br> PAL20RA10 |  |  | $\begin{aligned} & \text { TIBPAL20L8 } \\ & \text { TIBPAL20R4 } \\ & \text { TIBPAL20R6 } \\ & \text { TIBPAL20R8 } \end{aligned}$ | GAL20V8 |
|  | PAL20L10 <br> PAL20X4 <br> PAL20X8 <br> PAL20X10 | GAL20XV10 |  | $\begin{aligned} & \text { TIBPAL20L10 } \\ & \text { TIBPAL20X4 } \\ & \text { TIBPAL20X8 } \\ & \text { TIBPAL20X10 } \end{aligned}$ | GAL20XV10 |
|  | GAL22V10 | GAL22V10 |  | TIBPAL22V10 <br> TICPAL22V10 | GAL22V10 |
|  | GAL26CV12 | GAL26CV12 |  |  |  |
|  | GAL6001 | $\begin{array}{r} \text { GAL6001 } \\ \text { or... GAL6002 } \end{array}$ |  | TIBPLS506C <br> TIBPLS507C <br> TIB82S105 <br> TIB82S167 | GAL6002 ${ }^{1}$ |

1) Conversion possible but not $100 \%$ compatible with this device.

## Package Thermal Resistance

The following table provides information on the package thermal resistance of Lattice commercial and industrial grade devices. For information on the package thermal resistance of Lattice military grade devices, please refer to "MIL-M-38510, Appendix C."

Testing was performed per SEMI TEST METHOD G3887: "Still and Forced-Air Junction-to-Ambient Thermal Resistance Measurements of IC Packages" with devices
mounted on a thermal test board conforming to SEMI SPECIFICATION G42-88: "Thermal Test Board Standardization for Measuring Junction-to-Ambient Thermal Resistance of Semiconductor Packages."

## Test Conditions

Power Dissipation $=0.5$ watts (IC reverse biased)
Ambient Air Velocity = Zero (still air)
Ambient Temperature $=65^{\circ} \mathrm{C}$
Measuring Current $=3 \mathrm{~mA}$

## PACKAGE THERMAL RESISTANCE

| Package | Pin Count | $\theta_{\text {JA }}$ | $\theta_{\text {jc }}$ |
| :--- | :---: | :---: | :---: |
| Plastic DIP | 20 -pin | $67^{\circ} \mathrm{C} / \mathrm{W}$ | $30^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 24 -pin | $65^{\circ} \mathrm{C} / \mathrm{W}$ | $25^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 28 -pin | $52^{\circ} \mathrm{C} / \mathrm{W}$ | $23^{\circ} \mathrm{C} / \mathrm{W}$ |
| PLCC | 20 -pin | $67^{\circ} \mathrm{C} / \mathrm{W}$ | $25^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 28 -pin | $56^{\circ} \mathrm{C} / \mathrm{W}$ | $23^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 44 -pin | $50^{\circ} \mathrm{C} / \mathrm{W}$ | $16^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 68 -pin | $45^{\circ} \mathrm{C} / \mathrm{W}$ | $13^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 84 -pin | $42^{\circ} \mathrm{C} / \mathrm{W}$ | $12^{\circ} \mathrm{C} / \mathrm{W}$ |
| SOIC | 20 -pin | $85^{\circ} \mathrm{C} / \mathrm{W}$ | $18^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic DIP | 20 -pin | $62^{\circ} \mathrm{C} / \mathrm{W}$ | $10^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 24 -pin | $60^{\circ} \mathrm{C} / \mathrm{W}$ | $10^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 28 -pin | $58^{\circ} \mathrm{C} / \mathrm{W}$ | $10^{\circ} \mathrm{C} / \mathrm{W}$ |
| LCC | 20 -pin | $65^{\circ} \mathrm{C} / \mathrm{W}$ | $8^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 28 -pin | $62^{\circ} \mathrm{C} / \mathrm{W}$ | $7^{\circ} \mathrm{C} / \mathrm{W}$ |
| JLCC | 44 -Pin | $69^{\circ} \mathrm{C} / \mathrm{W}$ | $4^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 68 -pin | $52^{\circ} \mathrm{C} / \mathrm{W}$ | $3^{\circ} \mathrm{C} / \mathrm{W}$ |
| PQFP | 120 -pin | $50^{\circ} \mathrm{C} / \mathrm{W}$ | $15^{\circ} \mathrm{C} / \mathrm{W}$ |
| TQFP | 44 -pin | $65^{\circ} \mathrm{C} / \mathrm{W}$ | $19^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | 100 -pin | $55^{\circ} \mathrm{C} / \mathrm{W}$ | $20^{\circ} \mathrm{C} / \mathrm{W}$ |
| MQFP | 160 -pin | $20^{\circ} \mathrm{C} / \mathrm{W}$ | $2^{\circ} \mathrm{C} / \mathrm{W}$ |
| CPGA | 84 -pin | $38^{\circ} \mathrm{C} / \mathrm{W}$ | $3^{\circ} \mathrm{C} / \mathrm{W}$ |
|  | $167-$-PIN | $25^{\circ} \mathrm{C} / \mathrm{W}$ | $2^{\circ} \mathrm{C} / \mathrm{W}$ |

## Tape and Reel Specifications

A tape-and-reel packing container is available for plastic leaded chip carriers to protect the product from mechanical/ electrical damage and to provide an efficient method for handling. Lattice's tape-and-reel containers are shipped in full compliance to Electronics Industry Association Standard EIA-RS481.

The tape-and-reel packing system consists of a pocketed carrier tape loaded with one device per pocket. A protective cover tape seals the carrier tape and holds the devices in
the pockets. A full reel holds a maximum quantity of devices depending on the package size. Lattice requires ordering in full reel quantities. Once loaded, the tape is wound onto a plastic reel for labeling and packing.

Devices packaged in tape-and-reel containers must be factory programmed (pre-patterned). Custom marking of devices prior to mounting on tape-and-reel is available upon request. Contact your local Lattice sales office for more details on Lattice's tape-and reel packing system.

TAPE-AND-REEL QUANTITIES AND DIMENSIONS

| Package | Pin Count | Carrier Tape Dimensions |  | Quantity Per <br> 13 Inch Reel |
| :--- | :---: | :---: | :---: | :---: |
|  |  | Width |  |  |
| PLCC | 20 -pin | 16 mm | 12 mm | 1000 |
|  | 28 -pin | 24 mm | 16 mm | 750 |
|  | 44 -pin | 32 mm | 24 mm | 500 |
|  | 68 -pin | 44 mm | 32 mm | 250 |
|  | 84 -pin | 44 mm | 36 mm | 250 |

## Package Diagrams

Index of Package Diagrams
20-Pin SOIC ..... 8-7
20-Pin PLCC ..... 8-8
20-Pin Plastic DIP ..... 8-8
20-PIn LCC ..... 8-9
20-Pin CERDIP ..... 8-10
24-Pin Plastic DIP ..... 8-10
24-Pin CERDIP ..... 8-11
28-Pin PLCC ..... 8-11
28-Pin Plastic DIP ..... 8-12
28-Pin LCC ..... 8-13
28-Pin CERDIP ..... 8-14
44-Pin PLCC ..... 8-14
44-Pin TQFP ..... 8-15
44-Pin JLCC ..... 8-15
68-Pin PLCC ..... 8-16
68-Pin JLCC ..... 8-16
84-Pin PLCC ..... 8-17
84-Pin CPGA ..... 8-17
100-Pin TQFP ..... 8-18
120-Pin PQFP ..... 8-18
128-Pin PQFP ..... 8-19
160-Pin MQUAD ..... 8-19
167-Pin CPGA ..... 8-20
20-Pin SOIC Package
Dimensions in Inches MIN. / MAX.

. 050 BSC


## Package Diagrams

## 20-Pin PLCC Package

Dimensions in Inches MIN. / MAX.


## 20-Pin Plastic DIP

Dimensions in Inches MIN. / MAX.


## Package Diagrams

## 20-Pin LCC

## Dimensions in Inches MIN. / MAX.


$.045 / .055$


## 20-Pin (300-Mil) CERDIP

Dimensions in Inches MIN. / MAX.


24-Pin Plastic DIP
Dimensions in Inches MIN. / MAX.


# Package Diagrams 

## 24-Pin (300-Mil) CERDIP

Dimensions in Inches MIN. / MAX.


## 28-Pin PLCC Package

Dimensions in Inches MIN. / MAX.


## Package Diagrams

## 28-Pin Plastic DIP

Dimensions in Inches MIN. / MAX.


## 28-Pin LCC

Dimensions in Inches MIN. / MAX.


## Package Diagrams

## 28-Pin (300 MIL) CERDIP <br> Dimensions in Inches MIN. / MAX.



44-Pin PLCC Package
Dimensions in Inches MIN. / MAX.


# Package Diagrams 

## 44-Pin TQFP Package

Dimensions in Millimeters MIN. / MAX.


68-Pin PLCC Package
Dimensions in Inches MIN. / MAX.


68-Pin JLCC Package
Dimensions in Inches MIN. / MAX.


## 84-Pin PLCC Package

Dimensions in Inches MIN. / MAX.


## 84-Pin CPGA Package

Dimensions in Inches MIN. / MAX.


## Package Diagrams

## 100-Pin TQFP Package

Dimensions in Millimeters MIN. / MAX.


120-Pin PQFP Package
Dimensions in Millimeters MIN. / MAX.


## Package Diagrams

## 128-Pin PQFP Package

Dimensions in Millimeters MIN. / MAX.


160-Pin MQUAD Package
Dimensions in Millimeters MIN. / MAX.


## Package Diagrams

## 167-Pin CPGA Package <br> Dimensions in Inches MIN. / MAX.



## Sales Offices

## FRANCE

Lattice Semiconductor
Les Algorithmes Bâtiment Homère 91190 - Saint Aubin
TEL: (33) 141148300
FAX: (33) 142539731

## GERMANY

Lattice Semiconductor
Hanns-Braun-Str. 50 85375 Neufahrn bei München
TEL: (49) 8165-9516-0
FAX: (49) 8165-9516-33

## HONG KONG

Lattice Semiconductor 2802 Admiralty Centre, Tower 1 18 Harcourt Road
Hong Kong
TEL: (852) 529-0356
FAX: (852) 866-2315
JAPAN
Lattice Semiconductor
N Bld 9 F
2-28-3, Higashi-Nihonbashi
Chuo-ku, Tokyo 103
TEL: (81) 3-5820-3533
FAX: (81) 3-5820-3531

UNITED KINGDOM
Lattice Semiconductor
Castle Hill House
Castle Hill
Windsor
Berkshire SL4 1PD
TEL: (44) 753-830-842
FAX: (44) 753-833-457

## NORTH AMERICA

## CALIFORNIA

Lattice Semiconductor
1820 McCarthy Blvd.
Milpitas, CA 95035
TEL: (408) 428-6400
FAX: (408) 944-8450
Lattice Semiconductor
15707 Rockfield Plaza, Ste. 110
Invine, CA 92718
TEL: (714) 580-3880
FAX: (714) 580-3888

## FLORIDA

Lattice Semiconductor
12424 Research Pkwy.
Suite 101
Orlando, FL 32826
TEL: (407) 281-6500
FAX: (407) 658-0208

## GEORGIA

Lattice Semiconductor
3091 Govemors Lake Drive
Building 100, Suite 500
Norcross, GA 30071
TEL: (404) 446-2930
FAX: (404) 416-7404

## LLLINOIS

Lattice Semiconductor
1 Pierce Place
Suite $500-\mathrm{E}$
Itasca, IL 60143
TEL: (708) 250-3118
FAX: (708) 250-3119

## MASSACHUSETTS

Lattice Semiconductor
67 S. Bedford St.
Suite 400 West
Burlington, MA 01803
TEL: (617) 229-5819
FAX: (617) 272-3213

## MINNESOTA

Lattice Semiconductor
3445 Washington Dr.
Suite 105
Eagan, MN 55122
TEL: (612) 686-8747
FAX: (612) 686-8746

NEW JERSEY
Lattice Semiconductor
115 Route 46
Suite F-1000
Mountain Lakes, NJ 07046
TEL: (201) 316-6024
FAX: (201) 316-6619

## NEW YORK

Lattice Semiconductor
Linden Oaks Park
70 Linden Oaks
3rd Floor
Rochester, NY 14625
TEL: (716) 383-5320
FAX: (716) 383-5321

## OREGON

Lattice Semiconductor
5555 N.E. Moore Ct.
Hillsboro, OR 97124
TEL: (503) 691-2657
FAX: (503) 692-1443

## TEXAS

Lattice Semiconductor
100 Decker Ct. Ste. 280
Inving, TX 75062
TEL: (214) 650-1236
FAX: (214) 650-1237
Lattice Semiconductor
9600 Great Hills Trail \#150W
Austin, TX 78759
TEL: (512) 502-3057
FAX: (512) 343-7309

## NORTH AMERICAN SALES REPRESENTATIVES

## ALABAMA

CSR Electronics, Inc. 303 Williams Avenue Ste. 931
Huntsville, AL 35801
TEL: (205) 533-2444
FAX: (205) 536-4031

## ARIZONA

Summit Sales
7802 E. Gray Rd. \#600
Scottsdale, AZ 85260
TEL: (602) 998-4850
FAX: (602) 998-5274

## CALIFORNIA

Bager Electronics
17220 Newhope St. \#209
Fountain Valley, CA 92708
TEL: (714) 957-3367
FAX: (714) 546-2654

Bager Electronics
6324 Variel Ave. \#314
Woodland Hills, CA 91367
TEL: (818) 712-0011
FAX: (818) 712-0160
Criterion Sales
3350 Scott Blvd, Bldg. 44
Santa Clara, CA 95054
TEL: (408) 988-6300
FAX: (408) 986-9039
Earle Associates
7585 Ronson Rd. \#200
San Diego, CA 92111
TEL: (619) 278-5441
FAX: (619) 278-5443

## COLORADO

Waugaman Associates
4800 Van Gordon
Wheat Ridge, CO 80033
TEL: (303) 423-1020
FAX: (303) 467-3095

## CONNECTICUT

Comp Rep Associates 60 Connolly Pkwy.
Bldg. 12 Suite 210
Hamden, CT 06514
TEL: (203) 230-8369
FAX: (203) 230-8394
FLORIDA
Sales Engineering Concepts
4701 N. Federal Highway
Suite 430, Box B-11
Lighthouse Point, FL 33064
TEL: (305) 783-6900
FAX: (305) 782-7274
Sales Engineering Concepts 600 S. Northlake Blvd. \#230
Altamonte Spgs, FL 32701
TEL: (407) 830-8444
FAX: (407) 830-8684

## GEORGIA

CSR Electronics, Inc.
1651 Mt. Vemon Rd. \# 200
Atlanta, GA 30338
TEL: (404) 396-3720
FAX: (404) 394-8387

## ILLINOIS

Sumer, Inc.
1675 Hicks Rd
Rolling Meadows, IL 60008
TEL: (708) 991-8500
FAX: (708) 991-0474

## INDIANA

Electronic Sales and
Engineering
7739 E. 88th St.
PO Box 5009
Indianapolis, IN 46250
TEL: (317) 849-4260
FAX: (317) 841-0231

## IOWA <br> Stan Clothier Company <br> 1930 St. Andrews NE <br> Cedar Rapids, IA 52402 <br> TEL: (319) 393-1576 <br> FAX: (319) 393-7317

## KANSAS

Stan Clothier Company
13000 West 87th St. \#105
Lenexa, Kansas 66215
TEL: (913) 492-2124
FAX: (913) 492-1855

## MARYLAND

Deltatronics
24048 Sugar Cane Ln.
Gaithersburg, MD 20882
TEL: (301) 253-0615
FAX: (301) 253-9108

## MASSACHUSETTS

Comp Rep Associates
100 Everett Street
Westwood, MA 02090
TEL: (617) 329-3454
FAX: (617) 329-6395

## MICHIGAN

Greiner \& Associates
15324 E. Jefferson Ave.
Grosse Pointe Park, Ml 48230
TEL: (313) 499-0188
FAX: (313) 499-0665

## MINNESOTA

Stan Clothier Company 9600 W. 76th St., Ste. \#A
Eden Prairie, MN 55344
TEL: (612) 944-3456
FAX: (612) 944-6904

## MISSOUR

Stan Clothier Company 3910 Old Highway 94 South

## Suite 116

St. Charles, MO 63304
TEL: (314) 928-8078
FAX: (314) 447-5214
NEW JERSEY
Technical Marketing Group
175-3C Fairfield Ave.
West Caldwell, NJ 07006
TEL: (201) 226-3300
FAX: (201) 226-9518

## NEW YORK

Technical Marketing Group 150 Broad Hollow Rd.

## Suite 310

Melville, NY 11747
TEL: (516) 351-8833
FAX: (516) 351-8667
Tri-Tech Electronics 300 Main St.
E. Rochester, NY 14445

TEL: (716) 385-6500
FAX: (716) 385-7655

Tri-Tech Electronics
14 Westview Dr.
Fishkill, NY 12524
TEL: (914) 897-5611
FAX: (914) 897-5611
Tri-Tech Electronics
6836 E. Genesee St.
Fayetteville, NY 13066
TEL: (315) 446-2881
FAX: (315) 446-3047

## NORTH CAROLINA

CSR Electronics, Inc.
5848 Faringdon Place, Ste. 2
Raleigh, NC 27609
$\begin{array}{ll}\text { TEL: } & \text { (919) } 878-9200 \\ \text { FAX: } & (919) 878-9117\end{array}$
FAX: (919) 878-9117
CSR Electronics, Inc. 6425 Creft Cr.
Indian Trail, NC 28079
TEL: (704) 882-3995
FAX: (704) 882-3999
OHIO
Makin \& Associates
3165 Linwood Rd.
Cincinnati, OH 45208
TEL: (513) 871-2424
FAX: (513) 871-2524
Makin \& Associates
6631 Commerce Pkwy. Ste. K
Dublin, OH 43017
TEL: (614) 793-9545
FAX: (614) 793-0256
Makin \& Associates
6519 Wilson Mills Rd.
Mayfield Village, OH 44143
TEL: (216) 461-3500
FAX: (216) 461-1335
OKLAHOMA
West Associates
5555 E. 71st St. \#8150
Tulsa, OK 74136
TEL: (918) 492-4300
FAX: (918) 492-4370

## OREGON

Components West, Inc.
16300 SW Hart Rd.
Suite G
Beaverton, OR 97007
TEL: (503) 642-9110
FAX: (503) 642-9592
PENNSYLVANIA
Deltatronics
790 Penllyn Pike
Suite 201
Blue Bell, PA 19422
TEL: (215) 641-9930
FAX: (215) 641-9934

IENNESSEE
CSR Electronics, Inc.
Grand Union Bldg.
406 Union Ave.
Suite 550
Knoxville, TN 37902
TEL: (615) 637-0293
FAX: (615) 637-0466

## IEXAS

West Associates
363 N. Sam Houston Pkwy E Suite 615
Houston, TX 77060
TEL: (713) 999-0101
FAX: (713) 820-2001
West Associates
9171 Capital of Texas Hwy. N.
Houston Bldg. \#120
Austin, TX 77060
TEL: (512) 343-1 199
FAX: (512) 343-1922
West Associates
801 E. Campbell Rd. \#350
Richardson, TX 75081
TEL: (214) 680-2800
FAX: (214) 699-0330
UTAH
Waugaman Associates
876 East Vine St.
Murray, UT 84107
TEL: (801) 261-0802
FAX: (801) 261-0830

## WASHINGTON

Components West, Inc. 4020 148th Ave. NE Suite C
Redmond, WA 98052
TEL: (206) 885-5880
FAX: (206) 882-0642

## WISCONSIN

Sumer, Inc.
13555 Bishops Court
Brookfield, WI 53005
TEL: (414) 784-6641
FAX: (414) 784-1436

## PUERTO RICQ

Sales Engineering Concepts
Condo. Buena Vista C-1
Urb. Mercedita
Ponce, P.R. 00731
TEL: (809) 841-4220
FAX: (809) 259-7223

ALBERTA
Dynasty Components
Calgary, Alberta
TEL: (403) 560-1212
FAX: (403) 686-2364

## BRITISH COLUMBIA

Dynasty Components
Vancouver, British Columbia
TEL: (604) 657-4433
FAX: (604) 298-8318

## ONTARIO

Dynasty Components
1140 Morrison Dr.
Unit 110
Ottawa, Ontario
Canada, K2H 8S9
TEL: (613) 596-9800
FAX: (613) 596-9886
Dynasty Components
Toronto, Ontario
TEL: (416) 672-5977
FAX: (416) 489-3527

## QUEBEC

Dynasty Components
Montreal, Quebec
TEL: (514) 843-1879
FAX: (514) 694-6826

AUSTRALIA
ZATEK Components, Ltd.
1059 Victoria Road
P. O Box 397, Suite 8

West Ryde, NSW 2114
Sydney, 3153
TEL: (61) 2 874-0122
FAX: (61) 2 874-6171

## AUSTRIA

Avnet / E2000
Waidhausenstr. 19
A-1140 Wien
TEL: (43) 1-9112847
FAX: (43) 1-9113853
Steiner Electronic GmbH.
Egererstrasse 18
A-3013 Tullnerbach
TEL: (43) 223355 366-0
FAX: (43) 223355360
BELGIUM
Alcom Electronics nv/sa
Singel 3
2550 Kontich
TEL: (32) 3 458-3033
FAX: (32) 34583126

## CTECH REPUBLC

HT-EUREP Electronic s.r.o.
Comp. Ap spoi s.r.o.
Rosenberggovych 10
180 00, Praha 8
TEL: (42) 2-6833858
FAX: (42) 2-683385

## DENMARK

Ditz Schweitzer
Vallensbaekvej 41
Postboks 5,
DK-2605 Brendby
TEL: (45) 42453044
FAX: (45) 42459206

## FINLAND

Integrated Electronics OY
Turkhaudantie \#1
00700 Helsinki
TEL: (358) 03513134
FAX: (358) 03513133

## ERANCE

Company 3D
3-8 Rue Ambroize Croizat 91127 Palaiseau Cedex
TEL: (33) 164472929
FAX: (33) 164470084

## Compress

30, Rue du Morvan
Silic 539
94633 Rungis Cedex
TEL: (33) 146878020
FAX: (33) 146866763

## GERMANY

Avnet / E2000 GmbH
Stahlgruberring 12
81829 München
TEL: (49) 8945110 -01
FAX: (49) $8945110-129$

Eurodis Enatechnik GmbH
Schillerstrasse 14
25451 Quickbom
TEL: (49) 4106 612-0
FAX: (49) 4106 612-268

## HONG KONG

RTI Industries Co. Ltd.
Rm. 402, Nan Fung Commercial
Centre
No. 19, Lam Lok Street
Kowloon Bay
Kowloon
TEL: (852) 7957421
FAX: (852) 7957839
HUNGARY
HT-EUREP Electronic Kft.
X-Byte Kft.
Nepfürdö u, 17/E
1138 Budapest
TEL: (36) 1-270167
FAX: (36) 1-1731530

## INDIA

Hindetron
23B, Industry House
Mahal Industry Estate
Mahakali Caves Rd.
Andheri (East), Bombay 400093
TEL: (91) 812348266
FAX: (91) 812345022

## IRELAND

Silicon Concepts
Norebank House
Greens Hill, Kilkenny
TEL: (353) 5664002
FAX: (353) 5651438
ISRAEL
Telsys Ltd.
Dvora Hanevia Str.
Neve Sharet, Atidim Bldg. 3
Tel-Aviv 61431 Israel
TEL: 03-492001-11
FAX: 03-497407
ITALY
Comprel S.P.A.
Via Po, 37
20031 - Cesano Mademo
Milano
TEL: (39) 3-62553991
FAX: (39) 3-62553967

## Avnet De Mico

Divisione della Avnet Adelsy s.r.I.

Viale Vittorio Veneto, 8
20060 Cassina De Pecchi

## Milano

TEL: (39) 02-95343600
FAX: (39) 02-9521912
JAPAN
Ado Electronic Indust. Co., Ltd.
18-10, Sotokanda 2-Chome
Chiyoda-ku
Tokyo 101
TEL: (81) 3-3257-2614
FAX: (81) 3-3257-1579

Macnica, Inc.
Hakusan High-Tech Park
1-22-2 Hakusan, Midori-ku
Yokohama, 226
TEL: (81) 45-939-6140
FAX: (81) 45-939-6141
Hakuto Co., Ltd.
1-13, Shinjuku 1-Chome
Shinjuku-ku, Tokyo 160
TEL: (81) 3-3355-7617
FAX: (81) 3-3355-7680
Hoei Denki Co., Ltd.
6-60, 2-Chome, Niitaka
Yodogawa-Ku,
Osaka 532
TEL: (81) 6-394-4596
FAX: (81) 6-396-5647
KOREA
Ellen \& Company
\#202 Sungkyung Bldg. 66
66 Yangjae-Dong
Seocho-ku, Seoul
TEL: (82) 2-579-3330
FAX: (82) 2-579-4440
Wooyoung Tech Co., Ltd.
5th Fl. Koami Bldg.
13-31 Yoido-dong
Youngdeungpo-Ku, Seoul
TEL: (82) 2-369-7099
FAX: (82) 2-369-7091
NETHERLANDS
Alcom Electronics B.V.
P.O. Box 358

2900 AJ Capelle AD ljssel
TEL: (31) 104519533
FAX: (31) 104586482

## NORWAY

Henaco A/S
Trondheimsveien 436
PO Box 126
Kaldbakken, Oslo 9
TEL: (47) 22162110
FAX: (47) 22257780
POLAND
HT-EUREP Electronic sp.z.o.o.
WG Electronics
ul. Nowogrodzka 42/3
00-695 Warszawa
TEL: (48) 22-217704
FAX: (48) 2-6284850

## SINGAPORE

Technology Distribution
No. 1 Syed Alwi Rd. \#05-02
Song Lin Bldg.
Singapore 0620
TEL: (65) 299-7811
FAX: (65) 294-1518
SOUTH AFRICA
Pace Electronic Components
Cnr. Vanacht \& Gewel St.
Isando 1600, P.O Box 701
TEL: (27) 119741525
FAX: (27) 113922463

SPAIN
Matrix Electronica
C/Belmonte de Tajo, 76-30 B
28019 Madrid
TEL: (34) 15602737
FAX: (34) 15652865

## SWEDEN

Pelcon Electronics
Box 6023
Girovägen 13
17506 Järfälla
TEL: (46) 87959870
FAX: (46) 87607685

## SWITZERLAND

Avnet / E2000
Böhnirainstr. 11
CH-8801 Thalwil
TEL: (41) 1-7221330
FAX: (41) 1-7221340
Eurodis Primotec AG
Täfemstrasse 37
CH-5405 Baden-Dättwil
TEL: (41) 5684-0171
FAX: (41) 5683-3454
TLX: 828221 apri ch

## TAIWAN

Master Electronics
16F, No.182, Sec. 2
Tun-Hwa South Rd.
Taipei
TEL: (886) 02-735-0905
FAX: (886) 02-735-0902
Score Zap Industry
1F, No. 26, Lane 60
Wen Hu Street
Nei Hu, Taipei
TEL: (886) 2-627-7045
FAX: (886) 2-659-0089

## UNITED KINGDOM

Micro Call
17 Thame Park Rd.
Thame, Oxon OX9 3XD
England
TEL: (44) 84 426-1939
FAX: (44) 84 426-1678
Silicon Concepts, Ltd.
PEC Lynchborough Rd.
Passfield, Liphook
Hampshire GU30 7SB
England
TEL: (44) 428751617
FAX: (44) 428751603
Silicon Concepts, Ltd.
Meridale, Welsh Street
Chepston, Gwent, NP6 5LR
Wales
TEL: (44) 291-624101
FAX: (44) 291-629878

ALABAMA
Arrow Electronics 1015 Henderson Rd.
Huntsville, AL 35816
(205) 837-6955

Hamilton Hallmark 4890 University Square Suite 1
Huntsville, AL 35816
(205) 837-8700

Insight Electronics
4835 University Square
Suite 19
Huntsville, AL 35818
(205) 830-1222

Marshall Industries 3313 Memorial Pkwy S.
Huntsville, AL 35801
(205) 881-9235

## ARIZONA

Arrow Electronics 2415 W. Erie Drive Tempe, AZ 85282
(602) 431-0030

Hamilton Hallmark 4637 S. 36th Place Phoenix, AZ 85040 (602) 437-1200

Insight Electronics 1515 W. University Dr.
Suite \#103
Tempe, AZ 85281
(602) 829-1800

Marshall Industries
9831S. 51st St. \#C108
Phoenix, AZ 85044
(602) 496-0290

## NORTHERN CALIFORNIA

Arrow Electronics
1180 Murphy Ave.
San Jose, CA 95131
(408) 441-9700

Arrow Electronics 90 East Tasman Dr.
San Jose, CA 95134
(408) 428-6400

Hamilton Hallmark 580 Menlo Drive
Suite 2
Rocklin, CA 95765
(916) 624-9781

Hamilton Hallmark
2105 Lundy Ave.
San Jose, CA 95131
(408) 435-3500

Insight Electronics
1295 Oakmead Pkwy.
Sunnyvale, CA 94086
(408)720-9222

Marshall Industries
336 Los Coches St.
Milpitas, CA 95035
(408) 942-4600

Marshall Industries
3039 Kilgore Ave. \#140
Rancho Cordova, CA 95670
(916) 635-9700

Zeus Electronics
6276 San Ignacio Ave. Ste. E
San Jose, CA 95119
(408) 629-4789

SOUTHERN CALIFORNIA
Arrow Electronics
Malibu Canyon Bus. Park
26677 W. Agoura Road
Calabasas, CA 91302
(818) 880-9686

Arrow Electronics
6 Cromwell, Suite 100
Invine, CA 92718
(714) 587-0404

Arrow Electronics
9511 Ridgehaven Ct.
San Diego, CA 92123
(619) 565-4800

Hamilton Hallmark 4545 Viewridge Ave.
San Diego, CA 92123
(619) 571-7540

Hamilton Hallmark
3170 Pullman St.
Costa Mesa, CA 92626
(714) 641-4100

Hamilton Hallmark
10950 Washington Blvd.
Culver City, CA 90230
(310) 558-2800

Hamilton Hallmark
21150 Califa St.
Woodland Hills, CA 91367
(818) 594-0404

Insight Electronics
4333 Park Terrace Dr.
Suite 101
Westlake Village, CA 91361
(818) 707-2101

Insight Electronics
9980 Huennekens St.
San Diego, CA 92121
(619) 587-1100

Insight Electronics
2 Venture Plaza
Suite 340
Invine, CA 92718
(714) 727-3291

Marshall Industries
26637 Agoura Rd.
Calabasas, CA 91302
(818) 878-7000

Marshall Industries
9320 Telstar Ave.
El Monte, CA 91731-3004
(818) 307-6000

Marshall Industries
One Morgan
Invine, CA 92718
(714) 458-5301

Marshall Industries
5961 Keamy Villa Rd.
San Diego, CA 92123
(619) 627-4140

Zeus Electronics
22700 Savi Ranch Pkwy.
Yorba Linda, CA 92687
(714) 921-9000

## COLORADO

Arrow Electronics
61 Invemess Drive East Suite 105
Englewood, CO 80112
(303) 799-0258

Hamilton Hallmark
12503 E. Euclid Drive
Suite 20
Englewood, CO 80111
(303) 790-1662

Insight Electronics
384 Invemess Drive South
Suite 105
Englewood, CO 80112
(303) 649-1800

Marshall Industries
12351 N. Grant
Thornton, CO 80241
(303) 451-8383

CONNECTICUI
Arrow Electronics
12 Beaumont Rd.
Wallingford, CT 06492
(203) 265-7741

Hamilton Hallmark
125 Commerce Ct.
Unit 6
Chesire, CT 06410
(203) 271-2844

Marshall Industries 20 Sterling Dr.
PO Box 200
Wallingford, CT 06492
(203) 265-3822

## FLORIDA

Arrow Electronics
400 Fairway Dr.
Deerfield Beach, FL 33441
(305) 429-8200

Arrow Electronics
37 Skyline Dr.
Bldg. D, Suite 3101
Lake Mary, FL 32746
(407) 333-9300

Hamilton Hallmark
10491 72nd St. North
Largo, FL 34637
(813) 541-7440

Hamilton Hallmark
3350 NW 53rd St.
Suite 105-107
Ft. Lauderdale, FL 33309
(305) 484-5482

Hamilton Hallmark
7079 University Blvd.
Winter Park, FL 32792
(407) 657-3300

Marshall Industries
380 S. Northlake Rd. \#1024
Altamonte Springs, FL 32701
(407) 767-8585

Marshall Industries
2700 Cypress Ck. Rd. \#D114
Ft. Lauderdale, FL 33309
(305) 977-4880

Marshall Industries
2840 Scherer Dr. \#410
St. Petersburg, FL 33716
(813) 573 -1399

Zeus Electronics
37 Skyline Dr. Bldg. D
Suite 1301
Lake Mary, FL 32746
(407) 333-3055

## GEORGIA

Arrow Electronics
4205E River Green Pkwy.
Duluth, GA 30136
(404) 497-1300

Hamilton Hallmark
3425 Corporate Way
Suite A
Duluth, GA 30136-2552
(404) 623-4400

Insight Electronics
2400 Pleasant Hill Rd.
Suite 200
Duluth, GA 30136
(404) 717-8566

Marshall Industries
5300 Oakbrook Pkwy \#140
Norcross, GA 30093
(404) 923-5750

## IOWA

Arrow Electronics
375 Collins Rd. NE
Cedar Rapids, IA 52402
(319) 395-7230

ILLINOIS
Arrow Electronics
1140 W. Thomdale Ave.
Itasca, IL 60143
(708) 250-0500

Hamilton Hallmark
1130 Thomdale Ave.
Bensonville, IL 60106
(708) 860-7780

Insight Electronics
1365 Wiley Rd., Suite 142
Schaumberg, IL 60173
(708) 885-9700

Marshall Industries
50 E. Commerce Dr. \# 1
Schaumberg, IL 60173
(708) 490-0155

## INDIANA

Arrow Electronics
7108 Lakeview Pkwy. W. Dr. Indianapolis, IN 46268
(317) 299-2071

Hamilton Halimark 4275 West 96 th Street Indianapolis, IN 46268 (317) 872-8875

## KANSAS

Arrow Electronics
9801 Legler Road Lenexa, KS 66214
(913) 541-9542

Hamilton Hallmark 10809 Lakeview Drive
Lenexa, KS 66215
(913) 888-4747

Marshall Industries
10413 W. 84th Ter.
Pine Ridge Business Park
Lenexa, KS 66214
(913) 492-3121

## MARYLAND

Arrow Electronics
9800J Patuxent Wood Dr.
Columbia, MD 21046
(301) 596-7800

Hamilton Hallmark 10240 Old Columbia Rd. Columbia, MD 21046 (410) 988-9800

Marshall Industries 9130B Guilford Columbia, MD 21046 (301) 470-2800

## MASSACHUSETTS

Arrow Electronics
25 Upton Dr.
Wilmington, MA 01887
(508) 658-0900

Hamilton Hallmark 10 P Centennial Dr.
Peabody, MA 01960
(508) 532-9808

Insight Electronics
55 Cambridge St.
Suite 301
Burlington, MA 01803
(617) 270-9400

Marshall Industries
33 Upton Dr.
Wilmington, MA 01887
(508) 658-0810

Zeus Electronics
25 Upton Dr.
Wilmington, MA 01887
(508) 658-4776

## MICHIGAN

Arrow Electronics 19880 Haggerty Rd.
Livonia, MI 48152
(313) 462-2290

Hamilton Hallmark
41650 Gardenbrook Rd.
Suite 100
Novi, MI 48375
(313) 347-4271

Marshall Industries
31067 Schoolcraft
Livonia, MI 48150
(313) 525-5850

## MINNESOTA

Arrow Electronics
10100 Viking Drive \# 100
Eden Prainie, MN 55344
(612) 941-5280

Hamilton Hallmark
9401 James Ave. South
Suite 140
Bloomington, MN 55431
(612) 881-2600

Insight Electronics
5353 Gamble Rd.
Suite 330
St. Louis Park, MN 55416
(612) 525-9999

Marshall Industries
14800 28th Ave. N.
Suite 175
Plymouth, MN 55447
(612) 559-2211

MISSOURI
Arrow Electronics 2380 Schuetz Rd.
St. Louis, MO 63146
(314) 567-6888

Hamilton Hallmark
3783 Rider Trail South
Earth City, MO 63045
(314) 291-5350

Marshall Industries 3377 Hollenberg Dr. Bridgeton, MO 63044 (314) 291-4650

NEW JERSEY
Arrow Electronics 4 East Stow Rd. Unit 11
Marton,NJ 08053
(609) 596-8000

Arrow Electronics
43 Route 46 East
Pinebrook, NJ 07058
(201) 227-7880

Hamilton Hallmark
1 Keystone Ave. Bldg. 36
Cherry Hill, NJ 08003
(609) 424-0110

Hamilton Hallmark
10 Lanidex Plaza West
Parsippany, NJ 07054
(201) 515-1641

Marshall Industries
101 Fairfield Rd.
Fairfield, NJ 07006
(201) 882-0320

Marshall Industries 158 Gaither Dr.
Mt. Laurel, NJ 08054
(609) 234-9100

NEW YORK
Arrow Electronics
25 Hub Drive
Melville, NY 11747
(516) 391-1300

Arrow Electronics
20 Oser Ave.
Hauppauge, NY 11788
(516) 231-1000

Arrow Electronics 3375 Brighton-Henrietta Townline Rd.
Rochester, NY 14623
(716) 427-0300

Hamilton Hallmark
1057 E. Henrietta Rd.
Rochester, NY 14623
(716)475-9130

Hamilton Hallmark
390 Rabro Dr.
Hauppauge, NY 11788
(516) 434-7400

Hamilton Hallmark 3075 Veterans Memorial Ronkonkoma, NY 11779
(516) 737-0600

Marshall Industries 97 Oser Ave.
Hauppauge, NY 11788
(516) 273-2695

Marshall Industries
1250 Scottsville Rd.
Rochester, NY 14624
(716) 235-7620

Marshall Industries
100 Marshall Drive
Endicott, NY 13790
(607) 785-2345

Zeus Electronics
100 Midland Ave.
Port Chester, NY 10573
(914) 933-4235

NORTH CAROLINA
Arrow Electronics
5240 Greens Dairy Rd.
Raleigh, NC 27604
(919) 876-3132

Hamilton Hallmark
5234 Green's Dairy Road
Raleigh, NC 27604
(919) 872-0712

Marshall Industries
5224 Greens Dairy Rd.
Raleigh, NC 27604
(919) 878-9882

OHIO
Arrow Electronics
6573E Cochran Rd.
Solon, OH 44139
(216) 248-3990

Arrow Electronics
8200 Washington Village Dr. \#A
Centerville, OH 45458
(513) 435-5563

Hamilton Hallmark
777 Dearbome Park Lane
Suite L
Worthington, OH 43085
(614) 888-3313

Hamilton Hallmark
5821 Harper Road
Solon, OH 44139
(216) 498-1100

Hamilton Hallmark
7760 Washington Village Dr.
Dayton, OH 45459
(513) 439-6735

## Marshall Industries

3520 Park Center Dr.
Dayton, OH 45414
(513) 898-4480

Marshall Industries 30700 Bainbridge Rd. Unit A
Solon, OH 44139
(216) 248-1788

OKLAHOMA
Arrow Electronics
12111 East 51st St. \#101
Tulsa, OK 74146
(918) 252-7537

Hamilton Hallmark
5411 S. 125th E Ave.,Ste. 305
Tulsa, OK 74146
(918) 254-6110

OREGON
Almac-Arrow Electronics
1885 N.W. 169th Place
Beaverton, OR 97006
(503) 629-8090

Hamilton Hallmark
9750 SW Nimbus Ave.
Beaverton, OR 97005
(503) 526-6200

Insight Electronics
8705 SW Nimbus Ave. Ste. 200
Beaverton, OR 97005
(503) 644-3300

Marshall Industries
9705 SW Gemini Dr.
Beaverton, OR 97005
(503) 644-5050

## IEXAS

Arrow Electronics
11500 Metric Blvd.
Suite 160
Austin, TX 78758
(512) 835-4180

Arrow Electronics 3220 Commander Dr.
Carrollton, TX 75006
(214) 380-6464

Arrow Electronics
10899 Kinghurst Dr. \#100
Houston, TX 77099
(713) 530-4700

Hamilton. Hallmark
11420 Pagemill Road
Dallas, TX 75243
(214) 553-4300

Hamilton Hallmark
12211 Technology Blvd.
Austin, TX 78727
(512) 258-8848

Hamilton Hallmark
8000 Westglen
Houston, TX 77063
(713) 781-6100

Insight Electronics
11500 Metric Blvd.
Suite 215
Austin, TX 78758
(512) 719-3090

Insight Electronics
1778 Plano Rd. \#320
Richardson, TX 75081
(214) 783-0800

Insight Electronics
15437 McKaskle
Sugarland, TX 77478
(713) 448-0800

Marshall Industries
8504 Cross Park Dr.
Austin, TX 78754
(512) 837-1991

Marshall Industries
10681 Haddington
Suite 160
Houston, TX 77043
(713) 467-1666

Marshall Industries
1551 N. Glenville Dr.
Richardson, TX 75081
(214) 705-0600

Zeus Electronics 3220 Commander Dr.
Carrollton, TX 75006
(214) 380-4330

## UTAH

Arrow Electronics
1946 West Parkway Blvd.
Salt Lake City, UT 84119
(801) 973-6913

Hamilton Hallmark
1100 E. 6600 South
Suite 120
Salt Lake City, UT 84121
(801) 266-2022

Marshall Industries
2355 South 1070 West
Salt Lake City, UT 84119
(801) 973-2288

WASHINGTON
Almac-Arrow Electronics 14360 S.E. Eastgate Way Bellevue, WA 98007
(206) 643-9992

Hamilton Hallmark
8630 154th Ave.
Redmond, WA 98052
(206) 881-6697

Insight Electronics
12002 115th Avenue, NE
Kirkland, WA 98034
(206) 820-8100

Marshall Industries
11715 N. Creek Pkwy. S.
Suite 112
Bothell, WA 98011
(206) 486-5747

WISCONSIN
Arrow Electronics
200 North Patrick Blvd.
Brookfield, WI 53045
(414) 792-0150

Hamilton Hallmark 2440 South 179th St. New Berlin, WI 53146 (414) 797-7844

Marshall Industries
20900 Swenson Dr. \#150
Waukesha, WI 53186
(414) 797-8400

## CANADA

ALBERTA
Future Electronics
3833-29th St. NE
Calgary, Alberta T1Y 6B5
(403) 250-5550

Future Electronics
4606-97th Street
Edmonton, Alberta T6E 5N9
(403) 438-2858

BRITISH COLUMBIA
Arrow Electronics
8544 Baxter Place
Bumaby, British Columbia
V5A 4 T8
(604) 421-2333

Future Electronics
1695 Boundary Road
Vancouver, British Columbia
V5K 4X7
(604) 294-1166

Hamilton Hallmark
8610 Commerce Ct.
Bumaby, British Columbia
V5A 4N6
(604) 420-4101

## MANITOBA

Future Electronics
106 King Edward
Winnipeg, Manitoba R3H ON8
(204) 786-7711

## ONTARIO

Arrow Electronics
36 Antares Dr. Unit 100
Nepean, Ontario K2E 7W5
(613) 226-6903

Arrow Electronics
1093 Meyerside Dr.
Mississauga, Ontario L5P 1M4
(416) 670-7769

Future Electronics
1050 Baxter Road
Ottawa, Ontario K2C 3P2
(613) 820-8313

Future Electronics
5935 Airport Rd., \#200
Mississauga, Ontario L4V 1W5
(416) 612-9200

Hamilton Hallmark
151 Superior Blvd.
Unit 1-6
Mississauga, Ontario L5T 2L1
(416) 564-6060

Hamilton Hallmark
190 Colonnade Rd.
Nepean, Ontario K2E 7J5
(613) 226-1700

Marshall Industries
4 Paget Rd.
Bldg. 1112, Unit 10
Brampton, Ontario L6T 5G3
(416) 458-8046

## QUEBEC

Arrow Electronics
1100 St. Regis Blvd.
Dorval, Quebec H9P 2 T5
(514) 421-7411

Future Electronics
237 Hymus Blvd.
Pointe Claire, Quebec H9R 5C7
(514) 694-7710

Future Electronics
1000 St-Jean Babtiste \#100
Quebec City, Quebec G2E 5G5
(418) 877-6666

Hamilton Hallmark
600 Transcanada Hwy
Suite 600
Ville St. Laurent, Quebec
H4T 1V6
(514) 335-1000

Marshall Industries
148 Brunswick Blvd.
Pointe Claire, Quebec H9R 5B9
(514) 694-8142

## 嘆达tice  <br> 

## Lattice Semiconductor Corp.

5555 Northeast Moore Ct.
Hillsboro, Oregon 97124 USA
Telephone: (503) 681-0118
FAX: (503) 681-3037
pLSI \& ispLSI Applications Hotline: 1-800-LATTICE GAL Applications Hotline: 1-800-FASTGAL


[^0]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

[^1]:    1. Internal Timing Parameters are not tested and are for reference only.
    2. Refer to Timing Model in this data sheet for further details.
[^2]:    * For ispLSI 1016 Only

[^3]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

[^4]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.

[^5]:    1. Internal Timing Parameters are not tested and are for reference only.
    2. Refer to Timing Model in this data sheet for further details.
    3. The XOR Adjacent path can only be used by Lattice Hard Macros.
[^6]:    * For ispLSI 1032 Only

[^7]:    * For ispLSI 1032 Only

[^8]:    *Pins have dual function capability for ispLSI 1032/883 only (except pin 63, which is ispEN only).

[^9]:    1. Internal Timing Parameters are not tested and are for reference only.
    2. Refer to Timing Model in this data sheet for further details.
[^10]:    *For ispLSI 1048 Only

[^11]:    *For ispLSI 1048C Only

[^12]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

[^13]:    * For ispLSI 2032 Only

[^14]:    * ispLSI 3256 Only

[^15]:    * ispLSI 3256 Only

[^16]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^17]:    1) Used with Configuration keyword.
    2) Prior to Version 2.0 support.
    3) Supported on Version 1.20 or later.
[^18]:    *Guaranteed but not 100\% tested.

[^19]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^20]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^21]:    1) Guaranteed but not $100 \%$ tested.
    2) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
    3) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
    4) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$
[^22]:    *Guaranteed but not 100\% tested.

[^23]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^24]:    *Guaranteed but not $100 \%$ tested.

[^25]:    *Guaranteed but not 100\% tested.

[^26]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^27]:    *Guaranteed but not 100\% tested.

[^28]:    1) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
    2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
    3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
[^29]:    *Guaranteed but not $100 \%$ tested.

[^30]:    subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 N.E. Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book

[^31]:    1) Guaranteed but not $100 \%$ tested.
    2) The leakage current is due to the internal pull-up resistor on all pins. See Input Buffer section for more information.
    3) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
    4) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T} A=25^{\circ} \mathrm{C}$
[^32]:    *Guaranteed but not 100\% tested.

[^33]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 N.E. Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^34]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 N.E. Moore Ct., Hillsboro, Oregon 97124 U.S.A.
    1994 Data Book
    Tel. (503) 681-0118 or 1-800-FASTGAL; FAX (503) 681-3037

[^35]:    1) The leakage current is due to the internal pull-up on all pins. See Input Buffer section for more information.
    2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
    3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
[^36]:    *Guaranteed but not 100\% tested.

[^37]:    1) The leakage current is due to the internal pull-up on all pins. See Input Buffer section for more information.
    2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
[^38]:    *Guaranteed but not 100\% tested.

[^39]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^40]:    *Guaranteed but not 100\% tested.

[^41]:    *Guaranteed but not 100\% tested.

[^42]:    * ${ }^{\text {L }}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

[^43]:    *Guaranteed but not 100\% tested.

[^44]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^45]:    *Guaranteed but not 100\% tested.

[^46]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-327-8425; FAX (503) 681-3037

[^47]:    *Guaranteed but not $100 \%$ tested.

[^48]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book

[^49]:    *Guaranteed but not 100\% tested.

[^50]:    1) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems by tester ground degradation. Guaranteed but not $100 \%$ tested.
    2) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
[^51]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-FASTGAL; FAX (503) 681-3037

[^52]:    *Guaranteed but not 100\% tested.

[^53]:    ${ }^{*} C_{L}$ INCLUDES TEST FIXTURE AND PROBE CAPACITANCE

[^54]:    1) The leakage current is due to the internal pull-up on all pins. See Input Buffer section for more information.
    2) One output at a time for a maximum duration of one second. Vout $=0.5 \mathrm{~V}$ was selected to avoid test problems caused by tester ground degradation. Guaranteed but not $100 \%$ tested.
    3) Typical values are at $\mathrm{Vcc}=5 \mathrm{~V}$ and $\mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
[^55]:    *Guaranteed but not 100\% tested.

[^56]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

[^57]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

[^58]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

[^59]:    Copyright (c) 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.

    1994 Data Book Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

[^60]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

[^61]:    Copyright © 1994 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
    LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A.
    1994 Data Book
    Tel. (503) 681-0118; 1-800-LATTICE; FAX (503) 681-3037

