Since the original printing of this material, Monolithic Memories has merged with Advanced Micro Devices. References in this handbook to either company now pertain to the new combined entity, which markets all products under the AMD name.
This book contains information about AMD's Programmable Gate Arrays, an exciting extension of our commitment to the field of programmable logic. The leader in programmable logic products, AMD continues to provide you with the quality, reliability and innovation you demand. As with every product we sell, AMD's Programmable Gate Arrays are backed by an extensive force of knowledgeable sales personnel and fully-trained field applications engineers. After reviewing the information in this book, you will see how PGAs can fit into your applications. Please contact your local AMD sales office, authorized representative or franchised distributor so that we can together, solve your technical problems with AMD's Programmable Gate Arrays.

Michael J. Callahan
Senior Vice President
Programmable Products Group
Table of Contents

Introduction ...................................................................................................................................................... 1-1
Table of Contents ........................................................................................................................................ 1-3

Section 2 2000 Series LCA Design Handbook Table of Contents .......................................................... 2-1
See Section 2

Section 3 Applications .................................................................................................................................. 3-1
Configuring the LCA Device ......................................................................................................................... 3-3
M2018 Provides Decoding for Six-Digit, Seven-Segment Liquid Crystal Display ........................................ 3-17
LCA Counter Applications ............................................................................................................................ 3-29
Time Division Multiplexing with LCA Device .............................................................................................. 3-43
Dual 32-bit Serial CRC Error Detection in a LCA Device ........................................................................... 3-53
LCA Device Implements an 8-bit Format Converter in a PBX Switching Module ..................................... 3-65
Reconfigurable Programmable Devices (LCA) Simplify Digital TDM Line Transcender ......................... 3-75
Building an ESDI Translator Using the M2064 Logic Cell Array .............................................................. 3-89
Using the Logic Cell™ Array to Build a Pseudo-Random-Number Generator ........................................ 3-101
64K Deep FIFO-Dynamic RAM Controller is Implemented in the M2018 LCA Device ....................... 3-109
Configuring the LCA™ from the PC Bus ................................................................................................. 3-125

Section 4 Product Information .................................................................................................................. 4-1
Logic Cell™ Array M2064/M2018 ................................................................................................................. 4-3
3000 Series Family of Programmable Gate Arrays ..................................................................................... 4-43
LCA-MDS21
  XACT Design Editor System .................................................................................................................... 4-116
LCA-MDS22
  P-SILOS Simulator .................................................................................................................................. 4-119
LCA-MDS23
  Automatic Design Implementation ............................................................................................................. 4-120
LCA-MDS24, LCA-MDS26, LCA-MDS27
  XACTOR In-Circuit Emulator .................................................................................................................. 4-121
LCA-MDS31/LCA-MDS33/LCA-MDS34/LCA-MDS35
  Schematic Design Entry Interface for Futurenet, Daisy, Mentor, OrCAD ........................................ 4-122
LCA-MDS151/LCA-MDS152
  PGA Development System/PGA Design Entry System ........................................................................ 4-124
LCA-MDS135
  OrCAD/SDT III PGA Design Entry System and Interface ...................................................................... 4-134
LCA-MEK01
  Logic Cell Array Evaluation Kit .............................................................................................................. 4-141

Section 5 Sales Office Listing ................................................................................................................... 5-1
THE 2000 SERIES LOGIC CELL ARRAY

DESIGN HANDBOOK

BY

AMD, ADVANCED MICRO DEVICES

© 1988, Advanced Micro Devices, Inc.
901 Thompson Place
P.O. Box 3453
Sunnyvale, CA 94088

TEL: 408-732-2400
TWX: 910339-9280
TELEX: 34-6306
TOLL FREE: 800-538-8450

APPLICATIONS HOTLINE: 800-222-9323

June 1988
Portions of this document have been reprinted with permission from XILINX, Inc.

Advanced Micro Devices reserves the right to make changes in specifications at any time and without notice. The information furnished by Advanced Micro Devices is believed to be accurate and reliable. However, no responsibility is assumed by Advanced Micro Devices for its use, nor for any infringements of patents or other rights of third parties resulting from its use. No license is granted under any patents or patent rights of Advanced Micro Devices.

XACT™, XACTOR™, Logic Cell™, and LCA™ are trademarks of XILINX, Inc.
P-SILOS™ is a trademark of SimuCad™ Corporation.
PREFACE

ACKNOWLEDGEMENTS

LCA PRODUCT APPLICATION AND COMPONENTS

CHAPTER 1: INTRODUCTION TO THE LCA
CHAPTER 2: THE LCA DESIGN CYCLE
CHAPTER 3: CONFIGURABLE LOGIC BLOCKS
CHAPTER 4: INPUT/OUTPUT BLOCKS
CHAPTER 5: PLACEMENT AND ROUTING
CHAPTER 6: CONFIGURING THE LCA

LCA DATA AND SPECIFICATIONS

CHAPTER 7: METASTABILITY OF LCA FLIP-FLOPS
CHAPTER 8: TESTING AND DATA INTEGRITY
CHAPTER 9: NONHERMETIC PACKAGE RELIABILITY

LCA REFERENCES

GLOSSARY
INDEX
# Table of Contents

## Chapter 1: Introduction to the LCA Device

1.1 Overview ............................................................................................................. 1-2  
1.1.1 SSI/MSI Devices ........................................................................................... 1-4  
1.1.2 Programmable Logic Devices ........................................................................ 1-4  
1.1.3 ASICs ............................................................................................................. 1-5  
1.1.4 LCA Devices .................................................................................................. 1-5  
1.2 Architecture Comparisons .................................................................................. 1-6  
1.2.1 Programmable Logic Devices ........................................................................ 1-6  
1.2.2 Gate Arrays .................................................................................................. 1-6  
1.2.3 LCA Devices ................................................................................................ 1-7  
1.3 LCA Benefits ..................................................................................................... 1-9  
1.3.1 Process ......................................................................................................... 1-9  
1.3.2 Quality ....................................................................................................... 1-9  
1.3.3 Reliability .................................................................................................... 1-10  
1.4 LCA Development Software ............................................................................. 1-11

## Chapter 2: The LCA Design Cycle

2.1 Overview ............................................................................................................. 2-2  
2.1.1 LCA Design System ..................................................................................... 2-2  
2.1.2 LCA Software and Design Cycle ................................................................. 2-5  
2.2 Design Entry and Conversion ........................................................................... 2-8  
2.3 Logic Verification ............................................................................................... 2-10  
2.4 Automatic Partitioning, and Placement and Routing ......................................... 2-12  
2.5 Design Optimization ........................................................................................ 2-14  
2.5.1 Routing Optimization .................................................................................... 2-14  
2.5.2 Delay Calculation ......................................................................................... 2-15  
2.6 Timing Verification ........................................................................................... 2-16  
2.7 In-Circuit Design Verification ........................................................................... 2-18  
2.7.1 Download Cable ......................................................................................... 2-18  
2.7.2 PROM Programming ..................................................................................... 2-19  
2.7.3 Xactor .......................................................................................................... 2-20
5.3 PLACEMENT ................................................................. 5-19
  5.3.1 PARTITION THE SYSTEM DESIGN............................ 5-19
  5.3.2 ANALYZE THE DATA FLOW ...................................... 5-20
  5.3.3 LOGIC BLOCK PLACEMENT .................................... 5-23
  5.3.4 I/O BLOCK PLACEMENT ......................................... 5-27
  5.3.5 EXAMPLES .......................................................... 5-29
  5.3.6 MODIFICATION GUIDELINES .................................... 5-34

5.4 ROUTING ................................................................. 5-37
  5.4.1 MANUAL EDITING .................................................. 5-37
  5.4.2 MANUAL PRE-ROUTING ........................................ 5-43
  5.4.3 ROUTING GUIDELINES AND FUNCTIONS .................. 5-49

5.5 TIMING ANALYSIS, DELAY CALCULATOR ..................... 5-56
  5.5.1 CLB AND IOB DELAYS .......................................... 5-56
  5.5.2 INTERCONNECTION DELAYS ................................... 5-56
  5.5.3 CLOCKED SYSTEM DELAYS .................................... 5-60
  5.5.4 SPEED GRADE DELAYS ......................................... 5-61
  5.5.5 SIGNAL DEGRADATION ......................................... 5-62

5.6 SUMMARY ............................................................... 5-68

CHAPTER 6: CONFIGURING THE LCA DEVICE ................. 6-1
6.1 LCA CONFIGURATION OVERVIEW ............................... 6-2
  6.1.1 CONFIGURATION BIT STREAM ................................. 6-2
  6.1.2 CONFIGURATION PROCESS .................................... 6-2

6.2 CONFIGURATION MODES .......................................... 6-6
  6.2.1 CONSIDERATIONS ............................................... 6-7
  6.2.2 CONFIGURATION PIN FUNCTIONS ........................... 6-14
  6.2.3 SLAVE MODE ...................................................... 6-19
  6.2.4 PERIPHERAL MODE ............................................. 6-22
  6.2.5 MASTER MODES .................................................. 6-27

6.3 CONFIGURE MULTIPLE LCA DEVICES ....................... 6-34
  6.3.1 DAISY-CHAIN CONFIGURATION .............................. 6-34
  6.3.2 PARALLEL CONFIGURATION .................................. 6-36

6.4 ASSIGNING MULTIPLE-FUNCTION ............................... 6-38
  6.4.1 POTENTIAL I/O CONFLICTS ................................. 6-38
  6.4.2 UNUSED I/O PINS .............................................. 6-40

6.5 CONFIGURATION DATA ............................................. 6-42
  6.5.1 CONFIGURATION FILE FORMAT .............................. 6-44
  6.5.2 A SAMPLE EQUIVALENT CONFIGURATION FILE ....... 6-46
  6.5.3 CONFIGURATION LOADING ..................................... 6-48

6.6 READ-BACK CONFIGURATION DATA ........................... 6-49
This handbook introduces the Logic Cell™ Array (LCA™) device by

- comparing it with other digital logic devices
- describing its three major components
- providing testing and data reliability specifications.

This handbook places each title and major topic at the top of a new page. Each chapter introduction lists the major topics therein. Each major topic introduction identifies the second-level topics to watch for, and so on.

**Note:** Abbreviations used in this handbook that are not explicitly defined are those deemed standard by the IEEE.

**AUDIENCE**

The reader of this handbook should have a working knowledge of the design, testing, and reliability of digital logic devices.
ACKNOWLEDGEMENTS

For information provided in this handbook, I would like to thank the following people from Xilinx, in alphabetical order.

Chuck Erickson  Dave Lautzenheiser
Steve Elischu  Richard Ravel
Rick Farabaugh  Rob Stransky
Dave Galli  Craig Wooster
Steve Knapp  Pardner Wynn
Steve Landry

For their great help during the preparation of this handbook, I would like to thank the following people from Advanced Micro Devices, in alphabetical order.

Audrey Dickey  Arlo Radcliffe
Chris Jay  Dieter Rathjens
Vivian Kong  Gail Tiberi
Jana McNulty  Joe Walcek
Joseph Parenteau
# Chapter 1

## Introduction To The LCA Device

<table>
<thead>
<tr>
<th>Section</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Introduction To The LCA Device</td>
<td>1</td>
</tr>
<tr>
<td>1.1 Overview</td>
<td>2</td>
</tr>
<tr>
<td>1.1.1 SSI/MSI Devices</td>
<td>4</td>
</tr>
<tr>
<td>1.1.2 Programmable Logic Devices</td>
<td>4</td>
</tr>
<tr>
<td>1.1.3 ASICS</td>
<td>5</td>
</tr>
<tr>
<td>1.1.4 LCA Devices</td>
<td>5</td>
</tr>
<tr>
<td>1.2 Architecture Comparisons</td>
<td>6</td>
</tr>
<tr>
<td>1.2.1 Programmable Logic Devices</td>
<td>6</td>
</tr>
<tr>
<td>1.2.2 Gate Arrays</td>
<td>6</td>
</tr>
<tr>
<td>1.2.3 LCA Devices</td>
<td>7</td>
</tr>
<tr>
<td>1.3 LCA Benefits</td>
<td>9</td>
</tr>
<tr>
<td>1.3.1 Process</td>
<td>9</td>
</tr>
<tr>
<td>1.3.2 Quality</td>
<td>9</td>
</tr>
<tr>
<td>1.3.3 Reliability</td>
<td>10</td>
</tr>
<tr>
<td>1.4 LCA Development Software</td>
<td>11</td>
</tr>
</tbody>
</table>

June 1988
This chapter introduces the AMD-supplied LCA family and covers the following topics.

- The overview, 1.1, introduces the Logic Cell™ Array, or LCA™ device.

- The discussion on architectural comparisons, 1.2, explains how LCA devices compare to other semiconductor devices.

- The discussion on LCA benefits, 1.3, compares the benefits of using an LCA device with those of other, more traditional semicustom devices.

- The discussion on LCA development software, 1.4, describes the available LCA design and verification software.
1.1 OVERVIEW

The following product features and improvements are motivating manufacturers of electronic systems to use high-density VLSI circuits.

- Lower cost
- Higher performance
- Reduced power consumption
- Smaller size
- Increased reliability

Microprocessors and memory devices are standard product ICs that have best exploited the advances in VLSI technology. Density improvements in these product types outpaced those in other digital integrated circuits and widened the technology gap between them and other logic devices. To achieve comparable densities for their proprietary functions, designers of digital equipment must consider using factory-programmed custom and semicustom application-specific integrated circuits (ASICs).

The advent of user-programmable gate arrays combines the production cost-effectiveness of VLSI with all the benefits of a standard product. The following figure illustrates the tradeoffs of density and development time for several digital logic device types.

The optimal solution, in the upper-left corner of the following diagram, represents the best tradeoff of density and complexity with design time. As illustrated, a new digital logic technology called the Logic Cell Array, or LCA, offers improvements over the traditional tradeoffs in both design complexity and design time.
Logic Technology Tradeoffs

Several common device classes are introduced below.

- 1.1.1, SSI/MSI Devices
- 1.1.2, Programmable Logic Devices (PLDs)
- 1.1.3, ASIC Devices
- 1.1.4, LCA Devices
1.1.1 SSI/MSI DEVICES

Standard SSI/MSI devices, which are well understood by most logic designers, provide much design flexibility and are readily available. However, they offer less density and consume more power than other device types. Also, they usually are manufactured in maturing technologies with limited opportunity for further cost reductions.

1.1.2 PROGRAMMABLE LOGIC DEVICES

Programmable logic devices (PLDs) include a number of competing alternatives, all based on a programmable AND/OR plane architecture. This architecture is most efficient for applications requiring up to a few hundred usable gates.

Typically, each programmable logic device replaces five to ten SSI/MSI devices. Because PLDs are user-programmable, designers achieve this gain in density with only a small increase in design time and little schedule risk. The design and device pattern for a specific application can be developed within days.

Bipolar PLDs are programmed by opening fuse links. CMOS PLDs are either one-time programmable, UV erasable (EPLD), or electrically erasable (EEPLD).

PLDs are best suited for state machines and decoders. For functions that are readily expressed as a sum-of-products, the PLD architecture provides efficient multi-variable decoding and high performance. Architectural restrictions limit the application of PLDs to general logic replacement, consolidation of miscellaneous glue logic and control functions, or complex processing tasks.
1.1.3 ASICS

Factory-programmable ASIC devices include gate arrays, standard cells, and compiled silicon. ASICs provide logic densities of up to 100,000 equivalent logic gates, and are sufficiently flexible for most digital logic functions. Fabricating factory programmed ASICs typically requires two to four months after a designer completes and verifies a design prototype. Manufacturing the first production quantities requires a similar period of time. Because of their high design costs and limited production flexibility, factory-programmed ASICs are most economical in very high production volumes. The logistics of verifying a workable design, testing ASIC devices, and coordinating production demand require substantial resources on the part of the manufacturer.

1.1.4 LCA DEVICES

The LCA device is a user-programmable gate array that provides the usable density of gate arrays and the short development times and low risk of standard logic circuits. The LCA device combines the design and production benefits of a standard logic device with the system benefits of increased reliability, power savings, space savings, and lower production costs than usually associated with ASIC device types.

The next discussion compares LCA devices to other semiconductor devices.
1.2 ARCHITECTURE COMPARISONS

Your benefits of the LCA device result from its flexible array architecture. This architecture is based on a number of technical breakthroughs that have resulted in patent disclosures. Discussions below compare familiar device architectures with that of the new LCA device.

- 1.2.1, Programmable Logic Devices
- 1.2.2, Gate Arrays
- 1.2.3, Logic Cell Arrays

1.2.1 PROGRAMMABLE LOGIC DEVICES

In PLD architectures, dedicated device input pins and some user-selectable input/output (I/O) pins or feedback paths directly drive the inputs to the AND/OR planes. Outputs are driven directly from the sum-of-products logic outputs, or from device flip-flops.

The primary limitations of the PLD architecture are the rigidity of the AND/OR plane logic and its dedicated interconnections. Flip-flops are typically driven by a common clock and are closely associated with specific output pins. As a result, gate use rarely exceeds 15%. Consequently, the practical upper limit of usable gates appears to be a few hundred, and the extension of this basic architecture to higher densities is limited. Also, PLD performance is fixed for each level of logic; each path through the AND/OR plane exhibits the same delay, typically 25 to 45 ns.

1.2.2 GATE ARRAYS

Array architectures provide more flexible resources than PLD architectures, both for I/O functions and for logic structures. A gate array typically implements user logic by interconnecting two-input NAND gates into more complex functions using mask-programmed metal segments. Factory processing customizes each gate array by creating the metal interconnections on standard, partially processed arrays.
Larger arrays can be generated through straightforward extensions of the I/O blocks, logic building blocks, and interconnection resources, much like extending the capacity of a memory device. Gate arrays offer usable densities of 25,000 gates or more. Usability of 80% to 90% is possible because of the architecture's flexibility and regularity.

Gate array performance depends on the placement and interconnection of the elements that make up each logic function. In a gate array characterized by 2 ns gate delays, frequently-used functions can have a total delay of 15 ns or more, due to the number of interconnections and gating levels needed to implement them.

The LCA architecture resembles a gate array with an interior matrix of logic blocks and a surrounding ring of I/O interface blocks. LCA devices also share the gate array architecture's flexibility and ease of extension to higher densities. However, they do not share the gate array's need for factory programming. Instead, a configuration bit stream stored in on-chip memory defines and controls the function of the LCA device's configurable logic blocks (CLBs), I/O blocks (IOBs), and user-programmable interconnections. Distributed memory cells are adjacent to the logic, I/O, or interconnection elements they control. The interconnections are located in the channels between the rows and columns of configurable logic blocks, and between the configurable logic blocks and I/O blocks.

Straightforward extensions of the LCA architecture can increase a 1200-gate array to one with more than 1800 gates. Further extensions of the LCA architecture have increased the number of usable gates to 9000.

Like other standard IC components, LCA devices provide a selection of low- and high-speed parts. You
can choose the most cost-effective speed grade for your application.

LCA performance depends on the fixed delays of the logic and storage elements plus the interconnection delays. During design, the LCA delay calculation software can quickly display worst-case timing. Typically, LCA performance is specified by the maximum toggle rate for a logic block storage element when it is configured as a toggle flip-flop. For typical configurations, a 70 MHz toggle rate translates to a system clock rate of up to 35 MHz.

Unlike conventional gate arrays, the LCA device requires no custom factory fabrication. Each device is identical until it is loaded with its application-specific configuration bit stream. During normal operation, the configuration bit stream is loaded automatically from an EPROM or a processor, either when the LCA device is powered up or on command while the system is operating. You can copyright your LCA configuration bit stream to protect your designs from unauthorized copying under the same legal precedents that are used effectively to protect microprocessor-based systems.

The next discussion lists and explains the main benefits of using LCA devices as logic devices.
1.3 LCA BENEFITS

LCA devices have three important logic design benefits discussed below.

- 1.3.1, Advanced process
- 1.3.2, High quality
- 1.3.3, Proven reliability

1.3.1 PROCESS

Over the last five years, the most pronounced trend in the semiconductor manufacturing process is the shift to CMOS technology. This shift is especially pronounced for ASIC devices. The advantages of advanced CMOS processes include both high speed and low power consumption.

LCA devices are fabricated using AMD’s 1.5µ advanced process. Two metal layers are essential for an efficient array architecture; the array must propagate logic signals in horizontal and vertical directions, with minimum delays. The LCA manufacturing process is very similar to that used for high-speed memories; it exploits the photolithography and wafer diameter advances achieved in memory process technology. These advances result in ever-higher device density and performance at ever-decreasing cost.

1.3.2 QUALITY

As quality consciousness has grown among semiconductor users, awareness of the importance of testing has also increased among manufacturers.

Testability is an important consideration in the design of microprocessors, memories, and other standard products. These devices are tested exhaustively by AMD with carefully developed programs.

The testing of most application-specific ICs is less comprehensive, due to limitations of design and test program development. However, the LCA device is
100% testable; each device is comprehensively tested during the manufacturing process. Testing is accomplished by AMD without involving you in the definition of test programs or the generation of test vectors.

1.3.3 RELIABILITY

The LCA manufacturing process used is based on a process developed for high-performance CMOS static memories. Extensive process-development work ensures the most reliable memory devices and provides the same benefits to the LCA device. Data collected over millions of operating hours confirm the reliability of the LCA design and the CMOS process.

Compared with other logic devices, the LCA device exhibits extremely low power dissipation. This translates to lower operating temperatures and higher reliability. Also, packaging materials for the LCA device are selected to match closely the thermal coefficient for the expansion of the silicon. This match minimizes thermal stresses and further improves reliability.

The memory cell used to store the LCA configuration bit stream is particularly robust. Memory is written only during device configuration and its static output controls the logic elements in the array. Because the two circularly linked inverters that make up the static latch are adjacent, transients cause only minor differences in voltages. Each inverter is a true complementary transistor pair, so that a low impedance path to the supply rail always exists regardless of the state. Furthermore, tests involving bombardment with high levels of alpha radiation verify that the storage cell is not disturbed by alpha particles.
The development system for LCA devices is similar in capability and usage to those for microprocessors.

Development support for the LCA device includes complete software-based design entry, analysis, and verification. The LCA development system offers a complete basic configuration and several powerful options to enhance designer productivity. LCA development system features include the following.

A. A consistent, user-friendly, menu-driven environment for all LCA development software

B. Schematic entry

C. Macro library support for standard AMD-supplied and user-defined functions

D. Simulation interface support that includes netlist extraction

E. Automatic placement and routing

F. Interactive timing calculation and design optimization

G. In-circuit emulation for one or multiple LCA devices
The LCA development system for the 2000 series requires the following hardware.

- IBM® PC-XT™, PC-AT™, or 100% compatible computer
- 640 kBytes of internal RAM
- A serial mouse

A system that must interface with printers and other output devices also requires

- a single parallel port
- two serial ports.

A variety of schematic editors and design workstation platforms are also available.

Chapter 2 discusses the LCA design cycle in detail.
CHAPTER 2

THE LCA DESIGN CYCLE

THE LCA DESIGN CYCLE........................................................................................................ 1

2.1 OVERVIEW.......................................................................................................................... 2
    2.1.1 LCA DESIGN SYSTEM.............................................................................................. 2
    2.1.2 LCA SOFTWARE AND DESIGN CYCLE................................................................. 5

2.2 DESIGN ENTRY AND CONVERSION............................................................................... 8

2.3 LOGIC VERIFICATION..................................................................................................... 10

2.4 AUTOMATIC PARTITIONING, AND PLACEMENT AND ROUTING.............................. 12

2.5 DESIGN OPTIMIZATION................................................................................................. 14
    2.5.1 ROUTING OPTIMIZATION.................................................................................. 14
    2.5.2 DELAY CALCULATION....................................................................................... 15

2.6 TIMING VERIFICATION.................................................................................................. 16

2.7 IN-CIRCUIT DESIGN VERIFICATION............................................................................ 18
    2.7.1 DOWNLOAD CABLE............................................................................................ 18
    2.7.2 PROM PROGRAMMING....................................................................................... 19
    2.7.3 XACTOR.............................................................................................................. 20
This chapter provides an overview of the LCA design cycle and explains each step of the cycle in detail.

- The overview of the design cycle, 2.1, introduces the LCA design process and software.

- The discussion on design entry, 2.2, explains entering an LCA design as a schematic and converting the schematic design to netlist data.

- The discussion on logic simulation, 2.3, describes pre-route simulation.

- The discussion on automatic partitioning, and placement and routing, 2.4, explains translating the netlist into the LCA file format as well as automatic placement and routing.

- The discussion on design optimization, 2.5, explains routing optimization and delay calculation.

- The discussion on timing verification, 2.6, describes post-route simulation.

- The discussion on in-circuit design verification, 2.7, explains three optional ways to verify an LCA design.
2.1 OVERVIEW

Before you begin your LCA design, it is important for you to understand the LCA design cycle and, in particular, how the design cycle relates to the LCA environment and the available software.

- Discussion 2.1.1 explains the LCA design system.
- Discussion 2.1.2 shows the relationship between the tasks in the LCA design cycle and the software tools you use.

2.1.1 LCA DESIGN SYSTEM

The LCA design system, shown in the following figure, consists of two independent design environments and a file format that can be used as a bridge among the formats of these environments.

- External design environment
- Internal design environment
- External netlist format

In the external design environment, all software packages deal with silicon-independent tasks such as schematic capture and simulation. These software packages frequently use incompatible file formats. Also, they may be supported on hardware platforms different from that of the internal design environment.

The internal design environment, in contrast, supports software packages dealing with silicon-dependent tasks such as logic partitioning, automatic placement and routing, and those tasks performed under the LCA software development system. These software packages communicate with each other through a common file format, the LCA format, which is proprietary. The LCA format contains silicon-dependent information such as delay, routing, and programming data.
The external netlist format, or XNF, provides the bridge among different file formats. This bridge permits files produced in one environment to be converted to a format that permits designers to use them in the other environment; it also permits conversion of files among different formats in the external environment.

AMD integrates the LCA design system with its interface software packages. These packages translate the different file formats into the XNF format, or the XNF format into the required file format. For example, the schematic to XNF interface translates the schematic file format into the XNF format; whereas the XNF to simulation interface translates the XNF format into typical simulation files such as the simulator netlist and input stimulus files.

After external files are translated into the XNF format, another software package offered by AMD can be used to convert the XNF format into the LCA format.

AMD will provide additional translation capabilities as new software packages in the external design environment require access to the LCA design system.
AMD supplies software that translates a design file from a unique schematic-capture format into the XNF format: name2XNF. AMD also supplies software to translate the XNF format to a simulation format, XNF2sim, and software that translates files between the XNF and LCA formats. These interfaces provide an environment that lets you perform all the tasks required to produce a consistent, integrated LCA design.

The diagram on the next page is divided into two vertical segments that show the relationship between each task in the LCA design cycle and the actual software you use to perform each task.

In the figure, square boxes on the left show major tasks in the design cycle. Although the tasks are depicted serially, the design cycle is actually an iterative process in which you repeat a task or sequence of tasks.

Rounded boxes in the LCA software cycle represent the product used for the task connected by the shading. Ovals show the format of the input and/or output file for each step.
*includes simulator-specific netlist and stimulus files
To produce an LCA design, you complete six major design tasks.

I. **Design entry** using a supported schematic-capture platform includes **design conversion** to produce an external netlist format (XNF) file.

II. **Logic verification** includes translating the XNF file to specific simulation file formats. You then run a unit-delay simulation.

III. **Automatic partitioning, and placement and routing** (APPR) reduces the design, minimizes or compresses the logic, and partitions the design into required CLBs and IOBs. You can then place and route automatically.

IV. **Design optimization** includes delay analysis and routing optimization. Any logic changes you make here dictate that you return to task I and repeat subsequent tasks.

V. **Timing verification** includes translation of the completely routed design from its LCA format into the XNF format, translation of the XNF format into a simulation netlist, and simulation. You compare the timing simulation results with those of the previous logic simulation to ensure that there are no logic changes.¹

VI. **In-circuit design verification** can include any of the following: using the download cable, programming a PROM, and using the in-circuit design verifier.

¹ Unless you complete timing verification on a completely placed and routed design, you cannot be sure the design will function under worst-case process, voltage, and temperature conditions.
When using a supported schematic-capture platform, the first two steps toward completing an LCA design are as follows.

1. Produce a schematic using the AMD-supplied LCA design library with a corresponding, supported schematic-capture platform.

2. Create an external netlist of the schematic-based design using the name2XNF interface software.

Schematic entry shortens your product development time by letting you enter complex LCA designs efficiently.

You enter the LCA design as a schematic using any AMD-supported schematic-capture platform. Rather than basing your design schematic on TTL or other standard parts, you base the schematic on the available LCA library parts.

The LCA library for each supported schematic-capture platform includes common logic functions and standard parts, such as gates, latches, and 7400-series parts.

While entering the schematic, you can constrain nets to direct design placement and routing with APR software later in the design cycle. You can also include constraints in a text file that APR can read. APR recognizes the following constraints.

- Critical nets that should be routed with as little interconnection delay as possible
- Nets that should be placed on long lines
- Specific placement of logic blocks
- Logic block grouping
• Locking nets and blocks

Once the schematic is produced, you must convert it to an external netlist file (XNF) format. AMD supplies a software interface product, name2XNF, for each supported schematic-capture platform. The interface software converts the schematic-based data into a netlist file that's needed to produce a simulation file or LCA design file.

Note: If the a schematic contains CLB or IOB macro symbols, which directly specify LCA elements, the XNF file must be translated into an LCA file and then back into an XNF file prior to logic verification. AMD supplies this interface in the XNF/LCA software product.
2.3 LOGIC VERIFICATION

The next step toward completing your design is to verify, during unit-delay simulation, that the logic is correct. This is done with a gate-level XNF file: one that does not have the physical routing paths specified in the LCA design. At this point it is not possible to make a realistic estimate of the timing because the design is not yet implemented as an LCA device.

The following steps outline the procedure for verifying the logic of an unrouted design with AMD-supplied software. For details, refer to specific topics in the LCA Development System manual before simulating.

1. Translate the XNF file into the simulation netlist file with XNF2sim.
   The netlist includes logic parameters and setup and hold times based on the selected LCA speed grade, operating under worst-case conditions.

2. Edit the input stimulus file created by XNF2sim, using a text editor.
   You specify simulation stimuli with a set of clock statements or with an input pattern for either pad inputs or internal nodes.

3. Simulate the design.
   Simulation results are available in tabular, plotted, and graphic formats. This flexibility makes it easy to correct the function and timing of the circuit.

4. Repeat design entry and logic verification until your design simulates correctly.

After schematic entry and before automatic partitioning, and placement and routing, you use a logic simulator to debug the design. This pre-route simulation saves design time because you can detect and correct logic
errors before final placement and routing. Later, you compare pre-route simulation with post-route simulation results to detect whether or not logic changes were introduced during optimization.

There are several software products available to assist you with simulation at various times in the design cycle. For each simulator there is one software interface product, XNF2sim, that translates the XNF file into the file format your particular simulator uses.
Once the design file is in the netlist format, you use the LCA2XNF translator to convert the schematic elements into LCA elements. You then partition, place, and route the LCA design. The following steps give an outline of this procedure.

1. Partition the design into CLBs and IOBs with the XNF2LCA software.

   This process efficiently groups as much logic as possible into each CLB, and translates the design into the LCA file format required by the LCA development system software.

2. Place and route the design.

   You can use automatic placement and routing (APR) software, or you can proceed directly to the LCA design editor, EDITLCA, and place and route the design interactively.

The XNF2LCA software completes the following tasks.

- Reduces and minimizes the logic
- Partitions the design into CLBs and IOBs
- Translates the design to the LCA format
- Performs design checking

The partitioning that occurs during translation may not result in the optimal placement of CLBs and IOBs. You can improve the layout of the design by including additional constraints to APR.

Both APR and XACT use the LCA file format. Thus, you can optimize the placement and routing of individual CLBs and IOBs in your design interactively with the interconnection feature of the LCA design editor,
EDITLCA. Refer to discussion 2.5 for more information on design optimization.

You can also take advantage of APR when you develop LCA designs incrementally. You can lock in place a partial LCA layout while APR places and routes additions to the design.

**Note:** If you do not lock in place a partially placed-and-routed design, the design is rearranged to yield a new placement when APR places and routes an **addition** to the design.

The APR software is extremely flexible. Through directives, you optimize the placement for a particular design. You can also specify routing resources to minimize clock skews and signal delays for critical paths. This results in faster product development.

Refer to Chapter 5 of this manual for a discussion of manual placement and routing. Refer to the LCA Development System manual, Volume II, Section I, for specific instructions on using APR.
2.5 DESIGN OPTIMIZATION

After initial placement and routing, you can optimize your design as follows.

1. Use the LCA design editor, EDITLCA, to optimize placement and routing.

2. Use the LCA design editor’s delay calculator to check point-to-point timing after optimization.

2.5.1 ROUTING OPTIMIZATION

Whether you enter a design using schematic-entry software or lay out a design manually, you may have to use manual placement-and-routing and delay analysis for design optimization. You can modify the placement of your design by moving CLBs and re-routing the affected interconnection.

You also can lay out a complete design manually by using EDITLCA to configure design elements such as CLBs, IOBs, or system macros.

In either case, individual elements are configured directly with EDITLCA, either through Boolean equations or Karnaugh maps. A macro can be selected to automatically configure a block or group of blocks for a specified function.

The AMD LCA device supports a variety of routing resources, including long lines, global clock buffers, and direct connection.

Refer to Chapter 5 of this manual for more information on how to manually place and route LCA devices, and how to optimize the placement and routing of your LCA design to improve its performance. Two good ways to monitor the performance of your LCA design are with the LCA design editor’s delay calculator, discussed next, and through timing verification, which is discussed under 2.6.
2.5.2 DELAY CALCULATION

You can perform timing analysis on a partially or completely routed LCA design to check its performance. Typically, you monitor the timing on critical paths as you complete the design. You can perform these timing checks quickly and efficiently using the LCA design editor's delay calculator.

The delay calculator is an interactive design tool that calculates and displays the worst-case delays associated with CLBs, IOBs, and interconnections. It is particularly useful for evaluating various placement-and-routing options during design optimization. The calculated delay represents the worst-case delay from the source block for that signal to the destination selected.

The delays are calculated based on the selected speed grade for the design; you can select an alternate speed grade to examine its impact on critical-path timing. Also, the worst-case delay calculations are from clock-edge to clock-edge for clocked systems.

The LCA design editor's delay calculator also flags any paths over which the signal is significantly degraded. In addition to displaying timing for individual networks, this delay calculator can produce a listing showing timing for all logic networks in a design.

Chapter 5 also contains a detailed discussion of timing analysis with the LCA design editor's delay calculator. See the DELAY command description in the LCA Development System manual, Volume I, Chapter 3.
2.6 TIMING VERIFICATION

At this point in the design cycle you should have an optimized, placed, and routed layout. You are ready to verify the timing and the logic.

Simulating a design's timing can be done either before or after the design has been verified in-circuit. You should simulate the critical paths to ensure that the design will function under worst-case process, voltage, and temperature conditions. The results obtained here should be compared with the logic simulation results to ensure that any layout editing did not change your design's functionality.

**Timing verification** lets you verify critical timing over worst-case power supply, temperature, and process conditions. It also helps you select the correct LCA speed grade for your application. To do this,

1. Use the LCA2XNF command to translate the routed CLB-based LCA design file into a CLB-based netlist that includes routing delays.

2. Use XNF2sim to translate the XNF netlist to an appropriate format for your simulator.

3. Simulate, review the timing information, and ensure no logic changes have occurred.

4. Use the LCA design editor, EDITLCA, to edit and optimize the design's timing until it meets your design specifications. Then repeat steps 1 through 4 above.

Once you are satisfied with the layout, you can proceed to in-circuit design verification. However, to make design changes, always return to the original schematic, make the design changes at that level, and then repeat all succeeding steps.
Once the design meets your specifications, you can verify the design in-circuit. **In-circuit design verification** is the final stage of the LCA design cycle. You ensure that your design meets the specifications in the **target system**, the one for which it was designed. In-circuit design verification includes the following.

1. Use the XACT Bit-Stream Generator to automatically create the LCA design's **configuration bit stream**.

2. Verify your design's logic and timing in any of the following three ways.
   - Use the download cable to transfer the configuration bit stream to the LCA device in the target system.
   - Program a PROM and use it to configure the LCA device(s) in the target system.
   - Use XACTOR, the in-circuit emulator, to emulate the LCA device(s) in the target system.

These three methods are discussed below. Refer to Chapter 6 in this manual for a detailed discussion of the configuration process, which includes generating a configuration bit-stream file from a design file in the LCA format.

### 2.7.1 DOWNLOAD CABLE

After you generate the configuration bit stream, you can use the bit-stream generator and download cable to program the LCA device for in-circuit verification, as described below.

The download cable connects the LCA device in the system under development to the parallel port on the LCA workstation, as shown in the next figure. The bit-
To program the LCA device, you use the bit-stream generator to transfer the configuration bit stream across the download cable to the LCA device in the target system.

**Note:** During development and debugging, you can use this capability to save time because you do not need to reprogram a PROM each time you modify the configuration bit stream.

For more information on the XACT bit-stream generator, MAKEBITS, and the download cable, refer to the LCA Development System manual, Volume I, Chapter 7.

**2.7.2 PROM PROGRAMMING**

After creating the configuration bit stream for your LCA design, you can use it to program a PROM and let the PROM configure the target system LCA device(s), as explained below.
To load a PROM with the configuration bit stream for one or more LCA device(s), first convert the configuration bit stream into a **PROM-format file**. The LCA PROM formatter can create files automatically in a variety of standard PROM formats, for PROMs from 2 kB to 8 kB and larger. Each PROM file can represent one or more LCA designs, so one PROM can configure one LCA device or several daisy-chained LCA devices.

The LCA Development System manual, Volume I, Chapter 6, provides a complete description of the LCA PROM formatter, including the formatter commands.

2.7.3 **XACTOR**

The XACTOR in-circuit emulator provides real-time, interactive target-system emulation of up to four LCA devices from the host PC.

**Note:** In-circuit emulation enhances design simulation by letting you verify your LCA design's functionality in the target system in real time, while working with all other circuits and system software.

The XACTOR configuration, shown next, consists of a microcomputer-based controller and from one to four universal emulation pods, each with an emulation header. One pod and header is included with the basic LCA system. The XACTOR controller, connected to the PC workstation through a serial port, provides the following.

- Local storage of configuration bit streams
- Control of individual device configurations
- Control of the isolation of the pod device(s) from the target system

You set the state and isolation for each control signal to provide debugging of the target system hardware.
To emulate your design, the XACTOR controller programs the emulation LCA device in each of up to four emulation pods. After programming, each emulation pod provides the functionality of one or more LCA devices plugged directly into the target system. You can program the LCA devices in the target system individually or in a daisy chain. XACTOR supports daisy chains of up to seven LCA devices from any of the four emulation pods. You control each device's isolation and configuration with menu or keyboard commands. These can be supplemented by user-defined setup files for easy system debugging.

Using XACTOR, you can read back the device configuration to verify the configuration process and to interrogate the internal states. After you perform a read-back operation, XACTOR displays the state of all internal storage elements, isolation switches, and control signals. XACTOR also automatically reports asynchronous status changes in the target system. Refer to the discussion on reading back the configuration bit stream in Chapter 6 of this manual for more specific information.

Due to the speed with which you can modify a design in-circuit with XACTOR, you may find it useful to implement temporary debugging circuitry in your design during development. For example, you could temporarily connect unused I/O blocks to internal nodes for viewing with a logic analyzer or an oscilloscope.

For complete information on the XACTOR in-circuit emulator, refer to the LCA Development System manual, Volume I, Chapter 8.
CHAPTER 3

CONFIGURABLE LOGIC BLOCKS

3.1 OVERVIEW ................................................................................................................ 2
3.2 LCA STRUCTURE ...................................................................................................... 4
  3.2.1 CLBS ............................................................................................................. 4
  3.2.2 THE INPUT/OUTPUT BLOCK .......................................................................... 9
3.3 LOGIC DESIGN WITH CLBS ...................................................................................... 11
  3.3.1 CREATE BASIC LOGIC ................................................................................. 11
  3.3.2 COMBINE OR SHARE CLBS ......................................................................... 15
3.4 CLB TIMING .............................................................................................................. 21
  3.4.1 TIMING FACTORS ........................................................................................ 21
  3.4.2 LATCHES, FLIP-FLOPS, AND REGISTERS ................................................... 23
  3.4.3 COUNTERS ................................................................................................. 25
    3.4.3.1 Johnson Counters ......................................................................... 25
    3.4.3.2 Binary-Weighted Sequence Counters ........................................... 26
  3.4.4 SYNCHRONOUS VERSUS ........................................................................... 30
    3.4.4.1 Asynchronous Ripple Counters ...................................................... 31
    3.4.4.2 Synchronous Linear Feedback Shift Registers ................................ 33
  3.4.5 ASYNCHRONOUS INPUTS ........................................................................... 35
  3.4.6 CLOCK SKEW ............................................................................................. 37
3.5 LOGIC DESIGN WITH XACT MACROCELLS ............................................................... 38
  3.5.1 MACRO OVERVIEW ..................................................................................... 38
  3.5.2 MACRO CREATION ...................................................................................... 39
  3.5.3 SAMPLE MACROS ...................................................................................... 40
This chapter introduces configurable logic blocks, the basic design element of the Logic Cell Array (LCA).

- The overview, 3.1, provides a brief introduction to the design of LCA devices and to the LCA development system's part in this process.

- The discussion of the LCA device structure, 3.2, explains configurable logic blocks (CLBs) and describes their basic structure.

- The discussion on CLBs, 3.3, explains how to generate logic designs with CLBs.

- The discussion on timing, 3.4, explains the timing characteristics of CLBs.

- The discussion on logic design, 3.5, discusses LCA design using macrocells from the LCA macrocell library.

The macrocell library mentioned in this chapter is the LCA development system macrocell library. The AMD-supplied LCA logic libraries that support the schematic design-entry method are discussed in Chapter 2.
3.1 OVERVIEW

Each new technology available for digital design offers the designer a new set of characteristics. These characteristics include speed, power, integration level, reliability and selection of logic functions. A good designer makes the best use of a technology's design characteristics by matching the design's methodology and logic architecture to these characteristics.

The digital design and architecture for LCA devices is similar to that of conventional TTL SSI/MSI or gate arrays. However, the designer of LCA devices has additional design flexibility because of the lack of typical design limitations, which could include logic in four-bit or eight-bit increments, a specific set of inputs and outputs, or a combination of logic functions.

The core of the CMOS LCA integrated circuit is an array of user-programmable logic elements called configurable logic blocks, or CLBs. User-programmable interconnections of the CLBs create the required logic networks. Individually programmable input/output blocks, or IOBs, provide the interfaces for the LCA device's input/output. With these resources, you are free to tailor the LCA logic; you are not confined to standard product devices or gate array library elements.

AMD's LCA device gives you a higher level of integration than other standard products. The benefits of this higher integration level include

- increased performance and reliability,
- reduced printed circuit board space,
- lower power requirements,
- shorter design time, and
- smaller component inventories.

To create the logic capacity of one LCA device usually requires 40 to 100 SSI/MSI packages. Also, the LCA user-programmability gives you a single, fully-tested inventory item you can use in multiple products.
Using the conventional gate array definition of one gate as a 2-input NAND function, the LCA 2000 family provides a logic capacity up to 2000 gates. Using a single LCA device to construct part of a system design can reduce the package pin count of the design from hundreds of SSI/MSI pins to 48, 64, or 84 LCA pins. These three available LCA packages provide up to 84 pins that you can program as logic input, output, or both.

The next discussion introduces two main components of the LCA device, the CLB and the IOB.
This discussion details the structure of a CLB. It also briefly discusses the IOB, which is described in more detail in Chapter 4.

The CLB is the basic logic building block in an LCA design. Each CLB has four logic inputs and two logic outputs. It includes a combinational-function portion and a storage-element portion. You can configure the combinational function to perform any function of four variables. You can configure the storage element as a transparent latch or an edge-triggered flip-flop.

You enter and verify an LCA design using the LCA development system, then generate a configuration bit stream that defines the appropriate functions within the CLB.

The interconnection of CLBs consists of a two-layer grid of metal segments. These metal segments are joined at each intersection by a switching matrix of controlled pass transistors that creates the interconnection paths of the CLBs and IOBs. Additional pass transistors connect these metal interconnections to the IOBs.
The following figure shows a single memory cell that controls a simple two-to-one multiplexer made of two pass transistors.

Combining eight of these readable memory cells to control an eight-to-one multiplexer tree, as shown below, creates a circuit capable of generating any logic function of the three-input variables A, B, and C.
As illustrated above, the C, B, A input code 101 reads the contents of memory cell five. The data pattern of the readable memory cells defines the logic function. Doubling the look-up table and multiplexer creates a circuit that can generate any function of four variables, which is the basis of the CLB's combinational portion. The CLB includes programmable multiplexers for input variables A, B, C, D, and Q, shown in the next figure, and a selection of outputs, to create either a single function of four variables or two functions of three variables each.

The following figure shows the CLB's combinational function generator. As you can see, some paths are shorter than others.
Combinational Function Generation

MIRROR COPY OF A, B, C, D, Q, AND MEMORY CELLS FROM ABOVE
When a CLB generates a four-variable function, both halves of the look-up table select either the input variable D, or the Q of the storage element; the single result produces both F and G outputs.

When a CLB generates two functions of three variables, the D vs. Q selection is independent for the functions F and G. Each function can then use any three of the five available variables as input: A, B, C, D, or Q.

A CLB can generate a third type of function by using the input variable B to select between the two three-variable combinational functions. This configuration results in a compound function that can involve some combinations of all five variables.

The programmable features of the CLB storage element are shown below.

CLB Storage Element

You can leave the storage element part of a CLB unused, or program it as a level-transparent latch or an edge-triggered flip-flop. The combinational function F supplies its data input. You can also select the
invertible flip-flop clock or latch enable from any of three sources, on a CLB-by-CLB basis. Each CLB storage element has available an active-HIGH asynchronous SET, and a RESET. RESET is dominant over SET; the active-LOW chip input, \( \sim \text{RESET} \), clears all storage elements.

### 3.2.2 THE INPUT/OUTPUT BLOCK

The IOBs provide access between the CLBs and the world external to the LCA device. As illustrated below, IOBs can provide a direct or registered input to the chip.

The positive-edge clock for the register function is common along each die edge. The chip configuration process, as well as the active-LOW chip reset, \( \sim \text{RESET} \), clears the storage elements.
Each IOB includes an input/output buffer you can enable continuously to create an output pin, disable continuously to create an input or unused pin, or enable by logic signals to create an I/O or bus pin.

For more information on IOBs, refer to Chapter 4 of this manual.
This discussion explains how to use CLBs to design basic logic elements. It explains how to use CLBs, partial CLBs, and multiple CLBs to generate common functions.

3.3.1 CREATE BASIC LOGIC

To create basic logic, you can choose from several equivalent ways of representing a CLB function, both schematically and mathematically. The LCA design editor, EditLCA, supports design entry through Karnaugh maps, truth tables, and Boolean equations. The CLB's ability to accommodate either sense of input variables, and to generate either sense of an output, lets you eliminate extraneous inverters. In most cases, however, it is practical to route only active-HIGH signals, thus avoiding the duplicate routing of both true and complement signals. The following figure shows

A. A typical four-variable combinational function as a logic diagram, a Boolean equation, and a Karnaugh map.

B. Equivalent forms of the function.

C. Equivalent forms of the function.

The active-LOW inputs replace the inverters of the conventional representation and the output symbol is an OR. AMD-supported schematic-capture interface software converts the logic in an LCA schematic design into an equivalent representation and groups the combinational gates while translating your design into LCA design files.
Alternate Representations of the Same Function in an LCA Device

\[ Z_1 = Z_2 = A \cdot (\overline{B} \cdot C) + B \cdot C \cdot D \]

\[ Z_1 = Z_2 = Z_3 \]

\[ Z_3 = \overline{A} \cdot (\overline{B} + C) + A \cdot C \cdot D \]
The ADDER shown below illustrates how to use two combinational functions of three variables. The SUM and CARRY functions are usually grouped in the same CLB because of their common input variables.

\[
\text{SUM} = A \cdot \overline{B} \cdot \overline{C} + \overline{A} \cdot B \cdot \overline{C} \\
\quad + \overline{A} \cdot B \cdot C + A \cdot B \cdot C
\]

\[
\text{CARRY} = A \cdot B + A \cdot C + B \cdot C
\]
The four-input exclusive-OR gates in the following figure are an example of a common logic function that is not obviously four-variable. It is a modulo-2 add without a carry.

\[
Z_a = A \oplus B \oplus C \oplus D
\]

\[
Z_b = A \oplus B \oplus C \oplus D
\]

Four-Input Exclusive OR

COMPARE, which is similar, is usually a two-input function. The figure below shows a CLB-generated dual compare function, which compares two bits from each of two sources.

\[
Z = (A_0 \cdot B_0 + \overline{A_0} \cdot \overline{B_0}) \cdot (A_1 \cdot B_1 + \overline{A_1} \cdot \overline{B_1})
\]

Dual Compare CLB
3.3.2 COMBINE OR SHARE CLBs

You can combine several CLBs to create an expanded function, or two different CLB functions can share a single CLB.

By using multiple CLB levels, you can expand the basic CLB design element of four input variables. For example, one CLB driven by four others can produce the sixteen-variable function shown below. If you select the decodes to use common terms in several functions, you can share those CLBs.

![Diagram of a function of 16 variables]

You can use a related technique to encode the results of a pair of three-input, two-output CLBs. Use one of three output codes to indicate which of three selected input conditions exist. Possible combinations of the two CLB outputs can represent four conditions, namely...
One, Two, Three, or Other. Each CLB encodes a three-input subset of the variables. When two of these first-level codes are input to another CLB, its result can be a complex function of six inputs.

The next figure shows two encoded results, each a function of three inputs. Each CLB responds with the selected code when its inputs match its part of the desired minterm. A HIGH output indicates that both codes match the same selected value, yielding a sum of three six-variable products.
Encoding Partial Results of Six Variables

<table>
<thead>
<tr>
<th></th>
<th>CLB2 INPUT</th>
<th>CLB2 OUTPUT</th>
<th>CLB1 INPUT</th>
<th>CLB1 OUTPUT</th>
<th>CODE</th>
<th>RESULT</th>
</tr>
</thead>
<tbody>
<tr>
<td>A5</td>
<td>A4 A3</td>
<td>F2 G2</td>
<td>A2 A1 A0</td>
<td>F1 G1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Z1</td>
<td>0 0 1</td>
<td>0 1</td>
<td>0 1 0</td>
<td>0</td>
<td>0 1 1 1 1 1</td>
<td>1</td>
</tr>
<tr>
<td>Z2</td>
<td>1 0 0</td>
<td>1 0</td>
<td>0 1 1</td>
<td>0 1</td>
<td>1 0 1 0 1</td>
<td>1</td>
</tr>
<tr>
<td>Z3</td>
<td>1 0 1</td>
<td>1 1</td>
<td>1 1 0</td>
<td>1</td>
<td>1 0 1 1</td>
<td>1</td>
</tr>
<tr>
<td>Z</td>
<td>OTHER</td>
<td>OTHER</td>
<td>OTHER</td>
<td>F2 G2 ≠ F1 G1</td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

\[ Z = Z_1 + Z_2 + Z_3 = \text{OTHER} \]
If a design does not require some part of a conventional logic function, you need not create that portion of the function. For example, the above design of the encoder does not use all of the decodes of a set of input variables, so you can omit the unused decodes.

In an output-intensive function, using each CLB to generate two functions of three shared variables can be more efficient than generating one function per CLB. The next figure illustrates this technique. The **PRESELECT enabling gates** created in this figure are an example of a common term of a wider input function. To improve system speed, you can use the input variables that become stable first at the first level of logic. Those variables can propagate, while the design's more timing-critical inputs drive the shorter propagation path.

![Decoder with Common Term and Only Required Outputs](image)

You can build **wide multiplexer functions** from a tree of 2-to-1 multiplexers. This kind of structure,
illustrated below, leaves the storage element and one input variable of each CLB available for use as an independent register function. In other cases, the multiplexer

- can be the data input to the storage element,
- can share input variables, or
- can use the output of the storage element.

These examples provide a natural grouping of shared functions in a CLB.
A common element in digital systems is a **group of registers with sets of enabled output buffers bused together**. The structure shown below is not always recognized as a multiplexer; however, the multiple sources provide the inputs, and the enables represent the select lines. All inputs driven by the bus are driven by the multiplexer output.

![Diagram of a 2:1 MUX](image)

Three-State Function Creates a MUX
3.4 CLB TIMING

This discussion explains the general timing factors in CLB design. It then discusses the specific timing for various CLB functions, including latches, flip-flops, registers, and counters. It also compares the timing of synchronous versus asynchronous design, and timing considerations for asynchronous inputs and clock skew.

3.4.1 TIMING FACTORS

Any Boolean function generated by a CLB has the same timing delay as any other CLB-generated function. The concept of levels of logic or gate delay loses its significance with LCA devices, in which higher-level primitives perform logic.

The primary timing factors involved in designing an LCA device are listed below.

- The propagation time of a CLB
- The clock-to-block output via Q
- The input setup time for the CLB flip-flop input variables
- The input and output pad buffer delays
- The interconnection timing

Although other switching characteristics are specified in the LCA data sheet, the timing factors listed above are the most important in determining LCA performance. Some of these factors are illustrated and discussed below.
MSI devices typically have matched internal delay paths and low-impedance outputs that are independent of loading. Logic delays are more sensitive to output loading in programmable CMOS array architectures than in bipolar devices. As with CMOS gate arrays, variations in internal signal delays are significant in the LCA device. Synchronous design techniques can minimize the complexities of signal timing caused by delay accumulations in CMOS designs. An additional advantage of synchronous design is better control of output timing.

The clock distribution resources of the LCA device simplify synchronous design. When you can program any function of the input variables, it is simple to include such control signals as RESET, CLOCK ENABLE, and PARALLEL ENABLE in the logic function for the data input of flip-flops. All flip-flops can then use a common clock. With the flexibility of the LCA device you can generate and use individual CLB clocks, as well as...
asynchronous SET and RESET, if required by the application.

3.4.2 LATCHES, FLIP-FLOPS, AND REGISTERS

LCA configurability lets you tailor the storage elements of the CLBs to fit your applications. Together with complex combinational data functions, this configurability lets you construct a wider variety of latches and flip-flops in LCA devices than is found in standard parts or gate array cell libraries.

The level-transparent form of the storage element is the D latch. The edge-clocked form is the D flip-flop. In both cases, the function $F$ supplies the data input, and the $K$ or $C$ pin or the function $G$ supplies the clock (LOAD ENABLE). You select the data input, the clock, and the active sense of the signal on a block-by-block basis.

Including a RESET variable in the combinational input of a flip-flop produces a synchronous RESET, as shown below.

You can use a combinational function of $Q$ with input variables to generate a CLOCK ENABLE, as illustrated in the next figure.
F = CLKENA • DATA + CLKENA • Q

As shown below, you can also create a multiplexer as the input of a flip-flop to provide a PARALLEL ENABLE.

F = PARENA • Dp + PARENA • Ds

A flip-flop can have parallel data or reset inputs that do, or do not, depend on the clock enable. As with the J-K flip-flop, an interesting derivative of the set-reset flip-flop is one that does not change state in the case of simultaneous set and reset conditions. The other types of flip-flops are set-dominant or reset-dominant. The availability of this variety of synchronous set-reset flip-flops provides you with alternatives for logic creation that can help you minimize next-state control conditions.

A group of related flip-flops with similar functions can form a register. You can group registers into two categories, namely data registers and shift registers. A data register is a set of flip-flops with independent parallel input paths and common control. A shift register is a set of flip-flops with a serial data relationship. Both
3.4.3 COUNTERS

Counters are a simple example of a state machine with a regular sequence. The most familiar counters are the Johnson or Mobius counter discussed under 3.4.3.1, the binary weighted sequence discussed under 3.4.3.2, and the Linear Feedback Shift Register discussed under 4.2.6.7.

3.4.3.1 Johnson Counters

Johnson counters often offer advantages for counter designs with a modulo of less than 10 to 12. Also, they are simple to place and route, and the basic combinational functions shown below are compatible with maximum clock frequency.

In a Johnson counter, decodes of single or consecutive states are simple and glitch-free. Initializing the LCA device clears all storage elements. However, due to the presence of unused states, the Johnson counter could enter an alternate state sequence if there are any asynchronous control inputs. As shown in the next figure, additional input variables from QB and QD in the feedback function can return the count to the proper sequence.
3.4.3.2 Binary-Weighted Sequence Counters

When creating a large-modulo CMOS binary-weighted counter, you are presented with a number of trade-offs. In terms of physical resources, the most effective counter of this type is a simple ripple counter; however, the accumulation of multiple clock-to-Q flip-flop delays can be prohibitive because the outputs ripple for varying times.
A synchronous toggle flip-flop is shown below.

A. Changes state synchronously if $T$ is HIGH.

B. Shows the simplified symbol for the flip-flop.

C. Illustrates the AND of two inputs, which produces the $T$. 

Toggle Flip-Flop
The following figure shows a fully synchronous counter solution composed of T flip-flops. This design generates the counter's toggle ripple carry for each bit by adding a carry gate, which tests the previous toggle carry and the state of its flip-flop in a daisy-chain fashion. The counter's maximum clock rate is determined by the total propagation time for the carry path from CLKENA to data setup of the last bit.

The fully parallel counter shown next generates each toggle function directly. This counter design requires an n-wide gate for toggle control of each bit of the counter. You can extend this design to 12 bits. The total delay would then consist of one combinational propagation delay between register CLBs, one clock-to-Q delay, one set-up time delay, and the interconnection delay.
When designing counters, you can use block-level carries. The 3-bit segment size shown in the lower half of the above figure accommodates the three stages and a carry-in within the single-CLB 4-input limit. The only combinational delays are those of T3' and T6'. Without a clock enable input, the first section could be 4 bits, followed by 3-bit sections. When designing LCA devices, you must watch for design trade-offs and not try to fit a standard solution into all applications.

The figure below illustrates another synchronous 8-bit counter with a single level of combinational propagation delay. The figure shows the merging of the sequential and combinational elements of the CLB. This counter uses periodic look-ahead carry terms to make efficient use of variables within the block.

3.4.4 SYNCHRONOUS VERSUS ASYNCHRONOUS DESIGN

Efficient LCA-based designs can differ from MSI designs. MSI elements are general purpose building blocks that exploit the strengths of a different technology. Most MSI parts are designed to fit a set of standard package sizes and the pin functions are chosen to provide a useful standard product. The LCA design goals and techniques are very different.

When designing LCA devices, your goal is to minimize the routing and number of blocks. In fact, you can often adapt your design's
3.4.4.1 Asynchronous Ripple Counters

logic to minimize the constraints of the available logic and routing resources and to optimize the LCA device's logic capacity and performance.

The three- and four-variable capability of the CLB is a good balance in LCA devices and gate arrays. You can use a conventional logic diagram of your design and group the combinational functions to give an approximate CLB count. In a register-intensive design, the number of flip-flops required by the design determines the logic capacity and related combinational functions merge with the sequential portions.

The ripple counter shown next incorporates a counter that sets and resets output control bits at specific times in the sequence. NAND gates that decode the desired states drive the asynchronous set and reset inputs of the flip-flops. When the counter increments to state D, it should asynchronously reset to 0.
Simple Asynchronous Ripple State Machine
3.4.4.2 Synchronous Linear Feedback Shift Registers

The above counter might operate properly if it were an MSI device because the counter bits in such a device are matched. To use this counter in a gate array or LCA device, however, the decodes of the counter states involve mismatched loading and layout of various counter bits. As a result, the decode gates are likely to produce output spikes, causing erratic operation of the output control flip-flops that use these signals as asynchronous inputs. Although the decode spikes can be so narrow that you do not notice them during design verification, they might produce erratic output control changes during operation. The decode of the terminal count also has the potential for spurious outputs. Even with a valid terminal count decode, a mismatch in counter bit speeds could result in some bits resetting and terminating the reset state decode signal before all bits of the counter are reset. This timing problem could leave the counter in an undefined or incorrect state. A reasonable alternative to the asynchronous ripple counter is the synchronous linear feedback shift register, which is discussed next.

The following figure shows a Linear Feedback Shift Register, which is a fully synchronous alternative to the asynchronous-reset binary counter. This class of counters follows a less familiar sequence, but its decodes of specific counts are predictable. Use of OR/AND feedback for inputs on the output flip-flops results in a synchronous SET/RESET function for the output control bits, making them immune to decoding spikes.

Notice that the resulting X and Y sequences are identical, although the counter sequences differ and the control decodes of the synchronous version represent the state before X or Y transition. This synchronous design revision also lets the clock control the output timing; in the ripple counter of the previous figure, the output timing is controlled by the
accumulation of delay from the clock to the counter output, then to the state decode, and finally through the flip-flop to the output. The use of a fully synchronous counter reset provides more reliable counter operation, and you may be able to increase the maximum clock rate due to the elimination of the terminal count delay path. Generating the flip-flop synchronous reset requires no more resources than that of the asynchronous reset described above for the ripple counter.

Synchronous State Machine
Another common source of design problems is the timing of asynchronous input signals that affect more than a single flip-flop. An example is a counter in which an asynchronous parallel load is removed near a clock edge. Various bits of the counter may change in response to the clock, while others retain the previous state. The result is an invalid value in the counter.

Another common design problem is that of an asynchronous system reset. If the reset signal is removed near a clock-edge, different parts of the logic may respond differently, resulting in invalid states as the logic tries to begin operation. Clearly, you should always synchronize asynchronous signals at their input, as shown in the following figure.
You can accommodate asynchronous inputs that require a response to their transition by using a resynchronizer, as illustrated below. The additional input delay this solution imposes may be undesirable in some applications but it results in a more reliable design when input latency is not a limiting factor. The resynchronizer also acts as a simple noise filter.
The problem of clock skew accounts for numerous gate array design iterations. Clock skew problems are caused by mismatched delay paths. For example, you could clock one flip-flop, and its new output level, lightly loaded, could propagate to another flip-flop input, arriving as much as one set-up time before the original clock reaches a second flip-flop. The difference in clock timing can occur because of clock gating or unequal routing delays. To minimize clock skew in an LCA device, the LCA clock buffers drive a dedicated metal clock distribution network.
3.5 LOGIC DESIGN WITH XACT MACROCELLS

Macrocells, also called macros, are predefined CLB or IOB configurations that use common logic functions. The LCA development system includes a library of macros that you can use to create your LCA designs. You can also create your own macros. This discussion provides detailed information about macros and gives you an overview of how to create one. It also shows some sample macros.

3.5.1 MACRO OVERVIEW

Using macros when you optimize your LCA design is a quick way to specify a function. Each macro is actually a file that contains all of the executable EditLCA commands required to define the macro’s function in the LCA design. When you invoke a macro, you provide the set of parameters needed to execute the file in the required order.

The parameters you supply customize each occurrence, or instance, of the macro in your design. The parameters include such information as an instance name, the names of networks providing inputs, and the block locations for each CLB or IOB in the macro. The instance name is used during macro execution to compose unique block and net names that distinguish each occurrence of a particular macro in your design.

Macros in the AMD macrocell library are stored in the \MACROS directory. Each macro file has an assigned name with a .MAC file extension that identifies the logic function. You can find a list of the macros in the AMD library and the order of their required parameters in the Quick Reference Card and the LCA Macrocell Library Manual. The macro documentation indicates the required parameter order in the syntax statement for each macro.

In addition to using the available macros, you can create customized macros as follows.
3.5.2 MACRO CREATION

EDITLCA commands and macro executions let you create an LCA design as well as modify macros. After editing, you may want to incorporate part of that new design or modified macro into a new macro. For example, you might create a new macro that is a one-bit slice of useful logic and which may include several CLBs. Then you can place several instances of that macro to create a more complex logic unit, such as a data path. Another useful user-defined macro could describe a section of a special counter that generates a unit of control logic.

To create a macro, you first use the keyboard or mouse to specify the individual blocks that must be included. The LCA development system assigns a parameter for each network that the user has selected as a macro input, as well as for each CLB and IOB that this macro uses. All block names and net names sourced by the macro blocks are included in the new macro's .MAC file, which is created in the current directory.

When you invoke the macro, you are prompted for parameters in the order they are needed. The first required parameter is always the instance name. This name differentiates one instance of a macro from any other instance of the same macro in the design. The instance name is added as a prefix to the macro's original net names for all nets driven by blocks included in the macro. The instance name is also added as a suffix to the original block name of all blocks in the macro to allow the first characters of the block names to show in the editor display.
Note: All block and net names must be unique. Reserved names include A, B, C, D, K, I, O, X, and Y, which are already used for block pin names. Also reserved are AA through last row/column of the LCA design, and P1 through highest pin number of the LCA design, as block names. Some additional reserved names are assigned to configuration and power pins.

Refer to Chapter 4 in the LCA Development System manual Volume I for specific information on how to create macros.

3.5.3 SAMPLE MACROS

Several sample macros are illustrated below. The first figure shows the logic diagrams for FDR, a simple D flip-flop with synchronous reset.

The macro for this figure is shown below. The first two lines in the macro are comment lines indicating the syntax and parameter order for macro execution. The comments in the macro are self-explanatory.

Note: %1 through %5 represent the parameter values you supply.
| Parameter NAME ? Enter instance name: |
| Parameter NET Clock Select Clock net: |
| Parameter NET Data Select Data net: |
| Parameter NET Reset select Reset net: |
| Parameter CLB ? Select %1 block: |

Nameblk %5 %1
Editblk %5
Base 3var
Equate F = B*-C
Endblk

Addpin %2 %5.K
Addpin %3 %5.B
Addpin %4 %5.C
Addpin %1Q %5.X

Parameter statements specify parameter type, the default names for nets, followed Parameter by the Select prompts for the editor screen.

Addpin commands define the nets. The first parameter variable is the name (or default) supplied by that parameter in the installation statement. The %1Q is a Q concatenation on the instance name %1.
The GOSC macro in the following figure is a simple oscillator that uses two external R-C networks, two IOBs and one CLB that functions as a set-reset latch.

\[ T = T_1 = T_2 = N ((R_1 C_1) + (R_2 C_2)) \]

where \( N \) = approx. 0.35 for TTL threshold
= approx. 0.75 for CMOS threshold

when each capacitor is allowed to be discharged by the LCA during opposite timing phase. Capacitor might partially charge due to a delayed 3-state routing.
The macro for this GOSC is shown below. Refer to Chapter 4 Volume I of the LCA Development System manual for specific information about how to use and create macros. Also, refer to the discussion in Chapter 2 of this manual for details about the AMD-supported logic libraries used in schematic entry of LCA designs.
<table>
<thead>
<tr>
<th>:macro</th>
<th>GOSC</th>
<th>Name</th>
<th>LocQ</th>
<th>LocCQ</th>
<th>LocCQL</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>%1</td>
<td>%2</td>
<td>%3</td>
<td>%4</td>
</tr>
</tbody>
</table>

Parameter NAME ? Enter instance name:  
Parameter CLB ? Select %1 CLB block:  
Parameter IOB ? Select CQ%1 I/O block:  
Parameter IOB ? Select CQL%1 I/O block:  

Nameblk %2 %1  
Editblk %2  
Base 3var  
Equate F = \~B* (C+A)  
Equate G = \~A  
Endblk  

Nameblk %3 CQ%1  
Editblk %3  
Base IO  
Config I:PAD BUF:TRI  
Endblk  

Nameblk %4 CQL%1  
Editblk %4  
Base IO  
Config I:PAD BUF:TRI  
Endblk  

Addpin %1Q %2.X %2.A %3.0 %3.T  
Addpin %1Reset %3.I %2.C  
Addpin %1Set %4.I %2.C  
Addpin %1QL %2.Y %4.O %4.T  

Parameter statements  
| Parameter (%) as  
| block name to block  
| specified by (%)  
| assigns the first parameter (%1) as block name to block specified by (%2) and configures it.  
| assigns the CQ prefix to instance name for the block selected as the third parameter and configures it.  
| assigns the CQL prefix to block name for the fourth parameter and configures it.  
| creates nets of names with concatenation to the pins .x, .a, .o, .t etc. of the blocks identified by the %2, %3, %4 parameters.  

2000 SERIES LCA DESIGN HANDBOOK CHAPTER 3  
June 1988
CHAPTER 4
INPUT/OUTPUT BLOCKS

INPUT/OUTPUT BLOCKS ........................................................................................................... 1
4.1 I/O BLOCK OVERVIEW .................................................................................................. 2
  4.1.1 IOB INTRODUCTION ................................................................................................. 2
    4.1.1.1 Input Signals ........................................................................................................ 4
    4.1.1.2 Output Signals ..................................................................................................... 5
    4.1.1.3 Voltage Levels .................................................................................................... 5
  4.1.2 REGISTERED INPUTS AND METASTABILITY ....................................................... 5
4.2 LCA I/O STRUCTURES .................................................................................................. 7
  4.2.1 STANDARD I/O STRUCTURES ................................................................................ 8
  4.2.2 OPEN-COLLECTOR STRUCTURES ........................................................................ 11
    4.2.2.1 Open-Drain Structures and Routing ................................................................. 12
    4.2.2.2 Wired-AND and Wired-OR Structures ............................................................. 15
    4.2.2.3 Multiplexers from Open Collector I/O Structures ............................................. 17
  4.2.3 SCHMITT-TRIGGER STRUCTURES ....................................................................... 18
  4.2.4 GENERAL PURPOSE OSCILLATOR STRUCTURES ................................................ 25
  4.2.5 ON-CHIP CRYSTAL OSCILLATOR STRUCTURES .................................................. 28
  4.2.6 REGISTERS AND COUNTERS ............................................................................... 30
    4.2.6.1 IOB-Based Register Delays ................................................................................ 30
    4.2.6.2 Wide Storage Registers ..................................................................................... 31
    4.2.6.3 Read/Write Registers ......................................................................................... 33
    4.2.6.4 Shift Registers ................................................................................................... 35
    4.2.6.5 Johnson Counters ............................................................................................... 37
    4.2.6.6 Glitchless Johnson Decoder ................................................................................. 39
    4.2.6.7 Linear Feedback Shift Registers ......................................................................... 41
  4.2.7 INCREASED DRIVE-CURRENT STRUCTURES ..................................................... 47
This chapter discusses IOBs, which comprise the LCA I/O structures. The chapter has the following structure.

- The I/O block overview, 4.1, introduces IOBs and discusses some specific IOB operating characteristics.

- The discussion on LCA I/O Structures, 4.2, illustrates the wide variety of I/O structures available for use in LCA designs.
4.1 I/O BLOCK OVERVIEW

This discussion explains LCA Input/Output Blocks, registered inputs, and metastability.

4.1.1 IOB INTRODUCTION

The IOBs in an LCA design surround the array of CLBs, as illustrated below. Where the CLBs are the logic building blocks in an LCA design, IOBs are the building blocks for LCA input, output, and bidirectional I/O structures.
The 2064 and 2018 IOBs are identical. Each IOB can

- drive an output,
- receive an input,
- clock the input into a flip-flop, or
- be both an input and an output under three-state control.

You can configure an IOB to perform a variety of logic functions.

The architecture of the LCA device provides great design flexibility in using inputs and outputs. The IOBs in an LCA device are not dedicated to any fixed logic. Therefore, you can use IOBs for logic structures beyond simple inputs or outputs. Often, designs do not use all IOBs available within the LCA device. You then can use the extra IOBs to build such logic structures as shift registers or Johnson counters.

The following figure shows the schematic of an IOB. The trapezoidal structures in the figure are data-path selectors or multiplexers. How you program these data-path selectors determines what function the IOB performs. For example, you can configure the IOB to perform as

- a direct or registered input,
- a direct or three-state output, or
- a bidirectional data line.
### 4.1.1.1 Input Signals

Along each edge of the LCA die, the IOBs share a common I/O clock signal that drives each input register. All internal registers are reset to a zero state after configuration, or after the ~RESET pin is asserted LOW. Data is clocked into the input register on the positive edge of the I/O clock signal.

A logic signal external to the LCA device comes in through an I/O pad and non-inverting buffer, as shown above. The logic signal is then either directly propagated or fed into the input register, depending on the configuration of the data-path selector.
4.1.1.2 Output Signals

Similarly, output data is driven by the non-inverting buffer shown in the previous figure. The output buffer is forced into a high-impedance state whenever the three-state (TS) control line is HIGH (TS = 1). Conversely, the output buffer propagates the output signal when the three-state control line is LOW (TS = 0). All outputs can source and sink 4 mA under specified worst-case conditions.

4.1.1.3 Voltage Levels

You can configure all IOBs to recognize either TTL-level ('VTH = 1.4 V) or CMOS-level (VTH = 2.2 V) input thresholds. The selected voltage level affects overall device power consumption; power consumption is lower when you select CMOS input levels.

4.1.2 REGISTERED INPUTS AND METASTABILITY

The following schematic shows a registered input within the LCA device. LCA devices are manufactured with a high-speed CMOS process that allows these IOB input registers to achieve flip-flop loop delays of three to five nanoseconds. These short loop delays provide very good performance under asynchronous clock and data transitions. Short loop delays also minimize the probability of a metastable condition that can result when the input to the flip-flop is still in transition while the clock is asserted.

The IOB's short loop-delay characteristics make them effective in synchronizing external signals. After the IOB synchronizes the external signals, you can use the signals internally without further consideration of their relative timing, except as it applies to internal logic and routing-path delays. Chapter 7 of this manual provides further information regarding the metastable behavior of flip-flops and registers in an LCA device.
I/O TYPE: Pad Input with Storage (registered input)
MACRO NAME: PINQ
SCHEMATIC:

CONFIGURATION:
I:Q
BUF:

Input Pad with Storage Register

LCA I/O Structures are discussed next.
4.2 LCA I/O STRUCTURES

This discussion explains some I/O and other logic functions available by configuring IOBs in various ways.

- Discussion 4.2.1 explains standard I/O structures.
- Discussion 4.2.2 explains open-collector structures.
- Discussion 4.2.3 explains Schmitt-trigger structures.
- Discussion 4.2.4 explains general purpose oscillator structures.
- Discussion 4.2.5 explains on-chip crystal oscillator structures.
- Discussion 4.2.6 explains registers and counters.
- Discussion 4.2.7 explains increased drive current structures.

The structures described below use the following conventions for input paths and output buffers. Discussions here show each structure in schematic form and describe its IOB configuration.

You can configure the input path as any of these functions.

- I:PAD - Direct input from the device pad
- I:Q - Registered input
- I: - No input

You can configure the output buffer as follows.

- BUF:ON - Direct output
- BUF:TRI - Three-state output
- BUF: - No output
If an LCA library macro exists for any structures described below, the macro is listed in the schematic as *macro name*.

### 4.2.1 STANDARD I/O STRUCTURES

The six standard LCA I/O structures are listed and pictured below. These *standard structures* are the basic input, output, and bidirectional I/O configurations for an LCA device.

- Input pad
- Input pad with storage register
- Output pad
- Output pad with three-state control
- Bidirectional pad
- Bidirectional pad with input storage

The input pad is shown first.

---

**I/O TYPE:** Pad Input  
**MACRO NAME:** PIN  
**SCHEMATIC:**

![Input Pad Diagram]

**CONFIGURATION:**
- I:PAD
- BUF:
The next two figures show the input pad with a storage register and the output pad, respectively.

**Input Pad with a Storage Register**

- **I/O TYPE:** Pad Input with Storage (registered input)
- **MACRO NAME:** PINQ
- **SCHEMATIC:**

**Configuration:**
- I:Q
- BUF:

**Output Pad**

- **I/O TYPE:** Pad Output
- **MACRO NAME:** POUT
- **SCHEMATIC:**

**Configuration:**
- I:
- BUF:ON
The figure below shows the output pad with three-state control.

![Output Pad with Three-State Control](image1)

The next figure shows a bidirectional input/output pad.

![Bidirectional Input/Output Pad](image2)
Next, you'll see a bidirectional pad with input storage.

I/O TYPE: Pad Input/Output with Input Storage
MACRO NAME: PIOQ
SCHEMATIC:

CONFIGURATION:
I:Q
BUF: TRI

Bidirectional Pad with Input Storage

4.2.2 **OPEN-COLLECTOR STRUCTURES**

The LCA macro library contains a variety of output functions, including wired-AND and wired-OR structures, based on available LCA open-collector structures. The MOS transistor has no collector; therefore, **open-drain outputs** is a more accurate term for MOS devices like the LCA device.

To build an open-drain-output structure in an LCA device, you tie together both the output and the three-state control lines. For an active-HIGH signal, the three-state control engages (high impedance), and the output signal is disabled through the output buffer.
4.2.2.1 Open-Drain Structures and Routing

The signal at the output pad is also high impedance, which allows that particular signal line to float. Connecting this signal line to VCC through a resistor pulls this line up for an active-HIGH output. However, for active-LOW signals the three-state control line is driven LOW to turn on the output buffer and allow the LOW signal to propagate directly to the I/O pad.

When designing with open-drain structures, you should be aware of an LCA-specific phenomenon caused by the different routing delays between the signal source and the output and three-state control loads.

Because a routed signal may take longer to reach an IOB's three-state control line than its output line, the pad can be driven for a short period of time during a LOW to HIGH transition, as shown in the next figure. This could occur if the output line (O) starts to go HIGH before the three-state control line does. Depending on how much routing delay there is between the output and three-state lines, the PAD output could start to go HIGH and then be driven into a high-impedance state. Excessive routing delay differences between the output and the three-state control line may cause a brief output glitch, as shown below. Careful design prevents this.

The above situation is not a problem in most designs. You can check the actual routing delay difference between the TS and O terminals of an IOB using the delay calculator in the LCA development system. See Chapter 2 of this manual for information about the delay calculator.
Brief Output Glitch Caused by Three-State Routing Delay

The next three figures show the available LCA macro library open-drain structures listed below.

- Open-Collector Output Pad
- Open-Collector Bidirectional Input/Output Pad
- Open-Collector Output Pad with Storage

First, the open-collector output is shown, followed by the open-collector bidirectional I/O pad.
I/O TYPE: Pad Output with "Open-Collector"
MACRO NAME: POUTC
SCHEMATIC:

CONFIGURATION:
I:
BUF: TRI

Open-Collector Output Pad

I/O TYPE: Pad Input/Output with "Open Collector"
MACRO NAME: PIOC
SCHEMATIC:

CONFIGURATION:
I: PAD
BUF: TRI

Open-Collector Bidirectional Input/Output Pad
4.2.2.2 Wired-AND and Wired-OR Structures

The open-drain capability of an IOB allows wired-AND and wired-OR structures to become part of the LCA macro library. The AND and OR implementations are essentially the same; the only difference between their forms is the type of logic each uses. You design with wired-AND structures in positive-logic implementations and wired-OR structures in negative-logic implementations.

The next figure shows a typical wired-AND or wired-OR structure. All output pads from the IOBs are externally wired together as a common signal. In a positive-logic system, when all of the logic outputs to the IOBs are TRUE, the three-state control is enabled and the IOB
output PADs are forced to high-impedance. However, since all of the IOBs are tied to Vcc through a pull-up resistor, the line is pulled up to Vcc. If the logic signal to any of the IOBs is FALSE, the corresponding output buffer is turned on and that LOW signal propagates to the common line, pulling the entire line LOW. The entire structure then acts as an AND function; when all outputs are HIGH, the common line is HIGH. If any output is LOW, then the common line is also LOW.

The following equation describes the wired-AND logic.

\[
\text{IOB}_1 \cdot \text{IOB}_2 \cdot \text{IOB}_3 \cdot \ldots \cdot \text{IOB}_n = \text{TRUE}
\]

A wired-OR structure is similar to the wired-AND, except that it is implemented in negative logic. It ORs together a number of active-LOW signals to generate a logic function. The logic equation for a wired-OR, shown below, is merely a DeMorgan-equivalent inversion of the previous equation.
IOB1 + IOB2 + IOB3 + ... + IOBn = FALSE

A typical application of a wired-OR structure is an active-LOW common-interrupt line. An interrupt request from any peripheral pulls the common interrupt line LOW, which informs the processor of the request. You can build a wired-AND or wired-OR function from any number of open-collector outputs.

4.2.2.3 Multiplexers from Open Collector I/O Structures

The LCA macro library also contains another structure built using open-drain IOBs: an n-bit multiplexer, as shown below. All pad outputs are tied together outside of the package, on a common line that becomes the multiplexer output. Each IOB in the multiplexer is configured as an output with three-state control using the LCA library macro POLITZ. The output line (O) of each IOB becomes an input for the multiplexer. Driving the corresponding three-state control line LOW, T = 0, selects a signal; the selected signal propagates to the common output line. The three-state control lines can be driven with a CLB.

Caution: You must avoid contentions on the common output line.
4.2.3 SCHMITT-TRIGGER STRUCTURES

The Schmitt trigger has numerous applications in digital designs. Two of the most common applications are shown below.
A. Schmitt-triggered inputs filter signal noise because of the hysteresis inherent in the switching characteristics of a Schmitt trigger.

B. A Schmitt trigger generates a fast transition for a slowly changing input function when that function reaches a predetermined level. Again, this capability is available due to the hysteresis of the Schmitt trigger.

You can build a variety of Schmitt-triggered input structures in an LCA device. For example, using three IOBs, a CLB, and three resistors, you can create a Schmitt trigger with selectable voltage hysteresis, as shown below.

**Note:** If the amount of hysteresis is not critical, then only two resistors and two IOBs are required.
**I/O TYPE:** Schmitt-Triggered Input With Selectable Hysteresis  
**MACRO NAME:** None

**SCHEMATIC:**

<table>
<thead>
<tr>
<th>EXTERNAL TO LCA</th>
<th>INTERNAL TO LCA</th>
</tr>
</thead>
<tbody>
<tr>
<td><img src="image" alt="Schematic Diagram" /></td>
<td></td>
</tr>
</tbody>
</table>

**CONFIGURATION:**
- IOB 1 - Input
  - I: PAD
  - BUF:
- IOB 2 - Output
  - I:
    - BUF: TRI
- IOB 3 - Output (inverted through CLB)
  - I:
    - BUF: TRI

**COMMENTS:**
Resistors pairs R1:R2 and R1:R3 form two voltage dividers that set the HIGH-going and LOW-going input hysteresis.
Resistors R1 and R2 set the HIGH-going hysteresis (VH) according to this equation:

\[ VH = V_{TH} \left( \frac{R1 + R2}{R2} \right) - V_{OL} \]

Resistors R1 and R3 set the LOW-going hysteresis (VL) according to this

\[ VL = V_{TH} \left( \frac{R1 + R3}{R3} \right) - V_{OH} \]

Three resistors in the above macro select the threshold voltage and the amount of hysteresis for the Schmitt trigger. The three resistors are separated into two-
resistor network pairs, R1:R2 and R1:R3. Each pair forms a voltage divider to set the input-voltage level. One voltage divider sets the HIGH-going transition level (V_H), the other sets the LOW-going transition level (V_L). The value at the input to IOB1 is inverted through a CLB, and then routed to the three-state control line IOB3. The CLB logic adds a small amount of time hysteresis to the signal because the CLB logic and the routing cause delay. The logic delay can be balanced by buffering the input before sending it to the three-state control of IOB2.

An inverting Schmitt trigger is similar to the non-inverting one shown above, except that the sense of the logic is inverted inside the LCA device.

Assume that the input voltage is near ground. The output voltage of IOB2 is at V_{OL}, which pulls resistor R2 toward ground. There is then no potential difference across R2. The output buffer of IOB3 is high-impedance because its three-state control pin is HIGH. Resistor R3 is effectively removed from the circuit and the input voltage is divided by the resistor network formed by resistors R1 and R2. As the input voltage continues to increase, the IOB1 pad voltage eventually reaches its switching threshold.

As soon as the threshold is crossed, IOB1 goes HIGH. This drives the output of IOB2 into high-impedance (IOB2 TS = 1) and enables the output buffer of IOB3 (IOB3 TS = 0). At V_{OH} then, IOB3 pulls the input of IOB1 HIGH through resistor R3. In this state, resistor R2 is effectively removed from the circuit because IOB2 is high-impedance.

The Schmitt-trigger structure remains in this state even if the input voltage fluctuates, unless it fluctuates to the opposite hysteresis limit. Then, the Schmitt trigger goes to the opposite state. In other words, the Schmitt
trigger stays HIGH until the input to IOB1 drops below the LOW-going hysteresis limit, and vice versa.

If the hysteresis values are not critical, the Schmitt-trigger structure requires only two IOBs and two resistors, as shown in the following figure. However, the range of $V_H$ and $V_L$ is very limited. This IOB configured as an output pulls the input HIGH or LOW, depending on the transition direction.

![Schmitt-Triggered Input With Limited Hysteresis](image)

**I/O TYPE:** Schmitt-Triggered Input With Limited Hysteresis  
**MACRO NAME:** None  
**SCHEMATIC:**

**EXTERNAL TO LCA**

**INTERNAL TO LCA**

**CONFIGURATION:**
IOB 1 - Output
  I:
  BUF:ON
IOB 2 - Input
  I:PAD
  BUF:

**COMMENTS:**
Hysteresis values are limited:

$$V_L = \left[\frac{R_1 + R_2}{R_2}\right] V_{TH} - V_{OH} \left(\frac{R_1}{R_2}\right)$$

$$V_H = \left[\frac{R_1 + R_2}{R_2}\right] V_{TH} - V_{OL} \left(\frac{R_1}{R_2}\right)$$

Schmitt-Triggered Input with Limited Hysteresis
If you need a selectable Schmitt trigger only for a single transition direction (HIGH going LOW, or LOW going HIGH), then you can use one of the Schmitt triggers shown in the following figure. These circuits are simpler versions of the one above.

**Note:** A single CLB is required to invert the sense of the input signal, which then enables or disables the output buffer for IOB2 (the one configured as a three-state output.)
I/O TYPE: Unidirectional Schmitt-Triggered Input
MACRO NAME: None

SCHEMATIC:

EXTERNAL TO LCA
R1

INTERNAL TO LCA
PAD
IOB1

DIRECT INPUT

INVERTED INPUT
PAD
CLB

COMMENTS:
\[ V_H = V_{TH} \]
\[ V_L = V_{TH} \left( \frac{R_1 + R_2}{R_2} \right) - V_{OH} \left( \frac{R_1}{R_2} \right) \]

Unidirectional Schmitt-Triggered Input HIGH Going LOW

SCHEMATIC:

EXTERNAL TO LCA
R1

INTERNAL TO LCA
PAD
IOB1

DIRECT INPUT

INVERTED INPUT
PAD
CLB

COMMENTS:
\[ V_H = V_{TH} \left( \frac{R_1 + R_2}{R_2} \right) - V_{OL} \left( \frac{R_1}{R_2} \right) \]
\[ V_L = V_{TH} \]

Unidirectional Schmitt-Triggered Input LOW Going HIGH
4.2.4 GENERAL PURPOSE OSCILLATOR STRUCTURES

The LCA macro library includes general purpose oscillators built using two IOBs and a CLB. The general theory of operation is similar to that described for Schmitt triggers.

In the oscillator shown and described below, the charging and discharging of two capacitors generates the oscillating signal. Capacitor C2 charges to a voltage threshold, on SET, to set a latch. As soon as the voltage across C2 exceeds the threshold, the SET line causes the Q line to go HIGH and discharges C2 by driving the IOB called CQL. After crossing the threshold, the RESET line, which has been held LOW, is allowed to rise as capacitor C1 charges. When capacitor C1 charges to its threshold, the Q output is reset and forced LOW. Capacitor C1 is then discharged by the IOB named CQ and capacitor C2 begins charging again. This process is repeated, creating a low-frequency resistor-capacitor oscillator.

Consider the routing delay of the three-state control lines within the IOBs, named CQ and CQL in the figure. The time period of the oscillator depends on each capacitor being completely discharged during the opposite timing phase. Also, timing depends on both capacitors beginning their charge near ground. A routing-delay difference between the output (O) of an IOB and the three-state control can prevent the capacitors from completely discharging.
I/O TYPE: Low-Frequency Resistor-Capacitor Oscillator
MACRO NAME: GOSC

EXTERNAL TO LCA

CONFIGURATION:
10B1
- ION
- BUF:TRI
10B2
- ION
- BUF:TRI

SAMPLE ARRANGEMENT

Low-Frequency Resistor-Capacitor Oscillator
The following figure illustrates the oscillator’s low-frequency timing characteristics.

\[ T = T_1 + T_2 = N \left( \frac{R_1 \times C_1}{R_2 \times C_2} \right) \]

where \( N \approx 0.35 \) for TTL threshold
\( N \approx 0.75 \) for CMOS threshold

**ASSUMPTIONS:**
1) Each capacitor is discharged during the opposite timing phase.
2) Capacitors begin charging from GROUND.
3) Effect of three-state routing delay is assumed minimal.

---

You can use any number of these low-frequency oscillators in a design. Most designs, however, require only one or two.

**Note:** If the oscillator output is used throughout the design to clock the registers in the CLBs, then you should place the oscillator near one of the clock buffers and use the clock buffer to route the signal.

The sample array element in the low-frequency oscillator figure above shows the oscillator built near the main clock buffer in the upper-left corner of the die. A similar low-frequency oscillator could drive the auxiliary clock buffer located in the lower-right corner of the die.

You should be aware that the low-frequency oscillator circuit causes an error when you use the timing calculator to examine the oscillator. The timing calculator in the LCA development system detects combinational loop conditions and flags them as errors. Because the oscillator circuit depends on a combinational loop for operation, it causes an error message. You can safely ignore such error messages if you detect them only in the oscillator circuit.
You can configure two special I/O Blocks to interface to the oscillator on-chip, located in the lower-right corner of the die. This oscillator is associated with the auxiliary clock buffer located near it. When you select the interconnection to drive the auxiliary clock buffer, two special pins interface to the internal high-speed inverting amplifier to form the oscillator. Externally, you should attach these pins to the crystal oscillator components, as shown below. The best way to configure the crystal oscillator is by using the GXTL macro in the LCA library.

Even before you finish configuring the LCA device, the on-chip oscillator begins operation so that its circuitry can stabilize. However, the actual internal connection of the oscillator to other circuitry on the chip is delayed until the device configuration completes.
I/O TYPE: On-Chip Crystal Oscillator Circuit
MACRO NAME: GXIL

SCHEMATIC:

SUGGESTED COMPONENT VALUES:

- **R1**: 1-4 MΩ
- **R2**: 0-1 KΩ (may be required for low frequency, phase shift and/or compensation level for crystal Q)
- **C1, C2**: 5-20 pF
- **Y1**: 1-10 MHz AT cut

<table>
<thead>
<tr>
<th>Pin Type</th>
<th>XTL1</th>
<th>XTL2</th>
</tr>
</thead>
<tbody>
<tr>
<td>48-PIN DIP</td>
<td>33</td>
<td>30</td>
</tr>
<tr>
<td>68-PIN PLCC</td>
<td>46</td>
<td>43</td>
</tr>
<tr>
<td>68-PIN PGA</td>
<td>J10</td>
<td>L10</td>
</tr>
<tr>
<td>84-PIN PLCC</td>
<td>56</td>
<td>53</td>
</tr>
<tr>
<td>84-PIN PGA</td>
<td>K11</td>
<td>L11</td>
</tr>
</tbody>
</table>

On-Chip Oscillator Circuit

The feedback resistor R1, from output to input, biases the amplifier at threshold and should be as large a value as practical, up to 4 MΩ. The inversion and delay of the amplifier, together with the R-C networks and crystal, produce a 360-degree phase shift, forming a Pierce oscillator.
Note: You can include the series resistor R2 to add to the amplifier output impedance, when needed. This may be needed for phase-shift control, crystal-resistance matching, or for limiting the amplifier input swing to control clipping at large amplitudes.

The ratio of capacitor C2 to C1 adjusts the excess feedback voltage. The amplifier operates in the range of 1 MHz, up to one-half the specified CLB toggle frequency. Using the oscillator at frequencies below 1 MHz requires individual characterization with respect to a series resistance. Operating at frequencies above 20 MHz is also more complex because it generally requires that the crystal operates in a third overtone mode in which the R-C networks must suppress the fundamental frequency.

4.2.6 REGISTERS AND COUNTERS

The previous examples in this chapter describe how to use IOBs in conventional I/O applications, using the IOB for input, output, or both. For any IOB that is not required for input or output, you can use the storage element within the IOB to create registers and various types of counters. The following designs use the output buffer (BUF:ON) fed back into the input register (l:Q). This configuration is shown below. These IOB’s pads usually are not connected to anything externally, although you may do this if necessary.

4.2.6.1 IOB-Based Register Delays

If you want to construct registers using IOBs, you must understand the delays in IO-based registers. The delays incurred through an IOB-based register depend on the sum of two parameters: the delay through the output buffer, and the delay back through the input buffer to the register. While these values are defined in the data sheet for an output load of 50 pF, they change only slightly for no output capacitance. The delay into an IOB-based register is shown below.
4.2.6.2 Wide Storage Registers

The first type of IOB-based registers is a wide storage register. The basic I/O structure illustrated below creates a wide storage register.

\[
T(IOB-reg) = Top = Tpl
\]

Where:

- Top = Output to Pad output
- Tpl = Pad input set up to I/O clock (minimum)

I/O TYPE: Pad With Input Storage (IOB-based)
MACRO NAME: PREG
SCHEMATIC:

Pad with Input Storage (IOB-Based Register)
The following figure shows the construction of an n-bit-wide storage register built from these IOBs. Wide storage registers are ideal for IOBs because the I/O clock feeding an IOB is common to all IOBs along each edge of the die.

**I/O TYPE:** N-bit Storage Register (IOB-based register)  
**MACRO NAME:** None  
**SCHEMATIC:**

![Schematic diagram of N-bit Storage Register]

**CONFIGURATION:**
All IOBs  
I:Q  
BUF:ON

**COMMENTS:**
The I/O clock into each IOB is common to all IOBs along each edge of the die. For best resource utilization, group the storage elements along one edge of the die.

N-Bit Storage Register (IOB-Based Register)
4.2.6.3 Read/Write Registers

Another variation of the basic IOB-based register is a simple read/write register. This structure allows external devices to write data into registers within the LCA device, and also to read the data back.

The following figure shows the structure of a read/write register. In this example, each IOB's input and output is connected. The three-state control line (T) controls the direction of data flow, where \( T = \text{LOW} \) for a read operation by the external device, and \( T = \text{HIGH} \) for a write operation to the LCA device. Typically, the read/write control line (three-state control) originates outside the LCA device and comes in through an additional I/O block.

The input register data from the read/write register can be read from within the LCA device but the data cannot be written to the LCA device. Writing the register from inside the LCA device would require that two network sources be active, which is not allowed.
**I/O TYPE:** N-bit Read/Write Storage register  
**MACRO NAME:** None  
**SCHEMATIC:**

```
   D         Q
  / \        / \                  1
PAD -> |    | -> REG 0 OUT  
   \     \        \  
    \     \        \  
   D         Q
  / \        / \                  2
PAD -> |    | -> REG 1 OUT  
   \     \        \  
    \     \        \  
   CLOCK
```

**CONFIGURATION:**
All IOBs  
I:Q  
BUF:TRI

**COMMENTS:**
The I/O clock into each IOB is common to all IOBs along each edge of the die. For best resource use, group the storage elements along one edge of the die. Also, the three-state control line controls the direction of data flow (T = LOW for read, T = HIGH for write). This control line typically originates off-chip and comes in through an additional IOB.

N-Bit Read/Write Storage Register
4.2.6.4 Shift Registers

You can easily construct shift registers with IOBs by feeding the output of one IOB to the input of the next. The figures below describe two shift registers: one shifts to the left, the other shifts to the right. The shift direction depends on the connections of each IOB's inputs and outputs.

I/O TYPE: Shift Left Register (IOB-based register)
MACRO NAME: None
SCHEMATIC:

![Shift Left Register Schematic]

CONFIGURATION:
All IOBs
I:Q
BUF:ON

COMMENTS:
Notice that the routing of the output of a given IOB goes to the input of the IOB on the left (shift left).
The following figure shows a shift-right IOB-based register.

**I/O TYPE:** Shift Right Register (IOB-based register)  
**MACRO NAME:** None  
**SCHEMATIC:**

![Schematic of Shift Right Register](image)

**CONFIGURATION:**
All IOBs  
I:Q  
BUF:ON

**COMMENTS:**
Notice that the routing of the output of a given IOB goes to the input of the IOB on the right (shift right).

**Note:** Because the I/O clock line of an IOB is common to all IOBs along each edge of the die, the IOB-based shift registers are placed along one edge of the die.
4.2.6.5 Johnson Counters

An n-bit Johnson counter counts to $2^n$ states as opposed to standard binary counters that count to $2^n$ possible states. Johnson counters have a variety of uses in digital design, including low-modulo counters and glitch-free decoders.

In an IOB-based design you can think of a Johnson counter as a special shift register. Only one bit changes during a state transition, as shown in the following table for a three-bit Johnson counter.

<table>
<thead>
<tr>
<th>Transitions of a Three-Bit Johnson Counter</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
</tr>
<tr>
<td>100</td>
</tr>
<tr>
<td>110</td>
</tr>
<tr>
<td>111</td>
</tr>
<tr>
<td>011</td>
</tr>
<tr>
<td>001</td>
</tr>
</tbody>
</table>

You can build a Johnson counter of unused IOBs, as shown below; however, it requires at least one CLB to perform an inversion. The Johnson counter is automatically reset to an all-zeroes state upon configuration or on a ~RESET pulse.

Refer to the application note on counters for more information on creating Johnson counters in LCA devices.
I/O TYPE: N-bit Johnson Counter
MACRO NAME: None

SCHEMATIC:

EXPANDABLE TO N BITS

CONFIGURATION:
All IOBs
I:Q
BUF:ON

N-Bit Johnson Counter (IOB-Based)
4.2.6.6 Glitchless Johnson Decoder

You can build a glitch-free decoder using IOBs and CLBs. The decoder is glitch-free because only one bit changes during a state transition. An n-bit Johnson counter/decoder can decode any one of the $2^n$ possible states, or any number of contiguous states, by decoding (ANDing) together just two of the appropriate counter bits. You can also create counters of various modulo and duty-cycle by using different Johnson decoders. For example, the next figure shows the schematic implementation of a Johnson counter/decoder with various two-input decode states.
As the above figure illustrates, you can decode any state of a Johnson counter, glitch-free, using only a two-input logic function.
4.2.6.7 Linear Feedback Shift Registers

Linear Feedback Shift Registers (LFSRs) are yet another modification of a simple shift register. An LFSR consists of a shift register that feeds back the appropriate bits to the first bit position. An LFSR requires some logic function in the feedback path, usually an exclusive-OR (XOR) function.

LFSRs have numerous applications, such as implementing the encryption and decryption functions in a UART.

The next figure shows the schematic for a three-bit LFSR that implements a modulo 5 (divide-by-five) counter. An n-bit LFSR counter can produce a pseudo-random sequence of up to $2^n-1$ unique states. By adding logic to the feedback path, you can force the LFSR counter to skip any number of states, from one to $2^n-1$. By forcing the counter to skip some number of states, $m$, an LFSR counter can implement any modulo as described in the following equation.

$$\text{MODULO} = (2^n-1) - m$$

- $n =$ number of shift-register bits
- $m =$ number of skipped states
The figure below shows the counting sequence for a three-bit LFSR counter with an exclusive-NOR (XNOR) in the feedback path. This figure also shows all possible skip paths and the stuck state.
In the counting sequence there are two counter states where only the first bits differ. For example, refer to the states 101 and 001. By forcing the feedback logic to invert the sense of the feedback into the first bit, the counter can be forced to skip all of the states between the two indicated values. You can accomplish this skip by decoding (ANDing) the state just previous to the state to be skipped.

Using the modulo 5 counter as an example, locate the initial value that allows the counter to skip two states, 101 for example. By decoding the state 011, which is the state just prior to the initial skip state of 101, you can invert the sense of the feedback into the first bit. The counter then skips from state 101 to state 010, implementing a modulo 5 counter. Using this method and the proper feedback into the register, you can build a counter of any modulo from 1 to $2^n - 1$. 

Three-Bit LFSR Counting Sequence Skip Path and Stuck State
Either device configuration, or an externally driven active-LOW RESET signal, resets all storage elements used in the LFSR counter to zero.

Be careful to avoid the stuck state in your designs. This is the missing state in the $2^n-1$ counting sequence. If the stuck state is included, the LFSR counter has $2^n$ possible states. The stuck state occurs when the feedback path forces the counter into an ever-repeating single state.

As a simple example, assume that you build an LFSR counter with a two-input XOR feedback path, as shown next. Upon configuration or an external active-LOW RESET signal, the counter begins operation in the all-zeroes state (000) and becomes stuck in that state due to the type of feedback used.
Simple LFSR with a **STUCK** State
An interesting situation occurs when all bits except the last bit of the stuck state are decoded (ANDed together) and included in the feedback path. Instead of counting over a possible range of $2^n - 1$ states, the extra decoding causes the LFSR counter to count to all $2^n$ states, as shown in the following figure.
You can build longer LFSR counters with higher possible modulos and more complex feedback mechanisms, but their discussion is well beyond the scope of this chapter. However, the following table presents some of the possible feedback combinations for LFSR counters of three to ten bits.

<table>
<thead>
<tr>
<th>2n-1</th>
<th>7</th>
<th>15</th>
<th>31</th>
<th>63</th>
<th>127</th>
<th>255</th>
<th>511</th>
<th>1023</th>
</tr>
</thead>
<tbody>
<tr>
<td>Modulo</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feed-back</td>
<td>1,3</td>
<td>1,4</td>
<td>2,5</td>
<td>1,6</td>
<td>1,7</td>
<td>1,2,7,8</td>
<td>4,9</td>
<td>3,10</td>
</tr>
<tr>
<td>Options into Bit 1</td>
<td>2,3</td>
<td>3,4</td>
<td>3,5</td>
<td>5,6</td>
<td>3,7</td>
<td>5,9</td>
<td>7,10</td>
<td>4,7</td>
</tr>
</tbody>
</table>

**4.2.7 INCREASED DRIVE-CURRENT STRUCTURES**

LCA devices are specified to have 4 mA worst-case source and sink capabilities at \( V_{OL} = 0.32 \) V and \( V_{OH} = 3.68 \) V. However, you obtain increased drive current at the cost of decreased voltage margins. For example, the following table illustrates the effect on \( V_{OL} \) and \( V_{OH} \) of increasing the drive current through a single IOB.

<table>
<thead>
<tr>
<th>Output Current and Output Voltage Levels for an IOB</th>
</tr>
</thead>
<tbody>
<tr>
<td>( V_{OH} )</td>
</tr>
<tr>
<td>-----------</td>
</tr>
<tr>
<td>3.86 V</td>
</tr>
<tr>
<td>( V_{OL} )</td>
</tr>
</tbody>
</table>
An alternate method of increasing the drive current is to parallel the output drivers of two IOBs. Paralleling two outputs enables the IOBs to source-and-sink double the worst-case current, with no reduction in voltage margins. This method is diagrammed below.

**Caution:** You should minimize the difference in routing delay between the two IOBs connected in parallel. Excessive delays can cause output contentions.

Chapter 5 discusses placement and routing.
# Chapter 5

## Placement and Routing

<table>
<thead>
<tr>
<th>Section</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>5.1</td>
<td>Overview</td>
<td>2</td>
</tr>
<tr>
<td>5.2</td>
<td>Interconnection Resources</td>
<td>3</td>
</tr>
<tr>
<td>5.2.1</td>
<td>General-Purpose Interconnection</td>
<td>3</td>
</tr>
<tr>
<td>5.2.2</td>
<td>Direct Connections</td>
<td>6</td>
</tr>
<tr>
<td>5.2.3</td>
<td>Long Lines</td>
<td>10</td>
</tr>
<tr>
<td>5.2.4</td>
<td>Clock Buffers</td>
<td>16</td>
</tr>
<tr>
<td>5.3</td>
<td>Placement</td>
<td>19</td>
</tr>
<tr>
<td>5.3.1</td>
<td>Partition the System Design</td>
<td>19</td>
</tr>
<tr>
<td>5.3.2</td>
<td>Analyze the Data Flow</td>
<td>20</td>
</tr>
<tr>
<td>5.3.3</td>
<td>Logic Block Placement</td>
<td>23</td>
</tr>
<tr>
<td>5.3.3.1</td>
<td>Placement Guidelines</td>
<td>24</td>
</tr>
<tr>
<td>5.3.3.2</td>
<td>Optimization Guidelines</td>
<td>26</td>
</tr>
<tr>
<td>5.3.4</td>
<td>I/O Block Placement</td>
<td>27</td>
</tr>
<tr>
<td>5.3.5</td>
<td>Examples</td>
<td>29</td>
</tr>
<tr>
<td>5.3.5.1</td>
<td>Using Macros, Example 1</td>
<td>31</td>
</tr>
<tr>
<td>5.3.5.2</td>
<td>The Long and Thin Approach, Example 2</td>
<td>33</td>
</tr>
<tr>
<td>5.3.5.3</td>
<td>Trade Off Resources for Performance, Example 3</td>
<td>33</td>
</tr>
<tr>
<td>5.3.6</td>
<td>Modification Guidelines</td>
<td>34</td>
</tr>
<tr>
<td>5.4</td>
<td>Routing</td>
<td>37</td>
</tr>
<tr>
<td>5.4.1</td>
<td>Manual Editing</td>
<td>37</td>
</tr>
<tr>
<td>5.4.2</td>
<td>Manual Pre-Routing</td>
<td>43</td>
</tr>
<tr>
<td>5.4.3</td>
<td>Routing Guidelines and Functions</td>
<td>49</td>
</tr>
<tr>
<td>5.4.3.1</td>
<td>Inputs and Outputs</td>
<td>49</td>
</tr>
<tr>
<td>5.4.3.2</td>
<td>High Fanout Nets</td>
<td>51</td>
</tr>
<tr>
<td>5.4.3.3</td>
<td>Useful Routing Functions</td>
<td>52</td>
</tr>
<tr>
<td></td>
<td>SWAPSIG</td>
<td>52</td>
</tr>
<tr>
<td></td>
<td>CLEARPIN</td>
<td>54</td>
</tr>
<tr>
<td></td>
<td>ROUTEPIN and ROUTE</td>
<td>55</td>
</tr>
</tbody>
</table>
This chapter discusses placement and routing of LCA designs. Placement and routing play an important part in determining both the performance of your design and how efficiently it uses the available LCA resources.

- The overview, 5.1, introduces LCA placement and routing.

- The discussion on interconnection resources, 5.2, describes different options for interconnecting the CLBs and IOBs in an LCA design.

- The discussion on placement, 5.3, explains how to optimize placement of CLBs and IOBs in a design.

- The discussion on routing, 5.4, explains how to route, and how to edit the routing of, an LCA design.

- The discussion on timing analysis, 5.5, describes how to use the delay calculator to analyze an LCA design's timing.

- The summary, 5.6, presents conclusions and recommendations for placing and routing LCA designs.
5.1 OVERVIEW

As with other high density ASIC devices, the LCA device offers placement and routing alternatives that can affect the use and the performance of your final design. In gate arrays and other factory-programmed solutions, you can explore these layout alternatives only through simulation. With the LCA device, however, you can see and modify the placement and routing at design time using the LCA development system.

The LCA development system includes several powerful capabilities that let you optimize your design for performance and use of resources. This chapter investigates these capabilities and the operations that you can employ to optimize your design.

If you are not familiar with LCA placement and routing, you should read this entire chapter. If you have some level of knowledge about the LCA device and have completed some design work, you may want to study only those discussions that interest you.

**Note:** If you intend to use the Automatic Placement and Routing software, APR, you should still read this chapter.

APR helps you plan your design so that the LCA resources are used as efficiently as possible. After using APR to place and route your design, you may need to optimize or complete the routing with XACT. All of the following guidelines can help.
5.2 INTER-CONNECTION RESOURCES

Placement and routing are closely interrelated. You make placement decisions based on efficient use of interconnection resources. Any changes in placement can change the routing and routability of a design and consequently, impact the design's performance. To make the best possible placement and routing decisions, you must understand the capabilities and trade-offs of the various types of routing available in an LCA device.

This discussion explains the following available interconnections.

- 5.2.1, General-Purpose Interconnection
- 5.2.2, Direct Connections
- 5.2.3, Long Lines
- 5.2.4, Clock Buffers

5.2.1 GENERAL-PURPOSE INTERCONNECTION

General-purpose interconnection provides routing for most signals on the LCA device. As shown below, it consists of four horizontal metal segments between adjacent rows and five vertical metal segments between adjacent columns of the CLBs and IOBs. The vertical segments are the same height as a CLB; the horizontal segments are the same width. A switch matrix at each row and column intersection controls how the segments are interconnected.
A switch on each CLB or IOB output can connect the output to the adjacent interconnection segments. Configuration bits in the LCA configuration file set up the switch connections in each matrix and on the block outputs. Configuration bits also program the multiplexers at the inputs of the CLBs and IOBs to select the appropriate input connections from the adjacent interconnection.
Special repowering buffers in the general-purpose interconnection provide periodic signal isolation and restoration for higher fanout and improved performance. Each LCA device is divided into nine sections, with buffers provided at the section boundaries. These buffers are bidirectional because signals on a general interconnection segment must be able to propagate in both directions.
5.2.2 DIRECT CONNECTIONS

Each CLB and IOB can connect directly to adjacent blocks, as shown below. A direct connection is a signal path with virtually zero delay, which does not use any of the general interconnection or long line resources.

Direct Connection Resources

Note: Repowering buffers are provided only for the general-purpose interconnection; direct connections and long line interconnections do not require them.
For maximum device performance and minimum routing resource impact, use direct connections as much as possible. Direct connections exist primarily in the vertical and left-to-right directions; therefore, you should arrange blocks that represent stages in a process sequentially: either vertically or from left to right. Left-edge I/O blocks naturally become data inputs, while right-edge I/O blocks become data outputs. Top- or bottom-edge I/O blocks can be either direct inputs or outputs, with alternate blocks having direct-out or direct-in paths. As an example, consider the following circuit.

An 8-bit parallel-load shift register loads the data byte into the shift register in parallel, then shifts it out one bit per clock cycle. The following figure shows two alternate implementations of this circuit.
A. The eight CLBs used for the stages of the shift register are arranged in a rectangular area in the upper-left corner of the device, with general interconnection providing many of the signal paths.

B. The design uses direct connections exclusively, which provides zero-delay paths from block to block and allows higher performance.
The general interconnection used in design A is still available for other uses. Also, the LOAD signal has been routed on a long line driven from a directly-connected I/O block. Long lines are discussed next.

For the design shown in B, the following table of worst-case delays shows that the maximum load and shift clock rate for the 33 MHz device is 31.3 MHz, and 43.5 MHz for the 50 MHz device.

Partial Delay Report for Direct Connection Placement of an 8-Bit Shift Register with Parallel Load

<table>
<thead>
<tr>
<th>Speed Device</th>
<th>From</th>
<th>Thru</th>
<th>To</th>
</tr>
</thead>
<tbody>
<tr>
<td>-30 MHz</td>
<td>BLK GA</td>
<td>NET S6</td>
<td>BLK HA</td>
</tr>
<tr>
<td>(CLOCK to GA.X)</td>
<td>(GA.X to HA.A)</td>
<td>(HA.A to SETUP)</td>
<td></td>
</tr>
<tr>
<td>20 ns ( 20 ns)</td>
<td>0 ns ( 20 ns)</td>
<td>12 ns ( 32 ns)*</td>
<td></td>
</tr>
</tbody>
</table>

For -50 MHz speed device

<table>
<thead>
<tr>
<th>From</th>
<th>Thru</th>
<th>To</th>
</tr>
</thead>
<tbody>
<tr>
<td>BLK GA</td>
<td>NET S6</td>
<td>BLK HA</td>
</tr>
<tr>
<td>(CLOCK to GA.X)</td>
<td>(GA.X to HA.A)</td>
<td>(HA.A to SETUP)</td>
</tr>
<tr>
<td>15 ns ( 15 ns)</td>
<td>0 ns ( 15 ns)</td>
<td>8 ns ( 23 ns)*</td>
</tr>
</tbody>
</table>

* Total Clock-to-Clock Worst-Case Delay

In designs that are not highly synchronous, such as those in glue logic replacement, you usually cannot exploit direct connections to the degree shown in the example. However, if possible, use a direct connection to route a signal from one block to another. Direct
connection considerations should be a primary factor in block placement. For each direct connection, you release a general interconnection resource that can then be used in some other function. Extensive use of direct connections can boost the logic use of the LCA device by up to 30%.

5.2.3 LONG LINES

Long lines are continuous metal segments that span the width or length of the LCA device, providing **minimum-delay and skew for long distance signal paths**. Although the automatic router uses long lines for general signal routing when other types of connections are not available, you should direct the use of long lines for specific signals. Ensure that long lines are efficiently used by considering their capabilities and interconnection potential. The following figure illustrates the locations of the long lines and shows the clock buffers that work with them. Clock buffers are described under 5.2.4.
Signals that can most effectively use long lines are generally classified as data distribution, or low-skew, control signals. Whether originating at an I/O block or a CLB, data signals typically have several destinations each of which uses the data differently. To follow the natural data flow of the device, you should route these signals on long lines with one bit per row or column.

An important consideration in data routing is the direction of the data flow. In the 2064/2018 series of LCA devices, internal signals must be unidirectional. For systems that require bidirectional data paths, you can use a pair of long lines in each column to carry input
data and output data, respectively. This bidirectional signal routing requires that the data input/output pins be located at the top or bottom of the device. The following figure shows an 8-bit bidirectional data bus with vertical routing on pairs of long lines.

Control signals, such as clocks, reset/set controls, and count or shift direction controls may have critical timing requirements between their source and their multiple destinations. For these signals, you must control skew to ensure that all of the destination blocks perform the desired function at the same time or on the same clock edge. If possible, you should arrange destination blocks in a single column or row and you should route the control function onto the appropriate long line. The
figures below show two different implementations of a reset function generated in a logic block and routed to four destination blocks. You can see the skew reduction associated with the use of the long line from their accompanying tables.
Delay: bidibus8.1ca, XACT 1.3

<table>
<thead>
<tr>
<th>From</th>
<th>Thru</th>
<th>To</th>
</tr>
</thead>
<tbody>
<tr>
<td>BLK BC</td>
<td>NET RESET</td>
<td>BLK HD</td>
</tr>
<tr>
<td>(BC.X)</td>
<td>(BC.X to HD.B)</td>
<td>(HD.B)</td>
</tr>
<tr>
<td>0ns</td>
<td>24ns (24ns)</td>
<td>0ns (24ns)</td>
</tr>
<tr>
<td>BLK BC</td>
<td>NET RESET</td>
<td>BLK ED</td>
</tr>
<tr>
<td>(BC.X)</td>
<td>(BC.X to ED.C)</td>
<td>(ED.C)</td>
</tr>
<tr>
<td>0ns</td>
<td>14ns (14ns)</td>
<td>0ns (14ns)</td>
</tr>
<tr>
<td>BLK BC</td>
<td>NET RESET</td>
<td>BLK DD</td>
</tr>
<tr>
<td>(BC.X)</td>
<td>(BC.X to DD.C)</td>
<td>(DD.C)</td>
</tr>
<tr>
<td>0ns</td>
<td>12ns (12ns)</td>
<td>0ns (12ns)</td>
</tr>
<tr>
<td>BLK BC</td>
<td>NET RESET</td>
<td>BLK AD</td>
</tr>
<tr>
<td>(BC.X)</td>
<td>(BC.X to AD.C)</td>
<td>(AD.C)</td>
</tr>
<tr>
<td>0ns</td>
<td>3ns (3ns)</td>
<td>0ns (3ns)</td>
</tr>
</tbody>
</table>

**21ns SKEW**

**DELYAS FOR GENERAL INTERCONNECT**

Signal Routed Via General Interconnection
Delay: bidibus8.1ca, XACT 1.3

<table>
<thead>
<tr>
<th>From</th>
<th>Thru: NET RESET</th>
<th>To</th>
</tr>
</thead>
<tbody>
<tr>
<td>BLK BC (BC.X)</td>
<td>(BC.X to HD.B)</td>
<td>BLK HD (HD.)</td>
</tr>
<tr>
<td></td>
<td>0ns ( 0ns)</td>
<td>0ns ( 0ns)</td>
</tr>
<tr>
<td>BLK BC (BC.X)</td>
<td>(BC.X to ED.C)</td>
<td>BLK ED (ED.C)</td>
</tr>
<tr>
<td></td>
<td>0ns ( 0ns)</td>
<td>0ns ( 0ns)</td>
</tr>
<tr>
<td>BLK BC (BC.X)</td>
<td>(BC.X to DD.C)</td>
<td>BLK DD (DD.C)</td>
</tr>
<tr>
<td></td>
<td>0ns ( 0ns)</td>
<td>0ns ( 0ns)</td>
</tr>
<tr>
<td>BLK BC (BC.X)</td>
<td>(BC.X to AD.C)</td>
<td>BLK AD (AD.C)</td>
</tr>
<tr>
<td></td>
<td>0ns ( 0ns)</td>
<td>0ns ( 0ns)</td>
</tr>
</tbody>
</table>

DELAYS FOR ROUTING VIA LONG LINE

---

**Signal Routing Via Long Line**
5.2.4 CLOCK BUFFERS

The LCA device has special-purpose on-chip buffers to provide high-fanout, low-skew signal distribution. You normally use these buffers for clock signals; however, you can also use them for any general-purpose signal that requires high-fanout or low-skew routing to multiple blocks. Clock buffers work with specific long lines for routing on a column basis. The global clock buffer, located in the upper-left corner of the LCA device, directly drives a long line in each column. The alternate clock buffer, located in the lower-right corner, drives a horizontal line that can be selectively connected to a long line in each column. The following figure shows the buffer locations.
In systems with a single common clock for all state elements, you can best distribute that clock using the global buffer. More difficult cases involve systems with multiple clocks and other critical control signals. If a system has two separate clocks, one clock can use the global buffer and the other can use the alternate buffer. This is particularly true when one clock is derived from the other.

**Note:** When you use the crystal oscillator, its output drives the alternate buffer directly; therefore, it can be the primary clock for the system.
In any case, you should drive the predominantly used clock with the global buffer.

For systems requiring more than two clocks, you should still drive the primary clock with the global buffer. Route other clocks onto vertical long lines and arrange their respective CLBs in columns adjacent to the long line that carries the appropriate clock signal. You can use direct connections to drive these column-oriented clocks either from an adjacent (to the left) CLB, or from an I/O block on the edge at either end of the column. When selecting the long line to be used, note that one of the nondedicated vertical long lines can be connected to the CLB K inputs, while the other cannot. Since most clock signals are best routed into the K input, you should choose the former long line.

You can also use one of the clock buffers to route a control signal to many CLBs or IOBs. By placing the source of the signal near the alternate buffer, you provide a low-delay path from the source to the buffer, and then to all the destination CLBs or IOBs. The following figure shows a shift register that has been placed and routed using both buffers: the global buffer for the overall shift register clock and the alternate buffer for a low-skew shift/hold control signal. If the shift/hold control logic timing is not well controlled, skews in the control signal, as seen by the blocks, could cause a partial shift. In a partial shift, some blocks could get the signal while others may not get it in time to hold relative to the next clock edge.

**Note:** This timing skew becomes less of a factor in choosing routing for control signals as you relax your timing constraints.
5.3 PLACEMENT  

Placement and routing determine how efficiently you can use an LCA device for a particular design. Placement of logic in an LCA design primarily involves determining the relative locations of the functions that most effectively use CLB, IOB, and routing resources. Efficient use greatly simplifies signal routing within functions and between groups of functions.

The following discussion explains how to accomplish efficient logic placement in your LCA designs. First, it provides some guidelines for system-level design partitioning to help you determine what parts of your system to implement in an LCA design. Then, it explains how to analyze the data flow for your LCA design. Finally, it describes CLB and IOB placement, and gives some examples.

This discussion has the following organization.

- 5.3.1, Partition the System Design
- 5.3.2, Analyze the Data Flow
- 5.3.3, Place the Logic Blocks
- 5.3.4, Place the I/O Blocks
- 5.3.5, Examples
- 5.3.6, Modification Guidelines

5.3.1 PARTITION THE SYSTEM DESIGN

You must partition your system-level design before you can implement an LCA design. Partitioning is a two-part process. First, you separate your design into external and internal LCA functions; then you group the internal LCA functions into related clusters.

The following are useful guidelines for determining what part of your design to implement in an LCA device.

- Implement standard LSI or VLSI functions with appropriate components.
5.3.2 ANALYZE THE DATA FLOW

After determining which part of your system design to place in an LCA design, you must analyze that part of the design to determine optimal data flow. You analyze the data flow of your design as follows.

To make placement and routing decisions, you evaluate the sequential nature of the logic to be created in the LCA device. Examine the data flow to determine the best placement of required logic blocks, and to determine the most effective signal routes.

In general, data processing in the LCA device flows most naturally either from left to right or vertically; flow up and flow down are virtually identical. To minimize interconnection, arrange structures such as counters in nearly square rectangles. Implement

- Use an LCA device to implement non-standard VLSI functions if a large portion or all of the LCA device is available for that function.

- Place required portions of standard VLSI functions inside an LCA device.

- Place random SSI and MSI functions inside an LCA device. You can implement functions or sub-functions that require four or fewer inputs, two or fewer outputs, and a single storage element using a single CLB.

- Group all parts of a complex function inside one LCA device, instead of placing them at remote locations in the circuit; this simplifies implementation and debugging.

- As a rule, use MSI components to implement a function with a large fan-out or fan-in and with few logic levels. Decoders and multiplexers fall into this category.
registers in columns of CLBs to take advantage of the direct interconnection between adjacent CLBs and the common clocking in columns of CLBs.

**If you must implement several independent functions**, you should position the function that requires the most CLBs so that the data flows through it from left to right. The exceptions are counters and shift registers, which should be arranged in columns to share common clocking.

To illustrate data flow analysis, consider the block diagram below.

![Serializer Block Diagram](image)

This diagram shows a dual-ported memory interface used as a high-speed serializer, which is a typical application in video pixel processing or serial...
communications systems. In the serializer, both the serial-data output device and the microprocessor must have access to the memory. In analyzing the data flow, you can see a need for an 8-bit bidirectional path between the memory and the microprocessor, as well as an 8-bit path from the memory to the serializer. The serializer requires an 8-bit parallel-to-serial data flow. The interface generates the memory addresses internally for the serialization process; external memory addresses are supplied by the microprocessor. The memory addresses are always outputs to the external memory.

The data flow paths are summarized below.

- 8 bits of data from microprocessor to memory
- 8 bits of data from memory to microprocessor
- 8 bits of data from memory to serializer
- 12 bits of address from address generator to memory
- 12 bits of address from microprocessor to memory

Clearly, the design requires a bidirectional data path between the memory and the microprocessor. This same path must supply data to the serializer. You can view the serializer as a process perpendicular to the data flow because it serializes parallel data. The memory address path is wider than the data paths but it is unidirectional and has a common connection only at the output point. The following diagram shows a flow analysis of this design example.
Based on this flow analysis, place the 8-bit data path vertically to take advantage of direct connection in the up and down directions. Then place the serializer, which could be connected in a left-to-right or vertical orientation, perpendicular to the vertical data path and use the direct connection left-to-right capabilities. Route the address path between CLBs, which are near the edge of the device, and the adjacent I/O blocks, that drive the address. This can be done because the path is unidirectional. Use direct connection as much as possible.

You should follow the general guidelines below to determine the block placement and the routing alternatives within the LCA device.

5.3.3 LOGIC BLOCK PLACEMENT

One of the most critical elements in achieving an efficient design with an LCA device is the proper placement of CLBs and I/OBs. CLB placement is more critical than I/OB placement for two reasons:

- it offers more degrees of freedom
• the final CLB placement can dictate most of the IOB placement.

You can improve both the performance and the routing of your design by proper placement. Good placement relieves routing problems and generally results in good initial performance, minimizing the placement and routing iterations.

**Note:** Maximizing the use of the direct connections between blocks is an important goal.

### 5.3.3.1 Placement Guidelines

The following guidelines should help you achieve optimum placement efficiently.

1. Consider the various functional elements in the design, the shapes that each can take, and their relative interconnection.

   Try the placement of these functional blocks on a printout of a blank LCA device to see how they might fit together. The layout in the following figure was obtained using this basic analysis technique.

2. Examine the internal and external inputs and outputs for each block of logic.

   Place blocks with a high number of common interconnections near each other.
When you consider the relative placements of individual CLBs and IOBs, remember the following.

3. Use direct connections wherever possible.

4. Arrange related groups of logic blocks in rectangular shapes, if possible.

5. Place CLBs and IOBs with the greatest number of interconnections next to other blocks at the perimeter of any rectangular shapes.
5.3.3.2 Optimization Guidelines

The following guidelines will help you optimize the placement of CLB designs.

1. Use only necessary functions. Many designs use only a portion of a standard-logic part and disable the unused inputs. LCA-based designs should never include unused inputs of standard-logic devices.

2. Use the function, not the equivalent logic gates. Many standard-logic designs use multiple gate levels. LCA-based designs are not subject to the same logic-gate restrictions; you can create any function of three or four variables, regardless of complexity, with one CLB.

3. Share CLBs wherever possible. Two independent functions can share one CLB. For example, a CLB configured as a data latch uses...
one input and one output. The remaining three inputs, the remaining output, and the output of the latch can be used to perform another function. A data-latching function and a function that uses the latched data can both be incorporated in one CLB, which effectively expands the CLB's four inputs to five.

4. **Group common intermediate outputs into one function.** If the same sub-function is performed for several inputs, CLBs are wasted. Perform the function to generate the intermediate output and use the single result in each place required. A common technique is to divide the design into functional pieces and look for commonality.

### 5.3.4 I/O BLOCK PLACEMENT

The placement of I/O blocks usually is dictated by the placement of the CLBs connected to them. However, you must consider IOB placement constraints because they can have a significant impact on overall placement and routing. General guidelines for I/O block placement are listed below.

1. **Locate IOBs adjacent to the CLBs that use the most associated signals.**

If I/O blocks are being used as buses, note the following considerations.

2a. **Locate data buses that are to be latched on a single device edge to allow use of the flip-flops in the I/O block, and to share the single I/O clock on the edge of the device.**

2b. **Limit address buses to the top of the device if the pins are used during configuration as the external EPROM/ROM address lines.**
3. Make unused IOBs data or shift registers.

**Note:** The IOBs must have available the I/O clock on that edge of the device.

When specifying IOB usage, use the following guideline.

4. Note which pins have special functions during configuration. In general, you should use pins that are inputs during configuration as user inputs during operation, while using pins that are outputs during configuration only as user outputs during operation. Careful specification generally eliminates any possible contention between configuration use and operation use.
5.3.5 EXAMPLES

The following examples illustrate many of the placement and optimization guidelines discussed above. This sample design is the data serializer used previously for data flow analysis. Individual elements of the design are used to illustrate each topic. The first figure below repeats the LCA layout of the data serializer. The figure following it shows the data serializer block diagram.

![Diagram of Interleaved Processor/Memory Data](image)

Serializer Placement Plan
Serializer Block Diagram

- 8-BIT DATA BUS TO PROCESSOR
- PROCESSOR CONTROL BUS
- 12-BIT PROCESSOR ADDRESS BUS
- CONTROL DECODE
- 12-BIT ADDRESS LATCH
- ADDRESS/DATA ARBITER AND CONTROL LOGIC
- 12-BIT ADDRESS GENERATOR
- 12 x 2:1 MUX FOR ADDRESS TO RAM
- 12-BIT ADDRESS BUS TO RAM
- DATA PATH SELECT
- 8-BIT SHIFT REGISTER
- ENCODE
- SERIAL DATA OUT
- 8-BIT DATA BUS TO RAM
5.3.5.1 Using Macros, Example 1

Macros are one method of implementing individual functional blocks. The address generator portion of the serializer is shown below. This function is a 12-bit binary counter that addresses the external RAM holding the data to be serialized. In generating the counter, this example uses macros, each of which represents three bits of the counter.

The placement of the logic blocks in the macro illustrates the advantages of rectangular placements.
The next figure shows the 3-bit macro C8BCR (Counter, modulo 8, Binary sequence, Clock enable and Reset synchronous controls) placed in two ways. Placement A is linear. Placement B uses the recommended placement from the LCA Macrocell Library manual.

Placement B:
Local Routing Does Not Block Other Routes

Placement A:
Routing Congestion Makes Other Vertical Routes Difficult

Notice that in the linear placement, all of the signals must travel the height of the macro to reach the terminal count (CTC name) block. This placement congests the routing in the columns to the left and right of the column containing the macro. The rectangular placement shown in B makes the routing more compact and provides additional space for routing around the module. Also, the square structure allows easier placement in a dense design.
5.3.5.2 The Long and Thin Approach, Example 2

An example of the long and thin approach is the data shift register at the top of the data serializer shown in discussion 5.3.5. The data comes in from the pins at the top and flows into the blocks of the shift register. If these blocks are placed in a traditional rectangular shape, some bits would have to travel long distances to reach the appropriate shift register block. With this long, thin arrangement, the secondary data register in the B-row of CLBs can receive the data as it flows from the pins through the shift register.

The address multiplexer also uses long, thin shapes, with emphasis on the direction of the information flow. The next figure shows how two different bits of the multiplexer use the direct connection paths. Direct connection can reduce the congestion in general interconnection and improve placement. The initial placement has alternate I/O blocks connected either to the memory or processor address bus. After examining the direct connection, use it by modifying the position of the processor bus interface I/O relative to the multiplexer block. This provides an input to each block. Along the bottom, place the processor blocks to the left of the memory block of the same bit, thus taking advantage of direct connection for input and output paths.

5.3.5.3 Trade Off Resources for Performance, Example 3

In some cases, you may need to make placements that trade off resource use for performance. In the following example, the primary performance-limiting element is the speed of the address generator, in particular the 12-bit counter. The initial serializer placement plan shown in discussion 5.3.5 uses macros to build the counter. Macros let you create the function quickly but may not provide optimum resource use or performance.
Each 3-bit section of the counter can operate at high speed because only a single logic function is required between clock edges. However, additional logic block delays inserted between each 3-bit stage reduce the overall performance. To obtain higher performance, you could generate the toggle condition of each bit in the counter in the minimum number of logic levels. This optimization requires approximately 18 blocks and much more care in placement and routing.

5.3.6 MODIFICATION GUIDELINES

If your initial placement of logic and I/O blocks fails to produce a design you can readily route, you must modify the placement. Some guidelines for doing this are described below.

If congestion exists in the middle of the placement, make the following changes.

1. Move the blocks inside the congested area to the outside and move the outside blocks inside. This method of turning it inside out normally alleviates congestion, except in cases where the original exterior blocks have a large number of
connections to resources outside the area being examined. The next figure shows a block of logic that has interior congestion and an alternative placement that relieves the congestion.
2. Spread I/O connections out, rather than clustering them together. This often relieves congestion near the edge of the device. Some I/O-intensive applications can benefit from interleaving related I/O blocks, which is done in the address bus area of the next figure.

3. Orient the majority of signals vertically to improve the placement for groups of logic with horizontal routing congestion. Remember, there are effectively 9 vertical connections in each column (five general-purpose, three long lines, and one direct connection to the block above and below), and only six horizontal connections in each row.

4. Move data register functions out of the logic block areas and have unused I/O blocks perform that function. This approach is particularly effective for function control registers written with an external data bus. You can use pins adjacent to the data bus input pins for direct data input connections.
5.4 ROUTING

This discussion explains manual routing and describes how to edit and pre-route your design's interconnection manually using the LCA development system.

The LCA routing resources consist of general purpose interconnections, long lines and direct connections from a block to adjacent blocks, and special buffers. You must balance the use of routing resources with the partitioning and placement of the logic to generate a complete design.

5.4.1 MANUAL EDITING

With some LCA designs, you must interact with the routing process to perform any of the following tasks.

- Relieve congestion to route a signal.
- Force use of selected resources to meet specific performance or use criteria.
- Modify existing routes to tune delays for a particular requirement.
- Complete the routing on a dense, partially-routed design.

EDITNET is the XACT design editor command used to manually route signals or nets. EDITNET selectively enables or disables any of the programmable interconnection points (PIPs) on the device with the following operations.

1. Select the EDITNET command, either with the mouse and cursor or type EDITNET from the keyboard.

2. Specify the net you wish to manipulate manually. The net must have the source and destination connections on block pins defined.
3. Move the cursor over a PIP for the desired path and press the SELECT button on the mouse to toggle the selected connection.

- If the PIP was previously connected, pressing SELECT disconnects it.

- If it was not connected, pressing SELECT connects it.

To modify the switching matrices located where the general interconnection segments meet, you must

4. Select a pair of magic pins, which are connected to the switch matrix.

The table below shows the allowed connections for the various switching matrices. You make or break connections by selecting the desired pair of pins. Selecting the second pin breaks current connections or connects unconnected pins.
Allowed Connections Through Switching Matrices

1 = VALID CONNECTION
0 = INVALID CONNECTION
The following figures show the sequence of operations for editing connections in the switch matrices.

Point to First Pin [Magic 5] and Select

Point to Second Pin [Magic 4] and Select
Result - Disconnect by Point to First Pin [Magic 4] and Select

Point to Second Pin [Magic 7] and Select
When you have made all the connections,

5. Select the DONE option. The XACT system automatically calculates the delays associated with the interconnections and makes them available for display. The delay from the source of a net to its destination is shown whenever you position the cursor at a destination pin.

When you use EDITNET to make a connection, this error message may appear: *connection shorts pin zz.v*. This indicates that with this connection you have assigned a signal to a block pin that has not been assigned to the net being routed. If you must connect that pin to the net, assign it using the ADDPIN command.

Although you cannot directly connect certain pairs of switch matrix pins, you can use a combination of valid connections to accomplish the desired routing. For example, a connection from pin 1 to pin 4 is not valid; however, you can accomplish it by connecting pin 1 to pin 5, and pin 5 to pin 4. This routing connection
causes an additional switch delay, yet may be essential for routing in a congested area.

Some additional routing guidelines are given below.

- Do not route through inputs and outputs.
- Do seed the routing for a net before using auto-routing.
- Do place pre-route selected nets onto long lines.
- Do route high fanout items first or last.

**Pre-routing, or seeding the routing, is explained below.**

### 5.4.2 MANUAL PRE-ROUTING

An effective technique to improve the resource use of the XACT router is to manually **pre-route** or seed the **routing** of particular nets prior to using the router. This seeding can take two forms, depending on the desired effect.

Even if you want to use a particular long line resource for a signal path, based on delays or general placement, the router typically does not route the signal onto that long line if an alternate path is available. One technique is suggested below.

1. Force a signal onto a long line to pre-route it onto the long line before you route the signal, as described in the stages below.
   1a. If you have already entered the net, use UNROUTE or CLEARPIN to deconfigure the routing for each pin on the net.
1b. If you have not entered the net, disable the automatic router with the AUTOROUTE OFF command on the PROFILE menu and define the net with the ADDNET command. This avoids the delays caused by routing each pin and the necessity to unroute them after they are entered.

2. Use EDITNET to choose the net to route on the long line and turn the appropriate switches on or off to get the signal from its source block onto the long line.

3. End the EDITNET command by selecting DONE. A warning message indicates that the net is not routed.

4. Select the ROUTE command from the NET menu, and when prompted, select the net you manually routed onto the long line. The router then completes routing that net.

The technique above is illustrated in the two figures below. In some cases, where the destination pins are not directly accessible from the long line, the router still does not use the selected long line. In these cases you may need to use both techniques I, above, and II, below, to force the use of the long line.
Output DB.X Routed via General Interconnection

After UNROUTE Command; EDITNET has Forced Output onto Long Line
In some cases, you add pins to a net throughout the course of a design. If you enable the XACT interactive router throughout this process, each pin is routed as you add it. The resulting net routing can become contorted and interwoven because each pin is routed independently. Extreme cases can have loops in the interconnection, or very long delays, as the source block becomes more heavily loaded and the routing more degenerate. Working with the automatic router enabled can also cause severe congestion in some areas, as the routing resources are unnecessarily consumed by the multiple routes. To help relieve this and similar multi-destination problems, you should use the following guidelines.
II. Enter the destinations in a sequence that progresses from the source location to the farthest destination. Remember, the router completes the routing from source to destinations in the order specified.

To avoid the necessity of entering destinations in location-specific sequence for large nets, you can do the following.

1. Enter the net into the design with the router disabled, or unroute the net as described in 1a, previously.

When you finish entering all of the destinations for the high fanout net, do the following.

2. Use EDITNET to manually route to the destination most distant from the source. If the routing to this pin does not use a long line, you can use ROUTEPIN to accomplish the initial routing. ROUTEPIN is described under Useful Routing Functions, 5.4.3.3.

3. Use the ROUTE command to let the router complete routing of the other destinations in the net.

The following figure shows the use of this technique for a net with many destinations. Another method to avoid entering destinations in the location-specific sequence is to use a text editor to modify the sequence of the destination pin specifications.
Routing Without Seeding

Routing After Seeding
5.4.3 ROUTING GUIDELINES AND FUNCTIONS

Following are some guidelines for routing inputs, outputs, and high-fanout nets, and a description of the XACT routing functions that are useful for design optimization.

5.4.3.1 Inputs and Outputs

Although the inputs and outputs of the various blocks are shown as lines with multiple connections on them, you cannot use them as connections between parallel interconnection segments. Each input or output connection to a pin of a block is unidirectional, and only one connection per pin is allowed.

Tip: You should not route through inputs and outputs.

The EDITNET command lets you turn on multiple programmable connections to an input; however, only
the connection from the driving interconnection segment to the input pin is valid. Any additional connection points that are turned on do not connect to the driving segment, although they appear to be connected. If you execute the XACT design rule check command, DRC, it flags nets that have been routed in this way as *unrouted* and does not calculate their attendant delays. The following figure shows an improperly connected net routed through an input switch path.

**Illegal Connections**

Outputs of blocks can drive multiple interconnection segments, although this usually is not necessary. You can *not* use the output path switches to interconnect a net that is not driven by that block. The figure above also shows an improperly connected net using the output path switches. In both the input and output cases, you can only make these connections with the EDITNET command. To avoid these improper
connections, exercise caution when using this command.

5.4.3.2 High Fanout Nets

When you place and route a design involving high fanout nets, you often encounter congestion problems when entering it with the auto router enabled. In these instances, you probably must use alternate placements to complete a good design. You should follow this sequence of steps to route high-fanout nets.

1. Plan an initial placement on a blank LCA printout using the placement guidelines discussed above. Pay particular attention to the appropriate use of direct connection.

2. Start entering the design with the automatic router enabled. However, enter only the destination pins when you enter each high fanout net. Leave the source undefined, even though you know what it is. This lets XACT route more quickly, and results in a less cluttered design.

When you finish entering all of the regular nets, perform the following tasks.

3. Look at the congested areas. You can easily identify them by counting the used vertical and horizontal general interconnection segments in each column/row. A printout of the complete design, with the option SHOW USED enabled, can be helpful.

4. Save the design as a backup in case subsequent modifications fail to produce anything useful.

5. Generate a new placement by modifying the congested areas identified above. Use MOVEBLK and SWAPBLK to move the blocks to new locations. The criterion for the new placement
5.4.3.3 Useful Routing Functions

should be to eliminate as much congestion as possible.

6. Make the new placement with the automatic router disabled.

7. Route the high fanout net or nets using techniques 1 and 2 above. You should be able to route the high fanout nets optimally with this technique. View the design in either large or medium scale so that you can see as many blocks as necessary to find out where to locate the routing. Also highlight the high fanout net to show stubs at each of the required connections. This lets you see their physical relationships better.

8. Save the intermediate results as a backup.

9. Route all the remaining nets with the ROUTE* command, or route selected nets individually with the ROUTE command.

This iterative technique of manually routing selected nets should minimize routing problems and improve device performance. It can be applied equally well to nets with performance constraints and to those with fanout constraints.

5.4.3.3 Useful Routing Functions

There are several other useful routing-related functions you can use to optimize designs. These are SWAPSIG, CLEARPIN, and ROUTEPIN, all of which are discussed below.

SWAPSIG

The SWAPSIG command, located in the PIN menu, is useful when you optimize the routing of a signal to a specific block. The SWAPSIG command logically interchanges the net connections of the block pins, and simultaneously changes the block function to match the new pin assignment of the signals.
In many cases, signals are better routed to a specific block pin, in spite of the general interchangeability of the pins. The following figure shows some typical signal routes for which you can modify the choice of block pins to relieve routing congestion.

**Note:** You should always use SWAPSIG and not SWAPPIN when working with pins on a single block, because it modifies the internal function to match the pin swapping.

SWAPPIN is valuable for moving a net connection from one block to another.

**A.** Connection From CC to CD

**B.** Result After SWAPSIG of CD.A and CD.B

A net routed with a general interconnection. SWAPSIG easily lets you interchange the pin assignment of the destination block to use the direct connection. This frees the general segment for use in other routing.

You can also use the SWAPSIG command on block outputs to swap them for direct connection, or to drive a specific adjacent general interconnection segment. In the case of outputs, X and Y are completely interchangeable internally.
so you can select and assign them entirely on their external connection usage.

B. Two pins that have been swapped using SWAPSIG, to provide more efficient use of the general interconnection. The initial connection to pin C is from a signal running in the adjacent horizontal channel; Pin D is from an adjacent vertical channel. When you swap the signals, the vertically oriented signal routes directly to C and the horizontal signal routes to D.

**Note:** The internal constraints on the input pins to logic blocks can limit some uses of SWAPSIG.

These constraints are flagged when the command is executed.

### CLEARPIN

The CLEARPIN command lets you deconfigure the interconnection for a particular pin on a net. It also removes any spurious interconnection segments from the net.

CLEARPIN, located in the PIN menu, is useful when attempting to relieve congestion. It lets you return the interconnection from a single pin on a net to the available pool of routing resources. When you route critical or high fanout nets, you can use the freed interconnection for a particular route. Then you can route the unrouted pin either manually or with the ROUTEPIN command.
ROUTEPIN and ROUTE

When you manipulate the routing for part of a design, you often leave pins unrouted. You can route these pins with the ROUTEPIN command for the pin; however, ROUTEPIN forces you to select all pins to be routed. ROUTE, on the other hand, routes all pins assigned to a selected net. The figure below shows how ROUTE can be more efficient if you must route a large number of pins. ROUTEPIN operates faster than ROUTE for a single pin. ROUTE checks each pin on the net and operates on a single net at a time.

Querynet: PNRFG25B.LCA, XACT 1.3

| net1  | DD.X | *** DE.A |
|       |      | *** CF.D |
| net2  | DE.X | *** CG.D |
|       |      | *** CE.D |
| net3  | ED.X | *** CF.B |
|       |      | *** EF.A |
|       |      | *** EE.B |
|       |      | *** EF.B |
|       |      | *** DG.C |

This report of unrouted nets indicates 9 unrouted pins.
With ROUTEPIN this requires 1 command selection and 9 location selections.
With ROUTE this requires 1 command selection and 3 location selections.

ROUTE and ROUTEPIN Comparison
5.5 TIMING ANALYSIS, DELAY CALCULATOR

After you complete the placement and routing of your LCA design, you analyze the timing of the design against the original design specifications. This discussion describes how to analyze performance.

**Note:** You can also perform timing simulation, as described in Chapter 2.

The LCA development system includes a unique interactive timing-*delay calculator* that shows you the worst-case delays associated with a design without having to translate and simulate the design. The delay calculator is useful for selecting placement-and-routing alternatives when tuning a design for maximum performance. The delay calculator can extract delay information for the CLBs, IOBs, and the interconnection paths, as follows.

### 5.5.1 CLB AND IOB DELAYS

CLB and IOB delays are perceived as fixed worst-case values based on the particular configuration of the block by the delay calculator. These delays are characterized from operating the devices at worst-case conditions and are typically constant for a particular speed grade.

### 5.5.2 INTERCONNECTION DELAYS

Interconnection delays are more complex. Each interconnection segment used in a signal path represents a distributed R/C delay. Inputs to each CLB or IOB have a negligible capacitance when compared to the capacitance of the interconnection segments.

To correctly calculate the worst-case delay for interconnection, the delay calculator accounts for the accumulation of the interconnection delays. Also, each transistor switch represents a non-linear impedance that modifies the drive characteristics as viewed by downstream interconnection segments. Passing through several interconnection segments and...
switches degrades the quality of LCA signals. In the general purpose interconnection area, the LCA device includes bidirectional buffers that re-power the signals after they pass through several segments. Each buffer also represents a delay, yet the buffer restores the initial quality. These buffer delays are accounted for in the overall delay calculation.

The next figure summarizes these delays and the elements included in the model for interconnection delay calculations.

Interconnection Delay Example
The delay calculator considers all of these elements when calculating interconnection delays. In XACT, when you position the cursor on a destination pin for a net, the worst-case delay from the net's source to that destination is shown on the information line, as shown below. As you position the cursor on each destination, the appropriate delay is shown.

Delay Calculator Result On-Screen

The delay calculator calculates the delays on a net-by-net basis because the complete net configuration must be considered to determine the delay. As you define a net, the net delay to each point is not available until you specify the source and all of the destinations. When you select the DONE option in the net specification process, interconnection delays are calculated if the net is already routed; this is typical if the automatic router is enabled. For pins not routed, a ? is shown in the delay field.
When you perform manual routing with EDITNET or other techniques, interconnection delays are not calculated until you select the DONE option and connect a destination pin to the source pin. If you subsequently modify a net by adding other pins or interconnections, a new net delay is calculated, and the new timing information becomes available.

You can obtain interconnection delay information interactively, on the information line of the display. You can also obtain delay information in text reports, either to the screen or in printed form. The following figure shows a sample delay report printed after selecting REPORT DELAY and specifying the desired FROM and TO options. You can also get delay information, on-screen or printed, with the QUERYNET command.
### 5.5.3 CLOCKED SYSTEM DELAYS

In a clocked system, delay calculations are made from clock-edge to clock-edge. Because it has no knowledge of the dynamic operation of the system, the delay calculator can only consider the elements that are connected logically from one clocked device, latch or flip-flop, to the next clocked device.
Note: You must perform timing simulation to investigate the operational constraints of the clocked system. However, the delay calculator does calculate the complete clock-edge to clock-edge path, including the clock-to-output delay and the required setup time. With these complete delay paths, you can easily obtain the worst-case clock frequency: worst-case frequency = 1/(clock-to-clock delay). In the figure above, the worst-case clock-to-clock delay for Net 17 and Net 18 is calculated as 98 ns, so you could clock this circuit at 10 MHz, worst-case.

5.5.4 SPEED GRADE DELAYS

The LCA family offers multiple speed grades for different system requirements. The delay calculator can calculate all delays for a design, given different speed grades.

You select the speed grade with the SPEED command from the MISC menu in XACT and the currently available speed grades for the selected device display. You select the appropriate one. The delay calculator then re-computes and makes available all delays for that speed grade of device, either for display on the screen or in the report file available for the design.
5.5.5 SIGNAL DEGRADATION

Because of the nature of the pass transistors used to interconnect the various signal-path elements, the rise-and-fall times and general signal quality are degraded by each switch element. When taken together over a long signal path, the change in rise-and-fall times and in the signal quality can significantly degrade the predictability of the delay for a particular path. The bidirectional buffers used to re-power the signals in the general interconnection normally alleviate most of these conditions, if they are on the signal path. The combination of manual editing and the router’s ability to route signals with remaining resources can create some paths with significant signal degradation.

The delay calculator flags signal paths with degraded signals with a tilde (~) preceding the calculated delay. These degenerate nets can be the result of one or more of the following factors.

A. A general interconnection segment and its associated signal drive a long line. Long lines have relatively high capacitance. This affects the signal quality, particularly when driven by a general interconnection segment and not the direct source of a signal.

B. A long line consists of one or more general interconnection segments. In general, long lines greatly decrease the drive capability of the signal source. When driving general interconnection segments, the combination of interconnection switch impedance and long line becomes a problem.

Degradation of signal quality affects the signal primarily in differences between rise and fall times. As the delay number increases, the difference between rising-signal delay and falling-signal delay also increases. For
example, consider a delay calculation of ~50. This indicates the following.

A. Falling signals, 1 to 0 transitions, occur more rapidly than indicated. Here, the falling transition can propagate in 35 to 40 ns, worst case.

B. Rising signals, 0 to 1 transitions, occur in more time than indicated. For this case, the rising transitions can require 70 ns or more, worst-case.

The percent variation between rising and falling transitions in the degenerate cases is difficult to predict, but it generally is in the range of 20 to 40% below or above the indicated value.

**Caution:** Be careful with degenerate nets. If these signals are timing critical, it is highly recommended that you reroute them to eliminate the tilde indication. In some cases, for example, static control, the actual delays are not critical and you can safely ignore the tilde.

In other cases, you can compensate for the difference between the rise and fall by appropriate logic sense selection. For example, a relatively common high-fanout signal used in counter applications is a synchronous RESET generated by a terminal count detection. If the signal sense is defined as HIGH-true, or reset when 1, the critical timing edge is the rising edge.

**Note:** Analysis indicates that the rising edge is slower than the falling edge, so if you redefine the signal to be LOW-true, or reset on 0, you can take advantage of the quicker propagation time for falling signal transitions.

This change can improve the overall capability of the system by eliminating potential metastability or partial counter-reset problems that might otherwise occur.
5.5.5.1 Analysis of Intermediate Timing

In a circuit with a long path, it is helpful to measure or predict the intermediate delays when considering placement and routing alternatives. One method of seeing the delay calculator results, or measuring delay differences along a path, is through temporary I/O block connections. The following figure shows two I/O blocks temporarily defined along the path. You can use the delay calculator to see the delay to each block; then use the differences to analyze the results of routing changes or to determine timing-skew related issues. Using the XACTOR In-Circuit Emulator you can temporarily define these I/O blocks as outputs and measure the timing differences directly.

Parallel Long Lines

Intermediate I/O Block

I/O Block to Allow Intermediate Delay Calculation or Measurement

Parallel Long Line to Provide Higher Fanout Signal Source
5.5.5.2 Examples

The example below shows a potential signal degradation problem.

The diagram illustrates two scenarios:

A. **Signal Route With Tilde Delay**

- Pin: AD.D
- Net: net19
- Delay: ~35ns

B. **Signal Re-Routed to Eliminate Tilde Delay**

- Pin: AD.D
- Net: net19
- Corrected Delay: 28ns

Routing with Tilde on Delay Value
A. An example with a potential signal degradation problem, with tilde delay, because the net is routed through several general interconnection segments prior to driving a long line. The timing delay calculator number in the lower-right corner of the screen is \(-35\) ns.

B. A routing modification that decreases the delay to 28 ns, and the tilde delay is no longer indicated.
The following figure shows an example where you can safely ignore the tilde indication. The net shown is a static input used by several blocks for function selection. In this case, the delay and signal quality are not of concern because the signal does not change, as might be the case for switch-type inputs or other interface signals generated by the user. The only concern with long delay signals of this type is that blocks using that signal must latch correctly after the transition.
5.6 SUMMARY

Appropriate use of the LCA development system capabilities gives you powerful control over all aspects of your LCA design. You can often enter simple designs directly, without paying significant attention to the details of placement and routing. Only when you must implement complex designs, or designs with stringent performance constraints, do the issues of placement and routing require special attention. The techniques discussed here should guide you in implementing a complex design with minimum effort.

Future products for designing with LCA devices will offer improved methods of design entry and increased isolation from the implementation details of the LCA device. Regardless of the sophistication of these development systems, there will continue to be a requirement for interactive design optimization, either for performance or resource use. The LCA development system fulfills that requirement by combining simplicity of operation with quick and efficient design optimization capabilities.
Chapter 6

Configuring the LCA Device

Configuring the LCA Device............................................................. 1
6.1 LCA Configuration Overview......................................................... 2
   6.1.1 Configuration Bit Stream....................................................... 2
   6.1.2 Configuration Process.......................................................... 2
6.2 Configuration Modes....................................................................... 6
   6.2.1 Considerations........................................................................ 7
      6.2.1.1 External versus Automatic Configuration Control.............. 8
      6.2.1.2 Configuration Time............................................................. 13
      6.2.1.3 Configuring Multiple LCA Devices................................. 14
   6.2.2 Configuration Pin Functions.................................................. 14
      6.2.2.1 M2, M1, and M0................................................................. 15
      6.2.2.2 DIN and DOUT................................................................. 16
      6.2.2.3 HDC and ~LDC................................................................. 16
      6.2.2.4 CCLK.................................................................................. 16
      6.2.2.5 ~RCLK............................................................................... 17
      6.2.2.6 ~RESET............................................................................. 17
      6.2.2.7 D/~P.................................................................................. 17
      6.2.2.8 ~PWRDWN................................................................. 18
   6.2.3 Slave Mode......................................................................... 19
   6.2.4 Peripheral Mode.................................................................... 22
   6.2.5 Master Modes....................................................................... 27
6.3 Configure Multiple LCA Devices................................................... 34
   6.3.1 Daisy-Chain Configuration..................................................... 34
   6.3.2 Parallel Configuration............................................................ 36
6.4 Assigning Multiple-Function............................................................ 38
   6.4.1 Potential I/O Conflicts........................................................... 38
   6.4.2 Unused I/O Pins.................................................................... 40
6.5 Configuration Data...................................................................... 42
   6.5.1 Configuration File Format..................................................... 44
This chapter discusses considerations for when you configure LCA devices and read back the configuration data. The configuration techniques covered here apply to the 2064 48-pin and 68-pin packages, and to the 2018 48-pin, 68-pin, and 84-pin packages.

- The overview, 6.1, introduces LCA configuration.
- The discussion on configuration modes, 6.2, explains design considerations, pin functions, and the Slave, Peripheral, and Master modes.
- The discussion on configuring multiple LCA devices, 6.3, describes how to configure multiple devices in a daisy-chain or parallel configuration.
- The discussion on assigning multiple-function I/O pins, 6.4, explains how to handle potential I/O conflicts and unused pins.
- The discussion on the configuration data, 6.5, introduces the content and format of the LCA configuration bit stream.
- The discussion on reading back configuration data, 6.6, explains how to read back an LCA configuration bit stream for verification.
6.1 LCA CONFIGURATION OVERVIEW

When designing an LCA device, you must first identify those parts of the system-level design that can be implemented in one or more devices. Then you partition these elements into clusters of basic logic functions, composed of CLBs and IOBs. Next, you enter, place, and route the interconnection networks for each device. Finally, for each device you compile a configuration bit stream that defines its function.

6.1.1 CONFIGURATION BIT STREAM

You design the configuration using the LCA development system design editor, EDITLCA. You use the bit-stream generator, MAKEBITS, to convert the LCA design into a configuration bit-stream file. Then, you use the download cable with the MAKEBITS software to transfer the configuration bit stream into an LCA device in the target system.

You can verify the bit stream, described later, using the READBACK command. The bit stream determines how the LCA device functions. Discussion 6.5, Configuration Data, details the configuration format.

6.1.2 CONFIGURATION PROCESS

You verify your LCA design(s) in any of three ways. The first method is the only one that does not include a configuration process.

- Use a timing simulator to verify the logic and timing of the LCA design.

- Use the MAKEBITS software to generate a configuration bit stream and use the download cable to transfer it into the LCA device in the target system.

- Use the MAKEBITS software to generate a configuration bit stream and use the XACTOR software for in-circuit emulation.
An LCA device is best described in terms of three distinct states.

- Initialization
- Configuration
- User-operation

After a power-up delay, the LCA device powers up in the initialization state. In this state, its internal configuration memory is cleared, and all internal user-definable logic is held in a quiescent, or idle, state. After initialization, the LCA device checks the input logic level at the ~RESET pin. When a valid logic-1 level is detected at the pin, the device enters the configuration state.

During the configuration state, the LCA device is ready to load the configuration data. The configuration data is a serial bit-stream format. The configuration data loads as though the device is a shift register.

The configuration mode, which is the method used for loading the configuration data, depends on the logic levels of the Mode Select pins: M2, M1, and M0. These pins and their functions are explained in discussion 6.2.2.1. Although you can use any of the modes to enter the configuration data, the content and format of the bit stream are fixed for a given logic application.

The configuration bit stream contains a preamble code plus a bit field that indicates its length. When the LCA device loads the preamble code followed by the correct number of bits, as indicated by the length count, the D/~P open-drain output pin goes HIGH to indicate that configuration is complete.

**Note:** After the configuration process begins, it must either terminate, or abort and restart. Partial configuration is not possible.
After configuration, the LCA device enters the **user-operation state** and performs the logic functions specified in the design. During operation, however, you can return to the initialization state and repeat the configuration process. A state diagram illustrating this sequence is shown below.

**Note:** You can disable the reconfiguration capability by setting the appropriate bit in the configuration bit stream. If you disable the reconfiguration capability, you can change the LCA device's configuration only by removing and reapplying power to it.
Note: During the initialization and configuration states, all user I/O pins, except those used by the configuration process, have passive internal pull-up resistors that cause those pins to go HIGH when not externally overdriven.

Upon entering the user-operation state, all user I/O pins simultaneously become functional, according to your specified pin definitions.

The following discussion explains the five possible modes for loading the configuration information into the LCA device.
The LCA device supports five configuration modes, including three Master modes, for loading LCA programming information.

1. Slave mode
2. Peripheral mode
3. Master-Serial mode
4. Master Parallel-Low mode
5. Master Parallel-High mode

You select a configuration mode by connecting the dedicated Mode Select pins, M0 and M1, and the programmable Mode Select pin, M2, to either a logic-1 or a logic-0 signal, as indicated in the following table.

<table>
<thead>
<tr>
<th>Configuration Mode Selection</th>
<th>Mode Select Pins</th>
</tr>
</thead>
<tbody>
<tr>
<td>Master-Serial mode</td>
<td>0 0 0</td>
</tr>
<tr>
<td>Master Parallel-Low mode</td>
<td>1 0 0</td>
</tr>
<tr>
<td>Master Parallel High mode</td>
<td>1 0 1</td>
</tr>
<tr>
<td>Peripheral mode</td>
<td>1 0 0</td>
</tr>
<tr>
<td>Slave mode</td>
<td>1 1 1</td>
</tr>
</tbody>
</table>

**Note:** The current mode selections do not use all possible combinations of M1, M2, and M3, which leaves room for future expansion of configuration options.

The following discussions describe available modes.

- Discussion 6.2.1 outlines considerations that impact selecting a configuration mode.
- Discussion 6.2.2 identifies the special LCA pin functions during the configuration process.
- Discussion 6.2.3 explains the Slave mode.
- Discussion 6.2.4 explains Peripheral mode.
- Discussion 6.2.5 explains Master modes.
6.2.1 CONSIDERATIONS

Each configuration mode has different design considerations and variations in device pin usage during configuration. The choice of a configuration mode depends on your specific system application.

The following are some questions you should ask before choosing a configuration mode.

1. Is control of the configuration process automatic or controlled externally?
   - If the configuration process is externally controlled, that is in Slave or Peripheral mode, is it controlled by software or DMA hardware?
   - If the configuration process is automatic, that is in Master mode, is the configuration
     a. shared with the microprocessor code?
     b. stored in a separate byte-wide PROM?
     b. stored in a serial memory device?

2. How much time is available for configuration?

3. For an application using multiple LCA devices, should they be configured serially as a daisy chain, or in parallel?

4. What are the I/O pin requirements?

   For example, are the I/O pins used by the target application also involved in the configuration? If so, can you assign pins to minimize or eliminate external isolation?

These considerations are discussed in more detail below.
6.2.1.1 External versus Automatic Configuration Control

The externally-controlled case requires that you use either Slave mode or Peripheral mode to load the configuration data into the LCA device serially. You can load the configuration data as part of the system's bootup process or you can load it on the fly.

This externally-controlled method is more flexible than automatic configuration because the configuration bit stream can be read from a PROM, disk, or any other source accessible by a processor. However, this method may take longer to complete than the automatic method.

Automatic configuration uses one of the three Master modes. With Master mode configuration, the LCA device automatically accesses (sends out to) an external PROM for the configuration bit stream. Then the LCA device configures itself using Master mode in 12 to 24 ms for the 2064, and 17 to 35 ms for the 2018.

The following table compares the configuration mode characteristics.
## Comparison of Configuration Modes

<table>
<thead>
<tr>
<th>Configuration Mode</th>
<th>Slave Mode</th>
<th>Peripheral Mode</th>
<th>Master Parallel-Low Modes</th>
<th>Master-Serial Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>Mode Selection Code (M2:M1:M0)</td>
<td>1:1:1</td>
<td>1:0:1</td>
<td>0:0:1 (Master-Low) 0:1:1 (Master-High)</td>
<td>0:0:0</td>
</tr>
<tr>
<td>Configuration Data</td>
<td>Bit-serial</td>
<td>Bit-serial</td>
<td>Byte-parallel</td>
<td>Bit-serial</td>
</tr>
<tr>
<td>Automatic Loading</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Programming Source</td>
<td>User Logic or Another LCA (Note 1)</td>
<td>CPU Data Bus Memory</td>
<td>External Byte wide Memory</td>
<td>External Serial</td>
</tr>
<tr>
<td>Number of User I/O Pins Required</td>
<td>2</td>
<td>6</td>
<td>25</td>
<td>3</td>
</tr>
<tr>
<td>Configuration Time</td>
<td>Source-dependent (Note 2)</td>
<td>Source-dependent (Note 2)</td>
<td>12-24 ms (2064) 17-34 ms (2018) (Note 3)</td>
<td>12-24 ms (2064) 17-34 ms (2018) (Note 3)</td>
</tr>
</tbody>
</table>

Notes: 1. Slave mode is also used by XACTOR for In-Circuit Emulation. 2. The minimum time in any case is approximately 12 ms for the 2064 and 17 ms for the 2018. 3. This parameter depends on internal timing circuits and is manufacturing-process dependent. Therefore, it may vary from device to device within the limits shown.

In all configuration modes, some user I/O pins are temporarily assigned configuration-related functions. The number of such pins ranges from five in Slave mode to 25 in Master mode. Once configuration is complete, these pins become general purpose I/O pins.

However, it is your responsibility to guarantee that no signal conflicts occur between the pin's use in the configuration state and its use in the user-operation state. Signal conflicts on these pins can create undesired side effects, such as disturbing the configuration process or other external logic. With a little care, however, you should not experience problems using these dual-function I/O pins. Although
signal conflicts may be resolved by using external buffers for isolation, careful selection of the pinout assignment can usually eliminate the need for isolation. The five figures below show the LCA device’s pin usage for each configuration mode.

**Slave Mode**

**Peripheral Mode**
Master-Serial Mode

Master Parallel-Low Mode
Master Parallel-High Mode

The following table summarizes the pins used in each mode. Individual pins are described in more detail below, under Configuration Pin Functions, 6.2.2. Also, refer to the example under discussion 6.4.1.
### Summary of Pins Used for Configuration

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Applicable Config. Mode(s)</th>
<th>Function During Configuration</th>
<th>Function During User Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>MO</td>
<td>S P MS MH ML</td>
<td>Mode Select 0 (I)</td>
<td>Readback Trigger (I)</td>
</tr>
<tr>
<td>M1</td>
<td></td>
<td>Mode Select 1 (I)</td>
<td>Readback Data Out (O)</td>
</tr>
<tr>
<td>M2</td>
<td></td>
<td>Mode Select 2 (I)</td>
<td></td>
</tr>
<tr>
<td>D/–P</td>
<td></td>
<td>Indicates configuration process is done</td>
<td>Initiates/Inhibits Re-configuration (I)</td>
</tr>
<tr>
<td>–RESET</td>
<td></td>
<td>Abort/Restart configuration (I)</td>
<td>Master Clear for all internal flip-flops (I)</td>
</tr>
<tr>
<td>CCLK</td>
<td></td>
<td>Configuration Clock(Notes 1 &amp; 2)</td>
<td>Readback Clock (I)</td>
</tr>
<tr>
<td>DIN</td>
<td></td>
<td>Configuration Data In (I)</td>
<td>&lt;User I/O&gt; (Note 3)</td>
</tr>
<tr>
<td>DOUT</td>
<td></td>
<td>Configuration Data Out (O)</td>
<td>&lt;User I/O&gt;</td>
</tr>
<tr>
<td>–LDC</td>
<td></td>
<td>Logic HIGH (O)</td>
<td>&lt;User I/O&gt;</td>
</tr>
<tr>
<td>A0–A15</td>
<td></td>
<td>Address Bus (O)</td>
<td>&lt;User I/O&gt;</td>
</tr>
<tr>
<td>D0–D7</td>
<td></td>
<td>Data Bus (I)</td>
<td>&lt;User I/O&gt; (Note 3)</td>
</tr>
<tr>
<td>–RCLK</td>
<td></td>
<td>Read Clock (O)</td>
<td>&lt;User I/O&gt;</td>
</tr>
<tr>
<td>–WRT</td>
<td></td>
<td>Write Strobe (I)</td>
<td>&lt;User I/O&gt;</td>
</tr>
<tr>
<td>–CS0</td>
<td></td>
<td>Chip Select 0 (I)</td>
<td>&lt;User I/O&gt;</td>
</tr>
<tr>
<td>–CS1</td>
<td></td>
<td>Chip Select 1 (I)</td>
<td>&lt;User I/O&gt;</td>
</tr>
<tr>
<td>CS2</td>
<td></td>
<td>Chip Select 2 (I)</td>
<td>&lt;User I/O&gt;</td>
</tr>
</tbody>
</table>

**Abbreviations:**
- S = Slave
- P = Peripheral
- MH = Master Parallel-High
- ML = Master Parallel-Low
- MS = Master-Serial
- I = Input
- 0 = Output

**Notes:**
1. The –RESET, CCLK, and D/–P pins have multiple functions. See text for further details.
2. During Slave mode configuration, the CCLK pin is an input, while for all other modes, it is an output.
3. DIN and D0 are the same physical pins but are associated with different configuration modes.

### 6.2.1.2 Configuration Time

For some applications, the time required to configure the LCA device is an important consideration. The minimum time required to load the LCA configuration data is the same for all configuration modes, approximately 12 ms for the 2064 and 17 ms for the 2018. The processor-driven configuration techniques under software control for Slave and Peripheral mode may take longer to complete.

Unlike the user-driven Slave and Peripheral modes, the internal oscillator controls the configuration loading time for Master mode. Because the frequency of this internal oscillator depends on the LCA fabrication...
process, configuration loading time can extend to twice the minimum time.

6.2.1.3 Configuring Multiple LCA Devices

In applications using multiple LCA devices, special daisy-chaining capabilities permit you to configure all the linked devices from a single data source. This is described in further detail under discussion 6.3.

6.2.2 CONFIGURATION PIN FUNCTIONS

There are two types of LCA pins used for configuration.

- **Non-programmable pins** are dedicated to the control function.
- **User-programmable pins** are available as general purpose I/O pins after configuration.

There are six non-programmable pins dedicated to control functions.

<table>
<thead>
<tr>
<th>Non-Programmable Pins</th>
<th>Control Functions</th>
</tr>
</thead>
<tbody>
<tr>
<td>M0, M1</td>
<td>Mode Select Pins</td>
</tr>
<tr>
<td>CCLK</td>
<td>Configuration Clock</td>
</tr>
<tr>
<td>~RESET</td>
<td>Master Reset</td>
</tr>
<tr>
<td>D/~P</td>
<td>Done/Program</td>
</tr>
<tr>
<td>~PWRDWN</td>
<td>Power-Down</td>
</tr>
</tbody>
</table>

In addition to the dedicated control pins, several user-programmable I/O pins have configuration functions assigned to them, regardless of which configuration mode you select. These pins, as well as the dedicated control pins, are described below. Other I/O pins are used in only one specific configuration mode and are described in the discussion of that mode.

The following are user-programmable I/O pins that can be used during configuration.
<table>
<thead>
<tr>
<th>User-Programmable Pins</th>
<th>Control Functions</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2</td>
<td>Mode Select</td>
<td>(Present)</td>
</tr>
<tr>
<td>DIN/D0</td>
<td>Configuration Data In</td>
<td>in</td>
</tr>
<tr>
<td>DOUT</td>
<td>Configuration Data Out</td>
<td>all</td>
</tr>
<tr>
<td>HDC</td>
<td>HIGH during configuration</td>
<td>Configuration</td>
</tr>
<tr>
<td>~LDC</td>
<td>LOW during configuration</td>
<td>Modes</td>
</tr>
<tr>
<td>~CS0, ~CS1, CS2</td>
<td>Chip Selects</td>
<td>Peripheral mode only</td>
</tr>
<tr>
<td>~WRT</td>
<td>Write Strobe</td>
<td>Peripheral mode only</td>
</tr>
<tr>
<td>~RCLK</td>
<td>Read Strobe</td>
<td>Master modes only</td>
</tr>
<tr>
<td>A0-A15</td>
<td>Address Bus</td>
<td>Master parallel modes only</td>
</tr>
<tr>
<td>D0-D7</td>
<td>Input Data Bus</td>
<td>Master parallel modes only</td>
</tr>
</tbody>
</table>

**Note:** Except for HCD and ~LDC, all unassigned user-I/O pins not used in configuration have passive internal pull-ups to Vcc, as described in discussion 6.2.2.3. The passive internal pull-ups on all user-programmable I/O pins are removed after configuration is completed.

### 6.2.2.1 M2, M1, and M0

M2, M1, and M0 are Mode Select input pins that select the configuration mode the LCA device uses, as explained under 6.2, Configuration Modes. Pins M0 and M1 are dedicated configuration pins. The M2 pin, unlike M0 and M1, becomes available as a general purpose user-I/O pin after configuration.

**During configuration,** pins M1 and M2 have internal pull-up resistors, while pin M0 does not. Except for Master-Serial mode, you should not drive pin M2 LOW during configuration. If left unconnected, it is pulled high.

In applications that do not use the LCA device's readback capability, you can tie the mode select pins directly to ground or to Vcc. Because the M1 and M2 pins are supplied with internal pull-up resistors, you may leave them unconnected after configuration is done.
**Note:** The mode select pins are sampled either at the conclusion of the initialization state, or with the rising edge of \( \sim \text{RESET} \) if used to delay configuration. Thus, you do not need to maintain their logic levels after configuration begins.

### 6.2.2.2 DIN and DOUT

DIN and DOUT are used as the serial data path for configuring both a Slave mode daisy chain, and a Master-Serial mode device. DIN and DOUT are also used for other purposes, such as a data bus or Slave mode without a daisy-chain.

Refer to the descriptions of the Slave and Master-Serial modes, under 6.2.3 and 6.2.5, respectively, for more information.

### 6.2.2.3 HDC and \( \sim \text{LDC} \)

HDC and \( \sim \text{LDC} \) are user-programmable I/O pins. During configuration, the LCA device drives HDC to constant HIGH and the \( \sim \text{LDC} \) to constant LOW. You use these two pins to control external logic during the initialization and configuration states. For example, you can use these pins to enable or disable various external logic circuits, depending on whether each logic circuit is required during or after configuration.

### 6.2.2.4 CCLK

CCLK is a dedicated control pin serving as a clock **input** during Slave mode configuration, and conversely as a clock **output** in all other configuration modes. As an input, CCLK is used during the serial loading of a configuration bit stream. As an output, CCLK serves as a clock source for configuring any Slave mode LCA devices to be daisy-chained to the master LCA device.

During operation, CCLK serves as a clock input for reading configuration data from the device in conjunction with the M0/RT and M1/RD pins. The
6.2.2.5 ~RCLK

The ~RCLK pin performs the function of a read strobe for dynamic memories in the Master-Parallel mode. For the Master-Serial mode, ~RCLK is an output pin that synchronizes the supply of serial data.

6.2.2.6 ~RESET

The ~RESET pin is an active-LOW master-reset input. Its function depends on the LCA device's state. During the initialization state, after power-up and prior to starting the configuration, this pin can delay the start of configuration. As soon as the configuration process starts, and until it completes, asserting ~RESET aborts the configuration process and returns the LCA device to the initialization state. Configuration restarts when initialization completes and ~RESET is HIGH. When configuration completes, the ~RESET pin changes function and becomes a master-reset control pin that clears all internal flip-flops and latches to the 0 state.

6.2.2.7 D/~P

The D/~P (DONE/~PROGRAM) pin is both an input and an open-drain-type output with an optional, programmable pull-up resistor. As an output, D/~P indicates the current configuration status of the LCA device.

Prior to initial configuration and during subsequent reconfigurations, the LCA device holds the D/~P pin LOW to indicate that the device is not ready for user operation. When D/~P goes HIGH, it indicates that configuration is done and that the device is in the user-
operation state. Consequently, you can use D/~P in your system reset logic to ensure that the LCA device is fully configured before the reset of the rest of the system is terminated.

The configured output pins on the LCA device become active one clock cycle before D/~P goes HIGH. This allows time for any user-I/O signals to propagate between LCA devices. You can initiate subsequent reconfigurations of the device by applying a logic-0 level to the D/~P pin, with an open-collector-type signal source. You must hold the D/~P pin LOW for several microseconds for the LCA device to recognize the LOW level. Noise is unlikely to trigger a reconfiguration.

As soon as the LCA device recognizes the LOW, it forces D/~P LOW until configuration is completed. The D/~P pin must go HIGH before it can initiate reconfiguration.

**Note:** By using its internal pull-up resistor option, you can leave the D/~P pin unconnected and eliminate its need for any external passive components.

**Also:** You can prevent the D/~P pin from going HIGH after configuration as an alternate technique for disabling the LCA reconfiguration.

---

**6.2.2.8 ~PWRDWN**

The ~PWRDWN pin is an active-LOW input that forces the LCA device into a low-power state. You can reduce Vcc to 2 V after ~PWRDWN is active. Entering the power-down state does not change or modify the configuration information stored in the LCA device; it merely reduces the device's overall power requirements by disabling its I/O pins and certain internal logic.

Power-down resets all internal storage elements, that is CLBs and IOBs but not memory cells, and forces all I/O pins to become high impedance. Internally, logic nodes...
that were driven by inputs to the LCA device prior to power-down are electrically isolated from their pins and forced HIGH.

You must leave the ~PWRDWN pin inactive (HIGH) during initialization and configuration; only assert it while D/~P is HIGH. If your application does not use the power-down feature, you should tie the ~PWRDWN pin to Vcc.

Note: All other user-I/O pins not involved in configuration have passive internal pull-ups to Vcc during configuration. The passive internal pull-ups on all user-programmable I/O pins are removed after configuration is completed.

6.2.3 SLAVE MODE

M2:M1:M0 = 1:1:1 configures the LCA device in Slave mode. This mode is simple and efficient because it uses fewer pins than any other configuration mode. It serially loads the configuration bit stream into the device.

During Slave mode configuration, each bit in the stream sequentially shifts into the DIN input on the LCA device with the rising edge of the clock applied to the CCLK pin, as illustrated below.

Note: In the following figure, TDS is equivalent to TCC, which may appear in other timing diagrams in this manual, and TDH is equivalent to TCCD, which may appear in other timing diagrams in this manual.
Slave Mode Configuration Timing

**Note:** In Slave mode, the CCLK pin is an input, not an output as in other modes.

After the configuration bit stream loads, completing the configuration process requires three additional clock cycles for a total of the length count plus three clocks.

**Slave mode configuration** is especially appropriate in applications where a host processor configures the LCA device through an I/O port. I/O instructions can drive the CCLK and DIN pins, and the system easily meets the minimum data setup and hold times.

**Slave mode** configuration is also useful in multiple LCA applications, where you string together the DIN and DOUT pins of several devices in a daisy-chain arrangement. This arrangement permits several LCA devices to share a common source of configuration data.

In addition to the **six non-programmable** configuration control pins, Slave mode configuration uses **five programmable** pins: M2, DIN, DOUT, HDC, and ~LDC. These become available as general-purpose user I/O pins after configuration is complete. The 53 remaining programmable I/O pins are not used during configuration, as shown in the figure and table below.
### Slave Mode Pin Summary

#### Fixed, Non-Programmable Pins

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Number</th>
<th>Pin Type</th>
<th>Value During Configuration</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M0</td>
<td>26</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>M1</td>
<td>25</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>CCLK</td>
<td>60</td>
<td>Input</td>
<td>&lt;Clock&gt;</td>
<td>Configuration Clock</td>
</tr>
<tr>
<td>~RESET</td>
<td>44</td>
<td>Input</td>
<td>HIGH</td>
<td>Master Reset</td>
</tr>
<tr>
<td>D/~P</td>
<td>45</td>
<td>Output</td>
<td>LOW</td>
<td>Done/Program</td>
</tr>
<tr>
<td>~PWRDWN</td>
<td>10</td>
<td>Input</td>
<td>HIGH</td>
<td>Power-down</td>
</tr>
</tbody>
</table>

#### User-Programmable Pins

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Number</th>
<th>Pin Type</th>
<th>Value During Configuration</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2</td>
<td>27</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>DIN</td>
<td>58</td>
<td>Input</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data In</td>
</tr>
<tr>
<td>DOUT</td>
<td>59</td>
<td>Output</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data Out</td>
</tr>
<tr>
<td>HDC</td>
<td>28</td>
<td>Output</td>
<td>HIGH</td>
<td>Constant &quot;1&quot; Level</td>
</tr>
<tr>
<td>~LDC</td>
<td>30</td>
<td>Output</td>
<td>LOW</td>
<td>Constant &quot;0&quot; Level</td>
</tr>
</tbody>
</table>
In daisy-chained LCA applications, if the first LCA device is configured in Slave mode with a free-running CCLK clock source, you must synchronize the first device with the other devices in the chain. To accomplish this synchronization, you must ensure that ¬RESET is released with the proper setup and hold times relative to CCLK. This timing guarantees that all LCA devices in the daisy chain become operational simultaneously. The devices all begin configuration on the same clock cycle. You can easily ensure this timing by de-asserting ¬RESET with the falling edge of CCLK.

**6.2.4 PERIPHERAL MODE**

M2:M1:M0 = 1:0:1 enables a host processor to load the configuration bit stream into the LCA device via the data bus. In this configuration mode, you can think of the LCA device as a one-bit-wide peripheral device because you load the configuration bit stream into it one bit at a time. Typically, you tie data bus bit 0 to the DIN pin of the LCA device. The processor then shifts each successive bit of the data byte into data bus bit 0 between load instructions to the LCA device. Peripheral mode requires the next fewest LCA device pins for configuration, as shown below.
Peripheral Mode Pin Usage

As in Slave mode, Peripheral mode loads the configuration bit stream into the LCA device bit-serially. When the correct number of bits are loaded into the device, the D/-P pin goes HIGH to indicate that the configuration bit stream is loaded. Completing the configuration process requires three additional clock cycles after the bit stream is loaded, for a total of three clocks more than the length count.

During Peripheral mode configuration, nine of the LCA device's programmable I/O pins function as configuration control pins in addition to the six fixed, non-programmable control pins. The next table shows the configuration pins used in this mode.
### Peripheral Mode Pin Summary

#### FIXED, NON-PROGRAMMABLE PINS

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Number</th>
<th>Pin Type</th>
<th>Value During Configuration</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M0</td>
<td>26</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>M1</td>
<td>25</td>
<td>Input</td>
<td>LOW</td>
<td>Mode Select</td>
</tr>
<tr>
<td>CCLK</td>
<td>60</td>
<td>Output</td>
<td>&lt;Clock&gt;</td>
<td>Configuration Clock</td>
</tr>
<tr>
<td>~RESET</td>
<td>44</td>
<td>Input</td>
<td>HIGH</td>
<td>Master Reset</td>
</tr>
<tr>
<td>D/~P</td>
<td>45</td>
<td>Output</td>
<td>LOW</td>
<td>Done/Program</td>
</tr>
<tr>
<td>~PWRDWN</td>
<td>10</td>
<td>Input</td>
<td>HIGH</td>
<td>Power-down</td>
</tr>
</tbody>
</table>

#### USER-PROGRAMMABLE PINS

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Number</th>
<th>Pin Type</th>
<th>Value During Configuration</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2</td>
<td>27</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>DIN</td>
<td>58</td>
<td>Input</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data In</td>
</tr>
<tr>
<td>DOUT</td>
<td>59</td>
<td>Output</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data Out</td>
</tr>
<tr>
<td>~CS0</td>
<td>50</td>
<td>Input</td>
<td>LOW</td>
<td>Chip Select (Active LOW)</td>
</tr>
<tr>
<td>~CS1</td>
<td>51</td>
<td>Input</td>
<td>LOW</td>
<td>Chip Select (Active LOW)</td>
</tr>
<tr>
<td>CS2</td>
<td>54</td>
<td>Input</td>
<td>HIGH</td>
<td>Chip Select</td>
</tr>
<tr>
<td>~WRT</td>
<td>56</td>
<td>Input</td>
<td>&lt;Strobed&gt;</td>
<td>Write Enable (Active LOW)</td>
</tr>
<tr>
<td>HDC</td>
<td>28</td>
<td>Output</td>
<td>HIGH</td>
<td>Constant &quot;1&quot; Level</td>
</tr>
<tr>
<td>~LDC</td>
<td>30</td>
<td>Output</td>
<td>LOW</td>
<td>Constant &quot;0&quot; Level</td>
</tr>
</tbody>
</table>

The following figure shows the timing relationship between the signals on these control pins.

**Note:** In the following figure, $T_{DS}$ is equivalent to $T_{DC}$, which may appear in other timing diagrams in this manual, and $T_{DH}$ is equivalent to $T_{CD}$, which may appear in other timing diagrams in this manual.
Peripheral Mode Configuration Timing

The DIN and DOUT pins function the same in Peripheral mode as in Slave mode. **Four** other pins serve as bus interface controls. Three of these pins, \(~CS0, ~CS1,\) and **CS2**, become Chip Select pins, while the fourth pin, \(~WRT,\) becomes the Write Strobe input. The \(~WRT\) pin serves the same function in Peripheral mode as CCLK does in Slave mode. A pulse applied to the \(~WRT\) pin, while the three Chip Selects are asserted, shifts one bit of the stream into the DIN input of the LCA device. Each write strobe to a Peripheral mode LCA device also produces a CCLK output pulse that drives the CCLK inputs of the cascaded devices, shown below. The three Chip Selects (two active-LOW, one active-HIGH) map the LCA device to a specific I/O or memory address for configuration.

**Note:** The nine pins mentioned above are available as general purpose, user-programmable I/O pins when configuration is completed.
The other 49 programmable I/O pins are not used for Peripheral mode configuration.

Peripheral Mode LCA Device with Daisy Chain
6.2.5 MASTER MODES

M2:M1:M0 = 0:0:0 configures the LCA device in Master Serial mode.

M2:M1:M0 = 1:0:0 configures the LCA device in Master Parallel-Low mode.

M2:M1:M0 = 1:1:0 configures the LCA device in Master Parallel-High mode.

In the Master configuration modes, the LCA device automatically controls loading the configuration bit stream.

In the Master-Serial mode, the LCA device uses ~RCLK to synchronize the serial input data that provides the configuration bit stream, shown in the figure below.

Master-Seriable Mode Pin Usage
In the **Master Parallel-Low** and **Master Parallel-High** modes, the LCA device uses on-chip control logic to address an external, byte-wide memory device. This memory device, for example an EPROM, holds the configuration bit stream. The following figure shows a typical Master Parallel-Low mode configuration.

![Master Parallel-Low Mode Pin Usage](image)

For the byte-wide or parallel modes, 16 of the LCA device's I/O pins form an address bus. Eight additional I/O pins form a unidirectional data bus. There are two types of byte-wide Master modes.

- The **Master Parallel-Low** mode addresses memory in *ascending* sequence, starting at address zero, 0.
The Master Parallel-High mode addresses memory in descending sequence, starting at hexadecimal address FFFF.

With this addressing flexibility, the configuration data can share space in a ROM or EPROM that typically stores a microprocessor program.

After configuration begins, memory-read cycles continue until the correct number of bits are read. The D/~P pin goes HIGH to indicate that the configuration bit stream is loaded.

**Note:** Bytes of data read from the external byte-wide memory are serialized on-chip, and are independent of physical byte boundaries.

In addition to using the 16 address outputs and 8 data-bus input pins, Master Parallel-Low and High modes also use several other signals. One is the ~RCLK output signal, which is active LOW, yet goes HIGH while the address bus is changing state. This allows clocked EPROMs to store configurations. Other signals are the CCLK and DOUT outputs, both of which drive cascaded or daisy-chained LCA devices, as shown in the following figure.
Master Mode LCA Device with Daisy Chain
The following table summarizes each pin's function in the Master-parallel modes.

### Master Low and High Modes Pin Summary

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Number</th>
<th>Pin Type</th>
<th>Value During Configuration</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M0</td>
<td>26</td>
<td>Input</td>
<td>LOW</td>
<td>Mode Select</td>
</tr>
<tr>
<td>M1</td>
<td>25</td>
<td>Input</td>
<td>LOW or HIGH</td>
<td>(Master-HIGH Mode)</td>
</tr>
<tr>
<td>CCLK</td>
<td>60</td>
<td>Output</td>
<td>&lt;Clock&gt;</td>
<td>Configuration Clock</td>
</tr>
<tr>
<td>~RESET</td>
<td>44</td>
<td>Input</td>
<td>HIGH</td>
<td>Master Reset</td>
</tr>
<tr>
<td>D/~P</td>
<td>45</td>
<td>Output</td>
<td>LOW</td>
<td>Done/Program</td>
</tr>
<tr>
<td>~PWRDWN</td>
<td>10</td>
<td>Input</td>
<td>HIGH</td>
<td>Power-Down</td>
</tr>
</tbody>
</table>

### User-Programmable Pins:

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Number</th>
<th>Pin Type</th>
<th>Value During Configuration</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2</td>
<td>27</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>DOUT</td>
<td>59</td>
<td>Output</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data Out</td>
</tr>
<tr>
<td>HDC</td>
<td>28</td>
<td>Output</td>
<td>HIGH</td>
<td>Constant 1 Level</td>
</tr>
<tr>
<td>~LDC</td>
<td>30</td>
<td>Output</td>
<td>LOW</td>
<td>Constant 0 Level</td>
</tr>
<tr>
<td>~RCLK</td>
<td>57</td>
<td>Output</td>
<td>&lt;Strobed&gt;</td>
<td>Chip Enable Output</td>
</tr>
</tbody>
</table>

### A0 - Axx Outputs

- A15
- A11
- A10
- A9
- A8
- A7
- A6
- A5
- A4
- A3
- A2
- A1
- A0
- A15
- A11
- A10
- A9
- A8
- A7
- A6
- A5
- A4
- A3
- A2
- A1
- A0
- D7
- D6
- D5
- D4
- D3
- D2
- D1
- D0

Although 16 address bits are generated in the Master parallel modes, not all 16 bits are required to configure a single LCA device. The extra addressing capacity of the LCA device lets it address multiple configuration bit streams in a single EPROM. Thus, you can configure several daisy-chained devices from a single source. The device illustrated above presents an example of a Master mode LCA device tied to a daisy chain of Slave devices.
Master Mode Configuration Timing
The Master mode device pauses briefly when powering-up, before it starts the configuration process. This ensures that it successfully configures daisy-chained LCA devices. This **power-up delay**, which is substantially longer than, and unrelated to, the initialization delay for either Slave or Peripheral mode, allows variations in the LCA device's response to Vcc rise times. It also ensures that all Slave mode LCA devices have time to become fully initialized and ready for configuration data. If your system requires longer delays to guarantee that all slave devices have been powered, you can use ~RESET to extend the power-up delay and to hold off the start of configuration.

The next discussion describes the configuration of multiple LCA devices in more detail.
6.3 CONFIGURE
MULTIPLE LCA
DEVICES

Designs using multiple LCA devices can reduce configuration overhead by logically concatenating stored configuration bit streams. Using this option, you can configure LCA devices in daisy chains or in parallel mode, as discussed below.

6.3.1 DAISY-CHAIN CONFIGURATION

If one data source supplies the configuration bit stream for all devices in the daisy chain, then you can configure the first LCA device in the daisy chain in any configuration mode. After it is configured, you load configuration bit streams for all remaining devices in the chain using the pin-efficient Slave mode. When you cascade LCA devices in this way, you configure them one at a time in sequence, starting with the first device in the chain. You can configure virtually any length of daisy chained devices in this manner.

You daisy-chain LCA devices by connecting the DOUT pin of one device to the DIN pin of the next device. Each device in the chain supplies data to the immediately following Slave mode device. As soon as a given device in the daisy chain receives its share of the configuration data, the balance of the data simply passes through it to configure the remaining devices in the chain. The DOUT pin is HIGH until the length count is reached and configuration is completed.

Data passing through an LCA device from the DIN pin to the DOUT pin is subject to a one-clock-cycle resynchronization delay. When configuration completes for all devices, both DIN and DOUT become available as general purpose I/O pins. The following figure illustrates how you can connect multiple LCA devices into a daisy chain.
Peripheral Mode LCA with Daisy Chain

Master Mode LCA with Daisy Chain
The following figure shows the configuration timing for the previously discussed daisy-chained LCA device.

6.3.2 PARALLEL CONFIGURATION

In multiple LCA applications, you have great latitude in designing the configuration logic. The serial daisy-chain technique described above is just one method to program multiple LCA devices.

Another possibility, which takes advantage of the bit-serial nature of the Slave and Peripheral configuration modes, is simultaneous parallel configuration. You simultaneously configure multiple LCA devices, as shown in the Peripheral mode example below. Each write-cycle loads one bit into each device.

Simultaneous loading reduces the total time required to configure a group of LCA devices, to the time required to configure a single device. You can further improve performance by adding hardware to configure this group via DMA transfers. For example, if a processor is available, you can simultaneously configure up to eight...
LCA devices in parallel, from a single disk file containing the interleaved device configuration data.

![Diagram of LCA configuration](image)

Parallel LCA Configuration Using Peripheral Mode

The following discussion explains considerations for assigning multiple-function I/O pins.
6.4 ASSIGNING MULTIPLE-FUNCTION I/O PINS

After selecting a suitable configuration mode, you must assign input/output functions to specific I/O pins. Typically, you base the pin assignments on

- logic block placement within the LCA device
- common I/O clock constraints, and
- I/O pin usage during configuration.

You can also use user-definable I/O pins to configure the LCA device, but these pins require careful design. For applications that require many programmable I/O pins, you should consider techniques for making efficient use of these dual-function pins, as discussed below.

6.4.1 POTENTIAL I/O CONFLICTS

Good design practice dictates that no logic signal conflicts occur during either the configuration phase or the user-operation phase. However, these conflicts may not be obvious. The directional nature of some I/O pins used for configuration changes when the LCA device completes configuration and enters the user-operation state. Your design should guarantee that pins used as outputs during configuration do not conflict with other logic sources also tied to those pins, even when they are not used in a given application.

The DOUT pin is an example of an output pin that is easily overlooked. During configuration, DOUT becomes an output, regardless of whether it drives the DIN pin of another LCA device. Other examples include the HDC and ~LDC pins, which are driven HIGH and LOW, respectively, during configuration. A design should be able to tolerate activity on these and other I/O pins used during configuration, without causing a problem if external circuits are also tied to these pins. You can usually prevent this problem by careful pinout assignment or use of isolation buffers.
The following cases describe three approaches that minimize potential signal conflicts.

- **Case 1**: I/O pins used for configuration are dedicated to that function and are not used during operation. In this case, no signal conflicts occur. However, this approach reduces the number of available I/O pins.

- **Case 2**: I/O pins used for configuration are also used during operation. However, the signals are similar in input/output sense and the system suffers no adverse effect from transitions occurring on those pins during configuration. Isolation buffers are not required.

- **Case 3**: I/O pins used for configuration are also used during operation. However, they either conflict in the input/output sense or have signal transitions during configuration that can adversely affect other system logic. You can use three-state buffers to solve this problem, perhaps with the D/~P, ~LDC, or HDC pins serving as the enable control for the buffers.

You can eliminate, or significantly reduce, external logic components in an LCA-based design by watching for the above-listed cases and carefully assigning I/O functions to actual pins. When faced with the conflicts described in Case 3, assign another pinout to eliminate the conflict. Usually, isolation buffers are not necessary because inputs and outputs are assigned without conflicts to the I/O pins used during configuration.

As an illustration, assigning output functions to pins that are already used as outputs during configuration, such as address outputs in Master mode, might obviate the need for buffering those signals. In general, any sharing of similar pin functions during and after
configuration might eliminate the need for external buffer logic.

The following cases illustrate how careful pinout assignment can reduce the number of external logic components in LCA-based applications.

- **Case 1**: When the LCA device is configured in Master mode, the final application can share pins with this mode's address and/or data buses.

- **Case 2**: When the LCA device is configured in Peripheral mode and interfaces to a CPU bus, the ~WRT, DIN, ~CS0, ~CS1, and CS2 pins are driven from this bus and, thus, can be assigned similar functions during configuration and final application.

- **Case 3**: When an application uses multiple LCA devices, and a signal passes from one device to another, you can assign the signal to the DOUT of the first device and to the DIN connection of the second device.

### 6.4.2 UNUSED I/O PINS

An LCA pin programmed as an input and not connected to any external logic is considered a floating input. As with any CMOS device, floating inputs can provide a low-impedance current path from Vcc to ground and result in permanent damage to the device. Thus, you should handle an unused LCA pin in one of the following three ways.

1. **Define it as an output**, and drive it with an internal signal, preferably a constant level 0 or 1.

2. **Define it as an input** and either
   a. drive it externally with logic, or
   b. tie it to an external pull-up or -down resistor, or
   c. tie it to Vcc or ground.
The relative advantages of defining unused pins as inputs or outputs depend on your specific application. You should try to minimize the following.

- Static and dynamic power dissipation
- Component count
- Risk of electrical damage to the device
- Future circuit board modifications

3. The preferred method of treating unused I/O pins follows.

   a. Externally leave the pin open or unconnected.

   b. Internally configure the pin as an output.

   c. Drive the pin internally with a constant level signal.

Typically, you select a nearby, unused CLB output, define it as a constant 1 or 0, and tie that signal to all nearby unused IOBs. If internal routing congestion precludes routing this DC signal to an IOB, your next best option is to drive the IOB's output pin with an accessible net. In this case, a net with the lowest toggle frequency is best because it results in less power dissipation.

Diagnostic test-point outputs are another practical use for unused LCA pins. These test points can be very valuable for monitoring internal logic nodes that would otherwise be inaccessible. Test-point-outputs aid in circuit analysis and debugging.
This discussion explains the LCA configuration bit stream format and loading.

The configuration data required to program the LCA device is a string of bits. The number of bits required to supply all the configuration information for a single device depends on the type of device, as outlined in the following table. For applications using multiple LCA devices connected as a daisy chain, the bit stream grows for each additional device.

**Note:** This description applies only to the bit stream generated by the LCA development system for use in EPROMs. The XACTOR in-circuit emulator uses a different version of the bit stream that is longer; the data is not packed.
### Configuration File Format Shown in Binary Equivalent

**M2064LCA**

| 1111 | Dummy Bits (4 Bits Minimum) |
| 0010 | Preamble Code |
| <24 Bit length count> | Configuration Bit Stream Listing |
| 1111 | Dummy Bits (4 Bits Minimum) |

- 0 <Data frame #001> 111
- 0 <Data frame #002> 111
- 0 <Data frame #003> 111

160 Configuration data frames

(Each frame consists of:
  - a 0 start bit,
  - a 71-bit data field,
  - and 2 or more dummy bits)

Repeated once for each LCA in the daisy chain

- 0 <Data frame #159> 111
- 0 <Data frame #160> 111

1111 Postamble code (4 bits)

**M2018LCA**

| 1111 | Dummy Bits (4 Bits Minimum) |
| 0010 | Preamble Code |
| <24 Bit length count> | Total Number of Bit Stream Bits |
| 1111 | Dummy Bits (4 Bits Minimum) |

- 0 <Data frame #001> 111
- 0 <Data frame #002> 111
- 0 <Data frame #003> 111

196 Configuration data frames

(Each frame consists of:
  - a 0 start bit,
  - an 87-bit data field,
  - and 2 or more dummy bits)

Repeated once for each LCA in the daisy chain

- 0 <Data frame #195> 111
- 0 <Data frame #196> 111

1111 Postamble code (4 bits)

**Notes:**

1. Data bits as shown in the table are shifted into the LCA device with the left-most bit of each line in the table being entered first. The bit field containing the length count is shifted in with the most significant bit first. For master-mode applications, bytes of data read from the EPROM are internally serialized so that D0 is sensed first, D7 last. Therefore, the first byte of the EPROM would read "0100 1111" in binary, or "4F" in hexadecimal notation.
2. In multiple LCA applications where a daisy chain is used for configuration, the length count reflects the total number of clock cycles for all LCA devices configured from this one bit stream.
6.5.1 CONFIGURATION FILE FORMAT

The configuration bit stream begins with several logic-1 level bits, termed dummy bits. These are followed by a 0010 preamble bit pattern, left-most bit first. Following the preamble are 24 bits that represent the length count. The magnitude of this count must equal or exceed a value that is two less than the total number of clock cycles required to shift in all bits in the bit stream, including the dummy bit. Length counts greater than this number (up to $2^{24} - 1$) are valid, and merely delay the D/~P pin from going HIGH to indicate the completion of configuration. All data associated with these additional clocks are ignored.

**Note:** Configuration bit streams for several LCA devices connected in a daisy chain have only a single preamble and length count.

Within the LCA device, the length-count value is held in the length-count register and compared to a CCLK clock-cycle counter to determine when the configuration process is completed. When the value of the CCLK cycle counter equals the value in the length-count register, and all required data frames are entered, configuration is done and the D/~P pin is released. Because all devices in the daisy chain start their clock cycle counters simultaneously, all LCA devices in the daisy chain complete configuration and become simultaneously operational.

The value used for the length count is a function of how many LCA devices the bit stream must configure. For example, if there are three 2064 LCA devices connected in a daisy chain, the configuration bit stream is over 36,000 bits long. The length count is included only once at the beginning of the bit stream. Several additional cycles are required to compensate for the resynchronization delay of the data at each DOUT pin.
The LCA development system computes the precise value of the length count and automatically enters it into the configuration file. The preamble and length-count bits are sensed by each LCA device at its DIN pin and immediately passed on to the next device in the daisy chain via the DOUT pin. Afterwards, however, each device in turn accepts its portion of the configuration bit stream before passing any subsequent data on to the next device. Refer to the following timing diagram.

Timing for Daisy-Chained LCA Devices (Example Using Four Devices)

Within the configuration bit stream, data are presented in frames that begin with a start bit, 0, and end with at least two dummy or stop bits. Between the start and stop bits of each frame, there is a data field that defines your design's logic functions. The last frame is followed by a field of postamble bits.

Note: AMD reserves the right to change the format, organization, and length of the bit stream used to configure the LCA device.
6.5.2 A SAMPLE EQUIVALENT CONFIGURATION FILE

This discussion assumes that a processor configures the LCA device in either Peripheral or Slave mode. The connections to the device, and the timing needed to perform the configuration, are discussed earlier in this chapter. Regardless of the configuration method, the bit stream data is the same. The bit stream for this example, created by MAKEBITS, is in a PROM file, formatted for Intel MCS86 compatibility.

The following figure summarizes the equivalent data format of the PROM file.

Recall: The information preceding the first data field is required to initialize the configuration logic on the LCA device with the proper bit-stream length. Each subsequent data field provides configuration information for a portion of the device.

Typical Equivalent Configuration-Data Arrangement for the 2064

The beginning of the sample PROM-format configuration file for a 2064 is shown next.
The required leading 1s are in the low nibble, with the preamble in the high nibble. The bits are arranged this way to simplify the connections from an external PROM or ROM to the LCA device in Master mode.

<table>
<thead>
<tr>
<th>Bytes</th>
</tr>
</thead>
<tbody>
<tr>
<td>020000020000FC</td>
</tr>
<tr>
<td>100000004F00F460EFFAF3F3FF7C5FFFF7FD39CD7</td>
</tr>
<tr>
<td>10001000A5EBBB5975F7FFFFF3F7FEFEFEB5F6E6</td>
</tr>
<tr>
<td>10002000DFB59AFBDBE4FFFBFFFDFFBEF6BF9F01</td>
</tr>
<tr>
<td>100030007F7F7FF7FFFFFDFFFDFFBEF8F6F6F6F</td>
</tr>
<tr>
<td>10004000CB7F7FFFDFFFDFFBEF3E7F7FFFEF7</td>
</tr>
<tr>
<td>10005000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>10006000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>10007000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>10008000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>10009000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>1000A000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>1000B000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>1000C000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>1000D000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>1000E000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
<tr>
<td>1000F000FFDF7FDFFFDFFFDFFFDFFFEFEE</td>
</tr>
</tbody>
</table>

Beginning of Typical Hex PROM File

**Note:** The first byte of the data field, underlined in line 2, is hexadecimal 4F.

Although the LCA device's internal memory always loads serially, the Master-parallel modes read the configuration bit stream in parallel directly from an external memory device, such as a PROM. The data is serialized internally for loading into the memory cells. The PROM connections serialize the least significant bit of the byte, D0, first. Consequently, the order of the data bits in the PROM file is the reverse of the order in which they are read by the LCA device. When a processor loads the configuration data, the PROM file data is read one byte at a time and supplied to the
device one bit at a time, beginning with the least significant bit, D0.

Consider the three bytes following the first byte, 4F, of the data field in the PROM file above. The hexadecimal 00F460 represents the 24-bit binary length count of 0000000001011110000110, or 12038 decimal, which is the total number of clock cycles required to load this bit stream. Three additional clock cycles are required to complete the configuration and activate the device. The fifth byte, hexadecimal EF, contains the four pad 1s, the start bit, and the first 3 bits of the 71-bit data field.

**Note:** The LCA device inverts the incoming data, so the data bits stored in the memory cells are the complement of the input data.

### 6.5.3 Configuration Loading

Data supplied to the LCA device during configuration is shifted into a 71-bit shift register. When the shift register is full, it is written into the internal memory cells as a single 71-bit word. In the 2064, there are 160 words of 71 bits, comprising a total of 11,360 bits of configuration data. Preamble data increases the total to 12,038 bits. For the 2018, there are 196 words of 87 bits, a total of 17,052 bits of configuration data.

The next discussion explains read-back of the configuration bit stream.
6.6 READ-BACK CONFIGURATION DATA

6.6.1 READ-BACK PROCESS

After you load and store the configuration bit stream, you can read the data back to confirm the configuration, as described below.

With the read-back process, you extract the configuration bit stream from the LCA device. You can use the read-back data to verify that the contents of the memory cells have not changed since the last programming cycle. The read-back data contain the state of the CLB storage elements, such as flip-flops and latches, IOB storage elements, and memory cells in the logic blocks, as well as the state of the input connection point on each I/O block.

The read-back process is accomplished without using user-programmable I/O pins. The data is read back serially by CCLK, M0, and M1. The read-back process is triggered by a LOW-to-HIGH transition on the M0/RT pin. On subsequent cycles of CCLK, internal configuration data are supplied on the M1/RD pin. The following figure illustrates the timing of this data read-back process.

[Diagram showing readback control timing with labels for CCLK, M0/RT, M1/RD, and bit positions]
Individual data frames are read back in the same sequence as they were supplied to the device. In the read-back serial data stream, the individual bits are the true sense of the internally stored data bit. Recall that the bits in the programming stream are the complement of those stored internally.

The initial data frame of the read-back data is preceded by a dummy clock cycle and two dummy bits with an unknown state. After the first data frame, there is a stop bit, 0, and a start bit, 1, prior to the next frame. After the last frame, there is a stop bit, 0. Even when additional CCLK cycles are applied after the last data frame is read, the M1/RD output is disabled. The pin is not driven after the final stop bit.

6.6.2 READ-BACK DATA CONTENTS

After you read the configuration bit stream back, you can compare the read-back bit stream with the input data stream to determine whether the device is correctly configured. You must remove the input data dummy bits and start bits, and the read-back data start and stop bits, either as part of the programming and read-back process or after the read-back process completes.

In the configuration and read-back bit streams, some of the memory locations do not correspond to actual memory cells in the device. These locations may be unused during both the configuration and the read-back processes. They contain the storage elements and input block values during the read-back. You can extract and display the storage element and input block values with the XACTOR in-circuit emulator during debugging. To verify configuration, ignore these bit locations, because their contents might not be the same as the corresponding positions in the bit stream.

By using the MAKEMASK command, you generate bit positions, which are ignored in the read-back data stream. You can convert the bit file generated with
MAKEMASK into a PROM file by using the MAKEPROM software. The MAKEPROM software converts the binary bit stream to hexadecimal format. The format for the final-mask PROM is now identical to the configuration bit-stream PROM. Each data bit in the read-back data stream that should be ignored is represented by a 0 in the mask PROM file.

The following figure shows the beginning of a mask bit-stream file for a 2064 that was converted from binary format into a hexadecimal PROM-format.

**Note:** This file has the same preamble, length count, and pad bits for one LCA device as the standard configuration data file.

```
: 0200000020000FC
: 10000004F00F4608FEDDE8DBBBB78770ECEF5D
: 1000100DF1FDCBFBF3F9463F7FFFFFFE9FFFFFFF3BC
: 100020001DFFWWBBDD7FNF7FFAFED587FDFEFEBEE2
: 10003000DFDF2DC7F7AFFFEEEFFDF7F9E6F7F7CD
: 10004000BFFEFEFFFF7FDB35FBFFFFF7F7FFFFFDEFEE77
: 10005000F1F3E7A7E7CFCFCF78FBBC7C7979F9F288
: 10006000F2FAFBF575EBEEB6D7D7FA7A74B4F33
: 10007000F979E9EFE3E3D5D7A7ABAF4F4D7ED3A
: 10008000EDDADBDBB5B7BD7F77F7FEFEEFFDF3A
: 10009000FDFDFFFFFEEEEEEEFFFEFFEBFBFF77F7B6
: 1000A000EBEF6F7FDEDFABFBF5F77F7BE78F89B
: 1000B000F0F0E1E1C1DEEFFSDKDBDBD7B7F4F65
: 1000C0007F77F77FEFEFEFEFDFF5D7F9F2F3F3E5C5
: 1000D000E7E78DCECF979F9F2F3F3EE7F7BBF4F7B7
: 1000E000EF7EDFF7DBFBF8F7F7EFEFEE7F7F4O
: 1000F000FFFEFFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDFDF
```
To use the mask information,

- strip off the preamble and length count information, and

- extract the appropriate data bits for each data field.

Because the PROM format has the data bits arranged with the least significant bit in the D0 position, they are reordered in the correct sequence, as shown in the figure below. For example, you could write a simple program to create the mask bit fields for each data field.

**Note:** You can verify the end of one data field, and the beginning of the next, by detecting the dummy bits and the start bit between each field.

![Data Bit Sequence Diagram]

**Data Bit Sequence**
This chapter discusses flip-flop metastability in an LCA design.

- The discussion on flip-flop metastability, 7.1, defines the topic and explains the importance of considering it when implementing LCA-based designs.

- The discussion on LCA flip-flop error probability, 7.2, analyzes the flip-flop error probability due to metastability.

- The discussion on minimizing error probability, 7.3, describes the flip-flop error reduction features and provides some design techniques to minimize the error probability.

**Note:** The following discussions on metastability in LCA-based designs merely indicate some of the considerations you should take into account during your design cycle. They are not intended to be exhaustive or definitive.
7.1 FLIP-FLOP METASTABILITY

Metastability is defined as an output state between a valid logic HIGH and LOW for any digital device. It can occur for registers or latches when certain parameters, such as data setup and hold times, are violated. Data at the input of a D-type register must be established as a valid logic LOW or HIGH at some specified time $t_{su}$ (setup) before applying a clock input to that register. This data must also be maintained or held at the input for a specified time $t_{h}$ (hold) after the clock pulse has been removed.

In a completely synchronous system, the clocking of data through registers can be synchronized to a clock edge that is generated from a local source, such as an on-board crystal oscillator. In this case, the timing is predictable and setup and hold times are adhered to when all system parts are connected. In this type of system, no metastability problems should occur. The designer can calculate propagation-delay values from published component data and ensure that no timing parameter violations occur.

With two independently clocked systems, it might not be possible to synchronize the clock frequencies or events, so when data are passed from one system output to the input of the next, setup and hold times might be violated for registered inputs to flip-flops. If the setup and hold time requirements are small relative to the sampling clock period, the probability of violating these parameters is not very high. It further decreases with a decrease in the sampling clock frequency. Also, if the setup and hold times can be reduced by using higher performance devices, then the probability of violating these parameters is further diminished. However, a small probability of a metastable state would still exist.

In digital circuits, valid data input to registers or latches are set either LOW or HIGH. The voltage level is dependent on the technology. If this valid condition is
set up prior to a clocking edge, the data is clocked to the register output and no metastable condition arises. A problem could occur if, at the time of sampling, the input signal is in transition.

In an LCA device, the following valid conditions can occur for TTL and CMOS circuits. In both cases $V_{cc} = 5\ V$

<table>
<thead>
<tr>
<th>Logic Level</th>
<th>Voltage Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>TTL logic HIGH</td>
<td>2.0 V to 5.0 V</td>
</tr>
<tr>
<td>TTL logic LOW</td>
<td>0.0 V to 0.8 V</td>
</tr>
<tr>
<td>CMOS logic HIGH</td>
<td>3.5 V to 5.0 V</td>
</tr>
<tr>
<td>CMOS logic LOW</td>
<td>0.0 V to 1.0 V</td>
</tr>
</tbody>
</table>

For a TTL circuit, any input between 0.8 V and 2 V sampled by a clock edge is neither a LOW nor a HIGH, and represents a violation of hold and setup times. The condition of the output can not be guaranteed to follow a valid logic state because none was sampled at the input.

The typical gate or inverter is essentially a high-gain linear amplifier circuit. Logic HIGH or LOW outputs represent saturation conditions; further input drive does not achieve a corresponding output change.

If, during sampling, the input is transitioning between two logic states, the register or latch could be operating as a linear high-gain amplifier. The ability to recover from a metastable state is then dependent upon the characteristics of the logic device, which is not operating in a valid mode. The gain/bandwidth product of the device in this mode influences the device behavior and determines the output recovery from a metastable condition.

Attempting to characterize the metastability of LCA devices is difficult because the timing associated with different interconnections varies from application to application. Setup and hold times to register and gate
combinations depend on the routing resources used, and these depend on the CLB/IOB layout and configuration. The best way to test for metastability is to test the completed design, deriving metastability data empirically.

One critical element in examining metastability is the gain/bandwidth product, which gives rise to a loop-delay in the system. Loop-delay is the time required for a signal at any point in the flip-flop to propagate through the flip-flop circuit and reinforce the signal at its starting point. The following figure shows one type of flip-flop with the loop delay path indicated.

![Loop Delay in a Typical Flip-Flop Implementation](image)

Loop Delay in a Typical Flip-Flop Implementation

A change in the state of a node in the flip-flop, for example, a change at the input, requires one loop delay for the flip-flop to hold the new state. In a metastable condition, an internal node, typically in the input stage, attains an intermediate level because the data signal changes while the clock is changing. This intermediate level, neither 1 nor 0, propagates around the loop and forces the output into a metastable state. The flip-flop only achieves a stable (1 or 0) output when a node at the intermediate level becomes 1 or 0, and this new value then propagates through the loop to force the output out of the metastable condition. Movement of internal nodes away from the intermediate level occurs randomly and cannot be predicted or guaranteed.
Another way to illustrate flip-flop metastability is to plot the worst-case clock to flip-flop output delay versus the delay from stable data to the clock edge. The figure below shows this type of plot for a typical flip-flop.

![Graph showing clock-to-output delay and normal delay with critical times](image)

Flip-Flop Output Critical Timing

As the data transition approaches the clock edge, the stable output delay begins to increase. For any flip-flop type, there is a finite probability that the loop delay $x$ at the critical data-to-clock relationship can be infinitely long.

The next discussion explains how error probability is determined; it also provides some sample calculations.
The two critical issues in examining metastability characteristics of flip-flops in any system are the probability of an error based on a metastable condition, and the methods of minimizing the error probability. For logic implemented with LCA devices, you have some additional control.

The probability of a flip-flop passing through a metastable region can be calculated as follows.¹

\[
\text{Probability} = 1 - e^{-\frac{\text{settling time}}{\text{loop delay}}}
\]

The probability of a flip-flop remaining in the metastable region is then calculated as follows.

\[
\text{Probability of Error} = e^{-\frac{\text{settling time}}{\text{loop delay}}}
\]

For the circuit shown and analyzed below, the **settling time** is the difference between the worst-case delay from a clock edge clocking the flip-flop in CLB 1 and the output propagating to the flip-flop in CLB 2; this includes the setup time and the delay from one clock edge to the next. This maximum delay path produces the lowest settling time with the highest probability of error.

Examining a specific case where the 2064 has a worst-case flip-flop loop delay of 2 ns, the critical timing parameters required to estimate the error probability for a metastable condition are shown below.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Flip-flop clock to output delay</td>
<td>20 ns</td>
</tr>
<tr>
<td>Interconnection delay</td>
<td>15 ns</td>
</tr>
<tr>
<td>Flip-flop setup time</td>
<td>12 ns</td>
</tr>
<tr>
<td>Flip-flop loop delay</td>
<td>2 ns</td>
</tr>
<tr>
<td>Clock Period (10 MHz)</td>
<td>100 ns</td>
</tr>
</tbody>
</table>
For this example, the error probability is calculated as follows.

\[
P [Error] = e^{-\frac{-[(100-(20+15+12))/2]}{2}} \\
= e^{-\frac{-53}{2}} \\
= 3.1 \times 10^{-12}
\]

This value represents the probability of a flip-flop remaining in a metastable region beyond the given settling time for a single event. For multiple events, which represent a repetitive clock sampling of an asynchronous signal, the time between failures obeys the following relationship.

<table>
<thead>
<tr>
<th>Failures Per Time Period</th>
<th>Probability per Event X Events per Time</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The time between failures is, then, the inverse of the failures per time-period value. For this example,

\[
\text{Failures per Time Period} = (3.1 \times 10^{-12}) \times (1 \times 10^7) \\
= 3.1 \times 10^{-5}
\]

\[
\text{Time Between Failures} = \frac{1}{(3.1 \times 10^{-5})} \\
= 3.3 \times 10^4 \\
= 8.96 \text{ hrs}
\]

This number indicates a very short time between errors for sampling an event at 10 MHz. This is a worst-case calculation because it is based on an assumption that a potential error condition exists for each clock edge. In a real system this is not the case. When the input clock edge is not synchronized with the arrival of data at the input of the same register, a violation of setup and/or hold times can occur. A metastable condition can result under these circumstances. The statistical probability of these violations, however, is relatively small.
The previous type of calculation indicates several ways of improving flip-flop performance. First, the AMD LCA devices have incorporated error reduction features. Second, there are several design techniques you can follow to increase the error-free performance of the flip-flops in your LCA design. These are explained in the next discussion.
7.3 MINIMIZING THE ERROR PROBABILITY

There are several features and design techniques that can be used to minimize the error probability due to metastability in LCA-based designs. These are summarized in the following discussions.

- 7.3.1, Reducing Errors
- 7.3.2, Using Direct Interconnection
- 7.3.3, Changing the System Clock Rate
- 7.3.4, Using a Faster Device
- 7.3.5, Summary

7.3.1 REDUCING ERRORS

One critical factor in flip-flop metastability is the length of the loop delay. As shown in the previous error-probability calculations, the longer the loop delay, the higher the error probability.

Flip-flops in the LCA 2000 family are specifically designed to reduce the loop delay to a minimum, thus minimizing the probability of a metastability-induced error.

Another critical factor in determining the metastability characteristics of flip-flops in a device is the loading of the flip-flop. In virtually all other technologies, particularly gate arrays, the flip-flop outputs can be loaded differently depending on how the user connects the devices. This variation in loading can significantly complicate the analysis of the flip-flop's metastability behavior.

Note: In LCA devices, all flip-flops are immediately followed by a buffer, and then by the possible user-programmable connections. The buffer isolates the flip-flop from any variations in loading that could induce metastability. This flip-flop isolation significantly simplifies analysis of metastability effects in the system by standardizing the LCA flip-flop output loading.
7.3.2 USING DIRECT CONNECTIONS

If you use direct connections in the critical-path area of the above example, you can eliminate the 15 ns delay for that interconnection. The effect on the error probability is calculated as follows.

\[
P [\text{Error}] = e^{-\left(\frac{100 - (20 + 12)}{2}\right)}
\]
\[
= e^{-68/2}
\]
\[
= 1.71 \times 10^{-15}
\]

For the same 10 MHz clock the error probability results in a significantly reduced mean time between failures (MTBF).

\[
\text{MTBF} = \frac{1}{(1.71 \times 10^{-15}) \times (1 \times 10^7)}
\]
\[
= 5.83 \times 10^7
\]
\[
= 675 \text{ days}
\]

Refer to Chapter 5 of this manual for more information on direct connections.

7.3.3 CHANGING THE SYSTEM CLOCK RATE

If you reduce the clock rate of the sampling, you can dramatically reduce the calculated failure rate. If, for example, you reduce the clock rate from 10 MHz to 5 MHz, you can analyze the error probability with the following parameters.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Clock to flip-flop output</td>
<td>20 ns</td>
</tr>
<tr>
<td>Interconnection delay to second block</td>
<td>15 ns</td>
</tr>
<tr>
<td>Setup time for second flip-flop</td>
<td>12 ns</td>
</tr>
<tr>
<td>Flip-flop loop delay</td>
<td>2 ns</td>
</tr>
<tr>
<td>Clock Period (5 MHz)</td>
<td>200 ns</td>
</tr>
</tbody>
</table>
The error probability is calculated as follows.

\[
P \text{[Error]} = e^{-\left[200-(20+15+12)\right]/2}
\]

\[
= e^{-153/2}
\]

\[
= 5.98 \times 10^{-34}
\]

And for a 5 MHz clock rate, the MTBF is calculated as follows.

\[
\text{MTBF} = \frac{1}{(5.98 \times 10^{-34})(5 \times 10^6)}
\]

\[
= 3.35 \times 10^{26}
\]

\[
= 3.87 \times 10^{21} \text{ days, or}
\]

\[
\approx 1.1 \times 10^{19} \text{ years}
\]

**7.3.4 USING A FASTER DEVICE**

If you use a faster LCA device, you improve all device-related performance parameters. Moving to the next higher LCA speed grade results in the following critical parameters.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Flip-flop clock to output delay</td>
<td>15.0 ns</td>
</tr>
<tr>
<td>Interconnection delay</td>
<td>7.0 ns</td>
</tr>
<tr>
<td>Flip-flop setup time</td>
<td>8.0 ns</td>
</tr>
<tr>
<td>Flip-flop loop delay</td>
<td>1.5 ns</td>
</tr>
</tbody>
</table>

If the clock period remains the same, at 100 ns, then the new error probability is calculated as follows.

\[
P \text{[Error]} = e^{-\left[100-(15+7+8)\right]/1.5}
\]

\[
= e^{-46.667}
\]

\[
= 5.4 \times 10^{-21}
\]

For the 10 MHz clock rate, this error probability results in a new MTBF, as calculated below.

\[
\text{MTBF} = \frac{1}{(5.4 \times 10^{-21})(1 \times 10^7)}
\]

\[
= 1.85 \times 10^{13}
\]

\[
= 2.14 \times 10^8 \text{ days, or}
\]

\[
\approx 563 \text{ years}
\]
7.3.5 SUMMARY

As shown by these examples, the probability of a flip-flop failure, based both on a metastable condition and on the subsequent system MTBF, can vary widely and depends on several factors. When using the LCA device to implement system-level functions, you have significant control over some of the critical parameters necessary to provide sufficient immunity to metastable conditions.
CHAPTER 8

TESTING AND DATA INTEGRITY

TESTING AND DATA INTEGRITY ................................................................. 1
8.1 LCA DEVICE TESTABILITY ....................................................................... 2
  8.1.1 TESTABILITY FEATURES ..................................................................... 2
    8.1.1.1 EPLDs .................................................................................. 2
    8.1.1.2 Gate Arrays ........................................................................ 3
    8.1.1.3 LCA Devices ....................................................................... 3
  8.1.2 TESTING PROCEDURES .................................................................... 4
  8.1.3 SUMMARY ..................................................................................... 5
8.2 DATA INTEGRITY .................................................................................... 6
  8.2.1 RELIABILITY .................................................................................. 6
  8.2.2 ALPHA PARTICLE SENSITIVITY ...................................................... 9
  8.2.3 ELECTROSTATIC DISCHARGE PROTECTION ..................................... 11
  8.2.4 LATCHUP PROTECTION ................................................................. 12
  8.2.5 RADIATION HARDNESS .................................................................. 14
  8.2.6 HIGH TEMPERATURE PERFORMANCE ......................................... 14
This chapter discusses the testing and data integrity features of the AMD LCA device.

- The discussion on LCA testability, 8.1, explains the built-in LCA test features.

- The discussion on data integrity, 8.2, explains the special LCA memory cell design that provides a high level of data integrity in the LCA device.

AMD is committed to providing LCA devices of the highest quality and reliability for its customers. Quality is best achieved by taking the necessary steps to achieve zero defects.

Comprehensive testing ensures that every LCA device is free of defects and that it conforms to data sheet specifications. The LCA memory cell design ensures the configuration integrity. Careful memory cell design also minimizes the effects of alpha-particle emission and electromagnetic radiation on the LCA device's operation.
8.1 LCA DEVICE TESTABILITY

As quality consciousness has grown among semiconductor users, awareness of the importance of semiconductor testability has increased among manufacturers. When manufacturers test standard components, including memories and microprocessors, they use carefully developed processes that exhaustively test the function and performance of each part.

For reasons explained below, most application-specific ICs (ASICs) cannot be comprehensively tested. Without complete testing, defective devices can escape detection and be installed in a system. In the best case, the failure is detected during system testing at a high cost. In the worst case, the device failure is detected only after shipping the system to a customer.

8.1.1 TESTABILITY FEATURES

The AMD LCA device has intrinsic testing advantages, which make it easy to test the device more comprehensively than is possible with other ASICs. The following discussion illustrates these advantages through a comparison with two other types of ASICs, Erasable Programmable Logic Devices (EPLDs) and gate arrays.

8.1.1.1 EPLDs

To test all of the EPLD's memory cells and logic paths, you must program it with many different patterns. This testing requires expensive quartz-lid packages and many lengthy program/test/erase cycles. To save time and reduce costs, you usually abbreviate this process and, therefore, you do not fully test the EPLD.
8.1.1.2 Gate Arrays

Testing a gate array is similar to testing an EPLD. Because each gate array is programmed with individual metal masks, you must test the part with software tailored to the specific design. Each new gate array design requires new test software and test vectors. And each time you create a new design, you must incorporate sufficient controllability and observability for comprehensive testing. Therefore, the design schedule for a new gate array device must include time to incorporate testability features, develop test vectors, and specify test software.

Software to test a complete gate array requires comprehensive fault simulation and test grading, and significant amounts of expensive computer time. It typically requires a series of time-consuming and expensive test iterations to reach 80% fault coverage for a typical design; the cost of greater coverage is often prohibitive. In production, many gate array vendors either limit the number of test vectors you can use, or charge for using additional ones.

When you design a gate array, you can improve your design's testability using special, testable, storage elements, called scan cells, in place of flip-flops and latches. Although using scan cells can reduce the production testing costs, it typically adds about 30% more circuitry, decreases performance by up to 20%, and increases design time.

8.1.1.3 LCA Devices

LCA devices are designed for ease of testing. The testability of an LCA device is similar to that of other standard products, including microprocessors and memories. LCA design and test strategies, discussed below, make LCA devices highly testable.
The LCA design strategy has the following features.

- It incorporates testability because you can configure each functional node and route it to I/O pads.

- It permits repeated exercise of the part without removing it from the tester, because only a short time is required to load new configuration data.

- It produces a standard product that guarantees that every valid configuration works.

The LCA test strategy is characterized by the following.

- It reads and writes all bits in the configuration memory, as in memory testing.

- It uses an efficient parallel-testing scheme that fully tests multiple configurable logic blocks (CLBs) simultaneously.

- It is exhaustive because all CLBs are identical.

8.1.2 TESTING PROCEDURES

As an LCA device user, you can better appreciate the LCA test procedures by examining each of the testing requirements listed below.

- LCA testing exercises and verifies all configuration memory bits using a read-back mode.

- LCA testing detects all possible process-related faults, such as short circuits. The LCA design lets you drive and observe every metal line directly from the I/O pads.

- LCA testing configurations provide good controllability and observability. The
controllability and observability requirements are feasible for LCA devices because all CLBs can be connected to I/O pads. This LCA characteristic makes CLBs easy to control, by testing different input combinations, and easy to observe, by comparing the actual outputs with expected values.

8.1.3 SUMMARY

The test features and procedures described above indicate that the LCA device was carefully designed to be 100% testable. This AMD test strategy uses numerous design configurations to fully test the LCA device. Furthermore, this strategy reduces your design time because testability requirements need not be considered during the design cycle.

The AMD LCA device frees you from the burden of developing a test program and generating test vectors. Also, it eliminates any questions about fault coverage and the need for fault grading.

Testability is very important in quality-sensitive applications. You can build significant added-value into your design by using the higher-quality levels of an LCA-based implementation.

The next discussion focuses on the integrity of data in an LCA device. It explains the various aspects of integrity, such as the robustness of the memory cells that contain the configuration bit stream, the effect of alpha particles, electrostatic discharge, latchup, radiation, and high temperature on the reliability of an LCA device.
The high level of data integrity in the AMD LCA device is based on the specially designed static memory cells that store the LCA configuration data. All characteristics that ensure reliable operation are designed into the memory cells. These characteristics are described in the discussions below.

- 8.2.1, Reliability
- 8.2.2, Alpha Particle (Soft Error) Sensitivity
- 8.2.3, Electrostatic-Discharge Protection
- 8.2.4, Latchup Protection
- 8.2.5, Radiation Hardness
- 8.2.6, High-Temperature Performance

An important aspect of the LCA device's reliability is the robustness of the static memory cells that store the configuration data.

The basic LCA memory cell shown below is a special, single-ended, five-transistor memory element and not the typical, six-transistor, memory cell. Eliminating the sixth transistor, which usually functions as a pass transistor for the complementary output bit, technically slows down the memory cell. However, using the five-transistor, memory cell achieves a higher circuit density with no impact on normal LCA device operation, as explained below.
During normal operation, LCA memory cell outputs are fixed; they hold the LCA configuration. Because these outputs do not change, the slower transition time of the five-transistor configuration does not impact normal operation of the LCA device at all.

The LCA memory cell outputs do change during the configuration write and read-back operations, so using the five-transistor cell slows down these operations.
However, the write and read-back operations have no impact on LCA performance during normal operation, so the LCA user gets more functionality per unit area with no noticeable performance impact.

The design of the basic memory cell also ensures the LCA user of high data integrity in a noisy environment. Consider the following three situations.

- Normal operation
- Write operation
- Read-back operation

In normal operation, the data in the basic memory element does not change. Because, as shown in the above figure, the two circularly linked inverters that hold the data are physically adjacent, supply transients result in only small, relative, voltages differences. Each inverter is actually a complementary pair of transistors; so a low impedance path exists to the supply rail whether the output is HIGH or LOW. This memory cell configuration results in extremely high-noise immunity. Power supply or ground transients of several volts have no effect on the stored configuration data.

For the write operation, the transistor driving the memory cell bit line is carefully designed so it can easily override the output of the feedback inverter whenever
the data to be written to the memory cell is the opposite sense of the stored data. The reliability of the write operation is guaranteed within the manufacturing process tolerances.

During a read-back operation, the bit line, which has a significant amount of parasitic capacitance, is precharged to a logic 1. The pass transistor is then enabled by driving the word line HIGH. If the stored value is 0, the line is discharged to ground. Reliable reading of the memory cell is achieved during a read-back operation by reducing the word line HIGH level to a level that ensures that the cell is not disturbed.

8.2.2 ALPHA PARTICLE SENSITIVITY

The CMOS static memory cell design is insensitive to alpha-particle emissions. The following tests verify that it achieves this design goal.

A 1-microCurie alpha-particle source (Americum 241) was placed in direct contact with the top surface of a 2064 die, allowing the die to capture at least 40% of the emissions from the radiation source. Next, the following tests were performed.

1. A complex pattern containing roughly 50% logic 1s was loaded into the 2064, at operating conditions of 25°C and 5.0V.

2. A pause of variable duration was allowed.

3. The entire contents of the 2064 were then read back and compared with the original data.

To ensure that the test setup would detect errors, validation tests were performed before and after the alpha particle tests, with the following results.
The following discussion analyzes this alpha particle testing. A 1-microCurie source emits $3.7 \times 10^4$ alpha particles per second. Assuming that 40% of these are captured by the 2064 during this experiment, this rate corresponds to $5.3 \times 10^7$ alpha particles per hour.

The alpha-particle-emission rate of the molding compound used by AMD is specified to emit fewer than 0.003 alpha particles per square centimeter per hour (alpha particles/cm²/hr). The 2064 die's surface area is less than 0.5 cm²; thus, less than 0.0015 alpha particles per hour are captured by the 2064 in normal operation. Therefore, the error rate acceleration in this test equals

\[
\frac{5.3 \times 10^7 \text{ particles/hour}}{0.0015 \text{ particles/hour}} = 3.6 \times 10^{10}
\]

The 0.61 hours of test time without error correspond to $2.2 \times 10^{10}$ hours, or 2.5 million years error-free operation.

Most ceramic packages are specified to emit less than 0.01 alpha particles/cm²/hr, which is about three times more than the plastic compound. For a 2064 in a ceramic package, this still results in almost one million years of error-free operation.

The highest rate of alpha particle emission comes from the sealing glass used in cerdip packages and some ceramic packages (frit lids). For instance, KCIM glass
emits about 24 alpha particles/cm²/hr. Low alpha glasses are specified at 0.8 alpha particles/cm²/hr.

Because the glasses are used only for the package seal, they present a relatively small emitting cross section, less than 0.1 cm² square, to the die. Therefore, a low-alpha glass would cause fewer than 0.8 alpha particle hits per hour. The acceleration factor is then $6.6 \times 10^8$, which translates to about 46,000 years of error-free operation.

Clearly, the AMD LCA memory cell design ensures that soft errors caused by alpha particles can be ignored.

### 8.2.3 Electrostatic Discharge Protection

Electrostatic discharge (ESD) protection for each LCA pad is provided by a circuit that uses forward- and reverse-biased distributed resistor-diodes, as shown in the following figure.

![Input Protection Circuitry](image)

Also, the inherent capacitance integrates any current spikes to give the diode and breakdown protections sufficient time to provide a low-impedance path to the power-supply rail. The LCA geometries and doping levels are optimized to provide sufficient ESD protection.
8.2.4 LATCHUP PROTECTION

Latchup is a condition in which parasitic bipolar transistors form a positive feedback loop; this allows the current to quickly reach levels that permanently damage the device, as shown in the following figure.

![SCR Model](image)

Latchup is caused by the formation of parasitic bipolar transistors around two adjacent CMOS transistors. A Semiconductor Controlled Rectifier (SCR), or thyristor, is formed, as shown in the diagram of the SCR model. The net effect of latchup is the static short circuit created from VDD to VSS as the positive feedback causes both parasitic transistors to turn on. The phenomenon of latchup can cause permanent damage, because the short circuit current overheats and ultimately, destroys the CMOS gate.

AMD uses techniques based on doping levels and circuit placement to avoid latchup. The cross section of...
the transistor shown below illustrates some of these protection features.

First, reducing the gain of the parasitic transistors protects against latchup. Because the overall loop gain is minimized, the likelihood of positive feedback is reduced. This is achieved by increasing the width of the transistor bases, which lowers the parasitic transistors' beta.

Second, the butting of contacts effectively shorts the N+ and P+ regions of both wells, so a forward bias $V_{BE}$ cannot be established to start the two parasitic transistors' conduction.

Finally, a guard ring surrounds each well. The N+ ring region is taken to $V_{DD}$ and the P+ ring region is taken to $V_{SS}$. This acts as a reversed-biased diode between the two CMOS transistors, effectively isolating them.
8.2.5 **RADIATION HARDNESS**

A preliminary estimate of the circuit's hardness to withstand ionizing radiation ranges from 10,000 to 100,000 rad SI. This estimate was reached with Sandia National Labs and is based on the design and layout parameters of the LCA device.

8.2.6 **HIGH TEMPERATURE PERFORMANCE**

AMD guarantees parts to perform within the specifications of the datasheet. Furthermore, AMD has performed extensive high-temperature life testing at 125°C with excellent results.
# Chapter 9

## Nonhermetic Package Reliability

<table>
<thead>
<tr>
<th>Section</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Nonhermetic Package Reliability</td>
<td>1</td>
</tr>
<tr>
<td>9.1 Testing Overview</td>
<td>2</td>
</tr>
<tr>
<td>9.2 Test Procedures</td>
<td>3</td>
</tr>
<tr>
<td>9.2.1.1 High-Temperature Life Test</td>
<td>4</td>
</tr>
<tr>
<td>9.2.1.2 Biased Moisture Life Test</td>
<td>4</td>
</tr>
<tr>
<td>9.2.2 PACKAGE INTEGRITY AND ASSEMBLY QUALIFICATION</td>
<td>4</td>
</tr>
<tr>
<td>9.2.2.1 Unbiased Pressure-Pot Test</td>
<td>5</td>
</tr>
<tr>
<td>9.2.2.2 Temperature-Cycling Test</td>
<td>5</td>
</tr>
<tr>
<td>9.2.2.3 Resistance to Solvents Test</td>
<td>5</td>
</tr>
<tr>
<td>9.2.2.4 Solderability Test</td>
<td>5</td>
</tr>
<tr>
<td>9.2.2.5 Lead Integrity Test</td>
<td>6</td>
</tr>
<tr>
<td>9.3 SUMMARY</td>
<td>7</td>
</tr>
</tbody>
</table>
This chapter describes the nature and purpose of the various reliability tests that AMD performs on finished devices.

- The overview of AMD’s testing software, 9.1, explains the applied testing standards.

- The discussion on AMD's test procedures, 9.2, describes the tests performed for die qualification, package integrity, and assembly qualification.

- The chapter summary, 9.3, shows test data from the initial qualification tests.
9.1 TESTING OVERVIEW

AMD is committed to delivering the highest quality, most reliable, programmable gate arrays possible. A strong quality assurance and reliability regimen begins at the initial stages of design and carries through to final shipment. The ultimate proof of AMD's success is in the performance of the LCA device in your applications.

AMD uses an extensive, continuing reliability-testing process to predict the field performance of the LCA device. These tests provide an accelerated means of emulating long-term system operation in severe field environments. From the performance of the devices during these tests, AMD predicts actual field performance.

AMD performs qualification testing of nonhermetic devices to demonstrate the reliability, both of the device die and of the materials and methods used in assembling the device. AMD testing methods are derived from, and patterned after, those specified in MIL-STD-883. However, AMD does not intend the MIL-STD-883 reference to imply that nonhermetic products comply with those requirements.

These test methods are recognized industry-wide as stringent tests of reliability. The tests are commonly used for non-military-grade semiconductor devices, as well as for fully compliant military-grade products.

The following discussion describes the various test procedures used. The summary shows the qualification test data for the 2064/2018 devices. Upon request, AMD's Quality Assurance and Reliability Department will make updated summaries available.
# 9.2 TEST PROCEDURES

The following table summarizes the reliability testing sequence for nonhermetic logic cell array device die-package qualification.

<table>
<thead>
<tr>
<th>Name of Test</th>
<th>Test Conditions</th>
<th>Results/Parameters</th>
</tr>
</thead>
</table>
| 1. High-Temperature Life      | ▪ 1000 hr min. equivalent at temperature = 125°C  
▪ Max, rated operating voltage  
▪ Life test circuit equivalent to MIL-STD-883 | LTPD = 5, S = 77, C = 1 |
| 2. Biased Moisture Life       | ▪ 1000 hr min. exposure  
▪ T = 85°C, RH = 85%  
▪ Max. rated operating voltage  
▪ Biased-moisture life circuit equivalent to MIL-STD-883 | LTPD = 5, S = 77, C = 1 |
| 3. Unbiased Pressure Pot      | ▪ 168 hr minimum exposure  
▪ T = 121°C, P = 2 atm H₂O sat | LTPD = 5, S = 77, C = 1 |
▪ -65°C to +150°C  
▪ 100 cycles | LTPD = 5, S = 77, C = 1 |
| 5. Resistance to Solvents     | MIL-STD-883, Method 2015 | S = 8, C = 0 |
| 7. Lead Integrity             | MIL-STD-883, Method 2004 | S = 15, C = 0 |

Notes: Lot Tolerance Percent Defective (LTPD); Minimum Sample Size (S); Maximum Acceptable Failures (C)

## 9.2.1 DIE QUALIFICATION

AMD performs a High-Temperature Life Test and a Biased-Moisture Life Test to check the long-term operating characteristics of the LCA die.
### 9.2.1.1 High-Temperature Life Test

AMD performs the High-Temperature Life Test to evaluate the long-term reliability and life characteristics of the die. It is defined by the Military Standard (from which it is derived) as a die-related test, and it is contained in the Group C Quality Conformance Test. Because of the time-acceleration factor induced by higher-temperature testing, AMD can accumulate, in a reasonable period of time, data representing a large number of equivalent hours at a normal temperature of 70°C.

### 9.2.1.2 Biased Moisture Life Test

AMD performs the Biased-Moisture Life Test to evaluate the reliability of the die under conditions of long-term exposure to severe, high-moisture environments that could cause corrosion. Although it clearly stresses the package as well, this test is typically grouped under the category of die-related tests. AMD operates the device at 5.0 VDC, and exposes it to 85°C and 85% relative humidity throughout the test.

### 9.2.2 PACKAGE INTEGRITY AND ASSEMBLY QUALIFICATION

AMD performs the following tests to check the quality and integrity of both the package and the assembly.

- Unbiased Pressure-Pot Test
- Temperature Cycling Test
- Resistance-to-Solvents Test
- Solderability Test
- Lead-Integrity Test
9.2.2.1 Unbiased Pressure-Pot Test

AMD performs the Unbiased Pressure-Pot Test at 21°C and two atmospheres of saturated steam to evaluate the ability of the plastic encapsulating material to resist water vapor. Moisture penetrating the package could induce corrosion of the bonding wires and bonding pads of the LCA die. Under extreme conditions, moisture could also cause drive-in and corrosion under the bonding pads. Although it is difficult to correlate this test to actual field conditions, it provides a well-established method for comparison of plastic packaging materials and assembly and molding techniques.

9.2.2.2 Temperature-Cycling Test

AMD performs the Temperature-Cycling Test to evaluate the long-term resistance of the package to damage from alternate exposure to extremes of temperature or from intermittent operation at very low temperature. The temperature range for the test is −65°C to +150°C. The transition time is longer than that in the Thermal Shock test but the test is conducted for many more cycles.

9.2.2.3 Resistance to Solvents Test

AMD performs the Resistance to Solvents Test to evaluate the integrity of the package marking during exposure to a variety of solvents. This is an important test because an increasing number of board-level assemblies are subjected to the severe conditions of automated cleaning before system assembly. AMD performs this test according to MIL-STD-883, Method 2015.

9.2.2.4 Solderability Test

The Solderability Test evaluates the solderability of the leads under conditions of low-soldering temperature following exposure to the aging effects of water vapor.
9.2.2.5 Lead Integrity Test

The Lead Integrity Test is performed to evaluate integrity of the package leads. AMD performs this test according to MIL-STD-883, Method 2004.

A summary follows.
### 9.3 SUMMARY

The following test data summarizes the performance of LCA devices during AMD’s qualification tests. These test results demonstrate the reliability and expected long life of the AMD nonhermetic product line. This continuing series is part of the AMD reliability testing of nonhermetic devices.

<table>
<thead>
<tr>
<th>Device Type: 2064/2018</th>
<th>Process/Technology: 1.5 and 2.0 Micron Double-Layer Metal CMOS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Die Attach Method: Silver Epoxy</td>
<td>Package Type: 68 lead PLCC</td>
</tr>
<tr>
<td>Molding Compound: Sumitomo 6300K, H</td>
<td>Date: 2Q, 1987</td>
</tr>
</tbody>
</table>

#### Test Data

<table>
<thead>
<tr>
<th>Test Type</th>
<th>Sample</th>
<th>Failures</th>
<th>Equivalent Mean hrs/Device at T=125°C</th>
<th>Equivalent Failure Rate in %/1000hrs at T=125°C</th>
<th>Equivalent Failure Rate in %/1000 hrs at T=70°C</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. High-Temperature Life Test T=125°C</td>
<td>Combined Sample 850</td>
<td>4</td>
<td>2332</td>
<td>0.19</td>
<td>0.0027</td>
</tr>
<tr>
<td>2. Biased-Moisture Life Test T = 85°C; RH = 85%</td>
<td>Combined Sample 486</td>
<td>2</td>
<td>Mean hrs per Device 1000</td>
<td>Total Device hrs 486000</td>
<td></td>
</tr>
<tr>
<td>3. Unbiased Pressure-Pot Test +121°C, 2 atm sat. steam</td>
<td>Combined Sample 488</td>
<td>1</td>
<td>Mean hrs per Device 139</td>
<td>Total Mean hrs 67832</td>
<td></td>
</tr>
<tr>
<td>4. Temperature Cycling Test -65°C + 125°C, 1000 cy. (min)</td>
<td>Combined Sample 233</td>
<td>1</td>
<td>Mean Cycles 812</td>
<td>Total Device Cycles 189196</td>
<td></td>
</tr>
<tr>
<td>5. Temperature Cycle Test 0°C to 150°C Method 1009, Cond. A</td>
<td>Combined Sample 50</td>
<td>0</td>
<td>Mean hrs per Device 24</td>
<td>Total Device hrs 1200</td>
<td></td>
</tr>
<tr>
<td>6. Resistance-to-Solvents Test MIL-STD-883, Method 2105</td>
<td>Combined Sample 16</td>
<td>0</td>
<td>Equivalent Mean hrs/Device at T=70°C</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7. Solderability Test MIL-STD-883, Method 2003</td>
<td>Combined Sample 30</td>
<td>0</td>
<td>Equivalent Failure Rate in %/1000hrs at T=70°C</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
## GLOSSARY

<table>
<thead>
<tr>
<th>Term</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>Active Edge</td>
<td>A low-to-high or high-to-low signal transition that initiates an action.</td>
</tr>
<tr>
<td>Active High</td>
<td>A high-voltage active sense.</td>
</tr>
<tr>
<td>Active Low</td>
<td>A low-voltage active sense.</td>
</tr>
<tr>
<td>Active Pod</td>
<td>The pod with setup information that is displayed on XACTOR's screen. The LED lights to indicate it is active.</td>
</tr>
<tr>
<td>Active Sense</td>
<td>The voltage level, either high or low, associated with the active state, which is a logical 1 or 0.</td>
</tr>
<tr>
<td>Adder</td>
<td>A digital circuit that adds numbers.</td>
</tr>
<tr>
<td>Analysis Tool</td>
<td>Software that automatically or interactively determines circuit characteristics.</td>
</tr>
<tr>
<td>AND</td>
<td>A logic function that is true if all variables are true, false if at least one variable is false.</td>
</tr>
<tr>
<td>Application Specific</td>
<td>ICs that are at least partially tailored for a particular application. Includes field programmable devices such as PALs and LCA devices, and factory programmable devices such as gate arrays, standard cells, and completely customized ICs.</td>
</tr>
<tr>
<td>Integrated Circuit</td>
<td></td>
</tr>
<tr>
<td>APR</td>
<td>See Automatic Placement and Routing.</td>
</tr>
<tr>
<td>ASCII</td>
<td>The American Standard Code for Information Interchange is an eight-bit code used for sending information over a data line.</td>
</tr>
<tr>
<td><strong>ASIC</strong></td>
<td>See Application Specific Integrated Circuit.</td>
</tr>
<tr>
<td>------------------</td>
<td>----------------------------------------------------------------------------</td>
</tr>
<tr>
<td><strong>Assert</strong></td>
<td>To cause a signal to change from its inactive to its active state.</td>
</tr>
<tr>
<td><strong>Assertions</strong></td>
<td>In timing analysis, designer-provided information that describes certain timing relationships between signals in a portion of the circuit.</td>
</tr>
<tr>
<td><strong>Asynchronous Logic</strong></td>
<td>Logic that is not clocked by, or synchronized with, the system clock.</td>
</tr>
<tr>
<td><strong>Automatic Placement and Routing</strong></td>
<td>A software tool that automatically positions logic blocks and calculates wiring paths or signal interconnections during circuit design.</td>
</tr>
<tr>
<td><strong>Back Annotation</strong></td>
<td>The process of attributing delay times to a design after it has been partitioned. This is only valid if the partitioned design is equivalent to the original schematic design.</td>
</tr>
<tr>
<td><strong>Base Configuration</strong></td>
<td>The arrangement of logic within a CLB. The base configuration can be either two functions of up to three variables each, one function of up to four variables, or two functions of up to three variables, multiplexed by the B input.</td>
</tr>
<tr>
<td><strong>Bidirectional</strong></td>
<td>A circuit element, or primitive, that passes signals or data in either direction. This contrasts with the more traditional unidirectional design elements, which only pass input signals from input ports to output ports.</td>
</tr>
<tr>
<td><strong>Bit</strong></td>
<td>One unit of binary data. A logical 1 or 0.</td>
</tr>
<tr>
<td><strong>Bit Stream</strong></td>
<td>The configuration data required by an LCA device to determine the functions of CLBs, IOBs, and interconnections.</td>
</tr>
<tr>
<td><strong>Block</strong></td>
<td>A CLB, IOB, clock buffer, or oscillator.</td>
</tr>
<tr>
<td><strong>Block Editor</strong></td>
<td>Part of the LCA design editor that performs commands to configure CLBs and IOBs. See LCA Design Editor.</td>
</tr>
<tr>
<td><strong>Bottom-up Hierarchical Design</strong></td>
<td>A structured approach to organizing circuit design data in which the designer begins with a definition of the lowest primitives, or elements, then proceeds to build higher-level functions using those elements. As the hierarchical definition process concludes, the designer expresses the overall circuit structure in terms of high-level functional blocks and their interconnections.</td>
</tr>
<tr>
<td><strong>Buffer</strong></td>
<td>An amplifier that increases drive capability and temporarily stores digital data.</td>
</tr>
<tr>
<td><strong>Byte</strong></td>
<td>Eight bits.</td>
</tr>
<tr>
<td><strong>Cerdip</strong></td>
<td>The ceramic IC dual in-line package that uses a frit-sealed process.</td>
</tr>
<tr>
<td><strong>Circuit</strong></td>
<td>A combination of electrical and electronic components that perform specific functions.</td>
</tr>
<tr>
<td><strong>Circuit Simulation</strong></td>
<td>A software breadboard to verify design functionality and performance. Software that logically emulates a circuit's functions to ensure proper design.</td>
</tr>
<tr>
<td><strong>CLB</strong></td>
<td>See Configurable Logic Block.</td>
</tr>
<tr>
<td><strong>Clear</strong></td>
<td>To force to a logical 0. See Reset.</td>
</tr>
<tr>
<td><strong>Clock</strong></td>
<td>A register whose content changes at regular intervals, generating periodic signals for synchronization and causing one logic decision to be made for each signal transition.</td>
</tr>
<tr>
<td><strong>CMOS</strong></td>
<td>See Complimentary Metal Oxide Semiconductor.</td>
</tr>
<tr>
<td><strong>Combinational Logic Gate</strong></td>
<td>A combination of gate networks that generates a specific function and has no storage capability.</td>
</tr>
<tr>
<td>Term</td>
<td>Definition</td>
</tr>
<tr>
<td>------------------------------</td>
<td>-------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>Command File</td>
<td>A text file consisting of XACT LCA Editor commands and run by the EXECUTE command.</td>
</tr>
<tr>
<td>Comparator</td>
<td>A digital device that compares the magnitudes of two digital quantities and indicates their relationship.</td>
</tr>
<tr>
<td>Complimentary Metal Oxide</td>
<td>A widely-used IC technology with low-power consumption, high noise immunity, and moderate speed.</td>
</tr>
<tr>
<td>Semiconductor</td>
<td></td>
</tr>
<tr>
<td>Configurable Logic Block</td>
<td>An LCA sub-unit that contains configurable combinational-logic and data-storage circuitry.</td>
</tr>
<tr>
<td>Configuration Data</td>
<td>The data required by an LCA device to determine the functions of CLBs, IOBs, and interconnections.</td>
</tr>
<tr>
<td>Congestion</td>
<td>A high concentration of interconnections routed in one area.</td>
</tr>
<tr>
<td>Control Signals</td>
<td>Signals that control functional elements through the data signals in a digital circuit.</td>
</tr>
<tr>
<td>Controllability</td>
<td>The degree to which signals in a part of a circuit can be made to take on specific values through manipulation of primary inputs; used in testability analysis.</td>
</tr>
<tr>
<td>Counter</td>
<td>A digital circuit capable of counting electronic events, such as pulses, by progressing through a sequence of binary states.</td>
</tr>
<tr>
<td>Critical Path Evaluation</td>
<td>The identification and analysis of signal paths whose delays could limit the speed of the circuit.</td>
</tr>
<tr>
<td>Current Block</td>
<td>The selected CLB or IOB to which all Block Editor commands apply until another block is selected. See Block Editor.</td>
</tr>
<tr>
<td>Current Design File</td>
<td>The design file that was designated by the user to be loaded when invoking an XACT program. See Design File.</td>
</tr>
<tr>
<td><strong>Cursor</strong></td>
<td>A screen symbol controlled by the mouse. Used for selecting and positioning menu items and objects on the screen. See Selection.</td>
</tr>
<tr>
<td>--------------------</td>
<td>----------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td><strong>D Flip-Flop</strong></td>
<td>A type of bistable multivibrator in which the output follows the state of the D input. See Flip-Flop.</td>
</tr>
<tr>
<td><strong>Daisy Chain</strong></td>
<td>Several devices connected in such a way that configuration data move serially from one device to the next.</td>
</tr>
<tr>
<td><strong>DBK File</strong></td>
<td>A temporary file that stores all commands entered during an (LCA Editor) editing session. After the session, the temporary file is saved with the extension .DBK. See Log File.</td>
</tr>
<tr>
<td><strong>De-assert</strong></td>
<td>To cause a signal to change from its active to its inactive state.</td>
</tr>
<tr>
<td><strong>Decoder</strong></td>
<td>A digital circuit that converts coded information into a recognizable form.</td>
</tr>
<tr>
<td><strong>Default Value</strong></td>
<td>The value used when none is specified by the user.</td>
</tr>
<tr>
<td><strong>Delay</strong></td>
<td>The timing interval between the occurrence of an event at one point in a circuit and the corresponding occurrence of a related event at another point.</td>
</tr>
<tr>
<td><strong>Design Analysis</strong></td>
<td>A set of tools and techniques used to study the operations of a circuit to determine, among other things, how a particular implementation compares to the design specification.</td>
</tr>
<tr>
<td><strong>Design Approach</strong></td>
<td>A method used to construct a system design. Possibilities include LCA devices, PALs, gate arrays, standard cells, silicon compilers, full custom ICs, and standard products.</td>
</tr>
<tr>
<td><strong>Design Cycle</strong></td>
<td>The sequence of phases through which a circuit design evolves. During each phase, the design is further developed by a combination of analysis, synthesis, and verification techniques, to create a more detailed representation of the circuit.</td>
</tr>
<tr>
<td><strong>Design File</strong></td>
<td>A file containing information about a specific LCA configuration. Design files contain the LCA suffix in their names.</td>
</tr>
<tr>
<td><strong>Design for Testability</strong></td>
<td>A design process to ensure that a product can be thoroughly tested with minimum effort, and that the test results are reliable.</td>
</tr>
<tr>
<td><strong>Design Methodology</strong></td>
<td>An approach or technique that solves certain circuit design problems.</td>
</tr>
<tr>
<td><strong>Design Productivity</strong></td>
<td>A measure of the rate at which circuit designs are produced, usually expressed in terms of design cost.</td>
</tr>
<tr>
<td><strong>Design Rule Checking</strong></td>
<td>Part of the design process that checks for conformance to electrical rules.</td>
</tr>
<tr>
<td><strong>Design Rules</strong></td>
<td>Circuit development guidelines that focus upon conformance to basic electrical engineering and logic design principles.</td>
</tr>
<tr>
<td><strong>Design Synthesis</strong></td>
<td>A design discipline that fills in the detail of an abstract design; for example, creating a Boolean equation.</td>
</tr>
<tr>
<td><strong>Design Verification</strong></td>
<td>The process of confirming or validating that the design meets the required specifications. There are many ways to verify a design, ranging from formal proofs or in-circuit emulation, to informal, tailored methods. The most common verification method is simulation.</td>
</tr>
<tr>
<td><strong>Design Verification Test Data</strong></td>
<td>Sequences of input stimuli applied to a design to determine that the circuit functions as intended.</td>
</tr>
<tr>
<td><strong>DFT</strong></td>
<td>See Design for Testability.</td>
</tr>
<tr>
<td><strong>Dice</strong></td>
<td>Multiple die. See Die.</td>
</tr>
<tr>
<td>-------------------</td>
<td>--------------------------------------</td>
</tr>
<tr>
<td><strong>Die</strong></td>
<td>A tiny piece of the silicon wafer that, when packaged, becomes an IC.</td>
</tr>
<tr>
<td><strong>Die Size</strong></td>
<td>The rectangular area of silicon, the measurement of which is expressed in square microns or mils.</td>
</tr>
<tr>
<td><strong>DIP</strong></td>
<td>See Dual In-line Package.</td>
</tr>
<tr>
<td><strong>Direct Interconnection</strong></td>
<td>Dedicated connection of adjacent CLBs, IOBs, and outputs. It provides the shortest propagation delay and uses minimal interconnection networks.</td>
</tr>
<tr>
<td><strong>DMA transfer</strong></td>
<td>A method of accelerated loading of configuration information into multiple LCA devices by means of direct memory access hardware.</td>
</tr>
<tr>
<td><strong>DRC</strong></td>
<td>See Design Rule Checking.</td>
</tr>
<tr>
<td><strong>Dual In-line Package</strong></td>
<td>Type of packaging widely used for IC chip assembly. It has two parallel rows of connection pins, usually on 0.100 inch (100 mil) centers.</td>
</tr>
<tr>
<td><strong>Edge-Triggered Flip-Flop</strong></td>
<td>A flip-flop for which the input and output data appear on the same clock edge. See Flip-Flop.</td>
</tr>
<tr>
<td><strong>EEPROM (E²PROM)</strong></td>
<td>See Electrically Erasable and Programmable ROM.</td>
</tr>
<tr>
<td><strong>Electrically Erasable and Programmable ROM</strong></td>
<td>Similar to an EPROM, but it stores the charge on a floating gate. Newer EEPROMs can erase individual data bytes.</td>
</tr>
<tr>
<td><strong>Electrostatic Discharge</strong></td>
<td>The neutralizing action of two oppositely charged materials.</td>
</tr>
<tr>
<td><strong>Enable</strong></td>
<td>Allows a circuit to respond to an input. For example, a clock enable signal lets a circuit respond to its clock input.</td>
</tr>
<tr>
<td>Term</td>
<td>Description</td>
</tr>
<tr>
<td>-----------------------</td>
<td>---------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>EPLD</td>
<td>Erasable Programmable Logic Device, such as an EPROM.</td>
</tr>
<tr>
<td>EPROM</td>
<td>See Erasable Programmable ROM.</td>
</tr>
<tr>
<td>Encoder</td>
<td>A digital circuit that converts data into coded format.</td>
</tr>
<tr>
<td>Erasable Programmable ROM</td>
<td>Usually refers to the UV erasable, 2764 device type. Generally, EPROMs are erased by shining ultraviolet light on the chip through a quartz window on the package.</td>
</tr>
<tr>
<td>ESD</td>
<td>See Electrostatic Discharge.</td>
</tr>
<tr>
<td>Exclusive-OR</td>
<td>A logic function that is true if one of the variables is true and the other is false.</td>
</tr>
<tr>
<td>Executive</td>
<td>The XACT software that sets initial values for, and invokes all other, XACT software modules.</td>
</tr>
<tr>
<td>Fall Time</td>
<td>The time interval between the 10 percent and the 90 percent points on the negative-going edge of a pulse.</td>
</tr>
<tr>
<td>Fanout</td>
<td>The number of equivalent gate inputs, or unit leads, that a logic gate can drive.</td>
</tr>
<tr>
<td>Fault Grading</td>
<td>The process of measuring a test vector's effectiveness in locating defects in an IC.</td>
</tr>
<tr>
<td>Field Programmable Logic</td>
<td>Standard products that the user can configure to a specific application, such as PALs, FPLAs, and LCA devices.</td>
</tr>
<tr>
<td>Flip-Flop</td>
<td>A digital circuit used to store one bit of information, either 0 or 1. Also known as a toggle.</td>
</tr>
<tr>
<td>Floppy Disk</td>
<td>A magnetic storage device. A flexible mylar disk.</td>
</tr>
<tr>
<td>Full Adder</td>
<td>A digital circuit that adds two binary digits and an input carry to produce a sum and an output carry.</td>
</tr>
<tr>
<td>Term</td>
<td>Definition</td>
</tr>
<tr>
<td>----------------------------------</td>
<td>-------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>Function</td>
<td>The specific purpose of an entity or its characteristic action.</td>
</tr>
<tr>
<td>Function Key</td>
<td>A programmable key on the IBM PC keyboard. Typically, the software defines the function.</td>
</tr>
<tr>
<td>Functional Primitives</td>
<td>Design building blocks such as adders, shifters, decoders, and memory. A functional primitive differs from a gate-level primitive only in the individual element’s degree of functional complexity.</td>
</tr>
<tr>
<td>Gate</td>
<td>A digital logic element. The binary value of the output depends on the values of the inputs according to some logic rule.</td>
</tr>
<tr>
<td>Gate Array</td>
<td>A digital IC with a configuration of uncommitted elements that are interconnected by one or more routing layers.</td>
</tr>
<tr>
<td>General Purpose Interconnections</td>
<td>Horizontal and vertical metal segments joining LCA switching matrices.</td>
</tr>
<tr>
<td>Glitch</td>
<td>An unwanted voltage or current spike, typically of short duration.</td>
</tr>
<tr>
<td>Half Adder</td>
<td>A digital circuit that adds two bits to produce a sum and an output carry. It cannot accommodate input carries.</td>
</tr>
<tr>
<td>Hard Macro</td>
<td>A macro with a predetermined physical layout.</td>
</tr>
<tr>
<td>Hold Time</td>
<td>The amount of time, after the clock transition, that the data input to a flip-flop must be stable for proper operation.</td>
</tr>
<tr>
<td>In-Circuit Emulation</td>
<td>A design system that uses software and hardware to test and debug LCA devices in a target system.</td>
</tr>
<tr>
<td>Initial Value</td>
<td>The preset value for an option when the software is invoked. After the software starts, the option’s value can be changed.</td>
</tr>
<tr>
<td><strong>Initialize</strong></td>
<td>The process of establishing an initial condition or starting state. For example, setting logic elements in a digital circuit, or the contents of a storage location, to known states so that subsequent application of digital test patterns drive the logic elements to another known state. Initialization sets counters, switches, and addresses to zero or other starting values at the beginning of, or at prescribed points in, a computer routine.</td>
</tr>
<tr>
<td><strong>Input Line</strong></td>
<td>A line on the XACT screen that displays the characters typed at the keyboard. Pressing the &lt;Return&gt; key signals that the content of the input line is complete.</td>
</tr>
<tr>
<td><strong>Input Loading</strong></td>
<td>The number of unit loads that one output can drive.</td>
</tr>
<tr>
<td><strong>Input Stimuli</strong></td>
<td>The parameters in a software program used to test a circuit or simulated circuit.</td>
</tr>
<tr>
<td><strong>Input/Output Block</strong></td>
<td>An IOB is a sub-unit that can be configured to connect the LCA device's internal circuitry to external pins.</td>
</tr>
<tr>
<td><strong>Instance Name</strong></td>
<td>A name assigned to each occurrence of a macro. The instance name is used to create unique net and block names. See Macro.</td>
</tr>
<tr>
<td><strong>Interactive Simulator</strong></td>
<td>A circuit-simulation tool that lets the designer halt circuit emulation at any point. This allows detailed investigations of localized signal relationships, changes to simulated input signals, or changes to simulator directives.</td>
</tr>
<tr>
<td><strong>Interconnection</strong></td>
<td>A sub-unit of an LCA device that can be configured to connect two or more internal points.</td>
</tr>
<tr>
<td><strong>Inverter</strong></td>
<td>A logic device that complements a logic variable.</td>
</tr>
<tr>
<td><strong>Invoke</strong></td>
<td>To load and run software on a computer. This action includes the setting of initial values.</td>
</tr>
<tr>
<td><strong>IOB</strong></td>
<td>See Input/Output Block.</td>
</tr>
<tr>
<td>Term</td>
<td>Description</td>
</tr>
<tr>
<td>-------------------------------</td>
<td>--------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>J-K Flip-Flop</td>
<td>A flip-flop that operates in the set, reset, no change, and toggle modes. See Flip-Flop.</td>
</tr>
<tr>
<td>Johnson Counter</td>
<td>A state machine based on shift registers using the absolute minimum amount of feedback. The output of the final register in the chain is inverted and fed into the least significant register in the chain.</td>
</tr>
<tr>
<td>Karnaugh Map</td>
<td>An arrangement of cells representing combinations of variables in a Boolean expression. Used for a systematic simplification of the expression.</td>
</tr>
<tr>
<td>Large Scale Integration</td>
<td>An IC equivalent of 100 to 10,000 logic gates.</td>
</tr>
<tr>
<td>Latch</td>
<td>A logic device that transfers the data of its input to its output when load enable is active; it retains its value when load enable is inactive.</td>
</tr>
<tr>
<td>Latchup</td>
<td>A condition in which the output of a circuit has become fixed near one of two voltage extremes. The circuit no longer reacts to changes in the input signal. This is a common problem with CMOS gates.</td>
</tr>
<tr>
<td>Layout</td>
<td>That portion of the design cycle during which the logical or electrical definition of the circuit is transformed, via placement and routing, into a physical equivalent that can be manufactured.</td>
</tr>
<tr>
<td>LCA</td>
<td>See Logic Cell Array.</td>
</tr>
<tr>
<td>LCA Design Editor</td>
<td>The XACT software used to create and edit the LCA design file.</td>
</tr>
<tr>
<td>LCC</td>
<td>See Leadless Chip Carrier.</td>
</tr>
<tr>
<td>Leadless Chip Carrier</td>
<td>A high-density IC package with J-bends suitable for socket or surface mounting.</td>
</tr>
<tr>
<td>Term</td>
<td>Description</td>
</tr>
<tr>
<td>----------------------</td>
<td>---------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>Length Count</td>
<td>Part of the configuration software that specifies the number of Configuration Clock (CCLK) cycles from the start of configuration to the start of operation.</td>
</tr>
<tr>
<td>LFSR</td>
<td>See Linear Feedback Shift Register.</td>
</tr>
<tr>
<td>Library</td>
<td>A collection of predefined elements, primitives, macros, and larger functional blocks.</td>
</tr>
<tr>
<td>Linear Feedback</td>
<td>A synchronous counter. The input bit is computed by XORing several bits of the current state.</td>
</tr>
<tr>
<td>Shift Register</td>
<td></td>
</tr>
<tr>
<td>Load Pin</td>
<td>The pin to which signals flow. See Source Pin.</td>
</tr>
<tr>
<td>Log File</td>
<td>A file containing all commands entered during an editing (LCA Editor) session. Each time an LCA design file is edited, a new log file replaces the existing one. Log files have the extension .LOG.</td>
</tr>
<tr>
<td>Logic Cell Array</td>
<td>A device that can be configured or programmed to perform a range of functions. LCA devices may replace circuits that range in size from SSI to VLSI devices.</td>
</tr>
<tr>
<td>Logic Element</td>
<td>A sub-unit of a CLB that contains combinational-logic circuitry.</td>
</tr>
<tr>
<td>Logic Simulation</td>
<td>The process of building and functionally validating a digital circuit model on a computer. A logic simulator computes signal values as a function of time in an arbitrary circuit, given the initial state and input sequence to the circuit.</td>
</tr>
<tr>
<td>Logical Primitive</td>
<td>Building blocks such as a NAND, NOR, inverter, or SSI/MSI TTL package.</td>
</tr>
<tr>
<td>Long Line</td>
<td>An interconnection that routes a signal to several destinations in an LCA device. This type of interconnection runs the length or width of an LCA device and is often used for clock signals.</td>
</tr>
</tbody>
</table>
LSI
See Large Scale Integration.

Macro
Explicitly identifiable portions of a design that can be described as entities. Design elements may be primitives, interconnections of primitives, or interconnections of larger elements.

Macro Library
A collection of macros provided by a vendor and used as building blocks in chip design. Organized or classified by function, macro libraries consist of files stored in directories. See Macro.

Master Mode
A configuration mode in which configuration data is transmitted in parallel, byte-wide form from an external memory to the LCA device. The LCA device generates read-addresses and automatically serializes the data for internal storage.

MB/ Mb
Megabyte/megabit.

Medium Scale Integration
Traditional, standard, digital logic components having approximately 10 to 100 functional logic gate equivalents.

Menu
A list of items that appears on the display. Each item can be input to the computer by selecting it with the mouse. See Selection.

Message Line
The display line on an active workstation through which commands can be entered and on which status messages or prompts appear.

Metastability
Metastability is defined as an output state between a valid logic HIGH and LOW for any digital device. It can occur for registers or latches when certain parameters, such as data set up-and-hold times, are violated.

Micron (µ)
One micrometer; one millionth of a meter. The basic unit of measure for VLSI geometries.
<table>
<thead>
<tr>
<th>Term</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>MS-DOS</td>
<td>A common IBM-PC operating system. The LCA development system runs under MS-DOS.</td>
</tr>
<tr>
<td>MSI</td>
<td>See Medium Scale Integration.</td>
</tr>
<tr>
<td>Multiplex</td>
<td>To put information from several sources onto a single line or transmission path.</td>
</tr>
<tr>
<td>Multiplexer</td>
<td>A digital circuit capable of multiplexing digital data.</td>
</tr>
<tr>
<td>Mux</td>
<td>Abbreviation for multiplexer.</td>
</tr>
<tr>
<td>NAND</td>
<td>A logic function that is true if at least one variable is false or false if all variables are true. This is equivalent to an inverted AND function; i.e., Not AND.</td>
</tr>
<tr>
<td>Net</td>
<td>A collection of nodes that are interconnected by wires. Also known as a signal network or signal net.</td>
</tr>
<tr>
<td>Netlist</td>
<td>A list of circuit elements and their interconnections.</td>
</tr>
<tr>
<td>Netlist Formatting</td>
<td>Extracting netlist data from a database and putting it into a format that can be used by another software tool.</td>
</tr>
<tr>
<td>Nibble</td>
<td>Four bits, or half a byte.</td>
</tr>
<tr>
<td>Node</td>
<td>An identifiable point in a design that must be electrically connected to other nodes by wires. A node can be associated with a specific device or geographic location.</td>
</tr>
<tr>
<td>Nominal Delay</td>
<td>The mean time signals take to propagate through a logic element or a wire. The effect of an input change to an element on the output does not occur until after the nominal delay.</td>
</tr>
<tr>
<td>Non-Recurring Engineering Costs</td>
<td>Costs charged to the user for development of tooling and other services during semicustom chip design and production.</td>
</tr>
<tr>
<td>Term</td>
<td>Definition</td>
</tr>
<tr>
<td>----------------------</td>
<td>-------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>Non-Volatile</td>
<td>Memory, such as PROMs and magnetic bubble memory modules that retain data even after power-off.</td>
</tr>
<tr>
<td>NOR</td>
<td>A logic function that is true if all variables are true, false if at least one variable is false. This is equivalent to an inverted OR function; that is, Not OR.</td>
</tr>
<tr>
<td>NRE</td>
<td>See Non-Recurring Engineering costs.</td>
</tr>
<tr>
<td>Observability</td>
<td>In testability analysis, a measure of the degree to which the operation of signals in a certain part of a circuit can be monitored.</td>
</tr>
<tr>
<td>OR</td>
<td>A logic function that is true if at least one variable is true, false if all variables are false.</td>
</tr>
<tr>
<td>Pad</td>
<td>An area on the chip used as a contact point by the IC's package pins.</td>
</tr>
<tr>
<td>Peripheral Mode</td>
<td>A configuration mode in which the LCA device acts as a peripheral device. An external device, such as a processor, that loads the configuration data bits serially into the LCA device.</td>
</tr>
<tr>
<td>PGA</td>
<td>See Pin Grid Array. Also ascribed to programmable gate array.</td>
</tr>
<tr>
<td>Physical Interconnection Editor</td>
<td>The LCA Editor that configures interconnections and the locations of configured blocks. See LCA Editor.</td>
</tr>
<tr>
<td>PIE</td>
<td>See Physical Interconnection Editor.</td>
</tr>
<tr>
<td>Pin</td>
<td>The point on a device at which an electrical connection can be made.</td>
</tr>
<tr>
<td>Pin Grid Array</td>
<td>A high pin density ceramic package.</td>
</tr>
<tr>
<td>PIP</td>
<td>See Programmable Interconnection Point.</td>
</tr>
<tr>
<td>PLA</td>
<td>See Programmable Logic Array.</td>
</tr>
<tr>
<td><strong>Plastic Leader Chip Carrier</strong></td>
<td>An IC package with J-bend leads suitable for socket or surface mounting.</td>
</tr>
<tr>
<td>-------------------------------</td>
<td>---------------------------------------------------------------------</td>
</tr>
<tr>
<td><strong>PLCC</strong></td>
<td>See Plastic Ledged Chip Carrier.</td>
</tr>
<tr>
<td><strong>Power-Down State</strong></td>
<td>An idle current condition when the LCA device's power supply requirement can be reduced to a minimal level. Under this condition, circuit activity is suspended and all configuration data are preserved.</td>
</tr>
<tr>
<td><strong>Preamble Nibble</strong></td>
<td>A specific series of four data bits that signals the start of the configuration data for LCA devices.</td>
</tr>
<tr>
<td><strong>Primitive</strong></td>
<td>The basic building block of design entry. Primitives are not expanded during design entry but are used as single blocks. There are several levels of primitives. Basic systems only use combinational gates and Boolean operators. More complex systems include sequential elements such as latches, flip-flops, delay lines, and monostables in their primitive sets. Some systems include higher-level functions such as counters, shift registers, ROM and RAM as primitives.</td>
</tr>
<tr>
<td><strong>Product-of-Sums</strong></td>
<td>A Boolean expression that is the ANDing of ORed terms.</td>
</tr>
<tr>
<td><strong>Profile</strong></td>
<td>A set of commands stored in a file with a .PRO extension to define options that configure the PC environment.</td>
</tr>
<tr>
<td><strong>Programmable Inter-connection Point</strong></td>
<td>A configurable connection between interconnection segments.</td>
</tr>
<tr>
<td><strong>Programmable I/O</strong></td>
<td>Buffers that the user can configure as input, output, or both.</td>
</tr>
<tr>
<td><strong>Programmable Logic Array</strong></td>
<td>A rectangular array of AND and OR gates used to generate a group of control functions in sum-of-products form. See also LCA.</td>
</tr>
</tbody>
</table>
Programmable Read-Only Memory
A ROM that can be programmed by the customer.

PROM
See Programmable Read-Only Memory.

Propagation Delay
The time difference between the change of an input signal, or clock, and the change of the output.

P-SILOS
A software breadboard that tests a hardware system to verify functionality before the actual hardware is programmed.

Pull-Down Menu
A menu that appears when you select its name using the device that drives the cursor. The menu usually overlaps other elements on the screen.

Race
In asynchronous digital logic, the concurrent change of two or more feedback lines. If the circuit's final state does not depend on the order in which the variables change, the race is noncritical; otherwise it is critical.

RAM
Random access memory.

Read
The process of retrieving information.

Register
A digital circuit capable of storing, or moving through, shifting binary information. Usually used as a temporary storage device.

Reset
The state of a flip-flop, register, or counter when only 0s are stored. Equivalent to the CLEAR function.

Ripple Counter
A digital circuit made up of a series of flip-flops in which the contents are continuously recirculated.

Rise Time
The time required for the pulse's positive-going edge to go from 10 percent of its full value to 90 percent of its full value.
<table>
<thead>
<tr>
<th>Term</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rise/Fall Delay</td>
<td>A circuit simulation feature that lets different output rise (0 to 1) and fall (1 to 0) times to be specified. This more closely approximates the actual timing parameters of a device, as compared to nominal delay models that assume equal rise and fall times.</td>
</tr>
<tr>
<td>ROM</td>
<td>Read only memory.</td>
</tr>
<tr>
<td>Route</td>
<td>To configure the interconnection between pins.</td>
</tr>
<tr>
<td>Routing</td>
<td>The process of configuring interconnections between pins.</td>
</tr>
<tr>
<td>Scan Test</td>
<td>A test method whereby data is shifted into SRLs and results are shifted out. Additional circuitry typically must be included in the design to support this type of testing.</td>
</tr>
<tr>
<td>Schematic Capture</td>
<td>The process of entering a circuit diagram into a computer system using a CAE editor.</td>
</tr>
<tr>
<td>Schematic Diagram</td>
<td>A circuit diagram in which components are represented by standard, simple, easily drawn symbols.</td>
</tr>
<tr>
<td>Schmitt Trigger</td>
<td>A circuit with snap action that produces a sharp, single transition from slowly changing inputs. Positive feedback shifts the threshold as soon as it is first reached. If the signal is diminished due to noise, the output remains steady.</td>
</tr>
<tr>
<td>Schottky TTL</td>
<td>An improved version of TTL logic in which saturation of the transistors is prevented and impedance of the output circuit is reduced. Thus, 74S logic gates have a maximum delay of 7 ns compared to 15 ns for TTL without Schottky. Power dissipation, however, is about twice that of TTL. Low-power Schottky TTL, or 74LS series, has a maximum delay of 28 ns and requires 80% less power than a normal TTL device.</td>
</tr>
<tr>
<td><strong>Selection</strong></td>
<td>The action of moving the cursor to a displayed item and pressing the mouse button. The selected item is received by the computer as input.</td>
</tr>
<tr>
<td><strong>Semicustom IC Setup Information</strong></td>
<td>The information that configures the XACTOR environment. Setup information may be stored in a file for use at any time for a given XACTOR environment.</td>
</tr>
<tr>
<td><strong>Set</strong></td>
<td>To force one or more storage elements to logical 1.</td>
</tr>
<tr>
<td><strong>Setup Time</strong></td>
<td>The amount of time, before the clock transition, that the data input to a flip-flop must be stable for proper operation.</td>
</tr>
<tr>
<td><strong>Shift Register</strong></td>
<td>A linear chain of storage elements that shifts the contents of the storage elements one position for each clock transition.</td>
</tr>
<tr>
<td><strong>Simulation</strong></td>
<td>The use of computer tools that imitate a proposed circuit design to validate its functionality. Timing and performance considerations are ignored during functional simulation.</td>
</tr>
<tr>
<td><strong>Simulator</strong></td>
<td>A software breadboard that tests a hardware system to verify functionality before the actual hardware is programmed.</td>
</tr>
<tr>
<td><strong>Slave Mode</strong></td>
<td>A configuration mode in which the LCA device receives serial configuration data and all control signals from another device, typically another LCA device.</td>
</tr>
<tr>
<td><strong>Small Scale Integration</strong></td>
<td>Refers to traditional, standard, digital logic components having one to approximately ten logic gate equivalents.</td>
</tr>
<tr>
<td><strong>Soft Error</strong></td>
<td>Refers to dropping or picking up bits in a non-rerepeatable manner. Often caused by alpha particles.</td>
</tr>
<tr>
<td><strong>Soft Macro</strong></td>
<td>A macro with no predetermined physical layout.</td>
</tr>
<tr>
<td><strong>Source Pin</strong></td>
<td>A pin from which a signal originates. See Load Pin.</td>
</tr>
<tr>
<td><strong>Specification (Spec)</strong></td>
<td>A document defining the ground rules for circuit design. It contains requirements, such as functionality, performance, cost, temperature, and interface.</td>
</tr>
<tr>
<td>-------------------------------</td>
<td>---------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td><strong>Spike</strong></td>
<td>The output condition where the inputs are being manipulated faster than the element's propagation delay.</td>
</tr>
<tr>
<td><strong>SR flip-flop</strong></td>
<td>Set-reset flip-flop. See Flip-Flop.</td>
</tr>
<tr>
<td><strong>SRL</strong></td>
<td>Shift Register Latch. See Shift Register and Latch.</td>
</tr>
<tr>
<td><strong>SSI</strong></td>
<td>See Small Scale Integration.</td>
</tr>
<tr>
<td><strong>Standard Cell</strong></td>
<td>A predefined mask-level design of a logic function or simple functional element. A library of such standard cells usually has a common height and a common power distribution protocol. Used in the design and layout of standard cell semicustom ICs.</td>
</tr>
<tr>
<td><strong>Standard Cell Semicustom IC</strong></td>
<td>Very large scale integrated circuits that are laid out using predefined mask level definitions of standard logic function cells. The standard cells are placed in rows or columns so that they share power rails and have open routing channels between adjacent row/column pairs.</td>
</tr>
<tr>
<td><strong>Standby Mode</strong></td>
<td>Also called power-down. A mode whereby volatile memory can retain data at a voltage level lower than normal operation.</td>
</tr>
<tr>
<td><strong>State</strong></td>
<td>The condition of one flip-flop or a set of flip-flops.</td>
</tr>
<tr>
<td><strong>State Machine</strong></td>
<td>A set of flip-flops for which the next state and the outputs are functions of its current state and a set of inputs.</td>
</tr>
<tr>
<td><strong>Stimulus</strong></td>
<td>Any physical or electrical input applied to a device intended to produce a measurable response.</td>
</tr>
<tr>
<td><strong>Storage Element</strong></td>
<td>A sub-unit of a block that can store data.</td>
</tr>
<tr>
<td>Term</td>
<td>Definition</td>
</tr>
<tr>
<td>-------------------------------------</td>
<td>-----------------------------------------------------------------------------</td>
</tr>
<tr>
<td><strong>Sum-of-Products</strong></td>
<td>A form of Boolean expression that is the ORing of ANDed terms.</td>
</tr>
<tr>
<td><strong>Switching Matrix</strong></td>
<td>An intersection of three or more segments of local interconnections. Two segments are connected by one switching-matrix connection.</td>
</tr>
<tr>
<td><strong>Switching Time</strong></td>
<td>A signal output's delay time from a defined HIGH to a defined LOW, or vice versa. This delay is calculated as the time between the specified reference points on the voltage waveforms.</td>
</tr>
<tr>
<td><strong>Synchronous Logic</strong></td>
<td>Clocked logic in which all logical signal changes are keyed to clock transitions.</td>
</tr>
<tr>
<td><strong>T Flip-Flop</strong></td>
<td>A type of flip-flop that toggles or changes state on each clock pulse. See Flip-Flop.</td>
</tr>
<tr>
<td><strong>Tag</strong></td>
<td>A user-definable label or flag that can be applied to sub-units of an LCA device.</td>
</tr>
<tr>
<td><strong>TDM</strong></td>
<td>See Time Division Multiplexing.</td>
</tr>
<tr>
<td><strong>Test</strong></td>
<td>A procedure or action that determines, under real or simulated conditions, the capabilities, limitations, characteristics, effectiveness, reliability, or suitability of a material, device, system, or method.</td>
</tr>
<tr>
<td><strong>Test Vector</strong></td>
<td>An array of inputs used to check for defects in an circuit.</td>
</tr>
<tr>
<td><strong>Testability</strong></td>
<td>A design characteristic that reliably determines in a timely fashion the status of a system or of any of its subsystems, i.e. operable, inoperable or degraded. One measure of the quality of a circuit design is the relative ease with which it may be tested.</td>
</tr>
<tr>
<td><strong>Testability Analysis</strong></td>
<td>A tool to measure the extent to which a design is testable.</td>
</tr>
</tbody>
</table>
Testability Measure
Attributes such as controllability and observability, which give a quantitative measure of the extent to which a design is testable.

Three-State
A mode in which the circuit functions as an output, input, or no connection (high impedance). Also called Tristate.

Time Division Multiplexing
Sending several signals during different time slots over the same channel.

Timing Analysis
Evaluation of the behavior of a circuit design that takes into account signal delay time but ignores logical functionality. Timing analysis determines whether signals arrive at their intended destinations in time.

Timing Verification
A tool for checking that the various rules, such as clock skews, are met and that the circuit functions at the required speed.

Toggle
To change to the opposite state.

Toggle rate
The maximum clock frequency at which a flip-flop storage element will toggle properly.

Top-Down Hierarchical Design
A design method by which increasing detail is added as the design progresses. Top-down is typically used at the beginning of the design cycle.

Transistor-Transistor Logic
A logic family that uses multitransistor emitters to perform logic functions. The gates have a 15 ns maximum delay and require +5 V power of about 2 mA per gate. Logic levels are normally +0.2 and +3.4 V, and input threshold is nominally 1.2 V.

TTL
See Transistor-Transistor Logic.

Unit Delay
A simulation technique used to verify functionality. In this technique all the delays of the elements are set to one time unit.
<table>
<thead>
<tr>
<th>Term</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Unit Delay Simulation</td>
<td>A simulation that assumes equal propagation delays.</td>
</tr>
<tr>
<td>Unit Load</td>
<td>Under specific conditions, a measure of impedance presented to an input or output. One gate input represents a unit load to a gate output within the same logic family.</td>
</tr>
<tr>
<td>Unknown Level</td>
<td>A simulated signal value (or an electrical net) that is not a one or a zero. This could be caused by an error or by the node not being initialized.</td>
</tr>
<tr>
<td>Unknown State</td>
<td>Most memory elements used in sequential circuits are bistable devices. When the power is turned on, they are normally designed to have symmetrical configuration; i.e., the initial state becomes unpredictable. Such memory devices begin operation with internal memory signal valuation designated as unknown. Unknown states can also be encountered during circuit operation as the result of critical races, oscillations, or ambiguous delays.</td>
</tr>
<tr>
<td>VDD</td>
<td>The most negative power supply voltage level in an MOS circuit.</td>
</tr>
<tr>
<td>Verification</td>
<td>See Design Verification.</td>
</tr>
<tr>
<td>Very Large Scale Integration</td>
<td>A circuit with more than 10,000 transistors.</td>
</tr>
<tr>
<td>VLSI</td>
<td>See Very Large Scale Integration.</td>
</tr>
<tr>
<td>Volatile</td>
<td>The attribute of losing stored information when power is removed from a memory device.</td>
</tr>
<tr>
<td>VSS</td>
<td>The most positive power supply voltage level in a MOS circuit.</td>
</tr>
<tr>
<td>Waveform Input</td>
<td>The input data for a simulated circuit represented as waveforms. Re</td>
</tr>
<tr>
<td>Term</td>
<td>Description</td>
</tr>
<tr>
<td>------------------------------</td>
<td>----------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>Wildcard</td>
<td>A symbol that can represent any character or characters.</td>
</tr>
<tr>
<td>Window</td>
<td>A user-specified part of the LCA device that is displayed on the LCA Editor screen and that can be manipulated.</td>
</tr>
<tr>
<td>Wired-AND</td>
<td>An arrangement of logic circuits in which the gate outputs are physically connected to form an &quot;implied&quot; AND function.</td>
</tr>
<tr>
<td>Wired-OR</td>
<td>Logic gates wired to implicitly create a logical OR function.</td>
</tr>
<tr>
<td>Wiring Congestion</td>
<td>See Congestion.</td>
</tr>
<tr>
<td>Workstation</td>
<td>A single-user, stand-alone work aid. In the engineering community, it consists of a microprocessor-based system with a high-resolution screen and software to carry out design functions. Popular workstation vendors include OrCAD, Daisy, FutureNet, Mentor, and Valid.</td>
</tr>
<tr>
<td>World View</td>
<td>The entire LCA design that can be displayed on the LCA Editor screen. See Window.</td>
</tr>
<tr>
<td>Write</td>
<td>The process of storing information in memory.</td>
</tr>
<tr>
<td>XACT</td>
<td>Software that lets you specify the configuration of an LCA device using interactive computer graphics.</td>
</tr>
<tr>
<td>XACTOR</td>
<td>A software/hardware package for performing in-circuit emulation.</td>
</tr>
<tr>
<td>Zero Delay Simulator</td>
<td>A simulator used for functional validation. The signals have no delay.</td>
</tr>
<tr>
<td>Zero/Unit Delay Simulator</td>
<td>Combination of the zero delay and unit delay simulation concepts. A circuit is modeled with zero delay elements and with unit delay circuits inserted into the feedback lines and memory elements.</td>
</tr>
</tbody>
</table>
INDEX

A
alpha particles 8-1, 8-5, 8-9, 8-10
amplifier
  input swing 4-30
  linear circuit 7-3
  output impedance 4-30
application-specific
  integrated circuits
    (see ASIC)
APR 2-12, 2-13, 5-2
  constraints 2-8
ASIC 1-2, 1-5, 8-2
automatic placement and
  routing (see APR)
applied automatic router 5-10

B
bit stream
  generator 2-17, 6-2
  loading 6-23
  multiple configuration
    6-31
  read from PROM 6-8
block arrangement 5-7
Boolean equations 3-11
buffer
  alternate 5-18
  bidirectional 5-62
  clock 4-27, 4-28, 5-10,
    5-16
  delay 5-57
  following flip-flop 7-10
  global 5-17, 5-18
  non-inverting 4-4, 4-5
  output 4-5, 4-11, 4-12,
    4-21, 4-23
  repowering 5-5, 5-6

C
circuit density 8-6
  CLB 3-1, 4-21, 5-26, 6-2
  combinational portion 3-6
  connection to IOB 5-6
  delays 5-56
  for inversion 4-37
  interconnections 3-4
  layout 7-4
  logic inputs and outputs 3-4
  placement 5-23
  programmable features 3-8
  sharing 3-15
  storage element 3-8, 3-9
  storage element clearing 3-9
  structure 3-4
  timing 3-21
clock
  buffer 2-14, 4-27, 4-28,
    5-18
  CLB 3-22
  common 5-21
  controls 5-12
  free-running CCLK 6-22
  frequencies 7-2
  global 2-14
  input to register 7-2
  lien 4-36
  maximum rate for counter 3-28
  metal clock distribution
    network 3-37
  multiple 5-17
  output via Q 3-21
  pulse 7-2
  rate 7-11
  shift register 5-18
  single 5-26
  skews 2-13, 3-21, 3-37
  system 5-60
  transition 4-5
  worst-case delay 7-5
CMOS 4-5, 8-9
  array architecture 3-22
  floating input 6-40
  gate 8-12
  PLD 1-4
  processes 1-9
  technology 1-9
  voltage 4-5, 7-3
  combinational loop 4-27
command
  MAKEMASK 6-50
  PROM formatter
    commands 2-19
  configurable logic blocks (see CLB)
  configuration
    automatic control 6-8
    bits 5-4
    bit stream 1-8, 2-18, 6-2,
      6-8
    CLB 7-4
    completion 6-3
    configuration state 6-3
    daisy chain 6-34
    delay 6-16
    device 4-28
    disable 6-4, 6-18
    DMA transfers 6-36
    file 5-4
    file format 6-44
    initialization state 6-3

June 1988

2000 SERIES LCA DESIGN HANDBOOK INDEX
input paths 4-7
IOB 7-4
LCA 6-1
length count 6-45
Master high mode 6-6, 6-28, 6-29
Master low mode 6-28, 6-29
Master mode 6-6, 6-27, 6-30
Master parallel-low mode 6-6
Master parallel-low pin usage 6-28
Master serial mode 6-6, 6-27
Master serial mode pin usage 6-27
memory 6-3
mode 6-1, 6-3, 6-5, 6-6, 6-15
multiple LCA devices 6-14, 6-34, 6-42
parallel 6-36
partial 6-3
Peripheral mode 6-23, 6-25, 6-26
pin function 6-14
power-up delay 6-33
program 6-42
readback 6-1
Slave mode 6-6
state 6-3
techniques 6-1
time 6-8, 6-13
user-operation state 6-3, 6-4
verification 6-1
connection
direct 5-6, 5-7, 5-9, 5-18, 5-23, 5-24, 5-33, 7-11
editing 5-40
spreading I/O connections out 5-36
temporary IOB 5-64
controls
clocks 5-12
count 5-12
set/reset 5-12
shift direction 5-12
controllability 8-4
control line
read/write (see three-state control line) 4-33
counter 5-21
binary-weighted 3-26
building counter of any modulo 4-43
designing 3-30
Johnson 4-3, 4-37, 4-39
LFSR 4-44, 4-46, 4-47
low-modulo 4-37
Schmitt trigger 4-19, 4-21
simple ripple 3-26
states 4-43
synchronous 8-bit 3-30
various modulo and duty cycles 4-39
D
data bus
unidirectional 6-28
data flow direction 5-11
data integrity 8-6
debugging 6-41
decoders 5-20
delay 1-8
accumulation 3-26
buffer 3-21, 5-57
calculator 2-15, 4-12, 5-42, 5-56, 5-58, 5-60, 5-62
CLB 3-21, 5-56
CMOS 3-22
combinational propagation 3-30
configuration 6-16
gates 3-21
interconnection 5-57
IOB 5-56
loop 4-5, 7-4, 7-5, 7-10
path 4-5, 7-6
power-up 6-3, 6-33
R/C 5-56
register 4-30
routing 4-12, 4-48
signal 5-62
synchronization 6-34
variations in LCA 3-22
worst-case calculations 2-15, 5-9, 5-56, 7-5
DeMorgan 4-16
density 1-2
design
analysis 1-11
configuration bit stream 2-17
controllability 8-3
data flow 5-20, 5-21, 5-22
editor (EDITLCA) 6-2
entry 1-11
flexibility 3-2
guidelines 5-19
in-circuit verification 2-17
long and thin 5-33
manual editing 5-37
modification guidelines 5-34
observability 8-3
optimization guidelines 5-26
performance 5-1
rule check (see LCA design rule check)
strategy 8-4
testability 8-3
time 8-3
timing optimization 2-16
tradeoffs 5-33
verification 1-11, 6-2
die-related test 9-4
doping levels 8-11
download cable 2-17, 6-2
DRC (see LCA design rule check)
E
electromagnetic radiation 8-1, 8-5
electrostatic discharge (see ESD)
emulation
in-circuit 2-17, 2-19, 6-2
pods 2-21
EPLD 8-2, 8-3
EPROM 1-8
erasable programmable logic device (see EPLD)
error probability 7-12
ESD 8-11
F
flip-flop
edge-triggered 3-4, 3-25
error probability 7-1, 7-6
improving performance 7-9
inverter enable 3-9
isolation 7-10
J-K 3-24
loading 7-10
loop delay 7-4, 7-10
metastability 7-1
output control 3-33
output loading 7-10
register 3-24
settling time 7-6
synchronous toggle 3-24, 3-27
T 3-28
worst-case delay 7-5
function
CARRY 3-13
dual compare 3-14
SUM 3-13
typical four-variable combinational 3-11
G
gain/bandwidth product 7-3
gate 2-8, 3-3
delay 3-21
multiple levels 5-26
NAND 1-6, 3-31
preselect enabling 3-18
gate array 1-6, 8-2, 8-3
architectures 1-6
LCA device 8-3
performance 1-7
glue logic replacement 5-9
H
hysteresis 4-19, 4-20, 4-22
selectable 4-22
I
I/O
bidirectional pad 4-10
input/output blocks (see IOB)
interconnection
direct 5-21
general-purpose 5-3, 5-5, 5-6, 5-9, 5-62
long line 5-6
minimizing 5-20
resources 5-3
internal
states 2-21
signals 5-11
inverter 1-10
IOB 3-4, 3-9, 6-2
asynchronous inputs 3-35
asynchronous ripple counters 3-31
bidirectional data line 4-3
binary-weighted sequence counters 3-26
bus 5-27
clock line 4-36
clock skew 3-37
combinatorial function 3-4
combinatorial portion 3-6
compound function of five variables 3-8
connection with CLB 5-6
constructing shift registers 4-35
counters 3-25, 4-30
D flip-flop 3-23
D latch 3-23
data-path selector 4-3, 4-4
data registers 3-24
delays 5-56
eight-bit synchronous counter 3-30
four-variable function 3-8
glitch-free decoder 4-39
interconnections 3-4
interleaving 5-36
Johnson counters 3-25, 4-3, 4-37
layout 7-4
memory cell 3-5
metastability 4-2
multiplexers 4-3
non-inverting buffer 4-4, 4-5
open-drain outputs 4-11, 4-12, 4-13, 4-17
oscillator 4-25
placement 5-24, 5-28
placement impact 5-27
programmable
multiplexers 3-6
registers 4-30, 4-32, 4-33
routing delay 4-48
Schmitt trigger 4-19, 4-21
shift registers 3-24, 4-3, 4-36
storage element 3-4
synchronous binary counter 3-29
synchronous LFSR 3-33
three-state control line 4-33
two functions of three variables 3-8
unused 4-37
use of 4-30
voltage range 4-22

J
Johnson counters 3-25

K
Karnaugh maps 3-11
latches 2-8, 7-2
level-transparent 3-8
transparent 3-4
latchup
causes 8-12
definition 8-12
LCA 3-2, 5-37, 5-68
architecture 1-7
automatic router 5-46
benefits 1-10
configurability 3-23
configuration program 1-8
data integrity 8-5
design cycle 2-5
design editor 2-16, 3-11
design flexibility 3-2
design rule check 5-50
design strategy 8-4
design system 2-2
design tradeoffs 3-30
development system 1-11, 1-12, 3-4, 5-2, 6-2, 6-42
device 1-5, 1-6, 1-8
extensions 1-7
integration level 3-2
introduction 1-1
macro library 4-13, 4-15, 4-17, 4-25, 4-28
manufacturing 1-9, 4-5
memory cell 1-10
packaging materials 1-10
power requirements 6-18
PROM formatter 2-19
reliability 1-10
software cycle 2-5
speed grade 1-8, 5-61
testing 8-2
user-programmable gate array 1-5
LCA commands
ADDPIN 5-42
AUTOROUTE OFF 5-44
CLEARPIN 5-43, 5-52, 5-54
DONE 5-58
EDITNET 5-37, 5-42, 5-44, 5-47, 5-49, 5-50, 5-59
HILIGHT 5-52
MOVEBLK 5-51
QUERYNET 5-59
REPORT DELAY 5-59
RESET 5-63
ROUTE 5-47, 5-52, 5-55
ROUTE* 5-52
ROUTEPIN 5-47, 5-52, 5-54, 5-55
SELECT 5-38
SHOW USED 5-51
SPEED 5-61
SWAPBLK 5-51
SWAPPIN 5-53
SWAPSIG 5-52, 5-53, 5-54
UNROUTE 5-43
LFSR
applications 4-41
decryption function 4-41

2000 SERIES LCA DESIGN HANDBOOK INDEX
June 1988

I-4

2
skip paths 4-42
stuck state 4-42, 4-46
Linear Feedback Shift
   Register (see LFSR)
logic
   functions 2-8
   glue logic replacement 5-9
   levels 3-21
   negative 4-15
   positive 4-15
   wired-AND 4-15, 4-16, 4-17
   wired-OR 4-15, 4-16, 4-17
logic blocks
   grouping 2-8
   locking 2-9
Logic Cell Array (see LCA)
   long line 5-10, 5-11, 5-18, 5-62
   skew 5-13
loop delays 4-5, 7-5
definition 7-4

M
macro 4-20, 5-31, 5-33
design tradeoff 5-33
GXTL 4-28
invoke a macro 3-38
POUTZ 4-17
samples 3-38
syntax 3-40
Macrocells
   'MACROS directory 3-38
   create a macro 3-39
   instance 3-38
   sample macros 3-40
MAKEBITS 6-2, 6-46
memory
byte-wide 6-29
   CMOS 8-9
   five-transistor 8-6
   six-transistor 8-6
metastability
calculating probability 7-6
defined 7-2
empirical data derivation 7-4
error probability 7-7, 7-10
IOBs 4-2
minimizing 4-5
MIL-STD-883 9-2, 9-5, 9-6
Mode Select input pins 6-15
moisture 9-3, 9-4, 9-5
monitor performance 2-14
multi-destination 5-46
multiple connections 5-49
multiplexer 3-5, 5-4, 5-20
   address 5-33
   tree 3-5
NAND 3-3
nets
   high fanout 5-51
   noise filter 3-36
   nonhermetic devices 9-2
   normal operation 8-8
observability 8-4
open-collector 4-7, 4-11
operation
   long-term characteristics 9-3
optimize
design timing 2-16
oscillator 4-7, 4-27
crystal 4-7, 4-28, 5-17, 7-2
internal 6-13
low-frequency timing
   characteristics 4-27
on-chip 4-28
Pierce 4-29
output
   buffer 4-21
   spikes 3-33

P
part
   7400 series 2-8
partitioning 5-19
   LCA elements 6-2
pass transistors 5-62
path
   bidirectional 5-11, 5-22
data-path selector 4-4
maximum delay 7-6
routing path delays 4-5
unidirectional 5-23
phase shift 4-29
pin
   CCLK 6-29
   connections 5-38
   control 6-14
   CS2 6-25
   D/~P 6-29, 6-44
   DIN 6-20, 6-25, 6-34, 6-38, 6-45
   DIN and DOUT 6-16
   DOUT 6-25, 6-29, 6-34, 6-38
dual-function I/O 6-9
floating input 6-40
general purpose I/O 6-9
HDC 6-38
IOB output 6-41
magic 5-38
mode select 6-3, 6-6
multiple-function I/O 6-1
non-programmable 6-14, 6-23
number in Master mode 6-9
number in Slave mode 6-9
open-drain output 6-3
potential I/O conflicts 6-38
RESET 6-3
unused 6-40
user-programmable I/O 6-5, 6-14, 6-23, 6-26
~CS0 6-25
~CS1 6-25
~LDC 6-38
~RCLK 6-29
~WRT 6-25
pin function
~RESET 4-4
PIPs 5-37
placement
CLB 5-23
control logic 5-26
examples 5-29
guidelines 5-24
improving 5-36
IOB 5-24, 5-27, 5-28
logic 5-19
modification 5-34
rectangular 5-31
tradeoffs 5-33
placement and routing
APR 2-1
LCA design editor,
EDITLCA 2-12
plane logic
AND/OR 1-6
PLD 1-6
architecture 1-4, 1-6
bipolar 1-4
CMOS 1-4
preamble code 6-3
programmable
interconnection
points (see PIPs)
programmable logic device
(see PLD)
Q
quality assurance and
reliability regimen 9-2
R
readback 2-21, 6-49, 8-9
CCLK, M0, and M1 6-49
control timing 6-50
data contents 6-50
MAKEPROM 6-51
register (see also LFSR)
7-2
8-bit, parallel-load shift
5-7
constructing shift
registers with IOBs
4-35
D-type 7-2
data input 7-2
data shift 5-33
delay 4-30
input 4-4
IOB 4-3, 4-33, 4-36
LFSRs 4-41
read/write 4-33
shift 3-24, 5-18, 5-21,
6-48
storage 4-9, 4-32
reliability 1-10
RESET 3-9
~RESET 3-9
reset function 5-13
resynchronizer 3-36
routing
alternatives 5-23
automatic (see APR)
bidirectional signal 5-12
congestion 5-32
guidelines 5-43, 5-49
high-fanout 5-16, 5-51
inputs and outputs 5-49
LCA 5-37
low-skew 5-16
pre-routing or seeding 5-43
routing resources
global clock buffers 2-14
long lines 2-14
S
scan cells 8-3
schematic capture
software 3-11
Schmitt-trigger
structures 4-7
SCR 8-12
semiconductor controlled
rectifier (see SCR)
serializer 5-22, 5-23, 5-29,
5-31, 5-33
SET 3-9
shift register 5-33
signal
degradation 5-62
delay 5-62
falling 5-63

2000 SERIES LCA DESIGN HANDBOOK INDEX

June 1988
isolation and restoration
5-5
minimizing conflict 6-39
quality 5-57
rising 5-63
transition 5-63
simulation 2-11
logic 2-1, 2-10
results 2-16
timing 2-16
SSI/MSI 1-4, 3-2
standard product ICs 1-2
state
initialization 6-4
static latch 1-10
structures
standard LCA I/O 4-8
switch
connections 5-4
matrices 5-3, 5-40
switching threshold 4-21
synchronous system 7-2

T
target system 2-17, 2-19, 6-2
temperature 9-3, 9-5
testability 8-1, 8-2, 8-5
comprehensive 8-1
testing
automated cleaning 9-5
configurations 8-4
corrosion 9-5
emulating severe
environments 9-2
group C conformance 9-4
high-moisture 9-4
lead integrity 9-6
methods 9-2
moisture 9-3, 9-5
packaging 9-5
predictions 9-2
procedures 8-4, 9-2
solderability 9-5
temperature 8-5, 8-14, 9-3, 9-5
water vapor 9-5
thermal stresses 1-10
three-state control line 4-5, 4-11, 4-12, 4-15, 4-17, 4-21
timing
analysis 2-15, 5-56
between control pins 6-24
calculator 4-27
checks 2-15
CLB delays 3-21
clock-to-block output via Q 3-21
CMOS delay
accumulations 3-22
critical path 2-15
daisy-chained LCA
devices 6-45
delay calculation 4-12, 5-42, 5-58, 5-60,
delays in IOB-based
registers 4-30
design optimization 2-16
excessive routing delay 4-12
input and output pad
buffer delays 3-21
input setup time 3-21
interconnection delay 3-21, 5-57
loop delays 4-5
low-frequency
characteristics 4-27
Master configuration
mode 6-32
oscillator 4-25, 4-27
Peripheral mode 6-25
propagation time of a
CLB 3-21
R/C delay 5-56
readback control 6-50
routing 4-5, 4-21
simulation 2-16, 5-56
skew 5-18
synchronization delay 6-34
tilde 5-67
verification 2-16, 2-17
worst-case delay 5-9, 5-56
transistors
parasitic 8-13
transition
clock 4-5
data 4-5
direction 4-22
translate
CLB-based LCA design
to netlist 2-16
trigger
hysteresis 4-19
Schmitt 4-18, 4-19, 4-20, 4-21
truth tables 3-11
TTL 4-5
voltage 7-3

U
UART 4-41
UNROUTE 5-43

V
verification
download cable 2-17
in-circuit 2-17
logic and timing 2-17
VLSI 1-2
voltage
CMOS 4-5, 7-3
input 4-21
IOB 4-22
levels 7-2
margins 4-47
output 4-21
range for IOBs 4-22
threshold 4-20
transient 8-8
transition level 4-21
TTL 4-5, 7-3

W
wired-AND 4-11
wired-OR 4-11
write operation 8-8

X-Y-Z
XACT 2-12
delay calculator 2-15
PROM formatter 2-19
XACTOR 2-19, 2-21, 6-2
in-circuit emulator 5-64,
  6-42, 6-50
XNOR 4-42
XOR 4-41
Table of Contents Section 3
Applications

<table>
<thead>
<tr>
<th>Section 3 Applications</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Configuring LCA Device</td>
<td>3-3</td>
</tr>
<tr>
<td>M2018 Provides Decoding for Six-Digit, Seven-Segment Liquid Crystal Display</td>
<td>3-17</td>
</tr>
<tr>
<td>LCA Counter Applications</td>
<td>3-29</td>
</tr>
<tr>
<td>Time Division Multiplexing with LCA Device</td>
<td>3-43</td>
</tr>
<tr>
<td>Dual 32-bit Serial CRC Error Detection in a LCA Device</td>
<td>3-53</td>
</tr>
<tr>
<td>LCA Device Implements an 8-bit Format Converter in a PBX Switching Module</td>
<td>3-65</td>
</tr>
<tr>
<td>Reconfigurable Programmable Devices (LCA) Simplify Digital TDM Line Transcoder</td>
<td>3-75</td>
</tr>
<tr>
<td>Building an ESDI Translator Using the M2064 Logic Cell Array</td>
<td>3-89</td>
</tr>
<tr>
<td>Using the Logic Cell™ Array to Build a Pseudo-Random-Number Generator</td>
<td>3-101</td>
</tr>
<tr>
<td>64K Deep FIFO–Dynamic RAM Controller is Implemented in the M2018 LCA Device</td>
<td>3-109</td>
</tr>
<tr>
<td>Configuring the LCA™ from the PC Bus</td>
<td>3-125</td>
</tr>
</tbody>
</table>
Configuring the LCA Device

By Ed Valleau
Configuring the LCA Device

By Ed Valleau

Introduction

The Logic Cell™ Array device from Monolithic Memories is a new revolution in programmable logic. It offers the user gate array logic density while still providing the versatility of a programmable logic device (PLD). Its architecture is based on an array of static RAM cells, which must be configured when power is initially applied to the circuit. This gives the LCA device a high degree of flexibility since the functional logic contained in the device may be changed during development, thus shortening prototyping cycles. To update existing equipment, logic circuits may be modified with new configuration data. It is also possible to reconfigure the LCA device “on the fly” without the need for hardware changes. This would prove specifically useful in systems that need to change their protocols of operation dynamically.

Configuration data is stored in a nonvolatile source and read by the LCA device at “power up”. The time it takes to perform a configuration is variable, from 12 to 34 ms depending on device type and mode of configuration. A typical storage medium for the LCA’s configuration data would be an EPROM or EEPROM, which would be connected to the LCA and accessed immediately after “power up”. When the configuration process is complete and the device is fully functional, the EPROM or EEPROM may be put into a three-state condition and left deselected until the next configuration cycle.

There are a number of different modes of LCA device configuration, each mode being better suited to a particular operating environment or application than another mode. The following information outlines these various modes.

Overview of the Configuration Process

The LCA device is comprised of three distinct programmable elements: Configurable Logic Blocks (CLBs), Input/Output Blocks (IOBs) and Programmable Interconnect. Because the device architecture is based on static RAM cells, the configuration of the CLBs, IOBs and Programmable Interconnect is random and indeterminate when power is first applied to the device. The LCA device goes through two states prior to being functionally operational. The first is a general initialization state, followed by a configuration sequence. (See Figure 1.)

The device uses a number of dedicated input/output pins to control the loading process. Configuration sequentially programs the RAM cells, ultimately creating functionally operational and interconnected logic blocks. The entire procedure is comparable to programming a PLD except that a conventional PLD is nonvolatile, and maintains its logic functionality when power is removed from the circuit.

The smaller of the two LCA devices, the M2064, is a 64-CLB device which requires exactly 12,040 binary bits of information to complete the configuration process. The M2018 is a 100-CLB device which needs 17,880 bits of information.

Table 1 shows the different modes that can be selected via the three dedicated mode input pins M0, M1 and M2. These will usually be hardwired to select a single mode. The LCA device reads the digital code applied to the mode pins prior to configuration, then enters one of five specific modes before becoming a functional logic system. The exact number of bits for successful configuration must be read into the LCA device, partial configuration is not possible.
Configuring the LCA Device

### Table 1. Comparison of Configuration Modes

<table>
<thead>
<tr>
<th>Configuration Mode</th>
<th>Slave Mode</th>
<th>Peripheral Mode</th>
<th>Master-High Mode</th>
<th>Master-Low Mode</th>
<th>Master Serial Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>Mode Selection code (M0:M1:M2)</td>
<td>1:1:1</td>
<td>1:0:1</td>
<td>0:0:1 (Master-Low)</td>
<td>0:1:1 (Master-High)</td>
<td>0:0:0</td>
</tr>
<tr>
<td>Configuration data</td>
<td>Bit-serial</td>
<td>Bit-serial</td>
<td>Byte-parallel</td>
<td>Bit-serial</td>
<td></td>
</tr>
<tr>
<td>Automatic loading</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
<td>Yes</td>
<td></td>
</tr>
<tr>
<td>Programming source</td>
<td>User Logic or Another LCA (Note 2)</td>
<td>CPU Data Bus Memory</td>
<td>External Byte-wide Memory</td>
<td>External Serial Memory</td>
<td></td>
</tr>
<tr>
<td>Number of user I/O pins required</td>
<td>2</td>
<td>6</td>
<td>25</td>
<td>3</td>
<td></td>
</tr>
<tr>
<td>Configuration time</td>
<td>Source Dependent (Note 1)</td>
<td>Source Dependent (Note 1)</td>
<td>12-24 ms (M2064)</td>
<td>12-24 ms (M2064)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>17-34 ms (M2018)</td>
<td>17-34 ms (M2018)</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. The minimum time in any case is approximately 12 ms for the M2064 and 17 ms for the M2018.
2. Also used by Monolithic Memories' XACTOR for In-Circuit Emulation.
3. This parameter depends on internal timing circuits and is manufacturing process-dependent. Therefore it may vary from device to device within the limits shown.

### Choice of Configuration Mode

The choice of a configuration mode is influenced by the actual operating environment. For example, questions that might arise are: is the LCA being used as a standalone logic unit, or with a microprocessor? Can it be configured by a serial link? Other considerations include whether pins used for configuration are also used for functional operation, and whether or not these pins should be isolated from activating external logic during configuration. The designer has a choice of configuration modes for multiple LCA designs, and can use either parallel or serial support for a master mode LCA device which in turn can configure a slave or number of slave LCA devices.

### The Configuration Pins

The pins used to configure the LCA device come in two forms: dedicated configuration pins which are used exclusively for configuring the LCA device, and multifunction configuration pins which can be used as general-purpose I/Os after configuration has been completed.

### The Multi-Function Configuration Pins

<table>
<thead>
<tr>
<th>PIN</th>
<th>DESCRIPTION</th>
<th>USAGE</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2</td>
<td>Mode Select</td>
<td>Present in all configuration modes</td>
</tr>
<tr>
<td>Din</td>
<td>Configuration Data In</td>
<td></td>
</tr>
<tr>
<td>Dout</td>
<td>Configuration Data Out</td>
<td></td>
</tr>
<tr>
<td>HDC</td>
<td>High During Configuration</td>
<td></td>
</tr>
<tr>
<td>LDC</td>
<td>Low During Configuration</td>
<td></td>
</tr>
<tr>
<td>¬CS0, ¬CS1, ¬CS2</td>
<td>Chip Selects</td>
<td>Peripheral Mode Only</td>
</tr>
<tr>
<td>¬Wrt</td>
<td>Write Strobe</td>
<td></td>
</tr>
<tr>
<td>¬RCLK</td>
<td>Read Strobe</td>
<td></td>
</tr>
<tr>
<td>A0-A15</td>
<td>Address Lines</td>
<td>Master Mode Only</td>
</tr>
<tr>
<td>D0-D7</td>
<td>Input Data Lines</td>
<td></td>
</tr>
</tbody>
</table>

### Pin Names and Functional Description

**Done/Program Pin D/~P**

The Done/Program D/~P pin performs a dual function. It is an open-drain output with an internal programmable pull-up resistor. During configuration the pin is an output that is driven LOW by the LCA and can be monitored by external logic to determine whether or not the LCA is ready for functional use. When configuration is completed this pin is pulled HIGH by an internal programmable pull-up resistor of 3KΩ value. In a multi-LCA environment, the D/~P pin goes HIGH one clock cycle before the configuration is complete allowing time for user I/O signals to propagate between other LCA devices before entering the functional mode of operation. The LCA may be reconfigured at any time by pulling the D/~P input LOW with an external logic open-drain (open-collector) driver. When the internal logic recognizes a LOW input it drives the D/~P output LOW forcing a reconfiguration cycle.
There is a time delay of several microseconds before an active LOW input is recognized, so random triggering due to short noise bursts is highly unlikely. If the D/-P input is prevented from going HIGH immediately after configuration, then further reconfigurations will be suppressed and functional operation will not commence until that input is permitted to go HIGH. In multiple LCA designs the D/-P pins are wire-OR'ed, so the last LCA device to be configured will prevent other, already configured, devices, from functioning. When the last device is configured the composite wire-OR line goes HIGH and all LCA devices enter a functional mode simultaneously.

~RESET
The ~RESET input is active LOW and is used to start the initialization process before or during configuration, but not during functional operation. Figure 1 shows the initialization and configuration procedure as a flow diagram. Asserting the ~RESET line will put the LCA device into an initialization mode, aborting the current cycle of configuration.

Once configuration is complete the ~RESET input takes on a different role. It may be used to reset the device as if the device were a functional logic system. When asserted, internal registers and/or latches are reset. The reset condition may then be relaxed and functional operation resumed without the generation of a reconfiguration cycle.

To initiate reconfiguration the D/-P pin should be used instead of the ~RESET input. When ~RESET is LOW at the initialization cycle, its LOW-to-HIGH transition will sample the logic condition at the mode input pins. The logic state sampled determines the mode of configuration. Once configuration has started these pins are not required to be held. However, it is recommended that these pins remain unchanged until the configuration phase is completed.

<table>
<thead>
<tr>
<th>MODE CONFIGURATION INPUTS M0, M1, and M2</th>
</tr>
</thead>
<tbody>
<tr>
<td>M0</td>
</tr>
<tr>
<td>-----------------------------------------</td>
</tr>
<tr>
<td>0</td>
</tr>
<tr>
<td>0</td>
</tr>
<tr>
<td>0</td>
</tr>
<tr>
<td>1</td>
</tr>
<tr>
<td>1</td>
</tr>
</tbody>
</table>

Table 2.

PWRDWN-
The PWRDWN-- input is an active LOW power-down pin that can be used to reduce power consumption of the LCA device when it is not being used. The LCA device is then considered off-line because all I/O lines are disabled while internal configuration is maintained. The VCC input may be reduced to 2.0 Volts and configuration data will not be lost. With internal logic disabled and I/O pins in a high impedance condition, the D/-P pin is forced LOW and all internal storage elements become cleared. It is essential that this pin is used only while D/-P is HIGH after initialization and configuration. It is common to tie this input to a valid logic HIGH if the power-down feature is not required.

Non-Dedicated Pins used in all Configuration Modes

DIN and DOUT
DIN (configuration Data IN) is used as a serial data port into the LCA device. Individual data bits are applied to this input and clocked into the device by rising clock edges applied to the CCLK input. DIN is used in both slave and peripheral modes.

DOUT (configuration Data OUT) is used to configure multiple LCA devices in a daisy chain. The DOUT signal from the preceding LCA device drives the DIN of the succeeding device and is synchronized to rising edge of the clock pulse on the CCLK line.

CCLK
CCLK (Configuration CLocK) as described above is used to synchronize the serial data stream into the data input DIN pin. The CCLK can be an input pin or output pin depending on the mode of configuration. It is an output for every mode of configuration except for the slave mode. The CCLK reverts to an input in the slave mode, and can be driven either by an external source or the CCLK output of another LCA device configured in the master mode. In the operational mode the CCLK is an input to enable configuration data to be read back from the LCA via the M0 and M1 pins, which have the dual function of Readback Trigger (RT) and Readback Data (RD), respectively. CCLK has an internal pull-up resistor which allows the input to be pulled HIGH when not in use.

RCLK
The Read CLocK is used as an output signal which goes LOW when the LCA device expects to see valid input data, and HIGH when the address bus contents are changing states. It can be used to enable the external EPROM, and in the master serial mode can be used to clock an external address counter. This pin is used to clock the CCLK input of the serial EPROM, a support device for the LCA.

HDC and LDC
High During Configuration (HDC) and Low During Configuration (LDC) are driven HIGH and LOW, respectively, for the duration of the configuration process. They are used to control external logic during configuration. When configuration has been completed HDC and LDC become general-purpose input/output pins. All of the other I/O pins not involved in the actual configuration process are connected to internal pull-ups to VCC, which are removed after configuration.

CHIP SELECT INPUTS ~CS0 ~CS1 CS2 ~WRT
~CS0, ~CS1, and CS2 are the chip select pins used during the Peripheral Configuration Mode only. The three enables can be used to map the LCA device to a specific address. Active LOW inputs to ~CS1 and ~CS0, and an active HIGH input to CS2 will select the LCA device as if it were a memory or peripheral location mapped into the address space of a microprocessor system.
Configuring the LCA Device

~WRT in the Peripheral Configuration Mode is the same as CCLK in the slave mode. A single data bit is transferred from the data bus into the LCA device on each rising edge of ~WRT.

**A0-A15 and D0-D7**

The address and data pins are used in the master parallel modes only, and are converted to general-purpose input/output pins after successful configuration. A0-A15 are the address lines used to access the external EPROM. In the Master Low mode, address location 0000 hexadecimal is read first, and the addresses increment each time a data byte is read until all of the configuration data is loaded into the LCA device. The D-/P pin then goes HIGH indicating that the device is loaded. The address counter outputs convert to general-purpose I/O, unless the D-/P pin is held LOW by the wire-OR function of a D-/P output from a slave device. In that case the counters will continue to count, downloading the slave's configuration data. Counting will continue for more than one slave. In the Master High Mode, address FFFF hexadecimal is accessed first, and the address lines are decremented. This allows the LCA device to share addressing space with an EPROM or EEPROM used by the system. D0-D7 are the data lines connected to the external memory device.

---

### Table 3. Summary of Pins Used for Configuration

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>APPLICABLE CONFIGURATION MODE(S)</th>
<th>FUNCTION DURING CONFIGURATION</th>
<th>FUNCTION DURING USER OPERATION</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>S</td>
<td>P</td>
<td>MH</td>
</tr>
<tr>
<td>M0</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>M1</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>M2</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>D/P (Note 1)</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>RESET (Note 1)</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>CCLK</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>DIN</td>
<td>•</td>
<td>•</td>
<td>—</td>
</tr>
<tr>
<td>DOUT</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>HDC</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>LDC</td>
<td>•</td>
<td>•</td>
<td>•</td>
</tr>
<tr>
<td>A0-A15</td>
<td>—</td>
<td>—</td>
<td>•</td>
</tr>
<tr>
<td>D0-D7</td>
<td>—</td>
<td>—</td>
<td>•</td>
</tr>
<tr>
<td>RCLK</td>
<td>—</td>
<td>—</td>
<td>•</td>
</tr>
<tr>
<td>WRT</td>
<td>—</td>
<td>•</td>
<td>—</td>
</tr>
<tr>
<td>CS0</td>
<td>—</td>
<td>•</td>
<td>—</td>
</tr>
<tr>
<td>CS1</td>
<td>—</td>
<td>•</td>
<td>—</td>
</tr>
<tr>
<td>CS2</td>
<td>—</td>
<td>•</td>
<td>—</td>
</tr>
</tbody>
</table>

**Notes:**
1. The RESET, CCLK, and D/P pins have multiple functions. See text for further details.
2. During Slave mode configuration, the CCLK pin is an input, while for all other modes, it is an output.
3. DIN and D0 are the same physical pins but are associated with different configuration modes.

**Abbreviations:**
- S = Slave
- P = Peripheral
- I = Input
- O = Output
- MH = Master high
- ML = Master low
- MS = Master serial

---

**Slave Configuration**

::<莫 M1 M2> = <1 1 1>

The Slave Configuration Mode (Figure 2a) is simple to implement requiring only three pins, two lines to perform handshake and synchronization and one line for data transmission. Slave configuration is used in the XACT Development System to download data to the support hardware. In this mode data is presented to the LCA device as a serial bit stream, which is transferred to the device as if it were a very large shift register. The data is presented to the DIN pin and sequentially clocked into the device using the CCLK input. When the device is completely loaded, the D-/P pin goes HIGH to confirm that configuration is complete and that the device is ready to function as a programmed unit.

In Figure 2a the LCA device is shown connected to a microcomputer/microprocessor port with the data line (D0) connected to the DIN input. The rising edge of the strobe output will clock valid data on D0 into the LCA. The process continues until the D-/P confirms that configuration is complete to the microcomputer via the data input (D7). The microcomputer can poll D7 to...
Configuring the LCA Device

determine the configuration status, or set input D7 to generate an interrupt. Another application for the slave mode would be in a multiple LCA design where one LCA device can serially load subsequent slave LCA devices arranged in a daisy chain. Using LCA devices connected as master and slave or slaves is discussed more fully in a later section.

![Diagram of LCA device configuration]

**Figure 2a. Slave Mode**

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>PIN NUMBER</th>
<th>PIN TYPE</th>
<th>VALUE DURING CONFIGURATION</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>M0</td>
<td>26</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>M1</td>
<td>25</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>CCLK</td>
<td>60</td>
<td>Input</td>
<td>&lt;Clock&gt;</td>
<td>Configuration Clock</td>
</tr>
<tr>
<td>RESET</td>
<td>44</td>
<td>Input</td>
<td>HIGH</td>
<td>Master Reset</td>
</tr>
<tr>
<td>D/^()</td>
<td>45</td>
<td>Output</td>
<td>LOW</td>
<td>Done/Program</td>
</tr>
<tr>
<td>PWRDWN</td>
<td>10</td>
<td>Input</td>
<td>HIGH</td>
<td>Power-down</td>
</tr>
</tbody>
</table>

**Fixed, Non-programmable Pins**

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>PIN NUMBER</th>
<th>PIN TYPE</th>
<th>VALUE DURING CONFIGURATION</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2</td>
<td>27</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>DIN</td>
<td>58</td>
<td>Input</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data In</td>
</tr>
<tr>
<td>DOUT</td>
<td>59</td>
<td>Output</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data Out</td>
</tr>
<tr>
<td>HDC</td>
<td>28</td>
<td>Output</td>
<td>HIGH</td>
<td>Constant “1” Level</td>
</tr>
<tr>
<td>LDC</td>
<td>30</td>
<td>Output</td>
<td>LOW</td>
<td>Constant “0” Level</td>
</tr>
</tbody>
</table>

**User-Programmable Pins**

**Figure 2b. Slave Mode Pin Summary**

![Slave Mode Configuration Timing]

**Figure 2c. Slave Mode Configuration Timing**
Peripheral Mode Configuration

\[<M0 \ M1 \ M2> = <1 \ 0 \ 1>\]

The Peripheral Mode (Figure 3a) is similar to the Slave Mode in that the data is presented in a bit serial form. In the Peripheral mode, however, the LCA device is configured as a microprocessor-compatible peripheral device. The microprocessor can access the LCA device directly through its internal address bus, and map it through chip select logic. Control of the write operation is direct to the LCA device. Less hardware is required to connect the LCA to a microprocessor in this mode, and the loading of data is serial over a single data line. Synchronization is achieved by the falling edge of a \(~\text{WRT}\) input, while data is set up on the DIN line and strobed by the falling edge of a microprocessor-generated write signal.

Figure 3a. Peripheral Mode

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>PIN NUMBER</th>
<th>PIN TYPE</th>
<th>VALUE DURING CONFIGURATION</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>Fixed, Non-programmable Pins</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>M0</td>
<td>26</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>M1</td>
<td>25</td>
<td>Input</td>
<td>LOW</td>
<td>Mode Select</td>
</tr>
<tr>
<td>CCLK</td>
<td>60</td>
<td>Output</td>
<td>&lt;Clock&gt;</td>
<td>Configuration Clock</td>
</tr>
<tr>
<td>RESET</td>
<td>44</td>
<td>Input</td>
<td>HIGH</td>
<td>Master Reset</td>
</tr>
<tr>
<td>D/P</td>
<td>45</td>
<td>Output</td>
<td>LOW</td>
<td>Done/Program</td>
</tr>
<tr>
<td>PWRDWN</td>
<td>10</td>
<td>Input</td>
<td>HIGH</td>
<td>Power-down</td>
</tr>
<tr>
<td>User-Programmable Pins</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>M2</td>
<td>27</td>
<td>Input</td>
<td>HIGH</td>
<td>Mode Select</td>
</tr>
<tr>
<td>DIN</td>
<td>58</td>
<td>Input</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data In</td>
</tr>
<tr>
<td>DOUT</td>
<td>59</td>
<td>Output</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data Out</td>
</tr>
<tr>
<td>CS0</td>
<td>50</td>
<td>Input</td>
<td>LOW</td>
<td>Chip select (Active LOW)</td>
</tr>
<tr>
<td>CS1</td>
<td>51</td>
<td>Input</td>
<td>LOW</td>
<td>Chip select (Active LOW)</td>
</tr>
<tr>
<td>CS2</td>
<td>54</td>
<td>Input</td>
<td>HIGH</td>
<td>Chip select</td>
</tr>
<tr>
<td>WRT</td>
<td>56</td>
<td>Input</td>
<td>&lt;Strobed&gt;</td>
<td>Write enable (Active LOW)</td>
</tr>
<tr>
<td>HDC</td>
<td>28</td>
<td>Output</td>
<td>HIGH</td>
<td>Constant &quot;1&quot; Level</td>
</tr>
<tr>
<td>LDC</td>
<td>30</td>
<td>Output</td>
<td>LOW</td>
<td>Constant &quot;0&quot; Level</td>
</tr>
</tbody>
</table>

Figure 3b. Peripheral Mode Pin Summary
**Parallel Master Mode Configuration**

**MASTER MODE LOW** \(<M0 \, M1 \, M2> = <0 \, 0 \, 1>\)

**MASTER MODE HIGH** \(<M0 \, M1 \, M2> = <0 \, 1 \, 1>\)

In the Master Low Parallel mode (Figure 4a) data is loaded in parallel at a rate determined by an on-chip timer in the LCA device. Configuration data is stored in an EPROM or EEPROM, and a parallel data path is connected from the memory output data lines D0-D7 to dedicated data inputs on the LCA device. There are sixteen address outputs, A0(LSB)-A15(MSB), connected to the EPROM. At the start of configuration in master mode low the LCA device sends an incrementing address starting at address 0000 hexadecimal and sequentially selects the configuration bytes. Data is serialized when loaded into the LCA device.

When configuration is complete the address and data lines become general-purpose I/O blocks. The D/-P pin is used to provide external logic, an indication that the LCA is currently functional or configuring.

The D/-P pin can be used to select the EPROM/EEPROM during configuration. An active LOW output applied to the memory’s Chip Select input will select the device to read the configuration data and deselect it when configuration is complete. The method shown in Figure 4a is suggested for logic systems that have no host processor available to perform the configuration. A drawback is that address and data lines might require isolation from external logic circuits while the LCA device is configuring. The logic designer must determine which signals need isolation and which do not. Using IOBs which are not address and data lines might be a solution to avoid any conflict that might occur when external logic is driven during configuration. Also, the designer must avoid loading address and data lines with capacitive or inductive components. For example general IOBs should be used for circuits such as relaxation oscillators which require capacitive loads. Loading address or data lines with capacitors might lead to a violation of setup and hold times, causing erroneous configuration information to be read.
In the Master Mode HIGH the initial starting address is hexadecimal FFFF, and the address decrements after each data byte is read. For both Master Mode HIGH and Master Mode LOW, the LCA device will set the D/-P pin HIGH after enough bits have been read to configure the one master LCA device. This permits configuration data to be stored in an EPROM that also holds microprocessor firmware. Only 1505 (5E1 hex) bytes are required for an M2064 LCA device and 2235 (888 hex) bytes for the M2018, so large EPROMs can store configuration data for a number of LCA devices. Configuration information is concatenated in one EPROM and read by the master device, then sent to slave LCA devices as outlined in the section describing the configuring of multiple LCA devices.

**Bytewide Master Mode Pin Summary**

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>PIN NUMBER</th>
<th>PIN TYPE</th>
<th>VALUE DURING CONFIGURATION</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>Fixed, Non-programmable Pins</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>M0</td>
<td>26</td>
<td>18</td>
<td>Input</td>
<td>LOW</td>
</tr>
<tr>
<td>M1</td>
<td>25</td>
<td>17</td>
<td>Input</td>
<td>LOW or HIGH</td>
</tr>
<tr>
<td>CCLK</td>
<td>60</td>
<td>42</td>
<td>Output</td>
<td>&lt;Clock&gt;</td>
</tr>
<tr>
<td>RESET</td>
<td>44</td>
<td>31</td>
<td>Input</td>
<td>HIGH</td>
</tr>
<tr>
<td>D/P</td>
<td>45</td>
<td>32</td>
<td>Output</td>
<td>LOW</td>
</tr>
<tr>
<td>PWRDWN</td>
<td>10</td>
<td>7</td>
<td>Input</td>
<td>HIGH</td>
</tr>
</tbody>
</table>

| User-Programmable Pins | | | | |
| M2 | 27 | 19 | Input | HIGH | Mode Select |
| DOUT | 59 | 41 | Output | <Data> | Configuration Data Out |
| HDC | 28 | 20 | Output | HIGH | Constant “1” Level |
| LDC | 30 | 21 | Output | LOW | Constant “0” Level |
| RCLK | 57 | 39 | Output | <Strobed> | Chip enable output |

**Table 4b. Master Mode Pin Summary**

<table>
<thead>
<tr>
<th>ADDRESS BUS (OUTPUTS)</th>
<th>ADDRESS (n)</th>
<th>ADDRESS (n+1)</th>
<th>ADDRESS (n+2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>RCLK (OUTPUTS)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DATA BUS (INPUTS)</td>
<td>BYTE (n)</td>
<td>BYTE (n+1)</td>
<td>BYTE (n+2)</td>
</tr>
<tr>
<td>CCLK (OUTPUTS)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DOUT (OUTPUTS)</td>
<td>BYTE (n-1)</td>
<td>BYTE (n)</td>
<td>BYTE (n+1)</td>
</tr>
</tbody>
</table>

**Figure 4c. Master Mode Configuration Timing**
Serial Master Mode

The Master Serial Mode (Figure 5) uses a Serial Data PROM (SDPROM) which has an internal address counter and a serial data port for the conversion of parallel data from the SDPROM to a single data output. Figure 5a shows the schematic diagram required for this mode. Configuration data is stored in the PROM section and downloaded to the LCA device in the most pin-efficient way, avoiding large numbers of address and data interconnections. The SDPROM is connected to the LCA device using only three pins. In this mode the LCA generates a clock signal which is used to increment the address counter built into the SDPROM. The SDPROM then sends data to the DIN pin on the LCA device. This mode is very similar to the Slave and Peripheral Modes in that data input is through the DIN pin. However, the SDPROM requires a clock input to increment its internal address counter which is supplied by the RCLK output of the LCA device. The configuration time is therefore determined by the LCA devices on chip counter. The D/-P input terminates the configuration process by disabling the SDPROM.

One SDPROM can hold enough configuration data for three M2064 or two M2018 devices, and they can be cascaded for larger configuration arrays.

The data to be loaded into an LCA device is developed using the XACT Development Software, and is stored in one of two modes: a serial bit stream to be used in the Peripheral and Slave modes, or a 1500-byte PROM file for use in the Master Mode.

### Table: Master Serial Configuration Mode Pin Summary

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>PIN NUMBER</th>
<th>PIN TYPE</th>
<th>VALUE DURING CONFIGURATION</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>M0</td>
<td>26</td>
<td>Input</td>
<td>LOW</td>
<td>Mode Select</td>
</tr>
<tr>
<td>M1</td>
<td>25</td>
<td>Input</td>
<td>LOW</td>
<td>Mode Select</td>
</tr>
<tr>
<td>CCLK</td>
<td>60</td>
<td>Output</td>
<td>&lt;Clock&gt;</td>
<td>Configuration Clock</td>
</tr>
<tr>
<td>RESET</td>
<td>44</td>
<td>Input</td>
<td>HIGH</td>
<td>Master Reset</td>
</tr>
<tr>
<td>D/-P</td>
<td>45</td>
<td>Output</td>
<td>LOW</td>
<td>Done/Program</td>
</tr>
<tr>
<td>PWRDWN</td>
<td>10</td>
<td>Input</td>
<td>HIGH</td>
<td>Power-down</td>
</tr>
<tr>
<td>M2</td>
<td>27</td>
<td>Input</td>
<td>LOW</td>
<td>Mode Select</td>
</tr>
<tr>
<td>DIN</td>
<td>58</td>
<td>Input</td>
<td>&lt;Data&gt;</td>
<td>Configuration Data In</td>
</tr>
<tr>
<td>RCLK</td>
<td>57</td>
<td>Output</td>
<td>&lt;Strobed&gt;</td>
<td>SDPROM Clock</td>
</tr>
<tr>
<td>HDC</td>
<td>28</td>
<td>Output</td>
<td>HIGH</td>
<td>Constant &quot;1&quot; Level</td>
</tr>
<tr>
<td>LDC</td>
<td>30</td>
<td>Output</td>
<td>LOW</td>
<td>Constant &quot;0&quot; Level</td>
</tr>
</tbody>
</table>

- **Fixed, Non-programmable Pins**
- **User-Programmable Pins**

Figure 5b. Master Serial Configuration Mode Pin Summary

![Figure 5b. Master Serial Configuration Mode Pin Summary](image)

Figure 5c. Master Serial Mode Configuration Timing

![Figure 5c. Master Serial Mode Configuration Timing](image)
Configuring Multiple LCAs

Recognizing that multiple LCAs could be used in a system, the designers added a feature which makes configuration easier by allowing several LCAs to be connected together in a daisy chain. In the Master mode, the first LCA reads data from the EPROM in parallel until it has received all of its configuration data. At this point its D/P pin would normally be pulled passive HIGH but it is wire-ORed to the remaining LCA devices configured in the slave mode and is held LOW. The first LCA, although configured will not start to function, but continue to pass configuration data to the next LCA device. The data out line (DOUT) drives the DIN line of the first slave, and the CCLK input clocks the configuration data through until the next LCA is configured. The wire-OR action holds the D/P input LOW preventing the configured LCAs from entering a functional mode. The sequence continues until the last LCA in the slave chain is configured and allows the D/P line to go HIGH. All the configured devices in the chain start to function simultaneously because the composite wired-OR function goes HIGH on all LCAs simultaneously.

Due to the current sink capability of the D/P input being able to handle only one pull-up load satisfactorily, only one of the LCA devices in the daisy chain should be configured with 'pull ups'. The first device in the chain can be configured in any of the four modes. All other devices in the chain would use the slave mode.

The daisy chain configuration mode is the easiest and most pin efficient, but the total configuration time increases linearly for each LCA added to the chain. It is also possible to configure LCAs in parallel in the slave or peripheral modes as shown in Figure 7. The total configuration time is then reduced to the configuration time of a single device.

Connecting parallel LCA's in the peripheral mode also allows the use of DMA transfer techniques to decrease configuration time.

Figure 6a. Master Mode LCA with Daisy-Chain
Use of the Multiple I/O Pins

When designing with the LCA, careful consideration must be given to which signals are connected to the multiple-function I/O pins. Conflicts can arise when a pin normally used as an input to the LCA suddenly becomes an output during the configuration cycle. Similarly, outputs which are normally under tight control by the LCA logic can transition erratically during configuration, causing adverse effects to the circuitry connected to them.

By simply assigning LCA outputs to pins which become outputs during configuration, and LCA inputs to pins which become inputs during configuration, the designer assures that conflicts can be held to a minimum. If all conflicts cannot be resolved using this method, then external buffers may be added to eliminate the possibility of any bus contention. The signals HDC (High During Configuration) and LDC (Low During Configuration) can be used to enable or disable the buffers at the appropriate times. See Figure 8.
Configuring the LCA Device

- M2, DIN, DOUT, MDC, LDC, and -RCLK all become I/O pins after configuration and need to be buffered accordingly.

- User inputs will conflict with address lines during configuration, and need to be buffered.

- Address lines which are user outputs must be isolated during configuration to prevent damage to the user's circuitry.

- Data lines become inputs to the LCA during configuration.

- Address lines become outputs from the LCA during configuration.

- I/O pins which are only I/Os do not need isolation.

Figure 8. Isolation of I/O Pins During Master Mode Configuration
M2018 Provides Decoding for Six-Digit, Seven-Segment Liquid Crystal Display

Chris Jay

Abstract

The Logic Cell™ Array (LCA) from Monolithic Memories is a high density programmable device capable of supporting true VLSI logic functions. Its unique properties can be viewed as providing the benefits of Programmable Logic Devices (PLDs) while approaching the high functional density of a gate array. Combining these features makes the LCA device a product capable of bridging the gap between PLDs and Gate Arrays.

The LCA structure differs from the conventional concept of the PLD because it is based on a CMOS RAM cell architecture. Its internal logic circuits, input/output (I/O) resources plus the interconnect are all programmable. In comparison to the traditional fuse array of a PLD which is linked to a fixed logic structure. The efficiency of this logic structure reduces as functional density increases.

The low-power CMOS RAM locations of the LCA device must be initialized and configured immediately after power has been applied to the circuit. Once configured, functionality is maintained by the continued application of power to the device. To ease configuration, the device can reside alongside a low-cost EPROM which holds the configuration data. The LCA device can automatically load itself and be reprogrammed any number of times. This feature of reconfigurability can be used for system development, modifying existing designs, or supporting multiple system choice, with very little actual hardware modification. In many instances this can be achieved dynamically or “on the fly.”

The following applications note describes the design of a six-digit, seven-segment decoder/driver for Liquid Crystal Displays (LCDs). Design methodology is outlined and the use of the XACT™ software is discussed in the role of a CAD design tool for the LCA device. The final designs are available to readers of this applications note on request.

Logic Cell™ Array and XACT™ are trademarks of XILINX Inc.
IBM® is a registered trademark of International Business Machines Corporation.
PC™, PC/AT™ and PC/XT™ are trademarks of International Business Machines Corporation.
P-SILOS™ is a trademark of Simucad Corp.
**M2018 Provides Decoding for Six-Digit, Seven-Segment Liquid Crystal Display**

Chris Jay

**Introduction**

There are two types of low-voltage, seven-segment displays available as indicator panels of multimeters, frequency counters, tachometers and other digital instruments: the light emitting diode displays (LEDs), and Liquid Crystal Displays (LCDs). The advantages of the LCD are mainly associated with very low power consumption and ease of readability. Instruments and portable equipment can benefit from low-power CMOS technology and use these displays. The problem with LED displays is that a much higher operating current is required to illuminate the segments, virtually precluding their application in portable battery-operated equipment. Also, LED display outputs tend to "wash out" in sunlight, so they are very unsuitable in bright daylight, or where the ambient presence of light is high. In the display instrumentation of an automobile, for example, an LED display panel might be "washed out" by high levels of reflected sunlight. LCD displays are preferable because the visual quality is good even in brightly lit environments.

Despite the good visual quality and low-power consumption of the LCD display, an LED type can easily be driven from a multiplexed bus output. The output pin requirement of a seven-segment LED driver can be reduced considerably by a multiplexed output arrangement. In a six-digit display, each anode (or cathode) drive is selected in synchronism with its multiplexed seven-segment output. A total of thirteen pins are required, seven pins to drive the segments and six pins to control the anode (or cathode) of each display. If each digit is multiplexed at high speed with a proportionally larger pulse current per display, then the readability of the output is unaffected. With an LCD display, multiplexing is virtually impossible for two reasons. First, the LCD display has a slow response time and can not be multiplexed to give a good visual output. Second, the display backplane has to be pulsed. Any beating of a multiplexing frequency with the backplane bias frequency can occur, resulting in an unreadable output.

LCD displays have drawbacks because any driver circuit will need one pin per segment, plus a backplane driver pin for the whole display unit. Seven segments for each digit, in a six-digit display requires forty-two outputs pins, plus the one backplane pin. The input pin requirement is twenty-four, four pins for each of the six digits. The total pin count is sixty-seven. Additional input circuitry to support register enables and oscillator inputs would use up even more I/O resources and pins.

**Block Function of the LCD Decoder/Driver**

Figure 1 shows a schematic block diagram of the system as designed into the M2018 Logic Cell Array. Additional pins to synchronize the clocking of data into the internal data registers take three more pins. Since a backplane oscillator is required, two pins are configured to a resistor/capacitor (RC)
network. The RC combination generates a square wave which is used as a backplane bias to the display. The pin count is seventy-two.

Binary data applied to byte 1 is registered after the rising edge of CLKO. The registered data is decoded to illuminate the relevant segments forming the hexadecimal display. Decoded data is then routed to the two least significant digits of the six-digit LCD. Byte data applied to inputs 2 and 3 are loaded by a clock rising edge, CLK1 and CLK2, respectively. A backplane oscillator output drives the LCD's backplane with a low-frequency square wave, which is determined by the RC time constants of a resistor/capacitor network. To display a segment the decoder circuitry will drive the selected segment with a square wave that is 180 degrees phase-shifted from the backplane reference. If a segment is driven from an in-phase signal, then it is blanked.

The advantage of the M2018 Logic Cell Array in this application is that it is a CMOS device, and consumes low power at low operational frequencies. Its power consumption is dependant on the internal clocking frequency and also on the percent usage of on-chip logic. There are one hundred individually configured logic blocks in the M2018, and any logic blocks that remain unused will consume only static substrate leakage current. Since the M2018 contains seventy-four general-purpose user I/O blocks, there is ample programmable logic and I/O capability to perform decoding, registering and storage of data for six seven-segment digits.

**LCA Configuration**

Since the LCA device is based around a programmable array of volatile RAM cells, it must receive configuration information at "power up." In this application it is programmed from an EPROM which holds the configuration data. Configuration takes place after power has been applied to the circuit, and it has been successfully reset. The LCA device enters a configuration mode, sequentially reads the data from the EPROM into its RAM cells, and becomes functionally operational in approximately twenty-five milliseconds. It disables the EPROM after configuration. The volatility of the M2018 is a distinct advantage in many applications. In this case, different display decode operations may be selected at 'power up'. Higher order address lines may be "hardwired" to select different configuration patterns from separate pages in the EPROM. So a small amount of deferred design may be added to the system.

The M2018 has many advantages over custom VLSI circuits. Here, designers have control over how they wish to configure the circuit. Different display fonts can be programmed, for configuration. The volatility of the M2018 is a distinct advantage in many applications. In this case, different display operations may be selected at 'power up.' Higher order address lines may be "hardwired" to select different configuration patterns from separate pages in the EPROM. So a small amount of deferred design may be added to the system.

Different display fonts can be programmed, for configuration. The volatility of the M2018 is a distinct advantage in many applications. In this case, different display operations may be selected at 'power up.' Higher order address lines may be "hardwired" to select different configuration patterns from separate pages in the EPROM. So a small amount of deferred design may be added to the system.

The configuration mode chosen for the LCA device was the Master Low mode. Data is sequentially read from the EPROM during the configuration cycle. After power has been applied and the RESET input has been deasserted, the M2018 will output a series of incrementing addresses to the memory starting at the initial address of 0000. The DONE/PROG (D/¬P), which is an output during configuration, is driven active LOW. It is tied to the CS and OE inputs of the EPROM. When configuration is finished, D/¬P is pulled passive HIGH by an internally-configured "pull-up" resistor in the LCA device. The EPROM is then deselected. The normal data flow into the device is via dedicated input lines D0-D7 during configuration, and afterwards these become general-purpose I/O lines. The total time for configuration can vary between 17 to 34 ms.

The advantage of the M2018 Logic Cell Array in this application is that it is a CMOS device, and consumes low power at low operational frequencies. Its power consumption is dependant on the internal clocking frequency and also on the percent usage of on-chip logic. There are one hundred individually configured logic blocks in the M2018, and any logic blocks that remain unused will consume only static substrate leakage current. Since the M2018 contains seventy-four general-purpose user I/O blocks, there is ample programmable logic and I/O capability to perform decoding, registering and storage of data for six seven-segment digits.

**Design of the Backplane Oscillator**

To establish a backplane bias frequency, an R/C network is used in conjunction with a logic block that is designed to function as a relaxation oscillator. The Configurable Logic Block (CLB) is connected to two Input Output Blocks (IOBs) which in turn are connected to two external R/C networks, R1,C1 and R2,C2 as shown in Figure 3a. The calculation of the R/C values to create a low-frequency backplane oscillation of even mark space ratio is given below. For an even mark/space ratio R = R1 = R2 and C = C1 = C2. The time constants for period t are given by the following formula:

\[ T = N \times [\frac{C}{R} X R2] \] ;for TTL voltage ;thresholds.

\[ T = 0.35(C X R2) \] ;for CMOS voltage ;thresholds.

The general expression for the calculation becomes:

\[ T = N \times [(R1 X C1) + (R2 X C2)] \] ;... (1)
Where N is the TTL, or CMOS multiplying factor of 0.35 for TTL or 0.75 for CMOS. The LCA device can be programmed to be compatible with either technology.

The values of 1 Kohm and 2.2 microfarad gave a backplane oscillation frequency of about 80 Hz.

Figure 3a shows the schematic arrangement of the backplane oscillator as it would be configured in the LCA device. Two R/C networks of 1 Kohm and 2.2 microfarads are connected to pins 67 and 65 respectively. The placement of the blocks is shown in Figure 3b as it would be seen on the color monitor of a PC when the XACT Design Editor is used. Pins dedicated to configuration functions must not be loaded with components such as capacitors because they could prevent the LCA device from reading valid data. Pin 66, which is associated with data line D2 was therefore assigned to drive one of the LCD segments.

XACT Editor and Macro Support for Quick Design Entry

The logic design is accomplished by using the XACT Design Editor running in an IBM® PC/AT™ or PC/XT™. This support software allows users to edit their designs via a mouse interface and a keyboard input. The CLB and IOB elements may be configured and connected to form complete logic subsystems through the programmable interconnect. The XACT Editor allows the user to view a section of the LCA device on the display unit of the PC, for CLB and IOB placement, and distribution of interconnect. Supported by the zoom-in and zoom-out facility, and a “world view” feature (this allows the user to see the entire LCA device layout) enables a designer to “hook” subsystems of the design together. Menus are displayed at the head of the video display, and a designer may move the cursor with a mouse to select options. These include BLOCK commands enabling CLB/IOB editing; CONFIG to enable configuration of blocks; and NET and PIN to assign pins to nets, so creating the overall interconnection. This could be analogous to interconnections on a printed-circuit card, making the electrical connection between pins of 74LSXX or other types of logic devices.

The XACT editor is equipped with a support MACRO library. This library allows widely used functions to be invoked without redesign. The relaxation oscillator, used for the backplane generator, is supplied as an existing design configuration in the MACRO. The oscillator MACRO may be called by downloading the GOSC MACRO file.

When using the XACT editor the application of already existing MACRO support files can dramatically reduce the overall design cycle time. The six-digit decoder display driver is basically repetition of the same six logic subsystems, one for each digit as shown in Figure 4. The CUTMACRO feature is useful as a support facility in avoiding repetitive design operations on individual IOBs or CLBs. Once a CLB has been designed, it can be stored as a MACRO, and given a user-defined name. The designer may call that MACRO wherever the IOB or CLB needs configuration and placement. The CUTMACRO feature also supports multiple CLBs, IOBs and interconnects of subsystems. A decode section identical to the one shown in Figure 4 can be stored as a MACRO and given a user-defined name. The design for a decoder section needs only to be performed once. The remaining five sections may be called and placed using the user-defined MACRO support facility.

Wide Used XACT Functions

As described, the XACT software is menu-driven and operations supported by the design editor are listed at the head of the screen with a schematic representation of a portion of the device shown below. A mouse interface permits the designer to scan a cursor over the schematic, or choose a functional operation by “clicking” on the selected option. Following are the available options from left to right:

NET PIN BLK CONFIG SCREEN MISC PROFILE

When selected, a heading will list its menu options. The BLK command gives nine options. The most commonly used options are EDITBLK and ENDBLK, which allow the designer to select a specific logic block and enter a logic description into it. The latter command will terminate the editing process and return the designer to a world view of the LCA schematic. Details on editing CLBs are described in more detail in the CLB Configuration Section. Other commonly used commands in the BLK menu include COPYBLK, to copy a repetitive logic design into other unconfigured blocks, DELBLK to erase unwanted designs from the network; CLRBLK, to clear the contents of a block but leave its input and output pins attached to the nets; MOVBLK, move a configured block with its associated nets to another block location; and NAMEBLK, to permit the assignment of user-defined names. Each time a function is invoked, the XACT editor prompts for a response at the bottom of the screen. For example, EDITBLK would invoke a “SELECT...
M2018 Provides Decoding for Six-Digit, Seven-Segment Liquid Crystal Display

The CONFIG command has six subcommands which relate to the editing of a CLB. The BASE command directs which logic arrangement is to be selected: one Boolean function of four-input variables, or two functions of three-input variables, or multiplexed input selecting either one choice of two three-input variables. EQUATE is commonly used, and allows a designer to generate a Boolean equation from keyboard input and configure it to an output. Other choices include ORDER, to establish blank truth tables for Karnaugh map entry; CLEAR, to delete unwanted functions; and CDATA (see data), for a text description of the block configuration.

The creation of configured blocks must have the support of interconnections. The NET and PIN commands are invoked to establish the connection of CLB outputs to CLB or IOB inputs. The NET menu may be invoked to create a net onto which input pins and one output pin is listed. The ADDNET command allows a designer to add a net to the netlist, and ADDPIN allows the user to add pins to a selected net. The NAMENET subcommand in the NET menu allows the default value of netx (where x is an XACT default-assigned integer) to be overruled by a user-assigned name. This is similar to the NAMEBLK command for BLK functions. Nets can be routed, unrouted, deleted and merged by the ROUTE, UNROUTE, DELNET and JOINNET commands, respectively. Manual editing of the net is invoked by the EDITNET command. A net is established and manually interconnected to Programmable Interconnect Points (PIPs) to create a circuit. The other NET options include FLAGNET, which assigns critical or non-critical status to a net; and HIGHLIGHT/UNHIGHLIGHT commands which “bright up” or “clear” net distribution on the “world view.”

The PIN commands are: ADDPIN for adding pins to nets, and CLEARPIN for removing them. The SWAPPIN allows pins to be switched without switching functionality, where SWAPSIG exchanges the logic functionality inside the CLB without switching the pins. MOVEPIN will move a pin from one location to another, and ROUTEPIN will establish an interconnection on a net.

These and other menu functions are described in greater detail in Monolithic Memories’ XACT Development System manual.

Design Methodology

Figure 4 shows a block schematic of one seven-segment decoder driver. Seven logic blocks decode the four data inputs DA, DB, DC, and DD, where DA is the least significant data input. Each block has the capability of storing the data in a register inside the logic block. The backplane oscillator drives the LCD backplane for all segments. The individual segments are driven from an exclusive-‘OR” (XOR) gate, which is programmed to invert the backplane waveform for an illuminated segment, and not invert for a blanked segment. The segment decoder circuits, SAO, SBO to SGO, provide a logic LOW output for an active segment drive. Therefore, the backplane input to the XOR gate is inverted in a second logic block and provides the correct phase control for the segment driver. The configuration was repeated six times in the LCA device to support a total of six digits.

Figure 5 shows the truth table for decoding four binary inputs into a hexadecimal segment drive. DA is the least significant binary input and DD is the most significant. The hexadecimal weighting of the binary input is also shown in the table. To illuminate a zero digit, all the segments are driven active except for segment “g,” for digit “one”, segments “b” and “c” are active, and for digit “two” segments “a,” “b,” “d,” “e” and “g” are driven. The complete decode arrangement is shown at the head of Figure 6.

The Karnaugh maps, derived from the truth table shown in Figure 5 are given in Figure 6, and provide the decode equations for all the segments. Logic “one” entries represent illuminated segments and logic zeros represent extinguished segments. A greater reduction efficiency of minterm entries was achieved using reduction techniques applied to map locations containing logic zeros. This required an inverted input to the exclusive OR (XOR) polarity control gate, as shown in Figure 4. The logic equations derived from the

![Figure 4. Liquid Crystal Display Decoder Driver](image-url)
Karnaugh maps in Figure 6 could be used for Boolean design entry, the active LOW equation for segment "a" is given as:

$$-a = -A \cdot -b \cdot -c \cdot -d + A \cdot B \cdot C \cdot D + A \cdot B \cdot C \cdot D$$

where the inputs to the CLB are A, B, C and D. The tilde sign (\(-\)) represents signal inversion, the * and + signs represent product and sum terms, respectively. The Boolean entry also supports the function XOR by the \(\oplus\) symbol, the function \(-A \cdot B + A \cdot B\) is condensed to \(A \oplus B\).

The conventional logic gate configurations are shown in Figure 7. Seven "sum of product", combinational circuits were derived from the Karnaugh maps shown in Figure 6. Logic designers familiar with PLD designs will recognize a sum of products architecture. Having generated Karnaugh maps and equations, the design can be implemented in the LCA device by using the facilities of the XACT Design Editor running in a PC/AT or PC/XT.

**Binary to Seven-Segment Decoder**

The display font shows the decoding function required for a binary to seven-segment hexadecimal display. A logic one represents an illuminated segment, from the table shown in Figure 5.

### Table: Binary Encoded Input

<table>
<thead>
<tr>
<th>HEX.</th>
<th>DA</th>
<th>DB</th>
<th>DC</th>
<th>DD</th>
<th>LSB</th>
<th>MSB</th>
<th>Segment Label</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

**Figure 5. Liquid Crystal Display Decoder Driver**

**Figure 6. Liquid Crystal Display Decoder Driver**

A logic one represents an illuminated segment, from the table shown in Figure 5.
M2018 Provides Decoding for Six-Digit, Seven-Segment Liquid Crystal Display

The decode logic for each segment is shown in the conventional sum of products form and was derived from the Karnaugh Maps. It is possible to encode these logic configurations in one "CLB" for each segment. The "CLB" is capable of producing one output that is a Boolean function of up to a maximum of four inputs.

Editing the Design

The XACT Design Editor was used to create the design, and generate the configuration data, suitable for programming into an EPROM. Three programmable elements have to be considered; the IOBs, CLBs and the interconnection of IOB and CLB blocks.

CLB Configuration

Figure 8 shows the exploded view of a CLB that has been configured as the segment "a" decoder. The XACT Design Editor provides a mix of text and diagram editing supported by a keyboard and mouse interface. The logic equation is shown as text entry at the bottom of the diagram. The combinational block, AA (user defined as SAO by invoking the NAMEBLOCK feature in XACT), has been configured as the "a" segment decoder. Each CLB can be configured as a single output function of four Boolean input variables, or two output functions of three-input variables each. Both configurations were used in this design example.

The Karnough map reflects the equation entered from the keyboard. An alternate way of entering configuration information may be achieved by using the mouse to select individual locations in the Karnough map. These locations may be "clicked" on or off, to select or deselect minterm entries. The equation relevant to the Karnough map entry is updated after modification. If designers have generated Karnough maps during the design cycle of the project, they could use this visual aid to enter and check the logic integrity of the design. Also, a truth table is available for verification purposes.

An unconfigured CLB will not display a Karnough map so to generate a four-input map, the instruction:

```
Config(Order(F(A(B(C(D)))))
```

is typed to create one output F that is a function of four Boolean inputs. A blank Karnough map will be displayed ready for editing.

The top left-hand portion of Figure 8 indicates how the CLB is configured. The Q output from the register is connected to the X output of the CLB. To activate this path, the mouse is used to select the Q option. The register could be bypassed if the F output was selected. Either register or combinational configurations may be realized. The path from the register output to the CLB X output is established by activating the PIP represented by the block tying Q to X shown in Figure 8. The alternate output, Y has the same assignment options of registered or combinational outputs. There are two configurations available to the storage element; either register or transparent latch. The register's output will change as a result of a transition being applied to its clock input. For a latch, the control input is level-sensitive requiring a logic HIGH or LOW level to distinguish between storage or a transparent mode of operation. In the CLB the clock input polarity can be selected by the NOT function in the CLK submenu. Two features that were not used in this design are the asynchronous SET and RESET functions. If required, the SET option can be invoked by selecting either the A input, or choosing a combinational output from F, which can also perform RESET. A single input to RESET the register or latch is the D input. To the bottom right of the CLB configuration diagram in Figure 8, all the inputs to, and outputs from, the CLB are listed. The net to which each CLB input or output is associated is shown after the colon. The A input is tied to the net DAO; B, C and D inputs are connected to nets DBO, DCO, and ODO, respectively. The user can assign meaningful names to nets in the design process. In this example, net SAO, is segment "a" of the least significant digit and is driven from the X output of the CLB. DAO-DDO are the four binary inputs for the least significant digit. The clock input is assigned to the K terminal of the CLB, thus, the decoded output may be registered after a rising edge of the clock has been applied to the net CLK0.

![Figure 8. Liquid Crystal Display Decoder Driver](image-url)
Like nets, individual blocks may be given meaningful names. The CLB situated on a grid location "AA" of the LCA device has been named SAO. Naming nets and blocks can help in debugging the final design. Figure 9 shows the configuration of the CLB elements for segments 'b', 'c', 'd', 'e', 'f' and 'g'.

Figure 10 shows the configuration of a CLB as a combinational logic circuit which provides two outputs at X and Y. The backplane waveform is fed to the A input where it is inverted. This signal will pass through the X and Y outputs, appearing either in phase with the backplane reference or shifted by 180 degrees from it. The control inputs come from the segment decoder circuitry. In Figure 10, SA0 and SB0 are the interconnecting nets that convey control signals from the segment 'a' and 'b' decoders. The configuration used was two Boolean outputs as functions of three-input variables, so outputs F and G were selected.

Figure 9. Liquid Crystal Display Decoder Driver

Figure 10. Liquid Crystal Display Decoder Driver
**IOB Configuration**

The Input/Output blocks must be configured to drive the segments, backplane, and to receive data for decoding. The segment and backplane IOBs are configured as outputs. Inputs are configured for data ports DA0-DD0, DA1-DD1, up to DA5-DD5. The IOBs are considerably less complex than the CLBs, having interface functionality rather than Boolean logic functionality. Each IOB is capable of being programmed as input, output, bidirectional, with HIGH-Z output, and registered input. Individual or composite I/O functions may be selected. Figure 11a shows an output buffer, the input of which is driven from net AO. Net AO is driven from the X output of the CLB featured in Figure 10. The designer has some control over the placement of IOBs around the perimeter of the LCA device, and can use the BLKMOVE commands to optimize pad layout for the best printed circuit design. Figure 11b shows an IOB that has been configured to receive data. The buffer is an input driving net DA0_.

![Image](image)

**XACT Supports Design Rule Checking**

During the design of the LCD decoder driver circuit the Design Rule Checker (DRC), was invoked to verify that no fundamental design rules were being violated. Errors can easily occur, especially for the uninitiated user. Errors such as two CLB outputs driving one net are usually caught dynamically. Also, a net listing of inputs that are not driven by an output would constitute an error. A general DRC run will list all design violations, errors and warnings. Warnings such as an assigned CLB output that is not connected to a net. This information can be sent to a line printer and the resulting list of Errors and Warnings can be used for design correction. Invoking DRC will check blocks, interconnect and nets. Also, prior to using the MAKEBITS command (for the eventual MAKEPROM) software, the DRC is invoked to trap any possible design violations. Of course, the design rule checker does not screen the design for logic function integrity. An additional software package is available in P-SILOS™ as a logic, and timing simulator. Inputs may be activated by HIGH, LOW, HIGH-Z levels etc., while output logic levels may be listed during the simulation run.

**Conclusion**

The design was modified for a decimal decoder display driver. Figure 12 shows the modifications necessary to each segment decoder. The choice of a latched version of the display driver was developed as an alternative to the registered type. In each registered CLB, the option was changed for a latched option. By removing the backplane oscillator and making the net BPLNE an input which is driven HIGH or LOW, high efficiency LED displays of common anode or cathode may be driven. The designs developed are as follows:

- XDES01.LCA REGISTERED HEX DECODER DRIVER.
- XDES02.LCA REGISTERED DEC DECODER DRIVER.
- XDES03.LCA LATCHED HEX DECODER DRIVER.
- XDES04.LCA LATCHED DEC DECODER DRIVER.

These designs are available as bit patterns for programming EPROMs on request.

The Print World of the design DES01.LCA shows the placement of CLBs, IOBs and the routing for the final design. This can be used as a reference for wiring the device into a circuit. Pin 1 is shown at the top center of the diagram and is the GND connection. The pins are numbered counter-clockwise from that reference pin. For example DB3 is connected to pin 2 and D2 connected to pin 3 etc.
M2018 Provides Decoding for Six-Digit, Seven-Segment Liquid Crystal Display

**LCD Seven-Segment Display Driver in LCA Binary Coded Decimal**

<table>
<thead>
<tr>
<th>BINARY ENCODED INPUT</th>
<th>SEGMENT LABEL</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>LSB</td>
</tr>
<tr>
<td>HEX. DA DB DC DD</td>
<td>a</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>1</td>
</tr>
<tr>
<td>A</td>
<td>0</td>
</tr>
<tr>
<td>B</td>
<td>1</td>
</tr>
<tr>
<td>C</td>
<td>0</td>
</tr>
<tr>
<td>D</td>
<td>1</td>
</tr>
<tr>
<td>E</td>
<td>0</td>
</tr>
<tr>
<td>F</td>
<td>1</td>
</tr>
</tbody>
</table>

**BCD to Seven-Segment Decoder**

The table below shows the decoding function required for a BCD to seven-segment hexadecimal display. A logic one represents an illuminated segment.
Figure 12. Liquid Crystal Display Decoder Driver
Abstract
Counters are used in many logic systems to control and synchronize events. Essentially, counters have one thing in common, they are all state machines. State machines, unlike basic combinational functions, require registers with feedback. The design creates an output that is a function of the previous state of the registers in the machine, and in some cases a function of other combinational inputs as well. Listed below are some of the systems that would use various types of counters.

- Direct Memory Access (DMA) Controllers
- Video RAM Refresh
- Dynamic RAM Control Refresh Counters
- Event timing
- Sequence Controllers
- Disc Controllers
- Status Sequencers

The type of counter chosen will depend upon the application. The simplest type of counter would be a free-running type as used for refreshing DRAM or Video RAM. Counter types vary, depending on application from the simple free-running type to loadable binary up/down counters which would be used in applications such as DMA control.

To design efficient counters in the LCA device, designers must consider the desired performance while keeping in mind the available logic and interconnection resources.

Familiarization with the different counter types and their characteristics will enable designers to choose the best counter for a specific application.
LCA Counter Applications
Chris Jay and Karen Spesard

Introduction

The LCA device has an architecture that is very well suited to the development of some counters. Designers already familiar with state machine applications in Programmable Logic Devices (PLDs) will probably be familiar with how to design counters in Programmable Array Logic (PAL®) and/or Programmable Logic Arrays (PLA). The differences between the structure of the PLA or PAL device and the Monolithic Memories' Logic Cell™ Array (LCA) impose both restrictions and freedoms in certain types of state machine design.

Ample width of the PLD "AND" gate means that counter depth can be limited only by the number of registers in the device. This applies especially in the PAL24X family that is specifically designed for applications in high-performance binary counting. In the LCA device, the maximum number of Boolean inputs to any CLB is four. This limiting factor is compensated by the high number of CLBs present in the device architecture. The design philosophy used in an LCA device for developing state machines is different from that of a PLD, but not less effective. Parallel counter architecture, and lookahead-carry techniques can be employed to create machines capable of medium performance.

Counters Using Shift Registers

The type of state machine well suited to an LCA device is based on a shift register. These types may be subdivided into different categories. In each state machine, there are “n” general registers, and the number of states that can be reached vary with counter type. The number of useable states are listed below with the counter type:

1) Johnson counters, 2^n states.
2) Linear feedback shift registers, with 2^n - 1 states.
3) Modified linear feedback shift register, with 2^n states.

These state machines are based on shift registers using the absolute minimum amount of feedback, and this is applied only to the least significant register in the chain. The CLBs may be located at close proximity in the LCA device and benefit from the smallest propagation delays provided by local interconnection. The disadvantage of the shift register structure is the inability to count through the conventional binary sequence. This might or might not be of any concern, depending on the system application.

The Johnson Counter

All of the states of a six-bit Johnson counter are listed in Table 1. The "D"-type register chain shown in Figure 1 illustrates the schematic diagram of the circuit. The output from Q0 feeds directly to D1, and Q1 to D2, and so on. If these registers are configured in adjacent CLBs, direct interconnect can be used to link each one. The output of the final register Q5 is inverted and fed back to the D0 input of the first register. If the entire structure is configured in a column or row in the LCA device, a long line should be used to convey the feedback signal back to the D0 input of the least significant register. Minimum propagation delay is achieved by using long line interconnect. The advantage gained with the small propagation delay of direct short interconnections between adjacent CLBs is not lost by the use of this long feedback path.

The counter design shown in Figure 1 uses six registers and the maximum number of states reached is 12, two times the number of registers. A binary counter with six registers could reach sixty-four individual states but would need combinational feedback to each register. Feedback propagation delay could degrade the potential clocking speed of the counter. The Johnson counter, with its decreased number of states, should be used whenever maximum operational performance is needed.

<table>
<thead>
<tr>
<th>STATE</th>
<th>Q0</th>
<th>Q1</th>
<th>Q2</th>
<th>Q3</th>
<th>Q4</th>
<th>Q5</th>
<th>HEX</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>3</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1F</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>3F</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>3E</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>3C</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>3B</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>30</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>20</td>
</tr>
</tbody>
</table>

Table 1. Truth Table of the Johnson Counter

Figure 1. Johnson Counter

PAL® is a registered trademark of Monolithic Memories.
Logic Cell™ and XACT™ are trademarks of Xilinx, Inc.
P-Silos™ is a trademark of SimuCad Corporation.
IBM® is a registered trademark of International Business Machines Corporation.
PC®, PC-AT®, and PC-XT™ are trademarks of International Business Machines Corporation.
**Linear Feedback Shift Register**

Figure 2 shows a modification to the Johnson counter. In this three-bit counter, six states are reached. The exclusive NOR feedback from register outputs Q1 and Q2 gives a HIGH input to D0 when both are HIGH or LOW. Again the design is based on a shift register, and this time the feedback is applied to the least significant register in the chain. The Linear Feedback Shift Register or LFSR shown in Figure 2 is implemented in three CLBs for small state machine designs. CLB placement and routing could be optimized for speed and performance. The LFSR counter would have a “stuck” state if all of the registers were set to a logic HIGH. The feedback input to D0 would remain HIGH and the XNOR inputs from Q1 and Q2 would remain stuck at a logic HIGH. The device has $2^n - 1$ states because in normal counting the “stuck” state cannot be entered. Table 2a shows the sequence and truth table of a three-register, free-running LFSR.

![Figure 2. Linear Feedback Shift Register (LFSR)](image)

**Modified Linear Feedback Shift Register**

The “stuck state” is included in the truth table shown in Figure 2b. If after the count of 3, the state machine could be modified with gating to accommodate the “stuck state” of 7, then an additional state could be used. Shifting a HIGH rather than a LOW into the least significant register would generate state 7, and all of the possible states could be reached. Table 2b shows the new entry in the truth table, and the Karnaugh map in Figure 3b shows the state assignment entry. For example, the map location Q0 = 0, Q1 = Q2 = 1 is the binary code 6. The State Diagram of the counter (Figure 3a), which is derived from the truth table (Table 2b), shows the sequential flow of each state into the next. From information in the State Diagram and State Assignment Map, a State Excitation Map may be developed as shown in Figure 3c. The next state, or excitation state from STATE 6 in Figure 3a is STATE 5. The corresponding entry of 6 in the Assignment Map is replaced by 5 in the Excitation Map and represents the transition from 6 to 5. Figure 3c is developed into Figure 3d by converting the entries to binary notation and placing the condition of the least significant bit into the Karnaugh map shown in Figure 3d. Minimization gives a Boolean equation:

$$Q_0 := ~Q_1·Q_2 + Q_0·Q_2 + ~Q_0·Q_1·Q_2$$  \hspace{1cm} (1)$$

Equation (1) is the functional input to the least significant register in the chain. The other registers in the chain require only the direct inputs from the preceding registers, so no additional minimization is required. Figure 4 shows the final gate implementation which can be incorporated into CLB 1 replacing the XNOR gate.

![Figure 3a. State Diagram for Modified Linear Feedback Shift Register](image)

The advantages of using every possible state in the counter avoids the possibility of a stuck state which, if entered, will prevent the entire design from functioning.

A very important consideration of the LFSR in CLB-intensive designs is the ability to use IOB registers in the counter. While the IOBs have no logic functionality they do have registers. The LFSR is based on the shift register, so if CLB resources run out, IOBs could be used.

<table>
<thead>
<tr>
<th>COUNT</th>
<th>Q0</th>
<th>Q1</th>
<th>Q2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**Table 2a. Truth Table of a Linear Feedback Shift Register**

<table>
<thead>
<tr>
<th>COUNT</th>
<th>Q0</th>
<th>Q1</th>
<th>Q2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**Table 2b. Truth Table of a Modified Linear Feedback Shift Register**

<table>
<thead>
<tr>
<th>COUNT</th>
<th>Q0</th>
<th>Q1</th>
<th>Q2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**Table 2c. Truth Table of a Modified Linear Feedback Shift Register**

**Figure 3b. State Assignment Map**

**Figure 3c. State Excitation Map**

**Count Q0 Q1 Q2**

<table>
<thead>
<tr>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>
From the state excitation map, the condition of the least significant register Q0 is entered. Minimization gives the equation required for Q0 IN as a Boolean function of Q0, Q1 and Q2. When implemented, the modified LFSR will count through all states.

If this circuit is used to replace the exclusive NOR gate in CLB1 of Figure 2 then the count shown in Table 2b will be realized enabling a count through 2^n states.

**Provisions for Deeper Counting**

Deeper counters may be made from cascading 3-bit LFSRs. The same three-bit module may be repeated any number of times but the original circuit needs modification. When cascading counters it is essential to use an ENABLE or CARRY input to the next stage. The Karnaugh maps, shown in Figures 3b and 3c, represent State Assignment and State Excitation, respectively. The Assignment Map can be considered as identifying HOLD conditions while the Excitation Map indicates count activity. The Karnaugh map in Figure 5 merges the information contained in both Figures 3b and 3c, and an additional ENABLE input qualifying COUNT and HOLD activities. The registers will count if EN is HIGH and HOLD when it is LOW. The Karnaugh map in Figure 5 was developed to derive the Boolean equation for the least significant register in the chain. The other registered cells need modifying to incorporate an enable input. Table 3 shows a truth table of the current register contents Qn with the EN input B and the input from the next least significant register A. The required output Qn+1 is given as a HOLD condition if B = LOW, and when HIGH, data from the A input will be clocked into the register. For each of the three registers, an EN input will enable count activity to allow cascading of 3-bit counter modules.

General shift register with count enable. A = input from the next least significant register and B = enable count. Q is the state of the internal register. This Karnaugh Map has been developed from Table 3.

\[ Q := Q^*B + Q^*A + AB \]
**Propogation Carry**

To link counter modules together, it is necessary to pass a count enable signal from one module output to the next input. Figure 7 shows the configuration of CLBs 1 to 3 linked to CLB 4, which is configured as a carry generator providing an enable output to the next modified LFSR. The next counter module will not increment until it receives an assertion on its count enable input. Figure 8 shows the Karnaugh map from which the lookahead-carry output was generated. The penultimate count in the sequence, as shown in Figure 2a is two. This count is decoded in the CLB 4 where the registered output is passed to the next counter module and delayed by one clock cycle. The concept of decoding the penultimate count, and delaying it by one clock cycle provides a fast method for propagating the lookahead carry signal. If the ultimate count is decoded by a combinational circuit, the next counter module will have to wait for the carry to propagate through logic gates before the next clock pulse can be applied. Registering the next-to-last count allows premature carry propagation, providing the carry enable to be set up prior to the next clock edge.

Figure 9 shows two identical LFSRs linked by a carry generator's CLBs 5, 6 and 7 and a propagate carry configuration in CLB 8. The propagate carry circuit is a combinational circuit that enables the generated carry output, from CLB 4 to the ENB output, as shown in Figure 9. A third set of modified LFSRs may be added if a synchronous nine-bit counter is required.

Applications for a nine-bit counter might include a refresh counter for 256 K Dynamic RAMs. The EN input to CLB 1 can be used to hold off counter increment activity. If an LFSR with 2^n - 1 states were used, then one row in the DRAMs would never get refreshed, so the modified LFSR would be the appropriate choice. Moreover, the count sequence is not important because it does not have to be a binary code, just as long as the DRAMs are refreshed at regular intervals for every row.

Another application might be as a counter in a video controller. The system could count through the required states, and additional gating could be used to generate line and frame sync pulses at certain states during the count sequence.

![Diagram of counter configurations](image)

**Figure 7.**

**Figure 8.** To Enable a Second Stage as a Synchronous Counter a Carry Output Must Be Generated from the First Three Registers. The Enable Output from CLB 4 Is Decoded from the Penultimate Count and Clocked Through the Register. When the Ultimate Count Is Reached the Enable Input to the Next Stage Is Asserted.
LCA Counter Applications

Figure 9. Two LFSRs Are Linked by the Propagate Enable Logic Contained in CLB4. CLB5, 6 and 7 Contain the Same Logic as CLB1, 2 and 3 to Create a Modulo 6 Counter with Sixty-four States. Propagate Enable is Decoded from the Ultimate Count of the Second LFSR Stage. It Can Be Used as the Enable Input to a Third LFSR Stage to Make a 9-Bit Counter.

Design of a Four-Bit LFSR

If a four-bit free-running counter was required for standalone count applications, then a design can be realized using four CLBs. The truth table for a modulo four modified LFSR is shown in Table 4. The state assignment map in Figure 10 is developed into the state excitation map shown in Figure 11. The least significant bit of the hexadecimal data is entered into the Karnaugh map as shown in Figure 12. Minimization is performed to develop the equation for the least significant register input. The actual circuit implementation is complete in four CLBs as shown in Figure 13.

The Binary Counter

The number of states available in a binary counter is $2^n$, making it one of the most register-efficient types of counters. The three main categories of binary or weighted counters are ripple, ripple-carry, and lookahead-carry. As the amount of "look-ahead" logic decoded at each counter stage increases, the performance of the binary counter also increases. As a result, lookahead-carry counters are the fastest of the three categories of binary counters. On the other hand, the more "look-ahead" logic there is, the more decoding is needed. Increased decoding requires extra logic and routing resources which may be disadvantageous if these resources become scarce.
LCA Counter Applications

The Ripple Counter

Ripple counters are asynchronous in nature and do not generate carry signals. When the output of each counter stage clocks the next stage on the negative clock transition, a ripple effect is induced (thus the name). A schematic representation of a six-bit ripple counter is shown in Figure 14. One of the benefits of a ripple counter is that it requires few resources. Only one CLB per counter bit is needed to implement the counter and routing is simple regardless of the counter length. The tradeoff for this simplicity, however, is that ripple counters cannot be modified to be loadable or up/down which restricts their operation to be free-running, and they have lower performance.

The overall performance of a ripple counter degrades with each counter bit by one CLB delay time. This can be shown by the equation below:

\[
\text{Ripple Counter} = N \cdot (\text{Clock to Output Delay})
\]
\[
\text{Clock Period}
\]

where \( N \) = the number of ripple counter flip-flops

The overall counter clock period must therefore be greater than or equal to the total cumulative CLB delay.

The Ripple-Carry Counter

The ripple-carry counter is similar to the ripple counter. The ripple-carry counter has carry signals, however, whereas the standard ripple counter does not. Each carry signal propagates to the next counter stage to produce the counting sequence. This cascaded connection is called ripple-carry.

The ripple-carry counter differs from the ripple counter in the respect that it is synchronous in operation. Because of this, the ripple-carry counter provides more reliable operation and better performance. Performance still degrades with each additional counter stage though, due to the inclusion of combinational logic from the previous counter stage. Like the ripple counter, the ripple-carry counter requires only one CLB per counter bit and is easily cascadeable.

One example of a four-bit binary ripple-carry counter is shown in Figure 15. Here, a modulo-16 counter with count enable (CE) and reset is built with four CLBs and three levels of ripple logic. The same counter could be designed with two levels of ripple logic, if the two-input AND gate in CLB2 becomes a three-input AND gate, and the signals CE and Q0 from CLB1 were carried over to CLB2 and ANDed with Q1.

Another four-bit counter, this time with parallel enable (load), count enable, and reset, is shown in Figure 16. Here, just two ripple levels of logic were designed in, using two C8BCP MACROS from Monolithic Memories' Macrocell Library. Six CLBs, two more than the previous four-bit counter, were used in this design because of the addition of parallel enable circuitry and the reduction of ripple-carry logic levels. The Karnaugh map corresponding to the registered CLBs is shown in Figure 17.
Sometimes a designer will want to carry-over a counter implementation he or she was previously using to the LCA device. Consider an eight-bit ripple-carry counter with reset, built with two typical 74-series TTL devices: two 74-161's shown in Figure 18. Notice that the data bus as well as the LD and CET pins are not being utilized. This is wasteful. Obviously, the two 74-161 macros, available from Monolithic Memories' LCA Device Macrocell Library, requiring sixteen CLBs would also be inefficient. An equivalent counter, shown in Figure 19, requires only ten CLBs. It is built with two C8BC-rd MACROS and one C4BC-rd MACRO and contains three ripple-carry delay levels. It can be seen that implementing just the counter functions desired, instead of including additional functions not required in the counter, allows designers more control over their design. The designer can then better optimize the design for speed and performance while minimizing CLB and routing resources.

![Schematic of a 4-Bit Ripple-Carry Counter](image)

**Figure 15.** Schematic of a 4-Bit Ripple-Carry Counter. Although the Ripple-Carry Counter is Synchronous, the Carry Input to the Next Stage is Conveyed Through Combinational Logic. The Propagation Delay Due to this Logic Must be Taken into Account.

![Schematic of a 4-Bit Ripple-Carry Counter](image)

**Figure 16.** Schematic of a 4-Bit Ripple-Carry Counter. With Parallel Enable, Count Enable, and Reset, this Counter Only Contains Two Levels of Ripple-Carry Logic.
The Lookahead-Carry Counter

When the performance of binary ripple and ripple-carry counters is not adequate, synchronous binary lookahead-carry counters can be a solution. A lookahead-carry counter incorporates all the previous counter outputs into a single lookahead-carry signal for each counter stage. This logic reduction minimizes the overall delays of the design which makes the performance of lookahead-carry counters the highest among binary counters.

With lookahead-carry counters, the complexity of the design increases with each counter bit as the decoding inputs become ever wider. As a result, these counters usually need more CLBs and routing resources to implement than other binary counters. The equations which characterize an n-bit lookahead-carry counter with count enable and parallel enable are listed below:

\[
\begin{align*}
Q_0 &= \left( (\overline{PARENA} \cdot CE) \cdot Q_0 \right) + (PARENA \cdot D0) \\
Q_1 &= \left( (\overline{PARENA} \cdot CE) \cdot Q_0 \right) + (PARENA \cdot D1) \\
Q_2 &= \left( (\overline{PARENA} \cdot CE) \cdot Q_1 \right) + (PARENA \cdot D2) \\
& \quad \ldots \\
Q_n &= \left( (\overline{PARENA} \cdot CE) \cdot Q_{n-1} \right) + (PARENA \cdot Dn)
\end{align*}
\]

To decrease the complexity of the counter, one or more of the control signals can be removed.

For a ten-bit lookahead-carry counter with reset, a minimum of fourteen CLBs are needed as shown in Figure 20. The logic for the counter was partitioned as follows:

\[
\begin{align*}
\text{CLB 1} & \quad Q_0 := CE \cdot Q_0 \\
\text{CLB 2} & \quad Q_1 := (CE \cdot Q_0) \cdot Q_1 \\
\text{CLB 3} & \quad Q_2 := (CE \cdot Q_0 \cdot Q_1) \cdot Q_2 \\
\text{CLB 4} & \quad Q_02 = Q_0 \cdot Q_1 \cdot Q_2 \cdot CE \\
\text{CLB 5} & \quad Q_3 := Q_02 \cdot Q_3 \\
\text{CLB 6} & \quad Q_4 := (Q_02 \cdot Q_3) \cdot Q_4 \\
\text{CLB 7} & \quad Q_5 := (Q_02 \cdot Q_3 \cdot Q_4) \cdot Q_5 \\
\text{CLB 8} & \quad Q_35 = Q_3 \cdot Q_4 \cdot Q_5 \\
\text{CLB 9} & \quad Q_6 := (Q_02 \cdot Q_35) \cdot Q_6 \\
\text{CLB 10} & \quad Q_36 = Q_3 \cdot Q_4 \cdot Q_5 \cdot Q_6 \\
\text{CLB 11} & \quad Q_7 := (Q_02 \cdot Q_36) \cdot Q_7 \\
\text{CLB 12} & \quad Q_8 := (Q_02 \cdot Q_36 \cdot Q_7) \cdot Q_8 \\
\text{CLB 13} & \quad Q_38 = (Q_36 \cdot Q_7 \cdot Q_8) \\
\text{CLB 14} & \quad Q_9 := (Q_02 \cdot Q_38) \cdot Q_9
\end{align*}
\]

The first seven bits of the counter were decoded in a similar fashion to the counter in Figure 19. The next three bits continue to minimize the amount of ripple-carry logic implemented to make it a lookahead-carry counter.

When routing a design such as this in the LCA device, it is best to place the CLBs lengthwise. Then, if the high fan-out output signals for Q02 and Q36 CLBs can be routed through "long line" interconnects, the routing-dependent delays can be reduced allowing the counter to perform at its maximum potential speed.
Figure 19. An Efficient Implementation of an 8-Bit Counter with Reset. This Alternative Performs Only the Desired Function While Maximizing CLB and Routing Utilization.

Figure 20. Schematic of a Synchronous Counter with Reset as in Figure 19, but with Lookahead-Carry Logic. As More Counter Bits Are Added, the Design Becomes Increasingly Complex Due to Wider Gating.
The Up/Down Counter

The up/down counter can be a very useful device. For instance, status counters or address counters employed in DMA systems, dual slope integrators, and delta modulation systems usually use up/down counters. In operation, an up/down counter will count UP when all previous counter bits are HIGH and will count DOWN when all previous counter bits are LOW. Thus, in an up/down counter, each register output in a CLB will toggle when:

- Q0 through Qn-1 are HIGH and the counter direction is UP, or
- Q0 through Qn-1 are LOW and the counter direction is DOWN.

This translates to:

\[
Q_0 := Q_0 \oplus \left( (Q_{n-1} \cdot Q_{n-2} \cdot \ldots \cdot Q_1 \cdot Q_0 \cdot \text{UP}) + \left( /Q_{n-1} \cdot /Q_{n-2} \cdot \ldots \cdot /Q_1 \cdot /Q_0 \cdot /\text{UP} \right) \right).
\]

Design of the counter can become more complicated by adding new features to it such as enable, reset, or load (parallel enable). Because of this, it is best to limit the number of control signals which would require more complex logic. For example, a counter which only needs to be reset during initialization will not need additional reset capability since all registers are reset upon initialization of the LCA device.

Simple ripple-carry binary up/down counters require \(2 \cdot N - 4\) CLBs for implementation where \(N\) is the number of counter bits. For example, eight CLBs would be needed for a six-bit up/down counter and twenty-eight CLBs would be needed for a 16-bit up/down counter. An example of a six-bit ripple-carry up/down counter configured in CLBs is given in Figure 21.

The general equations used for this ripple-carry counter design were derived from equation 3 and are as follows:

<table>
<thead>
<tr>
<th>Running Total of CLBs</th>
<th>Equations</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>(Q_0 := /Q_0)</td>
</tr>
<tr>
<td></td>
<td>(C_{2X} = \text{UP} \cdot Q_0 \cdot Q_1)</td>
</tr>
<tr>
<td>2</td>
<td>(Q_1 := Q_1 \oplus (\text{UP} \cdot Q_0 + /\text{UP} \cdot /Q_0))</td>
</tr>
<tr>
<td></td>
<td>(C_{2Y} = \text{UP} \cdot /Q_0 \cdot /Q_1)</td>
</tr>
<tr>
<td>3</td>
<td>(Q_2 := Q_2 \oplus (C_{2X} + C_{2Y}))</td>
</tr>
<tr>
<td>4</td>
<td>(Q_3 := Q_3 \oplus (Q_2 \cdot C_{2X} + /Q_2 \cdot C_{2Y}))</td>
</tr>
<tr>
<td>5</td>
<td>(C_{3X} = C_{2X} \cdot Q_2)</td>
</tr>
<tr>
<td></td>
<td>(C_{3Y} = C_{2Y} \cdot /Q_2)</td>
</tr>
<tr>
<td>6</td>
<td>(Q_4 := Q_4 \oplus (Q_3 \cdot C_{3X} + /Q_3 \cdot C_{3Y}))</td>
</tr>
<tr>
<td>7</td>
<td>(C_{4X} = C_{3X} \cdot Q_3)</td>
</tr>
<tr>
<td></td>
<td>(C_{4Y} = C_{3Y} \cdot /Q_3)</td>
</tr>
<tr>
<td>8</td>
<td>(Q_5 := Q_5 \oplus (Q_4 \cdot C_{4X} + /Q_4 \cdot C_{4Y}))</td>
</tr>
</tbody>
</table>

To build a simple ripple-carry 16-bit up/down counter, this algorithm would be continued:

\[
Q_n := Q_n \oplus (Q_{n-1} \cdot C_{n-1X}) + (/Q_{n-1} \cdot C_{n-1Y})
\]

where:

\[
C_{n-1X} = C_{n-2X} \cdot Q_{n-2}
\]
\[
C_{n-1Y} = C_{n-2Y} \cdot /Q_{n-2}
\]
\[
C_{n-1X}, C_{n-1Y} \geq C_{2X}, C_{2Y}
\]

\[
C_{2X} = \text{UP} \cdot Q_0 \cdot Q_1
\]
\[
C_{2Y} = /\text{UP} \cdot /Q_0 \cdot /Q_1.
\]

The test file that was used to verify the logic of the six-bit up/down counter in Figure 21 is shown in Figure 22. It was generated by running the SIMGEN program included with the XACT Development System. This file, with a .DAT extension, was modified to include the desired input test vectors which would be executed. Once in the P-Silos™ simulator, "IN <filename>.DAT" is entered. This command automatically inputs the netlist to the simulator. Finally, a time period is entered which informs the simulator of the length of time the simulation should run. For instance, "SIM 0 10000" could be entered. The outputs will be plotted in a table format and will list the signals specified.

An alternative method for designing up/down counters is to use lookahead-carry logic, based on equation 3. This performance-driven method, however, is quite CLB intensive due to the wide gating of input signals required for implementation. Thus, for a six-bit lookahead-carry up/down counter, sixteen CLBs would be needed, whereas for the six-bit ripple-carry up/down counter, ten CLBs were needed. Therefore, it is advantageous to use the lookahead-carry method when maximum performance is needed.

A design of an n-bit ripple-carry up/down counter that can synchronously RESET and LOAD new values into the counter also becomes more difficult. From the general expression below, derived from state tables and Karnaugh maps, any up/down counter can be designed.

\[
Q_n = (/\text{RESET} \cdot \text{LOAD} \cdot D_n) \oplus (\text{RESET} \cdot \text{LOAD} \cdot \text{UP} \cdot Q_{n-1} \cdot \ldots \cdot Q_1 \cdot Q_0)
\]

where \(\text{RESET}\) and \(\text{LOAD}\) are active HIGH.

There are many ways to design up/down counters. The lookahead carry method, though it consumes a great deal of resources, usually enhances performance. The best way to design the up/down counter for systems that do not require high speed, is to use the ripple-carry method. This method is usually the most straightforward and requires the least number of resources.
Summary

Many ways exist for implementing counters in the LCA device. The ideal counter design for a specific application depends on the desired performance and the available logic and interconnection resources. See Table 5. For example, three main types of counters, Johnson, Linear Feedback Shift Register, and binary counters were discussed. Each of these counters utilizes different features of the LCA device but each can be optimized to perform a required function. Moreover, it was seen that by implementing only the logic necessary for a required function, resource efficiency was increased and by implementing more lookahead-carry logic or using LFSRs, performance was increased.
<table>
<thead>
<tr>
<th>COUNTING METHOD</th>
<th>COUNTER TYPE</th>
<th>MODULO</th>
<th>CLB EFFICIENCY</th>
<th>ROUTING EFFICIENCY</th>
<th>PERFORMANCE</th>
<th>ADVANTAGES/ DISADVANTAGES</th>
</tr>
</thead>
<tbody>
<tr>
<td>Non-binary</td>
<td>Johnson</td>
<td>$2^n$</td>
<td>Poor</td>
<td>Excellent</td>
<td>Excellent with low modulo</td>
<td>High performance, easy routing, Glitch-free decoding, Low-register efficiency</td>
</tr>
<tr>
<td></td>
<td>Linear feedback shift register or modified LFSR</td>
<td>$2^n - 1$ or $2^n$</td>
<td>Good</td>
<td>Very good</td>
<td>Very good decreases with increasing modulo</td>
<td>Good performance at high modulos</td>
</tr>
<tr>
<td>Binary</td>
<td>Ripple</td>
<td>$2^n$</td>
<td>Excellent</td>
<td>Excellent</td>
<td>Poor</td>
<td>Low resources, easy routing, but slow and asynchronous</td>
</tr>
<tr>
<td></td>
<td>Ripple-carry</td>
<td>$2^n$</td>
<td>Very good</td>
<td>Good</td>
<td>Good</td>
<td>Good general binary counters</td>
</tr>
<tr>
<td></td>
<td>Lookahead carry</td>
<td>$2^n$</td>
<td>Good but decreases with increasing modulo</td>
<td>Good but decreases with increasing modulo</td>
<td>Good for high-performance binary counters</td>
<td>Highest performance binary counter requires more CLB and routing resources</td>
</tr>
</tbody>
</table>
Time Division Multiplexing with the LCA Device

C.B. Lee and Theresa Shafer

Abstract

High-speed data communication lines are efficiently utilized when low-speed signals are time division multiplexed onto high-speed lines. Time division multiplexing requires data buffering, rate adaption and data selection. The data selection fits into a single CMOS Logic Cell™ Array (LCA device). The LCA device is designed and optimized using the FutureNet® schematic capture package, Monolithic Memories' automatic place and route software, and the XACT™ Design Editor System.

PAL® is a registered trademark of Monolithic Memories, Inc.
Logic Cell™, XACT™ and APR™ are trademarks of Xilinx, Inc.
FutureNet® is a registered trademark of FutureNet Corporation.
DASH™ is a trademark of FutureNet Corporation.
P-SILOS® is a registered trademark of SimuCad Corporation.
**Introduction**

The Logic Cell Array (LCA device) implements a multiplexer and counter used in time division multiplexing. With the device's flexible I/O pins, the multiplexer and counter are implemented into a single CMOS device. This application note covers time division multiplexing and the design of a multiplexer and counter. Additional information on how to design with an LCA device can be found in the LCA design methodology chapter in Monolithic Memories' LCA Design and Applications Handbook. For programming the LCA device, refer to "Configuring the LCA Device", Monolithic Memories' Application Note 182.

**Principles of Multiplexing**

Multiplexing efficiently utilizes data communication lines by combining multiple low-speed signals into a single, high-speed line. The two methods of performing multiplexing are Time Division Multiplexing (TDM) and Frequency Division Multiplexing (FDM). TDM divides the transmission bandwidth into equal time slots where each input signal is assigned one time slot per time cycle. Once assigned, that time slot is not used by any other input. Figure 1 shows a multiplexer combining three low-speed signals into one high-speed line. Terminal A transmits during the first time slot, B transmits during the second time slot, and C transmits during the third time slot. This sequence is repeated every time cycle. FDM, on the other hand, divides the frequency spectrum among logical channels where each channel has full bandwidth of its assigned frequencies. Analog systems usually use FDM.

![Figure 1. Time Division Multiplexing](image)

There are many classes of TDMs including bit interleave, character interleave, statistical TDM, and T1 multiplexers. In bit interleaved TDM, each input is assigned to one time slot. Each time slot's length is one bit. Character interleaved TDM is similar to bit interleave, except that each time slot represents one character. Statistical multiplexing assigns the bandwidth into unequal slots where only the active incoming lines are assigned slots. The slots are of variable length, so each input is assigned the amount of bandwidth needed. The T1 standard specifies twenty-four 64 kbps channels multiplexed on a 1.544 Mbps high-speed link.

**Data Selection/Time Slot Assignment**

To transmit data from terminal A in the first time slot as shown in Figure 1, data buffering, rate adaption and data selection must be performed. Data buffering and rate adaption are required since the rates of the lines to be multiplexed are slower than the high-speed link. A serializing FIFO or shift register can implement the required buffering. Rate adaption is performed by a clock/shift scheme tailored to the exact application. Once buffered, the data must be selected in the proper order. Several methods can be used for data selection; one method is a 32-to-1 multiplexer. To implement sequential selection of input lines, an on-board counter selects the multiplexer's output. However, for random selection needed in statistical multiplexing, more flexibility is needed. A 2-to-1 multiplexer provides this flexibility by selecting between the counter and random selection inputs.

**Comparison of Design Methodologies**

The 32-to-1 multiplexer and counter design can be implemented in several ways. Briefly, we will evaluate discrete logic, PAL and LCA device implementations.

For this design, thirty-eight inputs, five registers, and one output are required. Conventional PLD devices do not meet this large I/O requirement. A single PLD device is not suited for this specific application because flexible I/O and buried registers are not supported. Instead, the design must be divided into four sections. The counter fits in a PALC16R6Z device and the 32-to-1 multiplexer requires three PALC20L8Z devices.

Since a large 32-to-1 multiplexer is not available as a discrete part, it must be built using smaller multiplexers. The total chip count, using discrete logic, is five devices: two 74AS850s, two 74ALS257s and one 74AS867. A combination of PAL devices and discrete logic devices is possible, however, it is also a multiple chip solution.

Monolithic Memories' LCA device is a high-density programmable CMOS circuit with flexible I/Os. It has forty pins which are user-defined as either inputs, outputs, or bidirectional. The LCA device meets the I/O requirement for this design. Since the LCA circuit allows multiple logic levels, implementing the counter does not use up output pins. Moreover an LCA device enables the 32-to-1 multiplexer with counter to be implemented in a single low-power device.
Detailed LCA Design

The M2064 LCA device in a 48-pin DIP is used in this design, although both PLCC and PGA packages are available. Eight of the forty-eight pins are reserved for programming, power, and ground, and the remaining forty I/O pins are available to the user. Table 1 shows the efficient use of the package pinout.

<table>
<thead>
<tr>
<th>PIN</th>
<th>DESCRIPTION</th>
<th>TOTAL PINS</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR(4:0)</td>
<td>External Address Inputs</td>
<td>5 inputs</td>
</tr>
<tr>
<td>CK</td>
<td>External Clock Input</td>
<td>1 input</td>
</tr>
<tr>
<td>LD</td>
<td>Counter Load Input</td>
<td>1 input</td>
</tr>
<tr>
<td>D(31:0)</td>
<td>32-to-1 Multiplexer</td>
<td>32 inputs</td>
</tr>
<tr>
<td>OUT</td>
<td>Data Inputs.</td>
<td>1 output</td>
</tr>
<tr>
<td></td>
<td>TOTAL I/O</td>
<td>40 pins</td>
</tr>
</tbody>
</table>

Table 1. 32-to-1 Multiplexer Pins

Figure 2 shows the block diagram of the 32-to-1 multiplexer and the counter. The select lines of the 32-to-1 multiplexer are either the address lines or the output of the counter. When LD is deasserted, the 5-bit counter sequentially selects each input. Asserting the LD signal loads the counter with the external addresses. It also selects the external address for the 32-to-1 multiplexer's select lines. This permits random input selection from the external address lines which supports statistical multiplexing.

Table 2. 32-to-1 Multiplexer Function Table

<table>
<thead>
<tr>
<th>INPUTS</th>
<th>OUTPUT</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>LD ADDR(4:0)</td>
<td>OUT</td>
<td>Counter as Select</td>
</tr>
<tr>
<td>0 XXXXX</td>
<td>D(CNT)</td>
<td>Address as Select</td>
</tr>
<tr>
<td>1 ADDR(4:0)</td>
<td>D(ADDR)</td>
<td>Load Counter</td>
</tr>
</tbody>
</table>

Figure 2. Block Diagram

The select signals for the 32-to-1 multiplexer are determined by the LD signal. When LD = 0, the counter selects the multiplexer's output. When LD = 1, the counter is loaded and the external address selects the output. Also, the LD asynchronously loads the 5-bit counter. Table 2 summarizes the device operation.

Entering the Design with FutureNet

The design was entered with FutureNet's DASH schematic capture package using high-level macros. Then the schematic capture file was translated into an LCA design file. The translation software, called PIN2LCA, partitions the design into CLBs and generates the equations for the CLBs' configuration. The translation software produces an unrouted LCA design file. This design file requires final placement of CLBs and interconnect routing which was performed using Monolithic Memories' APR software, an automatic place and route program. After the design is placed and routed, it was optimized with Monolithic Memories' XACT Design Editor System. The XACT system provides a graphic interface to manually optimize the CLB logic functions and connections.

The logic functions and interconnects of an LCA device are established with CMOS memory cells, so the array is never physically altered, although it is physically programmed. A programmable LCA device can be reconfigured for the prototype. In addition, it can be reprogrammed any number of times in the target system. With reconfigurable devices such as this one, the array can also be programmed on power-up, or whenever the design details need to be changed. For volume production, a hard-array version will be available.

The schematic entered in FutureNet's DASH is comprised of different components called from the macro library supplied by Monolithic Memories. The MB-1 and M4-1 macros are the multiplexers which implement the 32-to-1 multiplexer as shown in Figure 3. The 5-bit counter was built from INV, C16BPRD, XOR2, and FDM macros. Since the C16BPRD macro is only a 4-bit parallel-load binary counter, the XOR2 and FDM macros were added to form another bit which increased the length to five bits. The GMUX macro, a 2-to-1 multiplexer, selects between the counter and the external address lines.

To translate from FutureNet to LCA, the PIN2LCA program is invoked. This program generates an unrouted <filename>.LCA from the FutureNet's <filename>.PIN. The PIN2LCA software partitions the design into CLBs and generates each CLB's configuration.

The PIN2LCA performs logic reduction by eliminating unused logic to maximize CLB utilization. With this design, for example, C16BPRD's reset logic is not used, and PIN2LCA eliminates all the reset logic in the C16BPRD macro. Another means to maximize CLB utilization is by combining macro logic. At times, this combined logic results in a single CLB which implements logic from two different macros. For designs not utilizing all the CLBs, this logic reduction is not required and may actually hinder placement and delay tradeoffs. If it does produce delay problems, it is possible to edit the CLBs in XACT.
At this stage in the design flow, the PIN2LCA software can generate a P-SiLOS simulation file. Since the `<filename>.SIM` was generated from an unrouted LCA design file, the simulation only has unit delays and does not have actual routing delays. The simulation verifies the logic, but does not give any timing information. It may be necessary to make changes in DASH™ depending on the simulation results.

### Place and Route Using APR

Once the logic is finalized, the LCA design must be placed and routed. Monolithic Memories' APR software performs the final placement of CLBs and interconnect routing. The input to APR is an unrouted `<filename>.LCA`, and a routed LCA design file and report document are the outputs.

At first glance, the APR program seems cumbersome to apply to every application. However, it can be used to create an efficient design. While the software uses random placement, it does allow tailoring for specific requirements.

Initially, the multiplexer and counter design did not route completely. To achieve good placement and 100% routing completion, several things were tried. Some worked well while others did not. An overview of how 100% routing completion was achieved is explained below.

Since this design utilizes only 53% of the LCA device, delay is a larger concern than CLB utilization. In this case, placement is critical to achieve an efficient design with the desired delays. The ideal placement would be for the 5-bit counter and 2-to-1 multiplexer to be placed near the ADDR(4:0), CK, and LD signals. The four M8-1 macros should be near the 8-bit cluster of inputs. The remaining M4-1 macro should be placed near the OUT signal.

In FutureNet, the IOs are assigned pin numbers so that the signals are clustered into groups. These I/O assignments restrict the APR's placement of the signals and are found in the `<filename>.SCP`. Other restrictions and options are specified when invoking the APR software. The options, "-a", "-g", "-e", and "-k", tailor the placement for this specific design.

The APR's "-a" option specifies the depth of CLB logic levels which are considered connected. In this design, "-a2" was selected because the C16BPRD and M8-1 macros are implemented in two CLB logic levels.

The "-g" and "-e" options are related. The "-g" option specifies the number of CLBs that should be grouped together. The "-e" option determines the number of CLBs in a group which should be evaluated for all possible placements. Since the C16BPRD and M8-1 macros contain four to six CLBs, the options, "-e4" and "-g4", were used. This particular value was selected because it was the largest possible value which maintained the e=g relationship. Avoiding values where e<g insures as much as possible that the CLBs within each group are placed in the best possible arrangement. This maintains the groups' integrity.

The "-k" option specifies the number of shapes per group. By trial and error, "-k6" works well for this design. With "-k6", six of the best arrangements or shapes were saved for each group of CLBs. Every combination of shaped group is tried with all six other grouped shapes and evaluated for best placement. Generally, the larger values result in better placements, however, run-time grows exponentially. While larger values of "-k" were tried, they did not improve the placement significantly.

Running APR with these options and restrictions did not result in a 100% routed design. Therefore, more application-specific information was required. Noting that the APR software was not fully utilizing the high-level macro information, placement could still be optimized. The APR's report file shows that the CLBs which comprise C16BPRD or the M8-1 macros were not grouped together. Instead, the CLBs were randomly spread over the device. In a constraint file, `<filename>.CST`, CLBs from the high-level macros could be grouped together (see Appendix A). If necessary, the exact CLB placement could be specified in the same file.

To generate the constraint file, CLBs which implement each high-level macro were identified using the cross-reference file generated by PIN2LCA, `<filename>.CRF`. The `<filename>.CRF` file is organized into three cross-reference sections: macros, CLBs, and IOBs.

The macro cross-reference section identifies and assigns a hierarchical symbol number to each macro. The symbol number is used to generate the default CLB names.

```plaintext
ASSIGNED
SYMBOL NUMBER
\USER\THERESA\TDM.DWG(32)

Title: M8-1
```

The CLB cross-reference section of the `<filename>.CRF` contains the CLB names. For macros with multiple CLBs, the system assigns default names. The default CLB name consists of two parts. The first is the macro symbol number as specified in the macro section and the second number is the signal name. By grouping CLBs with related symbol numbers, all the CLBs for a given macro will be placed together.

```plaintext
CLB BD Name = '21-D03':
F = signal '21-D03', contains:
symbol '26-OR(2)', output signal = '21-D03'
symbol '26-AND(3)', output signal = '26-S0'
symbol '27-OR(2)', output signal = '21-D01'
symbol '26-AND(1)', output signal = '26-S1'
```

The IOB cross-reference section shows the IOB assignments. For this design, the assignments are those specified in the FutureNet's schematic.

```plaintext
IOB P30: Name = 'D13', Symbol = 'PIN(40)'
I = signal 'D13'
```
Optimizing the Design with Monolithic Memories' XACT Design Editor System

Monolithic Memories' XACT Design Editor System can increase resource utilization and performance by manually modifying the placement and routing. The XACT system provides a graphic interface to specify the CLB design. All CLB logic functions and connections can be optimized for the designs' needs. With XACT, the designer can partition the design and optimize the placement of logic blocks to gain the utilization and performance required.

The clock line routing was optimized to reduce clock skew. Using the clock buffer resources, the common clock is driven by the global clock buffer. To optimize internal routing, "long lines" were used for signals with large fanouts such as the select lines for the multiplexers and the LD signal. Use of the "long lines" minimizes the delay for these control signals. The "long lines" were selected by manually routing the signal net through the programmable interconnect points (PIPs).

On the device itself, implementing the 5-bit counter and 2-to-1 multiplexers requires ten CLBs; and the 32-to-1 multiplexer requires twenty-four CLBs, giving a total of thirty-four CLBs. This design utilizes 53% of the LCA device.

Summary and More Information

For time division multiplexing systems, data selection can be implemented in a single CMOS device. FutureNet's DASH schematic capture with Monolithic Memories' LCA macro library was used to implement a design in an LCA device. Placement of CLBs and signal routing were performed by Monolithic Memories' APR software. Optimization, which may be required to improve performance, can be done using Monolithic Memories' XACT Design Editor System. This is useful for placing and routing critical signal nets such as clock or control signals. More information can be found in P-SILOS, FutureNet, and LCA user guides and handbooks.

This design, developed with an LCA device, is available upon request. The FutureNet drawing, LCA design and bit pattern files can be provided for programming the LCA device in an EP-ROM. Please ask for design XDES07.LCA.
; CONSTRAINT FILE GROUPING MACROS IN BLOCKS

DEFINE GROUP CNT_GROUP
  3-T3 3-T2 CKB
  C4 C2 C3 C1 C0
  M3 M2;

DEFINE GROUP OUT_GROUP
  CLB1 45-D23;

DEFINE GROUP M1_GROUP
  47-S0
  19-S0 19-S1
  13-D03 13-D47;

DEFINE GROUP M2_GROUP
  47-S1
  15-S0 15-S1
  21-D03 21-D47;

DEFINE GROUP M3_GROUP
  27-S0 27-S1
  23-S0 23-S1
  36-S0 36-S1;

DEFINE GROUP M4_GROUP
  OUTM4
  42-S0 42-S1
  37-D47 37-D67
  39-S0;
Time Division Multiplexing with the LCA Device

$ Simulation file for design 'TDM.sim', type '2064N48-50'
$ Created by PIN2LCA Ver. 1.0.1 at 10:58:00 JUL 14, 1987
$ !INPUT TDM.sim

GLOBALRESET - .CLK 0 50 1 51 $ Initial pulse to reset latches
CK.PAD .CLK 0 0 500 1 1000 0 .REP 0
LD.PAD .CLK 0 0 40000 1
ADDR0.PAD .CLK 0 0 40000 0 41000 1 42000 0 .REP 40000
+ 78000 0
ADDR1.PAD .CLK 0 0 40000 0 42000 1 44000 0 .REP 40000
+ 78000 1
ADDR2.PAD .CLK 0 0 40000 0 44000 1 48000 0 .REP 40000
+ 78000 1
ADDR3.PAD .CLK 0 0 40000 0 48000 1 56000 0 .REP 40000
+ 78000 0
ADDR4.PAD .CLK 0 0 40000 0 56000 1 72000 0 .REP 40000
+ 78000 1
D0.PAD .CLK 0 1 1000 0 40000 0 41000 1
D1.PAD .CLK 0 0 1000 1 2000 0 40000 1 41000 0 42000 1
D2.PAD .CLK 0 0 2000 1 3000 0 40000 1 42000 0 43000 1
D3.PAD .CLK 0 0 3000 1 4000 0 40000 1 43000 0 44000 1
D4.PAD .CLK 0 0 4000 1 5000 0 40000 1 44000 0 45000 1
D5.PAD .CLK 0 0 5000 1 6000 0 40000 1 45000 0 46000 1
D6.PAD .CLK 0 0 6000 1 7000 0 40000 1 46000 0 47000 1
D7.PAD .CLK 0 0 7000 1 8000 0 40000 1 47000 0 48000 1
D8.PAD .CLK 0 0 8000 1 9000 0 40000 1 48000 0 49000 1
D9.PAD .CLK 0 0 9000 1 10000 0 40000 1 49000 0 50000 1
D10.PAD .CLK 0 0 10000 1 11000 0 40000 1 50000 0 51000 1
D11.PAD .CLK 0 0 11000 1 12000 0 40000 1 51000 0 52000 1
D12.PAD .CLK 0 0 12000 1 13000 0 40000 1 52000 0 53000 1
D13.PAD .CLK 0 0 13000 1 14000 0 40000 1 53000 0 54000 1
D14.PAD .CLK 0 0 14000 1 15000 0 40000 1 54000 0 55000 1
D15.PAD .CLK 0 0 15000 1 16000 0 40000 1 55000 0 56000 1
D16.PAD .CLK 0 0 16000 1 17000 0 40000 1 56000 0 57000 1
D17.PAD .CLK 0 0 17000 1 18000 0 40000 1 57000 0 58000 1
D18.PAD .CLK 0 0 18000 1 19000 0 40000 1 58000 0 59000 1
D19.PAD .CLK 0 0 19000 1 20000 0 40000 1 59000 0 60000 1
D20.PAD .CLK 0 0 20000 1 21000 0 40000 1 60000 0 61000 1
D21.PAD .CLK 0 0 21000 1 22000 0 40000 1 61000 0 62000 1
D22.PAD .CLK 0 0 22000 1 23000 0 40000 1 62000 0 63000 1 73000 0
D23.PAD .CLK 0 0 23000 1 24000 0 40000 1 63000 0 64000 1
D24.PAD .CLK 0 0 24000 1 25000 0 40000 1 64000 0 65000 1
D25.PAD .CLK 0 0 25000 1 26000 0 40000 1 65000 0 66000 1
D26.PAD .CLK 0 0 26000 1 27000 0 40000 1 66000 0 67000 1
D27.PAD .CLK 0 0 27000 1 28000 0 40000 1 67000 0 68000 1
D28.PAD .CLK 0 0 28000 1 29000 0 40000 1 68000 0 69000 1
D29.PAD .CLK 0 0 29000 1 30000 0 40000 1 69000 0 70000 1
D30.PAD .CLK 0 0 30000 1 31000 0 40000 1 70000 0 71000 1
D31.PAD .CLK 0 0 31000 1 32000 0 40000 1 71000 0 72000 1


# Time Division Multiplexing with the LCA Device

<table>
<thead>
<tr>
<th><em>P - S I L O S</em></th>
<th><em>OUTPUTS</em></th>
<th>10:26:22</th>
<th>07-23-87</th>
</tr>
</thead>
<tbody>
<tr>
<td>CL AAAA</td>
<td>CCCCC</td>
<td>DDDDDDDD</td>
<td>DDDDDDDD</td>
</tr>
<tr>
<td>KD DDDDD</td>
<td>42120</td>
<td>01234567</td>
<td>89111111</td>
</tr>
<tr>
<td></td>
<td>011222222</td>
<td>222223333</td>
<td>U</td>
</tr>
<tr>
<td>PP RRRRRR</td>
<td>PPPPPP</td>
<td>FF.......</td>
<td>........</td>
</tr>
<tr>
<td>AA 43210</td>
<td>AAAAAAA</td>
<td>AAAAAAAA</td>
<td>AAAAAA</td>
</tr>
<tr>
<td>DD PPPPPP</td>
<td>DDDDDD</td>
<td>DDDDDDD</td>
<td>DDDDDDD</td>
</tr>
</tbody>
</table>

## TIME

| Time | CL | DDL | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD | DDD |
|------|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 0    | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 1    | 1  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 2    | 2  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 3    | 3  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 4    | 4  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 5    | 5  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 6    | 6  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 7    | 7  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 8    | 8  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 9    | 9  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 10   | 10 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 11   | 11 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 12   | 12 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 13   | 13 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 14   | 14 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 15   | 15 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 16   | 16 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 17   | 17 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 18   | 18 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 19   | 19 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 20   | 20 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 21   | 21 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 22   | 22 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 23   | 23 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 24   | 24 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 25   | 25 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 26   | 26 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 27   | 27 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 28   | 28 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 29   | 29 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 30   | 30 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 31   | 31 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 32   | 32 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 33   | 33 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| 34   | 34 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |

---

[3-51]
Time Division Multiplexing with the LCA Device
P - S I L 0

s

lU.3

CL AAAAA
KD DDDDI)
DDDDD
pp RRRRR
AA 43210
DD
ppppp

OUTPUTS

10:26:22

07-23-87

CC CCC DDDDDDDD DDDDDDDD DDDDDDDD DDDDDDDD 0

43210 01234567 89111111 11112222 22222233 u
•• 012345 67890123 45678901 T

pppppppp PP ......

AAAAAAAA AAPPPPPP PPPPPPPP PPPPPPPP p
DDDDDDDD DDAAAAAA AAAAAAAA AAAAAAAA A

DDDDDD DDDDDDDD DDDDDDDD D

AAAAA

ODD DD
TIME
43000
43500
44000
44500
'15000

45500
46000
46500
47000
47500
48000
48500
49000
49500
50000
50500
51000
51500
52000
52500
53000
53500
54000
54500
55000
55500
56000
56500
57000
57500
58000
58500
59000
59500
60000
60500
61000
61500
62000
62500
63000
63500
64000
64500
65000
65500
66000
66500
67000
67500
68000
68500
69000
69500
70000
70500
71000
71500
72000
72500
73000
73500
74000
74500
75000
75500
76000
76500
77000
77500
78000
78500
79000
79500
80000

3·52

01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01
11
01

00011
00011
00100
00100
00101
00101
00110
00110
00111
00111
01000
01000
01001
01001
01010
01010
01011
01011
01100
01100
01101
01101
01110
01110
01111
01111
10000
10000
10001
10001
10010
10010
10011
10011
10100
10100
10101
10101
10110
10110
10111
10111
11000
11000
11001
11001
11010
11010
11011
11011
11100
11100
11101
11101
11110
11110
11111
11111
00000
00000
00001
00001
00010
00010
00011
00011
00100
00100
00101
00101
10110
10110
10110
10110
101 0

00010 11101111 11111111 11111111
00011 11101111 11111111 11111111
00011 11110111 11111111 11111111
DODOO 11110111 11111111 11111111
00000 11111011 11111111 11111111
00101 11111011 11111111 11111111
00101 11111101 11111111 11111111
00110 11111101 11111111 11111111
00110 11111110 11111111 11111111
00111 11111110 11111111 11111111
00111 11111111 01111111 11111111
01100 11111111 01111111 11111111
01100 11111111 10111111 11111111
01001 11111111 10111111 11111111
01001 11111111 11011111 11111111
01010 11111111 11011111 11111111
01010 11111111 11101111 11111111
01011 11111111 11101111 11111111
01011 11111111 11110111 11111111
01000 11111111 11110111 11111111
01000 11111111 11111011 11111111
01101 11111111 11111011 11111111
01101 11111111 11111101 11111111
01110 11111111 11111101 11111111
01110 11111111 11111110 11111111
01111 11111111 11111110 11111111
01111 11111111 11111111 01111111
10100 11111111 11111111 01111111
10100 11111111 11111111 10111111
10001 11111111 11111111 10111111
10001 11111111 11111111 11011111
10010 11111111 11111111 11011111
10010 11111111 11111111 11101111
10011 11111111 11111111 11101111
10011 11111111 11111111 11110111
10000 11111111 11111111 11110111
10000 11111111 11111111 11111011
10101 11111111 11111111 11111011
10101 11111111 11111111 11111101
10110 11111111 11111111 11111101
10110 l l l l l l t l 11111111 11111110
10111 11111111 11111111 11111110
10111 11111111 11111111 11111111
11100 11111111 11111111 11111111
11100 11111111 11111111 11111111
11001 11111111 11111111 11111111
11001 11111111 11111111 11111111
11010 11111111 11111111 11111111
11010 11111111 11111111 11111111
11011 11111111 11111111 11111111
11011 11111111 11111111 11111111
11000 11111111 11111111 11111111
11000 11111111 11111111 11111111
11101 11111111 11111111 11111111
11101 11111111 11111111 11111111
11110 11111111 11111111 11111111
11110 11111111 11111111 11111111
11111 11111111 11111111 11111111
11111 11111111 11111111 11111111
00100 11111111 11111111 11111111
00100 11111111 11111111 11111101
00001 11111111 11111111 11111101
00001 11111111 11111111 11111101
00010 11111111 11111111 11111101
00010 11111111 11111111 11111101
00011 11111111 11111111 11111101
00011 11111111 11111111 11111101
00000 11111111 11111111 11111101
00000 11111111 11111111 11111101
00101 11111111 11111111 11111101
00101 11111111 11111111 11111101
10110 11111111 11111111 11111101
10110 11111111 11111111 11111101
10110 11111111 11111111 11111101
10110 11111111 11111111 11111101

11111111
11111111
11111111
11111111

0
0
0
0

11111111

11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111

llllllll
11111111
11111111

11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
01111111
01111111
10111111
10111111
11011111
11011111
11101111
11101111
11110111
11110111
11111011
11111011
11111101
11111101
11111110
11111110
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111
11111111

0
0
0
0
0
0
0
0
0
0
0
0
0
0

o
o
0
0
0

o
0
0
0

0
0
0

o
0
0

0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
1
1
1
1
0
0
0
0


Dual 32-bit Serial CRC Error Detection in an LCA Device

Karen Spesard

Abstract

The transmission and reception of digital data over local area networks (LANs) is more popular than ever. To transmit reliable information from one system to another over a LAN, an efficient error-detection technique is necessary. The error-detection scheme chosen by the IEEE for the Ethernet, a local area network developed by the Xerox Corporation, uses a 32-bit cyclic redundancy check (CRC).

A Dual 32-bit Serial CRC transmitter-receiver for the Ethernet is implemented in one Logic Cell™ Array (LCA device). The LCA device is a RAM-based CMOS circuit which is electrically programmable. It allows the designer to make design changes as necessary to accommodate other data communication protocols as well as other applications. This applications note describes the Ethernet CRC and how it is implemented in the versatile LCA device.
Introduction
In transferring digital information from computer to computer, or from computer to peripheral devices, it is possible that errors in transmission may be introduced. The Cyclic Redundancy Check, or CRC, developed for the data communications industry will detect most of these errors. With one LCA device, a dual 32-bit serial CRC transmitter-receiver was implemented for the Ethernet, one of the industry's most popular local networks. This article describes the methodology used for designing the Dual 32-bit Serial CRC with an LCA device.

Overview of the CRC
Central to a serial hardware CRC system is a set of n-bit linear feedback shift registers, or LFSRs. These registers are designed to represent a fixed generator polynomial G(x). The generator polynomial is the divisor in equation 1,

\[ x^n D(x) = Q(x) + R(x) \]

and D(x) is the data polynomial, which is transmitted and checked for errors. The data polynomial is prescaled by \( x^n \), the length of the generator polynomial, to insure the remainder is always different from the data itself.

The data is shifted in the LFSR and subsequently divided by G(x). The division generates the remainder polynomial R(x) but ignores the quotient polynomial Q(x). The remainder polynomial or redundancy check-bits remain in the registers after all of the data has been shifted in. The check-bits are then shifted out and appended to the data-bits to produce the encoded data. The encoded data becomes D(x) + R(x).

The encoded data is received in a similar LFSR with the same G(x). Because addition and subtraction operations are identical in modulo-2 arithmetic, equation (1) becomes:

\[ Q(x)G(x) = x^n D(x) + R(x). \] (2)

Since D(x) was prescaled, and appending the remainder to the data is equivalent to adding it, the new encoded polynomial should be exactly divisible by G(x). Thus, if the remainder of this operation is zero, all of the original transmitted data-bits are assumed unaltered. If the remainder is anything other than zero, an error occurred and an error flag is set.

Generating CRC Bits and Checking Data
An example of the LFSR hardware needed to generate CRC bits serially for a three-bit G(x) is shown in Figure 1. In this example, the output of the last register is XORed, or shift subtracted, with the data-bit before feeding back to registers X0 and X2. The feedback term positions in the LFSR correspond to all but the highest power of x in the generator polynomial. In this case, the feedback positions are determined from \( x^2 \) and \( x^0 \).

The redundancy check-bits can be calculated from Table 1 for \( G(x) = x^3 + x^2 + 1 \) where the internal state of each register in the LFSR after every shift is shown. Therefore, if the data is 10011, the redundancy check-bits are D5 = 0, D6 = 1, and D7 = 0 after the last data-bit is shifted in (5th shift). This is because D0 = 1, D1 = 1, D2 = 0, D3 = 0, and D4 = 1, (D(x) = 1 + 0x + 0x^2 + 1x^3 + 1x^4 and the least significant bit, LSB, is the first bit transmitted.) The check-bits are shifted out from the LFSR by

<table>
<thead>
<tr>
<th>REGISTERS</th>
<th>X0</th>
<th>X1</th>
<th>X2</th>
<th>COMMENTS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Initialize</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>If registers initialized to 0</td>
</tr>
<tr>
<td>1st shift</td>
<td>D0</td>
<td>0</td>
<td>D0</td>
<td></td>
</tr>
<tr>
<td>2nd shift</td>
<td>D0@D1</td>
<td>D0</td>
<td>D0@D1</td>
<td></td>
</tr>
<tr>
<td>3rd shift</td>
<td>D0@D1@D2</td>
<td>D0@D1</td>
<td>D1@D2</td>
<td></td>
</tr>
<tr>
<td>4th shift</td>
<td>D1@D2@D3</td>
<td>D0@D1@D2</td>
<td>D0@D2@D3</td>
<td></td>
</tr>
<tr>
<td>5th shift</td>
<td>D0@D2@D3@D4</td>
<td>D1@D2@D3</td>
<td>D1@D3@D4</td>
<td>Redundancy check bits</td>
</tr>
<tr>
<td>6th shift</td>
<td>D1@D3@D4@D5</td>
<td>D0@D2@D3@D4</td>
<td>D2@D4@D5</td>
<td></td>
</tr>
<tr>
<td>7th shift</td>
<td>D2@D4@D5@D6</td>
<td>D1@D3@D4@D5</td>
<td>D0@D3@D5@D6</td>
<td></td>
</tr>
<tr>
<td>8th shift</td>
<td>D0@D3@D5@D6@D7</td>
<td>D2@D4@D5@D6</td>
<td>D0@D1@D4@D6@D7</td>
<td>Zero remainder</td>
</tr>
</tbody>
</table>

Table 1. Calculation of Redundancy Check-Bits for \( G(X) = x^3 + x^2 + 1 \)
disabling the feedback terms of the LFSR. The check-bits can be verified by long division as in Figure 2.

The encoded data then becomes 010 10011. To check for data integrity, the encoded data is shifted in another LFSR with the same G(x). This time the last bit (8th bit) is shifted in, and if the message was unaltered, the bits residing in the registers are zero. If the redundancy bits are not zero, an error occurred. This can also be verified by long division as in Figure 3.

In summary, CRC modifies the data polynomial so that it is exactly divisible by a fixed polynomial G(x). When the modified polynomial is received, it is checked for the exact division by G(x). If an error occurred, the RDYFLG is set.

Figure 1. LFSR for \( G(X) = X^3 + X^2 + 1 \)

\[
\begin{array}{c|c}
1001 & \\
1101 & \text{PRESCALED DATA} \\
1101 & \text{WITH 3 ZERO BITS} \\
11000 & \text{REMAINDER} \\
11010 & \\
010 & \text{NO REMAINDER}
\end{array}
\]

Figure 2. Long Division Example - With Pure Data

\[
\begin{array}{c|c}
1001 & \\
1101 & \text{ENCODED DATA} \\
1101 & \\
011010 & \text{0 IN NO REMAINDER}
\end{array}
\]

Figure 3. Long Division Example - With Encoded Data

Why Use LCA Devices in CRC?
The 32-bit serial CRC, with transmission and reception sections, can be implemented in several ways. One way would be to acquire standard CRC chips. These chips, however, only exist with specific G(x) and therefore can be inflexible. Another method would be to design the transmission and reception sections of the CRC with traditional PLD devices. This would require eight PLD devices for the dual 32-bit LFSRs (eight bits in each PLD) even without additional control logic. A third method would use an LCA device, as it would take only one to implement the dual 32-bit CRC and with more flexibility than a dedicated custom part.

In addition, the LCA device can provide designers with more control after design release than the alternative solutions. For example, the designer can change the generator polynomial or the control logic "on-the-fly" by merely reprogramming the configuration data from separate sections of an EPROM. A large EPROM, 8Kx8 or 16Kx8, can typically store three and six configuration patterns, respectively.

32-Bit CRC Design
CRC error detection is one of the best methods for checking the validity of large frames of information. It can detect all errors within n successive bits, all errors with an odd number of bits in error for even G(x), and, of course, all error patterns that are not divisible by G(x).

The IEEE-802.3/Ethernet Local Area Network Standard defines a 32-bit CRC code. This code works with data ranges from 46 to 1500 bytes, and is also used in the Autodin-II Network.

The generator polynomial used for the Ethernet 32-bit CRC is defined as:

\[
G(x) = x^{32} + x^{26} + x^{23} + x^{22} + x^{16} + x^{12} + x^{11} + x^{10} + x^8 + x^7 + x^5 + x^4 + x^2 + x + 1,
\]

where the coefficients of the generator polynomial correspond to the feedback positions in the LFSR.

Figure 4 shows the block diagram of the Dual 32-bit Serial CRC. As the diagram illustrates, the transmitter portion of the CRC is controlled separately from the receiver portion.

On the receiver end, the data bits and the complemented check bits are sent. When the end of the frame is reached, the remainder is checked. If no error occurs, the final contents of the shift register are:

\[
X_{31} \quad X_0
11000111 \quad 00000100 \quad 11011101 \quad 01111011
\]

This remainder is not 0 because the check-bits are complemented before being transmitted to the receiver.

CRC Logic Implementation
Figures 5 and 6 show the complete design for the 32-bit CRC with the standard generator polynomial described above. The generator polynomial is implemented with thirty-two registers in each LFSR. The feedback terms (Q31 xor DIN) are at registers Q0, Q1, Q2, Q4, Q5, Q7, ..., Q23, and Q26 and correspond to the Ethernet generator polynomial, G(x) given above.

The registers in the LFSRs are D-type flip-flops and are clocked synchronously. In the transmitter portion, two pins - CONTROL and INIT - are respectively added for initializing the registers and controlling the feedback terms. When INIT is HIGH, all registers are initialized to HIGH. When CONTROL is HIGH, the multiplexer shifts out data bits and generates check-bits. When CONTROL is LOW, the feedback term is disabled and inverted redundancy check-bits are shifted out from the LFSR.

The five-bit synchronous ripple carry counter is enabled with the control line LOW and reset with the control line HIGH. When the five count bits reach all ones, the thirty-two check bits are shifted out of the LFSR, and the RDYFLAG is set.

The receiver LFSR is essentially the same as the transmitter LFSR. However, after data and the thirty-two check bits are received, the data is checked for errors. If an error occurred, the error flag is set.
Dual 32-bit Serial CRC Error Detection in an LCA Device

Figure 4. Block Diagram of the Dual 32-Bit Serial CRC
Dual 32-bit Serial CRC Error Detection in an LCA Device

Figure 5. Logic Implementation of Transmitter-Encoder Section
Dual 32-bit Serial CRC Error Detection in an LCA Device

Figure 6. Logic Implementation of Receiver-Decoder Section
Logic Cell Array Implementation

The Dual 32-bit Serial CRC circuit described above is implemented in an M2018 LCA device. It contains one hundred configurable logic blocks (CLBs) and seventy-four user-configurable input/output blocks (IOBs) providing a total of 1800 usable logic gates. The logic is partitioned and placed in a graphics environment on the IBM® PC-XT™ or PC-AT™ using the Monolithic Memories’ XACT™ LCA Editor.

The Monolithic Memories’ XACT LCA Editor provides the tools from which the logic and interconnects (CLBs, IOBs, and programmable interconnect points) are constructed. The configuration of specified logic blocks can be made with the XACT "Edit Block" command. Once in the "Edit Block" menu, a combinational, latched, or registered equation can be selected with the mouse. The clock input polarity, set and reset functions can also be selected as required. The CLB can be configured as one output function of four Boolean input variables, or two functions of three Boolean input variables. The logic equations can be input from the PC keyboard using Boolean algebra, or from the mouse using a Karnaugh map. For an IOB, the "Edit Block" menu can be used to select pad and/or latched inputs, buffered and/or three-state control outputs, or bidirectional I/Os.

The programmable interconnect points (PIPs), are configured using the XACT "NET" and "PIN" menus. The features used from the "NET" and "PIN" menus are summarized below.

<table>
<thead>
<tr>
<th>Command</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name Net</td>
<td>Names a Net</td>
</tr>
<tr>
<td>Add Net</td>
<td>Names and Adds a Net</td>
</tr>
<tr>
<td>Add Pin</td>
<td>Adds Net and Automatically Routes a Net</td>
</tr>
<tr>
<td>Edit Net</td>
<td>Manually Routes a Net</td>
</tr>
<tr>
<td>Route Net</td>
<td>Routes Named Nets</td>
</tr>
</tbody>
</table>

When the nets are routed, the PIPs are programmed automatically.

An example of a CLB is shown in Figure 7. Here the output of the CLB is combinational, and the CLB is configured as a multiplexer. The multiplexer selects the serial data when CONTROL or ENABLE are HIGH and selects Q31 when CONTROL and ENABLE are LOW. The Karnaugh map and the Boolean equation in the figure illustrate the logic used to implement this function. The output of the multiplexer is named ENCDATAOUT.

Figure 8 shows the configuration of the CLBs for the modulo-2 addition of the feedback signal with the data, when INIT is LOW and CONTROL is HIGH. The output again is combinational and is named QA.

Figure 9 to 11 show the configuration used to implement the logic for the first few shift registers, corresponding to equations in Tables 2 and 3. Note that these shift registers are configured as registered equations. Figure 12 illustrates the signal configuration of the RDYFLG in the transmitter section.

3.59
of the LFSR. It is also configured as a registered equation. The RDYFLAG is set when COUNT5 is HIGH and CTR14 is HIGH. CTR14 is an AND gate of input bits 1 - 4.

The placed and routed Dual 32-bit CRC design requires sixty-four CLBs for the two LFSRs and two CLBs for the feedback controls. It also requires one CLB for the multiplexer, five for the counter, two for the RDYFLG and eleven for the ERRFLG.

The design, therefore, requires eighty-five CLBs and utilizes 85% of the LCA device. A 68-pin package, 2018NL68, was chosen for this implementation. This 2018NL68 has a speed grade of 70 MHz, the flip-flop toggle rate. A copy of the Monolithic Memories' XACT EDITLCA file is shown in Figure 13 with all of the CLBs and IOBs labelled.

Figure 13. Monolithic Memories' XACT "EDITLCA" File for the Dual 32-Bit Serial CRC
Dual 32-bit Serial CRC Error Detection in an LCA Device

EQUATIONS FOR 32-BIT SERIAL CRC
TRANSMISSION SECTION

\[
\begin{align*}
QA &= \text{CTL*/INIT}(Q31@DIN) \quad ;\text{MOD 2 ADDITION, IF CTL*/INIT} \\
Q0 &= QA+\text{INIT} \quad ;\text{SHIFT QA OR INITIALIZE} \\
Q1 &= (Q9+\text{INIT})@QA \quad ;\text{SHIFT Q0@QA OR INITIALIZE} \\
Q2 &= (Q1+\text{INIT})@QA \quad ;\text{SHIFT Q1@QA OR INITIALIZE} \\
Q3 &= Q2+\text{INIT} \quad ;\text{SHIFT Q2 OR INITIALIZE} \\
Q4 &= (Q3+\text{INIT})@QA \quad ;\text{SHIFT Q3@QA OR INITIALIZE} \\
Q5 &= (Q4+\text{INIT})@QA \quad ;\text{SHIFT Q4@QA OR INITIALIZE} \\
Q6 &= Q5+\text{INIT} \quad ;\text{SHIFT Q5 OR INITIALIZE} \\
Q7 &= (Q6+\text{INIT})@QA \quad ;\text{SHIFT Q6@QA OR INITIALIZE} \\
Q8 &= (Q7+\text{INIT})@QA \quad ;\text{SHIFT Q7@QA OR INITIALIZE} \\
Q9 &= Q8+\text{INIT} \quad ;\text{SHIFT Q8 OR INITIALIZE} \\
Q10 &= (Q9+\text{INIT})@QA \quad ;\text{SHIFT Q9@QA OR INITIALIZE} \\
Q11 &= (Q10+\text{INIT})@QA \quad ;\text{SHIFT Q10@QA OR INITIALIZE} \\
Q12 &= (Q11+\text{INIT})@QA \quad ;\text{SHIFT Q11@QA OR INITIALIZE} \\
Q13 &= Q12+\text{INIT} \quad ;\text{SHIFT Q12 OR INITIALIZE} \\
Q14 &= Q13+\text{INIT} \quad ;\text{SHIFT Q13 OR INITIALIZE} \\
Q15 &= Q14+\text{INIT} \quad ;\text{SHIFT Q14 OR INITIALIZE} \\
Q16 &= (Q15+\text{INIT})@QA \quad ;\text{SHIFT Q15@QA OR INITIALIZE} \\
Q17 &= Q16+\text{INIT} \quad ;\text{SHIFT Q16 OR INITIALIZE} \\
Q18 &= Q17+\text{INIT} \quad ;\text{SHIFT Q17 OR INITIALIZE} \\
Q19 &= Q18+\text{INIT} \quad ;\text{SHIFT Q18 OR INITIALIZE} \\
Q20 &= Q19+\text{INIT} \quad ;\text{SHIFT Q19 OR INITIALIZE} \\
Q21 &= Q20+\text{INIT} \quad ;\text{SHIFT Q20 OR INITIALIZE} \\
Q22 &= (Q21+\text{INIT})@QA \quad ;\text{SHIFT Q21@QA OR INITIALIZE} \\
Q23 &= (Q22+\text{INIT})@QA \quad ;\text{SHIFT Q22@QA OR INITIALIZE} \\
Q24 &= Q23+\text{INIT} \quad ;\text{SHIFT Q23 OR INITIALIZE} \\
Q25 &= Q24+\text{INIT} \quad ;\text{SHIFT Q24 OR INITIALIZE} \\
Q26 &= (Q25+\text{INIT})@QA \quad ;\text{SHIFT Q25@QA OR INITIALIZE} \\
Q27 &= Q26+\text{INIT} \quad ;\text{SHIFT Q26 OR INITIALIZE} \\
Q28 &= Q27+\text{INIT} \quad ;\text{SHIFT Q27 OR INITIALIZE} \\
Q29 &= Q28+\text{INIT} \quad ;\text{SHIFT Q28 OR INITIALIZE} \\
Q30 &= Q29+\text{INIT} \quad ;\text{SHIFT Q29 OR INITIALIZE} \\
Q31 &= Q30+\text{INIT} \quad ;\text{SHIFT Q30 OR INITIALIZE} \\
\end{align*}
\]

\[
\begin{align*}
\text{ENCDATAOUT} &= (\text{ENABLE}+\text{CTL})*\text{SERDATAIN}+(\overline{\text{ENABLE}}*/\text{CTL})*Q31) \\
\text{RDYFLG} &= \text{COUNT5}*/\text{CTR14}
\end{align*}
\]

Table 2.
EQUATIONS FOR 32-BIT SERIAL CRC
RECEPTION SECTION

QB  := /INIT*(Q31@DIN) ; MOD 2 ADDITION, IF /INIT
QC0 := QB+INIT ; SHIFT QB OR INITIALIZE
QC1 := (QC0+INIT)@QB ; SHIFT QC0@QB OR INITIALIZE
QC2 := (QC1+INIT)@QB ; SHIFT QC1@QB OR INITIALIZE
QC3 := QC2+INIT ; SHIFT QC2 OR INITIALIZE
QC4 := (QC3+INIT)@QB ; SHIFT QC3@QB OR INITIALIZE
QC5 := (QC4+INIT)@QB ; SHIFT QC4@QB OR INITIALIZE
QC6 := QC5+INIT ; SHIFT QC5 OR INITIALIZE
QC7 := (QC6+INIT)@QB ; SHIFT QC6@QB OR INITIALIZE
QC8 := (QC7+INIT)@QB ; SHIFT QC7@QB OR INITIALIZE
QC9 := QC8+INIT ; SHIFT QC8 OR INITIALIZE
QC10 := (QC9+INIT)@QB ; SHIFT QC9@QB OR INITIALIZE
QC11 := (QC10+INIT)@QB ; SHIFT QC10@QB OR INITIALIZE
QC12 := (QC11+INIT)@QB ; SHIFT QC11@QB OR INITIALIZE
QC13 := QC12+INIT ; SHIFT QC12 OR INITIALIZE
QC14 := QC13+INIT ; SHIFT QC13 OR INITIALIZE
QC15 := QC14+INIT ; SHIFT QC14 OR INITIALIZE
QC16 := (QC15+INIT)@QB ; SHIFT QC15@QB OR INITIALIZE
QC17 := QC16+INIT ; SHIFT QC16 OR INITIALIZE
QC18 := QC17+INIT ; SHIFT QC17 OR INITIALIZE
QC19 := QC18+INIT ; SHIFT QC18 OR INITIALIZE
QC20 := QC19+INIT ; SHIFT QC19 OR INITIALIZE
QC21 := QC20+INIT ; SHIFT QC20 OR INITIALIZE
QC22 := (QC21+INIT)@QB ; SHIFT QC21@QB OR INITIALIZE
QC23 := (QC22+INIT)@QB ; SHIFT QC22@QB OR INITIALIZE
QC24 := QC23+INIT ; SHIFT QC23 OR INITIALIZE
QC25 := QC24+INIT ; SHIFT QC24 OR INITIALIZE
QC26 := (QC25+INIT)@QB ; SHIFT QC25@QB OR INITIALIZE
QC27 := QC26+INIT ; SHIFT QC26 OR INITIALIZE
QC28 := QC27+INIT ; SHIFT QC27 OR INITIALIZE
QC29 := QC28+INIT ; SHIFT QC28 OR INITIALIZE
QC30 := QC29+INIT ; SHIFT QC29 OR INITIALIZE
QC31 := QC30+INIT ; SHIFT QC30 OR INITIALIZE

IF /OE2, SERDATAOUT := ENCDATAIN

ERRFLG := /Q0+/Q1+Q2+/Q3+/Q4+/Q5+/Q6+Q7+/Q8+Q9+/Q10+/Q11+/Q12+Q13
+ /Q14+/Q15+Q16+Q17+/Q18+Q19+Q20+Q21+A22+Q23+/Q24+/Q25
+ /Q26+Q27+Q28+Q29+/Q30+Q31

Table 3.
Configuration

The LCA device is manufactured with a programmable RAM-based CMOS process and must be configured upon power-up. This requires the loading of a configuration program into the LCA device. A number of methods for doing this exist. The Master Mode LOW was selected in this application.

In this mode, the LCA device is configured from an external EPROM containing the configuration data as shown in Figure 14. After an initial power-up delay and with the RESET pin HIGH, the LCA device reads the byte-wide configuration data from the EPROM starting at address 0000 and loads it into pins D0-D7. When the DONE pin goes HIGH, configuration is complete and the LCA device is free to perform as designed. The configuration process, lasts approximately 25 ms.

Summary

In this applications note, the principles of designing a Dual 32-bit Serial CRC in a Monolithic Memories’ LCA device was described. The device implementation has many advantages which include its user-configurable logic functions, interconnects and I/O pins. This flexibility facilitates the design process significantly as standards in the data communications industry continually change. Thus, the LCA device is a viable solution for designers who wish to gain more control over their designs.

The Dual 32-bit CRC design developed for the LCA device is available upon request. The bit pattern and .LCA file will be provided for programming the LCA device in an EPROM. Please ask for design XDES09.LCA.

References

2. Vivian Kong, "Implementation of Serial/Parallel CRC Using PAL Devices." AN-125, Monolithic Memories Inc., 2175 Mission College Blvd., Santa Clara, CA 95054-1592

Figure 14. Master Mode Low Configuration for the Dual 32-Bit Serial CRC
LCA Device Implements an 8-Bit Format Converter in a PBX Switching Module

Raj Paripatyadar and C.B. Lee

Abstract

In Private Branch Exchanges, thousands of voice channels are multiplexed using time division multiplexing (TDM) techniques. Many of these voice channels may be multiplexed onto either serial or parallel channels. This application note describes an eight-bit format converter (parallel-to-serial and serial-to-parallel) circuit which transposes eight serial TDM highways into a single eight-bit parallel bus. A user-programmable Monolithic Memories' Logic Cell™ Array (LCA device) implements this circuit very efficiently using ninety-nine Configurable Logic Blocks (CLBs) out of one hundred CLBs available. Each CLB has a combinational logic section and a storage element. The circuit operates at up to 18.5 MHz when implemented in a 70-MHz CMOS, LCA M2018 device.
LCA Device Implements an 8-Bit Format Converter in a PBX Switching Module

Introduction

In a Private Branch Exchange (PBX) or Central Office (CO), incoming digitized voice circuits are "switched" or routed to their appropriate destination. The "switching" takes place while the data is in serial or parallel format. An eight-bit format converter circuit, widely used in a variety of PBX and CO architectures, translates the serial data streams into parallel data streams and vice-versa.

The eight-bit format converter circuit requires a large number of register elements. These elements, namely serial shift registers, can be implemented efficiently in an LCA device due to its high register content and flexible structure. The LCA M2018 programmable device contains one hundred configurable register elements, ninety-nine of which are used in the implementation of the converter circuit. This circuit is capable of running at 12.5 MHz and 18.5 MHz in a 50-MHz and 70-MHz LCA device, respectively.

Powerful software tools and circuit uniformity allowed the design to be laid out and simulated in just two days. However, if different support logic becomes necessary, PBX vendors are able to generate a new configuration program in the LCA reprogrammable device. Since these devices are manufactured in a CMOS technology, a complete PBX system with several LCA devices can help keep the active power consumption down. (Please refer to the LCA Design and Applications Handbook—Reference 3 for basic information regarding structure and programming aspects.)

Overview of a PBX

Central Offices (CO) and Private Branch Exchanges (PBX) provide both telephone and data services. A PBX may be considered as a localized telephone exchange serving the interconnection requirements of users in office environments. Outgoing calls are directed out of the PBX and routed through the local CO to the far destination. In general terms, a PBX or a CO consists of major blocks shown in Figure 1. Racks of peripheral equipment modules containing line cards provide access to telephone units, or to data adapter modules which provide data communication services. Trunk cards provide high-speed links to host computers, or other PBXs. Network switching modules interconnect calling parties to answering parties via digital multiplexed links. Control modules containing a Central Processor Unit (CPU), mass storage and local memory, perform the "setup" and "tear-down" of each circuit connection, as well as the monitoring of PBX activities. Central resources are modules of hardware and software which operate in a time-shared manner. The central resources include facilities such as ringing tone generator and message recording modules.

Figure 1. PBX Communication and Control Architecture
Hierarchy of Channel Multiplexing in a PBX

The main function of switching modules is to interconnect circuits between two or more parties such as in a conference call. A digital telephone unit, or a line card, contains a Coder/Decoder (CODEC) device. The CODEC device digitizes voice and transmits it into a Pulse Code Modulated (PCM) data stream on a common serial data highway at appropriate time intervals, which are assigned at the start of the call.

Analog voice is sampled at 8 KHz and passes through an eight-bit analog-to-digital converter. The digitized sample (eight-bit binary word) is transmitted serially to produce a serial data stream of \((8 \times 8 = 64)\) Kbps. Thirty-two of these samples or CODECs are normally connected to a common highway operating at \((32 \times 64 = 2048)\) Mbps. Each CODEC is assigned "Serial Time Slots" of eight-bit duration, and sends its eight bits of data at the rate of 2.048 Mbps every 8 KHz. Another time slot is available on a separate highway for the receive data stream. Therefore, a 2.048 Mbps highway can support thirty-two channels or voice connections in one direction. However, there are several ways to combine serial highways for additional voice connections. One way is to combine four highways into one high-speed highway of 8.192 Mbps. Further integration is possible, but the aggregate data rate becomes high and leads to implementation problems including timing, signal reflection, and radiation, to name a few.

Another way to integrate channels without increasing the clock rate is to convert eight serial data highways into a single eight-bit parallel bus. With this method, the serial clock rate and the parallel clock rate are the same, 2.048 Mbps. This means that data throughput on the eight serial highways of 16.384 Mbps is maintained in the eight-bit parallel bus operating at 2.048 Mbps. This works by careful alignment of the incoming parallel time slots to serial time slots on the serial highways. An eight-bit format converter scheme, sometimes called a "Corner Bender", is widely used in PBX or CO switching modules. Four of these parallel buses are combined (see Figure 2) to form a single parallel system bus that is thirty-two bits wide, yet still operates at 2.048 Mbps. The multiplexing architecture shown in Figure 2 is used in the Harris 20-20® Integrated Network Switch (see Reference 1).

Space switching and/or time slot switching to interconnect different parties is performed either in the serial highway format or in the parallel data stream format.
Description of the “Corner Bender” Circuit

The circuit consists of eight parallel-to-serial shift registers, and additional shift registers which provide proportional delays to synchronize the outputs. The principle of operation is shown in Figure 3, and the circuit is shown in Figure 4. Parallel data from the parallel bus is loaded with each clock into one of the eight shift registers in a rotating pattern. The data then shifts out of the shift register with each subsequent clock. After all eight registers have been loaded, the first register will be empty on the next clock. New data is loaded into this register at the same clock edge as the last bit shifts out to the next stage. Thus, a continuous flow of data through the registers is insured. The data out of the eight shift registers is skewed in relation to each other as shown in Figure 3b. The various space slots on the highways need to be aligned to keep synchronization. This is achieved by proportionally delaying the outputs. Channel 1 output is delayed by seven clocks (using a seven-bit serial shift register), channel 2 is delayed by six clocks, etc. Channel 8 output does not go through any additional delay. The final outputs of the delay registers are aligned and data is clocked out in a synchronous fashion. See Figure 3c.
Figure 4 also shows the additional circuitry needed to control
the shift registers. A preloadable three-bit counter keeps count
of eight clock pulses. The parallel-to-serial bus conversion can
be “programmed” to start in any register by setting the appro­
priate binary value on the counter preload inputs and applying a
pulse to the sync input. If the loading sequence produced by the
counter is not required, it can be disabled by connecting the
“clock” to “sync” input. At each positive clock edge, the register
loaded will depend upon the data at the counter inputs on the
previous positive clock edge. The 3-to-8 decode circuit produ­
ces load pulses to latch parallel data into the shift registers.
Figure 5 shows the parallel-to-serial conversion data matrix.
The description above shows the conversion of parallel data into
eight streams of serial data. However, the same circuit also
performs serial-to-parallel conversion. A serial eight-bit data
stream on one of the eight inputs appears as an eight-bit parallel
word on the eight outputs. Successive parallel words appearing
at the eight outputs correspond to the serial data on each of the
eight inputs in rotation. See Figure 5.

Figure 4. 8-Bit Format Converter ("Corner Bender") Circuit
Comparison of Implementation Techniques

The "Corner Bender" circuit can be implemented in several ways. The efficiency of an LCA design can be compared to that of a design in SSI/MSI logic devices or Erasable Programmable Logic devices (EPLDs). Table 1 contains the comparison of package counts with the different alternatives.

The circuit implemented in 74LSxx devices requires nineteen packages. Alternatively, sixteen simple PLD devices (such as a PAL20R8 or a PAL20R4) are required to implement the same circuit. Since the circuit is register intensive and not designed for high speed, PLDs are not chosen for this application.

The functionally larger EPLD devices, EP1200 and EP1800, are more register intensive and contain twenty-eight and forty-eight register elements, respectively. Nevertheless, four EP1200 devices, or two EP1800 plus a smaller PLD device, is required to implement this design.

The entire Corner Bender circuit fits neatly into a single LCA 2018 device. It uses ninety-nine out of the one hundred available internal macrocells and demonstrates efficient implementation of shift registers and small counters. An LSI device from Plessey (Reference 2) is available to implement the same circuit. However, it is an NMOS device and limited to speeds of under 2 MHz.

---

**Table 1. Implementation Alternatives for the 8-Bit Format Converter Circuit "Corner Bender"**

<table>
<thead>
<tr>
<th>EQUIVALENT CIRCUIT IN SSI/MSI DEVICES</th>
<th>PACKAGES</th>
</tr>
</thead>
<tbody>
<tr>
<td>Parallel in serial out shift Registers</td>
<td>74LS165</td>
</tr>
<tr>
<td>Serial in Parallel out shift Registers</td>
<td>74LS164</td>
</tr>
<tr>
<td>4-bit counter</td>
<td>74LS161</td>
</tr>
<tr>
<td>3 to 8 decoder</td>
<td>74LS138</td>
</tr>
<tr>
<td>Three-state buffers</td>
<td>74LS241</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>EQUIVALENT CIRCUIT IN EPLDs</th>
<th>PACKAGES</th>
</tr>
</thead>
<tbody>
<tr>
<td>a) EP1200</td>
<td>28 macro cells each</td>
</tr>
<tr>
<td>b) EP1800</td>
<td>48 macro cells each</td>
</tr>
<tr>
<td>plus PAL device e.g., 16R4</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>EQUIVALENT CIRCUIT IN MMI LCA DEVICE</th>
<th>PACKAGES</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCA 2018 device</td>
<td>100 macro cell</td>
</tr>
</tbody>
</table>
“Corner Bender” Design in an LCA Device

A count of the register elements in the circuit shows a need of sixty-four elements for the eight-shift registers, twenty-eight elements for the delay registers, three elements for the counter, and four elements for the 3-to-8 decode circuit. Each configurable logic block (CLB) in the LCA device can produce two outputs. Hence, only four CLBs are required for the 3-to-8 decode circuit. Since each CLB contains one register element, the total count of CLBs is therefore ninety-nine. The LCA 2018 contains one hundred CLBs. Twenty-two input/output blocks (IOBs) were used. Figure 6 shows the layout of the design in the LCA device. The circuit fits into a 68-pin PLCC package.

Figure 6. Layout Diagram of “Corner Bender” Circuit on LCA Device of Size 10x10
The Monolithic Memories' XACT™ Design Editor is used to create the design by implementing the appropriate logic functions in CLBs and IOBs. An example of a CLB for one bit of the eight-bit shift register in this design is shown in Figure 7. Input A is the decoder input and it is ANDed with input B, the data to be shifted. To implement the eight-bit shift registers from the one-bit shift register, eight of the one-bit shift registers were linked together so that the output of each register became an input to the next register. This is shown in Figure 8 where each CLB represents one bit of the eight-bit shift register.

The three-bit counter and the 3-to-8 decoder in this design were implemented in CLBs as shown in Figures 9 and 10. The counter is a synchronous binary counter with ripple carry and parallel load. The decoder is a standard 3-to-8 decoder. The outputs of the counter become inputs to the decoder, whereas the outputs of the decoder are used to decode the eight 8-bit shift registers.

With the XACT Development System, the designer can optimally arrange the logic blocks on the LCA device in order to minimize net delays between each block. With this in mind, the layout for the design is described below:

Four of the eight-bit parallel-to-serial shift registers were placed starting from the top left-hand edge of the LCA device (see Figure 7). The three-bit counter (three CLBs) and the 3-to-8 decoder (four CLBs) were then placed on the following row. The next four rows contained the last four parallel-to-serial shift registers. This allowed the shift register select lines to have minimal delay spread when accessing all eight shift registers. The seven serial-to-serial shift registers were placed in the remaining CLBs as uniformly as possible.

The optimum placement and distribution of configured blocks in the array is influenced by the performance needs of the system. Blocks placed in close proximity can use local interconnection resources which incur short signal propagation delays, whereas blocks placed further apart must use either "long lines" or other interconnection resources. Manual optimization using the delay efficient "long lines" was performed for the most critical net connections. After routing completion, the longest delay between two clock pulses was the delay for the counter to change state, the state which is decoded via the 3-to-8 decoder and selects the appropriate shift register to load the parallel data (see Figure 7). This delay was 54 ns, 79 ns, and 106 ns, respectively for the 70-, 50-, and 33-MHz versions of the device. The delays were measured using the XACT simulation package by invoking the timing delay calculator. This translates to a maximum circuit operating speed of about 18.5 MHz for the 70-MHz version of the device, or 9.43 MHz for the 33 MHz version.

Although fabricated in a CMOS technology, the inputs to the LCA device can be made either TTL or CMOS compatible. For high fan-out CMOS or LS TTL-compatible loads, the output buffers of the LCA device are capable of driving 4 mA. Moreover, each output buffer can be put into a HIGH-Z state for bus-driving applications. This feature was also used in the design of the eight-bit format converter.

More information about entering a design with the XACT Development System is included in the LCA Design and Applications Handbook (Reference 3). Information about configuring the LCA device is described in the "Configuring the LCA Device" applications note.
LCA Device Implements an 8-Bit Format Converter in a PBX Switching Module

Figure 9a. Decode Outputs 1 and 2 of 3-to-8 Decoder

Figure 9b. Decode Outputs 3 and 4 of 3-to-6 Decoder

Figure 9c. Decode Outputs 5 and 6 of 3-to-8 Decoder

Figure 9d. Decode Outputs 7 and 8 of 3-to-8 Decoder

Figure 9. CLB Configuration of a 3-to-8 Decoder

3-73
LCA Device Implements an 8-Bit Format Converter in a PBX Switching Module

**Summary**

The LCA device has achieved a good solution to the principles used for multiplexing digitally-encoded voice channels in both serial and parallel hierarchies. These hierarchies can accommodate thousands of voice circuits in a PBX switching module. The detailed design of the eight-bit (parallel-to-serial and serial-to-parallel) format converter circuit, or Corner Bender, developed in Monolithic Memories' LCA M2018 device was shown to be efficiently implemented. Despite the fast development of the system using the XACT Design Editor, the final design was programmed and bench tested to verify functional integrity.

The Corner Bender design is available from Monolithic Memories upon request. The bit pattern and .LCA file will be provided for programming the LCA device in an EPROM. Please ask for design XDES05.LCA

**References**

2) MJ1410, 8-bit Format Converter, Data Sheet, Plessey Semiconductors.
Reconfigurable Programmable Devices (LCA)
Simplify Digital TDM Line Transcoder

C. B. Lee and Cindy Lee

Abstract

The Logic Cell™ Array (LCA) is a high-density CMOS programmable integrated circuit. Its reprogrammability and reconfigurability make complex design of custom LSI devices easy and flexible.

This application note describes the design of a universal transcoder on trunk transmission lines. Any one of three different transcoders (B8ZS, B6ZS, and HDB3) can be implemented in a single LCA device (M2018). Because it is reconfigurable, any one of these different transcoders may be selected. Other common communication features can be implemented simply by reconfiguring the Configurable Logic Blocks (CLBs), Input/Output Blocks (IOBs), or interconnect.
TDM Hierarchies

Recently, the International Telegraph and Telephone Consultative Committee (CCITT) agreed on transmission hierarchies based on different national standards. Two major hierarchies are in use today. The first hierarchy, known as the T-carrier, is used in North America and Japan and multiplexes twenty-four voice channels together using Time Division Multiplexing (TDM) technique. T-carrier is based on a primary rate of 1.544 Mbps and multiples up to 274.176 Mbps (see Figure 1).

The other hierarchy, used in Europe, Africa, and South America, multiplexes thirty voice channels and two signaling channels together. This TDM hierarchy is based on a primary rate of 2.048 Mbps and multiples up to 139.264 Mbps (see Figure 2).

CCITT recommendation G.703 defines line coding for both TDM hierarchies with different orders. Table 1 shows a 1.544 Mbps primary rate T-carrier hierarchy with four different orders. Alternate Mark Inversion (AMI) or Binary 8 Zeros Substitution (B8ZS) is the proper line coding in the first order. In the second order, if the transmission medium is coaxial pair cables, then B8ZS is used. Otherwise, Binary 6 Zeros Substitution (B6ZS) is used for symmetrical pair cables. In the third order, Binary 3 Zeros Substitution (B3ZS) is used, while polar binary NRZ is used in the fourth order.

Similarly, Table 2 shows line coding based on a 2.048 Mbps primary rate with four different orders. High Density Bipolar (HDB3) is used in the first, second, and third orders. Finally, Code Mark Inversion (CMI) is used in the fourth order.
Binary Codes

Unipolar binary codes form the information exchange in computer systems from one device to another over short distances. Unipolar binary codes work well at short distances but DC wander and a lack of timing information make them unsuitable for long transmission lines. DC wander is caused from unipolar binary signals being transmitted via a certain medium over long-distance transmission lines. The signals will be attenuated after a few kilometers.

Bipolar Codes

Unipolar binary codes require two voltages to represent a binary state (see Figure 3a). On the other hand, bipolar binary codes, also known as AMI codes, need three different voltages (+5 V, 0 V, and -5 V) to represent the same binary condition: logic zero or logic one (see Figure 3b). By making logic one signals alternate between +5 V and -5 V, DC wander is eliminated on a long transmission line because the mean DC level is integrated to zero volts. If, however, two continuous ones have the same polarity a bipolar violation occurs (see Figure 4). A long string of ones of bipolar codes can provide timing information but a long string of zeros cannot. To counteract this problem, several modified bipolar codes provide timing information for a long string of logic zeros.

Modified Bipolar Codes

The B8ZS, B6ZS, and HDB3 codes are all modified bipolar codes. They provide timing information for a long string of zeros by forcing bipolar violations.

B8ZS line coding encodes logic ones as alternating positive (+5 V) and negative (-5 V) signals. It substitutes any continuous sequence of eight zeros with a special pattern (see Table 3). Depending on the preceding polarity, one of two B8ZS substitution codes is generated: 000+-0-+ or 000-+-0++. The "+" indicates positive voltage, "-" indicates negative voltage, and "0" indicates zero voltage. If the preceding polarity is positive, 000+-0-+ is generated; otherwise, 000-+-0++ is generated. The B8ZS substitution code forces bipolar violations in the fourth and the seventh bit positions.

B6ZS is similar to B8ZS. Rather than detecting eight continuous zeros, B6ZS substitutes for six continuous zeros with a special pattern. The B6ZS substitution codes are 0+-0-+ and 0-+0+-, depending on the polarity. B6ZS substitution code forces the second and fifth zeros to bipolar violation (see Table 4).

<table>
<thead>
<tr>
<th>ORDER</th>
<th>NUMBER OF VOICE CHANNELS</th>
<th>BIT RATE (Mbps)</th>
<th>LINE CODING</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>30</td>
<td>2.048</td>
<td>HDB3</td>
</tr>
<tr>
<td>2</td>
<td>120</td>
<td>8.448</td>
<td>HDB3</td>
</tr>
<tr>
<td>3</td>
<td>480</td>
<td>34.368</td>
<td>HDB3</td>
</tr>
<tr>
<td>4</td>
<td>1920</td>
<td>139.264</td>
<td>CMI (2-level NRZ)</td>
</tr>
</tbody>
</table>

Table 2. Line Coding for TDM Hierarchy at 2.048 Mbps Primary Rate

<table>
<thead>
<tr>
<th>ORDER</th>
<th>NUMBER OF VOICE CHANNELS</th>
<th>BIT RATE (Mbps)</th>
<th>LINE CODING</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>24</td>
<td>1.544</td>
<td>AMI or B8ZS</td>
</tr>
<tr>
<td>2</td>
<td>96</td>
<td>6.312</td>
<td>B8ZS-Coaxial Pair, B6ZS-Symmetric Pair</td>
</tr>
<tr>
<td>3</td>
<td>672</td>
<td>44.736</td>
<td>B3ZS</td>
</tr>
<tr>
<td>4</td>
<td>4032</td>
<td>274.176</td>
<td>Polar Binary</td>
</tr>
</tbody>
</table>

Table 1. Line Coding for TDM Hierarchy at 1.544 Mbps Primary Rate
The European HDB3 line coding also uses alternating positive and negative signals to represent logic ones. It also substitutes any four continuous zeros with a special HDB3 substitution code. This HDB3 substitution code forces the fourth bit to be a bipolar violation. The four possible HDB3 substitution codes are: +00+, 000+, -00-, and 000-. The choice of substitution code depends on the preceding polarity and the number of logic ones after the preceding bipolar violation. When the number of logic ones is odd, 000V is generated. Otherwise, 000V is generated. "V" indicates the bipolar violation while "B" indicates the bipolar signal. The polarity of V in 000V is the same as that of the preceding logic one signal. If the HDB3 code is 000V, the polarity of B is opposite that of the preceding logic one signal, and the polarity of V is the same as B (see Table 5).

<table>
<thead>
<tr>
<th>PRECEDING POLARITY</th>
<th>NUMBER OF LOGIC ONES AFTER THE PREVIOUS BIPOLAR VIOLATION</th>
</tr>
</thead>
<tbody>
<tr>
<td>Positive</td>
<td>EVEN</td>
</tr>
<tr>
<td>Positive +</td>
<td>000+</td>
</tr>
<tr>
<td>Negative</td>
<td>ODD</td>
</tr>
<tr>
<td>Negative -</td>
<td>000-</td>
</tr>
</tbody>
</table>

Table 5. HDB3 Substitution Table

The Logic Cell Array (LCA) is a high-density CMOS integrated circuit. Its user-programmable static RAM array architecture consists of Input/Output Blocks (IOBs), Configurable Logic Blocks (CLBs), and Interconnect. All of them are fully user-programmable and user-reconfigurable. High-density, programmability and reconfigurability of LCA devices allow customer-defined LSI functions to be incorporated and modified at low cost and with fast turnaround.

Currently, two LCA devices are available, their complexity is based on the number of CLBs within the device. All CLBs are arranged in a matrix in the center of the device. The M2064 has sixty-four CLBs which are arranged in an 8-row by 8-column matrix. The M2018 has one hundred CLBs arranged as a 10 by 10 matrix.

A CLB can be configured to be a storage element (registered or latched), a combinational logic block or a mixed combinational logic block with storage element. Each CLB has four general-purpose inputs (A, B, C, and D); and a special clock input (K). Also, each CLB can perform any function of up to four variables or any two functions of up to three variables. These variables can be selected from external inputs or from the internal register feedback path.

Initially, an attempt was made to design the line transcoder with the M2064 device. However, all three line transcoder designs required more than sixty-four CLBs each. Fortunately, it is easy to convert a design from M2064 to M2018 because the change is made just by selecting the M2018 part type in the convert command when using the XACT Design Editor. Any of the preceding line coding schemes can be implemented in a single M2018 because of its higher density (100 CLBs). Since the LCA device is reconfigurable, a line transcoder implemented in a single LCA device (M2018) can support the North American T1 carrier (B8ZS line coding) or T2 carrier (B6ZS line coding), or even the European standard (HDB3 line coding).

All three line transcoders can be configured and have the same pinout assignments. This offers a simple solution for supporting the different standards without component replacement. Once a design has been established, "on-the-fly" modification is possible through the reconfigurability of the component. For example, if the communication medium is changed in the T2

<table>
<thead>
<tr>
<th>PIN NUMBER</th>
<th>DESCRIPTION</th>
<th>B8ZS</th>
<th>B6ZS</th>
<th>HDB3</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pin 01</td>
<td>GND</td>
<td>GND</td>
<td>GND</td>
<td>GND</td>
</tr>
<tr>
<td>Pin 11</td>
<td>Clock</td>
<td>CLK</td>
<td>CLK</td>
<td>CLK</td>
</tr>
<tr>
<td>Pin 12</td>
<td>Master Reset</td>
<td>MR</td>
<td>MR</td>
<td>MR</td>
</tr>
<tr>
<td>Pin 13</td>
<td>Positive input for decoder</td>
<td>IPB</td>
<td>IPB</td>
<td>IPH</td>
</tr>
<tr>
<td>Pin 14</td>
<td>Positive output from encoder</td>
<td>OPB</td>
<td>OPB</td>
<td>OPH</td>
</tr>
<tr>
<td>Pin 15</td>
<td>NRZ input</td>
<td>INR</td>
<td>INR</td>
<td>INR</td>
</tr>
<tr>
<td>Pin 16</td>
<td>Negative input for decoder</td>
<td>INB</td>
<td>INB</td>
<td>INH</td>
</tr>
<tr>
<td>Pin 18</td>
<td>VCC</td>
<td>VCC</td>
<td>VCC</td>
<td>VCC</td>
</tr>
<tr>
<td>Pin 19</td>
<td>Negative output from encoder</td>
<td>ONB</td>
<td>ONB</td>
<td>ONH</td>
</tr>
<tr>
<td>Pin 34</td>
<td>NRZ output</td>
<td>ONR</td>
<td>ONR</td>
<td>ONR</td>
</tr>
<tr>
<td>Pin 35</td>
<td>GND</td>
<td>GND</td>
<td>GND</td>
<td>GND</td>
</tr>
<tr>
<td>Pin 52</td>
<td>VCC</td>
<td>VCC</td>
<td>VCC</td>
<td>VCC</td>
</tr>
<tr>
<td>Pin 56</td>
<td>Error*</td>
<td>ERR</td>
<td>ERR</td>
<td>ERR</td>
</tr>
<tr>
<td>Pin 57</td>
<td>Bipolar violation error</td>
<td>BVP</td>
<td>BVP</td>
<td>BVP</td>
</tr>
<tr>
<td>Pin 59</td>
<td>Special pattern detected</td>
<td>B8Z</td>
<td>B6Z</td>
<td>HDB</td>
</tr>
</tbody>
</table>

* Means that the ERROR is asserted when both positive and negative signals are high simultaneously.

Table 6. Cross Reference of Pin Names for Three Line Transcoders
standard, the transcoder may be reprogrammed from B8ZS to B6ZS, or vice versa, without any other alterations to the hardware. In total, fifteen pins are used in these designs; four power pins, two central control pins, three pins for the encoder, and six pins for the decoder. Table 6 cross references the pin names for the three different line transcoders.

### B8ZS Line Coding

A B8ZS encoder converts NRZ data to B8ZS code. The B8ZS encoder consists of a 3-CLB, 3-bit counter, a 5-CLB, 5-bit shift register, a 6-CLB sequence state machine, and a 13-CLB encoding state machine (see Figure 5). A 3-bit counter detects eight continuous zeros. A 5-bit shift register delays the NRZ input data to synchronize with the 3-bit counter's outputs. The sequence state machine provides the sequence state (Q2, Q1, and Q0) for encoding state machine. The encoding state machine generates the B8ZS code. It is a pair of signals which interface to line driver to provide three level signals: positive (PB8ZS), negative (NB8ZS), and zero signals.

A B8ZS decoder detects B8ZS code on a pair of positive and negative B8ZS signals (see Figure 6). When either of the following sequences: 000+-0-+ or 000-+0+- is detected, the decoder generates a string of eight zeros. Otherwise, the encoder converts bipolar signals to binary NRZ data.

Figure 7 is a block diagram of the B8ZS decoder. It includes a 19-CLB decoding state machine, an 8-CLB, 8-bit shift register, a 5-CLB RESET generator, and a 7-CLB bipolar violation and error flag generator. Four state variables (HQ3, HQ2, HQ1, and HQ0) are generated from the decoding state machine. The 8-bit shift register buffers DSOUT data in order to provide eight continuous zeros when the B8ZS signal is asserted. The B8ZS signal is generated when the B8ZS substitution code is detected. The bipolar violation error (BVP) occurs when any two sequential signals of the same polarity are detected except the B8ZS substitution code. If both positive B8ZS and negative B8ZS are detected simultaneously, the error signal (ERROR) is generated.

The implementation details of the B8ZS line transcoder within a single M2018 are shown in Figure-8. This design requires sixty-six out of the one hundred available CLBs.
Figure 8. B8ZS Line Transcoder LCA Design
**B6ZS Line Coding**

The M2018 implementation of the B6ZS line transcoder is shown in Figure 9. In total, sixty-seven CLBs are used to create the design. The single difference between a B8ZS encoder and a B6ZS encoder is the count for continuous zeros. While the 3-bit counter counts eight continuous zeros for the B8ZS encoder, it counts six for the B6ZS encoder. The B8ZS encoder consists of a 5-CLB, six-zeros detector, a 5-CLB, 5-bit shift register, a 6-CLB sequence state machine, and a 13-CLB encoding state machine.

A B6ZS decoder detects two B6ZS substitution codes: 0+0- or 0-0+. When one of those two B6ZS substitution codes is detected, the decoder generates six continuous zeros. Otherwise, the decoder converts bipolar signals to binary NRZ data. The B6ZS decoder includes a 20-CLB decoding state machine, a 6-CLB, 6-bit shift register, a 5-CLB RESET generator, and a 7-CLB bipolar violation and error flag generator. The 6-bit shift register is needed to buffer DSOUT data in order to provide six continuous zeros.

Figure 9. B6ZS Line Transcoder LCA Design
HDB3 Line Coding

In Figure 10, the HDB3 encoder includes a 4-CLB, 4-bit shift register, a 5-CLB HDB3 signal generator, and three-state machines. These state machines are: a 3-CLB ODD_EVEN state machine, a 5-CLB DETECT_4_ZEROS state machine, and a 23-CLB encoding state machine. The ODD_EVEN state machine detects the polarity of the preceding pulse. The DETECT_4_ZEROS state machine detects four continuous zeros. The 4-bit shift register delays NRZIN data to synchronize with the output of DETECT_4_ZEROS state machine. The encoding state machine provides four encoding states variables (Q3, Q2, Q1, and Q0) to generate two HDB3 signals: the positive HDB3 signal (PHDB) and negative HDB3 signal (NHDB).

A HDB3 decoder detects four HDB3 substitution codes: +00+, 000+, -00-, and 000-. When any of these four HDB3 substitution codes is detected, the decoder generates four continuous zeros. Otherwise, the decoder converts bipolar signals to binary NRZ data. Figure 11 is a block diagram of the HDB3 decoder. It includes a 23-CLB decoding state machine, a 4-CLB, 4-bit shift register, a 3-CLB RESET generator, and a 2-CLB bipolar violation and error flags generator. Four state variables (HQ3, HQ2, HQ1, and HQ0) are generated from the decoding state machine. The 4-bit shift register buffers DSOUT data in order to provide four continuous zeros when the HDB3 signal is asserted. The HDB3 signal is generated when the HDB3 substitution code is detected. The bipolar violation error (BVP) occurs when any two sequential signals of the same polarity are detected except the HDB3 substitution code. If both positive HDB3 and negative HDB3 are detected simultaneously, the error signal (ERROR) is generated. The M2018's layout of the HDB3 line transcoder is shown in Figure 12. This design requires seventy-two out of the one hundred available CLBs.
Figure 12. HDB3 Line Transcoder LCA Design
Logic Cell Array Design Methodology

All three designs are composed of similar building blocks, they all use shift registers, combinational logic and state machine logic.

Each of the three line transcoders require the use of two sets of shift registers. One set delays the input NRZ data, and the other set buffers the output NRZ data. To design a shift register using a CLB is simple. Two inputs (input variable, clock) are used to generate a single output (Figure 13); this output is then cascaded with additional registers to form a shift register. In the B82S design, five CLBs are used to implement a 5-bit shift register.

For state machines and combinational logic, both the state machine equations and combinational logic equations must be carefully partitioned to fit them into CLBs and IOEs. Two forms of optimization can be done. One can either optimize for implementation efficiency i.e., minimize the usage of CLBs and IOEs, or, one can optimize for speed. To optimize for CLB usage, one must carefully analyze the equations and group signals which can potentially share the same CLB outputs. On the other hand, to optimize for speed, one must pay attention to the routing paths used as well as fanout from each CLB output and the way in which each CLB is configured.

For example, the HDB3 encoding state machine uses four state variables (Q3, Q2, Q1, and Q0) in order to generate fifteen states. First, the state equations are derived from the state diagram. Then, the state equation is partitioned to fit into CLBs. The following equation is the most significant state variable (Q3) of this HDB3 encoding state machine.

\[
Q3 = Q2 \cdot Q1 \cdot Q0 + Q2 \cdot Q1 + Q2 + Q0 + RST + NRZIN
\]

Six CLBs are used to implement this Q3 state equation. Five of the CLBs (Q3INA, Q3INB, Q3INC, Q3IND, and Q3INE) are configured as 4-input variable CLBs which generate a single output. Because these CLBs perform the preliminary logic for input into the block Q3IN, no storage element is necessary in these CLBs. Instead, the storage function is implemented in the block Q3IN. The design details for each CLB is shown in Figure 14.

The B82S line transcoder can be implemented using three PAL® devices: two 16R8 devices and one 16R6 device. All equations for those PAL devices are assertive low; e.g., \(Q2 := C2 \cdot C1 \cdot C0 + C2 \cdot C1 + C2 \cdot C0 + RST + NRZIN\). The LCA device can easily incorporate this assertive low equation simply by adding a tilde (\(\sim\)) in front of the output equation (see Figure 15).

The HDB3 encoder has an ODD_EVEN state machine to check the number of preceding logic ones being odd number or even number. Its ODD_EVEN signal feeds back into the HDB3 encoding state machine. If these two state machines reference the same rising clock edge, it is possible to obtain the wrong result because the HDB3 encoding state machine always gets the ODD_EVEN signal one clock early. Using the falling clock edge can compensate for this timing problem. The positive and negative clock edges are available in each CLB. In this ODD_EVEN state machine, the negative clock is selected (see Figure 16).

Other common functions of communication equipment can be easily implemented using the reconfigurability of the LCA device. For example, two duplex schemes: half duplex and full duplex, can be implemented easily because of the reconfigurability of the IOE. Each IOE can be configured to an input, an output, or a bidirectional input/output with three-state control. Two IOEs are used to implement the full duplex communication, this scheme allows the device to transmit and receive at the same time (see Figure 17a). It can be easily modified to the half-duplex communication simply by using one bidirectional IOE, the information must be transmitted or received exclusively (see Figure 17b).

In addition, loop-back feature can be implemented by reconfiguring LCA's interconnect. Remote loop-back is implemented by disconnecting the line transcoder with the input and output pads, but connecting the input pad to the output pad directly within the transcoder (see Figure 18a). Local loop-back can also be implemented. Connecting the output of the transmitter to the input of the receiver directly, but disconnecting with input and output pads (see Figure 18b).
Reconfigurable Programmable Devices (LCA) Simplify Digital TDM Line Transcoder

Figure 14a. Q3INA's CLB Design

Figure 14b. Q3INB's CLB Design

Figure 14c. Q3INC's CLB Design

Figure 14d. Q3IND's CLB Design

Figure 14e. Q3INE's CLB Design

Figure 14f. Q3IN's CLB Design

Figure 14. The CLB's Design for the Q3 Equation
Reconfigurable Programmable Devices (LCA) Simplify Digital TDM Line Transcoder

Figure 15. C2 is Represented by \( -\overline{(C2)} \)

Figure 16. Negative Clock Edge in the CLB

Figure 17a. Full-Duplex Communication

Figure 17b. Half-Duplex Communication

Figure 18a. Remote Loop Back

Figure 18b. Local Loop Back
**Conclusion**

This design demonstrates the power versatility and benefit of using the LCA device in line coding by exploiting the reconfigurable feature of the device. A single M2018 LCA device can support three different line codes, such as B8ZS, B6ZS, and HDB3 codes.

The B8ZS is used at either 1.544 Mbps T1 carrier or 6.312 Mbps T2 carrier on coaxial pairs. The B8ZS encoder uses twenty-seven CLBs to convert NRZ data into two B8ZS signals, and the B8ZS decoder uses thirty-nine CLBs to convert two B8ZS signals to NRZ data. The B6ZS is used at 6.312 Mbps T2 carrier on symmetrical pairs. The B6ZS encoder uses twenty-nine CLBs to convert NRZ data into two B6ZS signals, and the B6ZS decoder uses thirty-eight CLBs to convert two B6ZS signals to NRZ data. The HDB3 is used at 2.048 Mbps or 8.448 Mbps transmission lines. The HDB3 encoder uses forty CLBs to convert NRZ data into two HDB3 signals and the HDB3 decoder uses thirty-two CLBs to convert two HDB3 signals to NRZ data.

The line transcoder is required when the signal is transmitted over transmission lines. It converts unipolar binary codes to bipolar codes or modified bipolar codes in order to eliminate DC wander and provide the timing information.

**References**

1. Theresa Shafer and Steve Patterson, "B8ZS Coding," Monolithic Memories Application Note AN-169.
4. Recommendation G.703, CCITT Red Book, Volume III.
Building an ESDI Translator Using the M2064 Logic Cell™ Array

Ken Won and Ken Tseng

Abstract

The ESDI (Enhanced Small Device Interface) Standard is a low-cost, high-performance Winchester disk drive interface. The ESDI Translator is an interface controller that is implemented in an ESDI-compatible disk drive.
Building an ESDI Translator
Using the M2064 Logic Cell Array

The ESDI Translator
ESDI is a low-cost, high-performance interface standard suitable for the smaller, high-performance Winchester disk drives currently being produced. The ESDI interface consists of a control cable and a data cable. The control cable allows for a daisy chain connection of up to seven devices (disk or optical drives) with only the last device being terminated. In our design, we assumed that the device is a disk drive. The data cable is attached in a radial configuration (See Figure 1).

The ESDI Translator handshakes serial commands from a disk controller, deserializes the commands and passes the commands to a microcontroller. The command data word structure is shown in Figure 2.

The Command Function bits define functions to be executed by the disk drive. These functions are seek, recalibrate, request status, request configuration, select head group, control, data strobe offset, track offset, initiate diagnostics, set bytes per sector and set configuration. Some of these functions, such as the control function, have modifiers for more detailed functional description. Other commands have parameters that contain numbers. For the seek command, the parameter specifies the cylinder number that the drive will seek to. The request status and request configuration commands require data from the disk drive to be transferred back to the disk controller. In our current design, internal registers A and B in the LCA device represent the upper and lower bytes of the command respectively.

Figure 3 illustrates the relationships between the disk controller, the ESDI Translator, and the microcontroller. The PROM is used to store the configuration data for the LCA device. The Done/Program (D/P) output is driven LOW when the device is being configured. Configuration data is read from the PROM device during configuration. After configuration is complete, the LCA device drives the D/P pin HIGH to deselect the PROM. Drive selection, write protection, command completion and fault detection are also handled by the ESDI Translator.

Figure 1. Connection Between the Controller and Multiple Drives

Figure 2. Command Data Word Structure

Logic Cell™ Array and XACT™ are trademarks of XILINX, Inc.
P-SILOS™ is a trademark of SimuCad Corp.
Why Use an LCA Device in an ESDI Translator

The ESDI interface standard requires more logic functions to be built into the disk drive than some other interface standards, such as the ST506 standard. However, the external dimensions of a disk drive usually have to conform to an industrial standard form factor. Thus, the use of high-density semicustom chips is the logical solution to increase functionality without increasing the external dimensions.

The LCA device is a high-density CMOS integrated circuit available from Monolithic Memories. Its high gate density allows the implementation of an ESDI Translator in a single chip. Fifteen standard SSI and MSI chips would be necessary for the same application. If PLDs are used to implement the ESDI Translator, more than one would be necessary because a large amount of logic is required, thus occupying more board space.

A major advantage in using the LCA device is that it can speed up the design cycle, enabling the manufacturer to have a shorter time-to-market. Also, many peripheral products are produced in relatively small quantities aiming at very specialized markets. The LCA device, which has no NRE cost, makes the production of small quantities more economical than the gate array. Another advantage of the LCA device over other semicustom chips, such as the gate array, is its reprogrammability feature. The LCA device is RAM-based which can easily be reprogrammed by the user in the final system. This feature is especially important in the peripheral products market, where many products have short life spans.

Design Implementation

The ESDI Translator is responsible for all control interfaces between the disk controller and the disk drive. An internal block diagram of the ESDI Translator is shown in Figure 4. It consists of five major logic building blocks:

- Drive selection
- Read gate/write gate
- Counter/controller
- Shift register and parity generator/checker
- Internal register address decoder

Drive selection on ESDI-compatible drives involves three signals from the disk controller, Drive Select 0-2. These three drive select lines are encoded so that up to seven drives may be connected to the same ESDI port, as shown in Table 1. On the LCA device, the drive number is selected by connecting the drive switch pins to either VCC or GND. When the code on the drive select lines, DSX, equals the code on the drive switch pins, DSWX, where X may be 0, 1, or 2, the drive is selected and the Drive Selected signal, DSELD, is asserted. Once the drive has been selected, serial commands output by the disk controller will be read by the LCA device. The actual implementation is shown in Figure 5, using two CLBs and seven IOBs. BDS0 and BDS1 are the names of the CLBs in the current design. In our design, names that begin with the letter B or P are used to designate a CLB or an IOB respectively. SCLK is the system clock.
Building an ESDI Translator Using the M2064 Logic Cell Array

![ESDI Translator Internal Block Diagram](image)

**Figure 4. ESDI Translator Internal Block Diagram**

<table>
<thead>
<tr>
<th>DS2/DSW2</th>
<th>DS1/DSW1</th>
<th>DS0/DSW0</th>
<th>DRIVE</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>None</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Select Drive 1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Select Drive 2</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Select Drive 3</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Select Drive 4</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Select Drive 5</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Select Drive 6</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Select Drive 7</td>
</tr>
</tbody>
</table>

**Table 1. Drive Selection**

![Configuration of the BDS0 and BDS1 CLBs to Provide the Drive Selected Signal](image)

**Figure 5. Configuration of the BDS0 and BDS1 CLBs to Provide the Drive Selected Signal**
Building an ESDI Translator Using the M2064 Logic Cell Array

Figure 6 shows the configurations of the two CLBs as displayed on the computer screen by the XACT development software. In Figure 6a, the CLB is configured as one function of four variables. The D flip-flop is not used. The logic representation, truth table, Karnaugh map, signal names, block name and Boolean equation are shown.

In Figure 6b, the CLB is configured as one function of three variables, the output of which is connected to the D flip-flop. The Q output of the D flip-flop becomes the output of this CLB.

The LCA device also performs logic functions for the Read Gate and Write Gate logic blocks. The Read Gate signal allows data to be read from the disk, and the Write Gate signal allows data to be written on the disk. These signals from the disk controller are input to the LCA device as Read Gate In and Write Gate In. Under normal operating conditions, Read Gate Out is asserted when Read Gate In is asserted and Write Gate Out is asserted when Write Gate In is asserted. When both Read Gate In and Write Gate In are asserted, a write error condition results and the Attention line is asserted, signalling the disk controller that an error has occurred. Also, the LCA device may be used to provide write protection to a disk drive. When the Write Protect signal is asserted, the Write Gate Out signal will not be asserted when the Write Gate In signal is asserted, preventing the write circuitry from being activated. These logic functions are implemented in two CLBs, BRWG0 and BRWG1, as shown in Figure 7.

The Counter/Controller handshakes commands from the disk controller. It also handshakes status/configuration data to the disk controller. It is also responsible for generating the Interrupt, Attention and Command Complete signals. Seventeen bit commands (one bit is parity) are transferred from the disk controller to the LCA device via the Command Data line. The serial bit transfer is performed using a pair of handshaking signals, Transfer Request (TREQ) and Transfer Acknowledge (TACK). TREQ is asserted by the disk controller when a bit is valid on the Command Data line, and TACK is asserted by the LCA device when the command bit has been read. The handshaking action is shown in Figure 8.

A 17-state counter counts the number of command bits shifted in or shifted out of the data registers. Its implementation is shown in Figure 9. The SHIFT signal is asserted, thus incrementing the counter, whenever there is a transfer request and the LCA device is selected. CNT_Q0 is the lowest bit of the shift register counter. This bit is inverted whenever SHIFT is asserted unless sixteen bits have already been shifted into the LCA device (CNT16 asserted, or CKCMD asserted when all seventeen bits have been shifted in). The DATAOUT signal is asserted after a Request Status command or a Request Configuration command has been transferred and the internal data registers have been loaded with data to be serially shifted out. Hence, when DATAOUT is asserted, CKCMD is negated and the counter is enabled.
The logic generation of the Attention signal, ATTEN, is shown in Figure 10. Whenever there is a write fault, WRFLT, a parity error, PARERR, an interface fault, INTFLT, or an external error, CSTS(Change of Status), the ATTEN signal is asserted. When both WRGIN and RDGIN signals are asserted and the LCA device is selected, the WRFLT signal is asserted. The WRFLT signal is negated when the command transferred to the LCA device Register A is the Reset command defined by the ESDI standard, which has a Command Function of 0101 (Control) and a Command Modifier of 0000 (Reset Attention and Standard Status). The Command Function and Command Modifier formats are shown in Figure 2.

Three CLBs, BPG0, BPG1, and BPG2, are responsible for generating the PARERR signal. BPG0 is a multiplexer that selects the source of the input to the parity generator/checker (BPG1). If data is being shifted into the LCA device (parity checker mode), the CMDBITA input is chosen. If data is being shifted out of the LCA device (parity generator mode), the RA_Q7 output is chosen. These two signals are also shown in Figure 11. BPG1 is an odd parity generator/checker. In the parity checker mode, whenever an odd number of ones are passed through this CLB, the output is one. This output signal is connected to BPG2, which inverts the signal and asserts or negates the PARERR signal accordingly. If parity is correct, an interrupt is asserted to the microcontroller informing the microcontroller that a command has been received and is ready to be read. In the parity generator mode, the output of BPG1 is the parity bit. BPG1 is clocked by the SHIFT input, which is asserted whenever there is a transfer request and the LCA device is selected. BPG1 is reset by the Reset Parity Generator input, RSTPGEN. This signal is asserted when either INT is asserted or an interface fault is detected.

The Interface Fault signal is asserted when the LCA device is selected and CNTR is negated before seventeen bits have been transferred. CNTR is asserted after the first command bit is shifted in and is negated after the seventeenth bit is shifted out. BINTFLT0 is clocked by the system clock, SCLK, and reset by the RSTCOS signal. The IOB PCSTS is configured as a buffered input to signal external error conditions.

The microcontroller is able to address four register locations in the LCA: two data registers, BRGA and BRGB, one error register, BDMX, and one command complete register, BRC7. Only three bits in the error register are used. They are bit 0 for parity error, bit 4 for interface fault and bit 7 for write fault. Only one bit in the command complete register is used. This is bit 0, which has a value of zero when the command is completed. The addresses and contents of the registers are shown in Table 2.

The LCA device implementation of the registers and multiplexer is shown in Figure 11. When the interrupt signal is asserted, the microcontroller reads the two data registers by setting the A1 and AO address lines appropriately and asserting the RD signal to the LCA device. These data registers contain the command that is transferred from the disk controller through the CMDBITA input. If the command is a request data command, configuration or status data is written to these two data registers by the microcontroller. These two bytes, plus a parity bit that is generated by the parity generator in the LCA device, are serially transferred to the disk controller over the Config/Status Data line through RA_Q7. After all seventeen bits have been transferred, the Command Complete signal is asserted. If the command is not a request data command, the microcontroller executes the command and upon completion, writes a byte of zeros to the command complete register of the LCA. When the command complete register is written with all zeros, the Command Complete signal is asserted by the LCA device. The command complete register may only be written, not read. The status register contains error bits that are set when errors are detected. This register may only be read and not written.

Table 2. Register Addresses and Contents

<table>
<thead>
<tr>
<th>A1</th>
<th>A0</th>
<th>REGISTER</th>
<th>BIT NUMBER</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>REGISTER A</td>
<td>7 6 5 4 3 2 1 0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>REGISTER B</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>ERROR REGISTER</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>COMMAND COMPLETE REGISTER</td>
<td></td>
</tr>
</tbody>
</table>

Figure 9. 17-State Counter Implemented in six CLBs
Figure 10. Generation of the Attention Signal by the Four Possible Error Conditions
Figure 11. Registers A, B, Error Register, and Multiplexer
Figure 11. Registers A, B, Error Register, and Multiplexer (Continued)
Design Considerations

The circuit diagram of the programmed LCA device is shown in Figure 12. This design implementation uses sixty-three of the sixty-four CLBs within the LCA. This translates into a 98% usage. The rightmost column of CLBs contains the multiplexer, which selects between registers A, B, or the error register to be placed on the data bus. Registers A and B are placed on the third and second column from the right end, respectively. The registers and multiplexer are placed physically close to each other to simplify routing. The CLBs which execute a particular function are placed physically next to each other. These functions include the parity generator/checker, 17-state counter, read gate/write gate logic, drive selection logic and error detection logic. The read gate/write gate logic and the drive selection logic, which require much I/O activity, are placed in CLBs near the edges of the device.

Another consideration in implementing an LCA design is routing. Long lines are available for signals that have to travel a long distance within the LCA device. These lines can also be used for signals that must have minimal skew between different destinations. An automatic routing program is available in the XACT software package.

Routing requires careful consideration when a design uses a high percentage of the available CLBs (above 95%). Although automatic routing is available, designs with high CLB usage may require point-to-point routing (EDITNET command in XACT). Some of the techniques that can be used are swapping input pins, swapping CLBs, and implementing buffers in unused sections of the CLBs. When swapping input pins, the designer must be careful because certain functions, such as the clock input to the flip-flop, may only be input on certain pins. Swapping CLBs is very simple because the XACT software provides a command for swapping CLBs, but sometimes not all of the signals can be successfully rerouted. Passing a signal through a CLB presents a routing channel that is not otherwise available. However, a delay is added to the signal. Usually, a combination of these techniques can be used to successfully route a high-density design.

The high number of IOBs in the LCA device gives the designer much flexibility in designing the pinout of the device. In this design, thirty-five of the IOBs are used. The IOBs that are not being used for the actual design are not left unused, but are configured as outputs and are connected to various signals within the LCA device to provide test points for the LCA device. This greatly increases the testability of the design once it is placed on the board.

XACT is used by the designer to define the CLBs and IOBs, and to perform EDITNET. Alternately, the design may be input using the schematic capture software offered by Daisy and Futurenet. In these methods, an automatic place and route software package divides the design into blocks that may be implemented in CLBs and IOBs, and routes the CLBs and IOBs automatically. Once the design has been completed, it may be simulated using the software package P-SILOS.

Conclusion

The LCA device provides many advantages to the user. Its high gate count and I/O capability could potentially replace several PLDs in many applications, hence reducing board space. The LCA device is preferred by many customers over gate arrays because it is reprogrammable 'on-the-fly' and there are no long design cycles and initial NRE cost of a gate array. The current design file, XDES15.LCA, is available upon request. The bit pattern and the .LCA file will be provided for programming the LCA device in an EPROM.
Figure 12. ESDI Translator LCA Design
Using the Logic Cell™ Array to Build a Pseudo-Random-Number Generator

Mohammed Wasfi

Abstract
The Logic Cell Array is a programmable integrated CMOS circuit that can easily be configured to perform many LSI functions. This Application Note will discuss how the LCA device can be used in the design of an 8-bit Pseudo-Random-Number Generator. The design consists of three major components: the registers that generate the random numbers, the 1-Hz Clock, and the decoding circuitry. The decoding circuitry can be used with two seven-segment displays to show the value of the binary random number in hexadecimal (00-FF) format.
Using the Logic Cell Array to Build a Pseudo-Random-Number Generator

Mohammed Wasfi

Introduction

The LCA device is a high-density programmable integrated circuit. Due to its flexible architecture and programmability, it can be configured to perform many functions. In this case, the LCA device was configured as an 8-bit Pseudo-Random-Number (PRN) Generator. The high density of this device made it possible to implement additional needed circuits such as the registers, clock, and the decoders for the seven-segment displays. Additional information on the LCA device can be found in the LCA Applications Handbook. Information on configuring the LCA device is discussed in Application Note 182.

Random Number Applications

A Pseudo-Random-Number Generator can be used in a wide range of applications. A common application for the PRN Generator is electronic games where a random number is used to create a random event. Another sophisticated application is signal scrambling, for securing communications, where a random number is added to a transmitted signal for scrambling, and subtracted for descrambling.

Pseudo-Random-Number (PRN) Generation

There are several different methods of generating a random number. In this LCA device application, however, the PRN is generated using a shift register with feedback. To achieve a random output, the feedback comes from the prime number bits (flip-flops).

Although the output of the shift register is a random number, the cycle of random numbers generated is repeated after a certain period. This is indicated by the term "pseudo." The length of the random number generation period depends on the number of flip-flops used. The period length is calculated as follows:

\[ \text{Period} = 2^n - 1, \text{where } n \text{ is the number of flip-flops.} \]

The reason for the subtraction of one state is that the state of all flip-flops set to zero is illegal (causes a lockout).

The Logic Cell Array

The LCA device is a configurable large scale integrated CMOS circuit. It is RAM based, so its configuration can be changed by simply loading it with a new configuration bit stream. The device architecture consists of Configurable Logic Blocks (CLBs) and configurable I/O Blocks (IOBs). Each CLB has a register and can implement any one function of up to four variables or any two functions of up to three variables. The IOB can be configured as an input, registered input, output, or an output with a three-state function.

Two types of LCA devices are currently available from Monolithic Memories, the M2064 and the M2018. The M2064 has 64 CLBs arranged as an 8 by 8 matrix. The M2018 has 100 CLBs arranged as a 10 by 10 matrix. For this design, an M2064 was used because only 52 CLBs were needed to implement the design fully (Figure 1).
Why Use an LCA Device?

There are several reasons for choosing the LCA device to design a random number generator. The LCA device not only offers a large number of flip-flops in the CLBs, but also offers additional IOB flip-flops (one flip-flop per CLB/IOB, one hundred CLBs and seventy-four IOBs in the M2018, sixty-four CLBs and fifty-eight IOBs in the M2064). This enables the user to generate a very large period during which the PRN sequence will not repeat itself. In addition, the large number of configurable IOBs available makes it easy to generate a large random number.

One of the many features of the LCA device is its high density. There are approximately 1,200 gates in the M2064 and 1,600 gates in the M2018. The high gate count allows the implementation of additional circuits, such as the clock for the registers that normally are added outside of the chip.

Another feature of the LCA device is its configurability. For example, the ability to output a PRN of a certain size, then change the size to make it smaller or larger, or change other logic without having to use a new part is a big advantage.

With an LCA device, one has access to a macro library in the XACT™ Development System, which is the software used to configure the LCA device (available from Monolithic Memories). These macros simplify the designs considerably. Approximately 75% of this design used Monolithic Memories-supplied macros.

Design Breakdown

The design of the PRN generator consists of three major components (Figure 2). The first component is the shift register. Three 8-bit shift registers are used to generate the PRNs using D-type flip-flops. Since there are 24 flip-flops, the length of the PRN sequence period is:

\[ 2^{24} - 1 = 16,777,215 \text{ states}, \]

after which the PRN sequence repeats itself.

The second component is the clock for the flip-flops. A low frequency (100-Hz) R-C Oscillator was used. This frequency is then divided by 100 (using two modulo-10 counters) which results in a 1-Hz clock that is used for the flip-flops.

The third component is the decoding circuitry for the seven-segment displays. Two seven-segment display decoding circuits are implemented in the LCA device to show the hexadecimal equivalent of the binary output. This makes it easier to study the nature of the PRNs generated.

Design Implementation in the LCA Device

The main component in this design is the shift register. The design of a shift register is relatively simple. A register (flip-flop) in a CLB uses one input, a clock, and outputs the value that was the state of the input delayed by one clock period (Figure 5). Then all twenty-four registers in the CLBs are cascaded together forming a 24-bit shift register. The macro, RS8, available with the Monolithic Memories XACT Macroccl Library, is an 8-bit shift register (Figure 3). Therefore, it is possible to invoke that macro and cascade three 8-bit shift registers (RQL, RQM and RQH) to get the required shift register size.

The feedback from the shift register, in order to produce a random outcome, has to come from a prime number bit (register). Therefore, the feedback from bits 11 and 23 were chosen. Since the PRN sequence cannot start without a logic high input seed from an IOB configured as an input (Figure 7b), a certain function (XOR_F) implementing the input seed and the two feedbacks was used. This function guarantees lockout will not occur (such as in the case of the input staying at a logic HIGH), and also adds to the randomness of registered outputs (Figure 6).

\[ \text{XOR}_\text{F} = (B + C) \oplus A \]

B : input seed
C : 2nd feedback (bit 23)
A : 1st feedback (bit 11)
@ : exclusive or function

The 8-bit output of the third shift register (RQH) is connected to eight (8) IOBs configured as outputs (Figure 7a). The output of RQH is also connected to the two seven-segment decoders.

The clock for the registers was chosen as 1 Hz. This frequency was generated using a low-frequency (100-Hz) resistor-capacitor oscillator. This oscillator is also available as a macro, GOSC, with the XACT Development System (Figure 8a). The values for the resistors and capacitors (R1, R2, C1, C2) used with CQ and CQL are 100 Kohms and 0.1 microfarads. The Boolean equations for the Clock are:

\[ \text{Q} = -R \cdot (S+R) \]
\[ \text{QL} = -Q \]

A modulo-100 counter was used as a “divide by” to get the 1 Hz clock needed. The modulo-100 is implemented using two cascaded 4-bit BCD (modulo-10) counters. The macro for the counters is also available with the XACT Development System (Figure 8b). The output of the modulo-100 is routed to the Global Clock Buffer (GCB). The output of the GCB is routed to the registers via long-line interconnects.
Finally, two decoders for the seven-segment displays were designed. The least and the most significant four bits of the PRN used one decoder each to decode binary 0000-1111 as hexadecimal 0-F (Table I). The decoder outputs were routed to IOBs configured as output buffers, where they were wired to a bus driver (74LS244), that could be used to drive the seven-segment display. Eight CLBs per decoder were used (Figure 4). Each CLB was configured to control one segment in the display, including the Decimal Point (DP). See Table II.

![Shift Register Macro](image)

**Figure 3. Shift Register Macro**

<table>
<thead>
<tr>
<th>4-BIT INPUT (FROM PRN)</th>
<th>HEXADECIMAL OUTPUT</th>
<th>SEGMENTS</th>
</tr>
</thead>
<tbody>
<tr>
<td>**D</td>
<td>C</td>
<td>B</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

**Table I. Decoding Table**
Using the Logic Cell Array to Build a Pseudo-Random-Number Generator

Figure 4a. A-Segment CLB

Figure 4b. B-Segment CLB

Figure 4c. C-Segment CLB

Figure 4d. D-Segment CLB

Figure 4e. E-Segment CLB

Figure 4f. F-Segment CLB

Figure 4g. G-Segment CLB

Figure 4h. DP-Segment CLB

Figure 4. Seven Segment Decoder
Using the Logic Cell Array to Build a Pseudo-Random-Number Generator

\[ T = T_1 + T_2 = N ((R_1 C_1) + (R_2 C_2)) \]

where 
- \( N = \approx 0.35 \) for TTL threshold
- \( N = \approx 0.75 \) for CMOS threshold

when each capacitor is allowed to be discharged by the LCA during opposite timing phase

Capacitor might partially charge due to a delayed three-state routing.

\[ Q = -R \cdot (S + Q) \]
\[ Q_L = \neg Q \]

Figure 8a. Clock Macro

Figure 8b. BCD Counter Macro

Figure 8. Register Clock Components
Using the Logic Cell Array to Build a Pseudo-Random-Number Generator

Figure 5. Shift Register CLB

Figure 7a. Output CLB

Figure 6. XOR _ F CLB

Figure 7b. Input CLB

Figure 7. I/O CLB
Using the Logic Cell Array to Build a Pseudo-Random-Number Generator

<table>
<thead>
<tr>
<th>PIN</th>
<th>NAME</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>1,35</td>
<td>GND</td>
<td>Ground</td>
</tr>
<tr>
<td>52,18</td>
<td>VCC</td>
<td>Power</td>
</tr>
<tr>
<td>11</td>
<td>INPUT</td>
<td>Input seed</td>
</tr>
<tr>
<td>12,14</td>
<td>CQ,CQL</td>
<td>rc oscillator inputs</td>
</tr>
<tr>
<td>13</td>
<td>HA_7seg</td>
<td>Decoder outputs for segments in high order display (a)</td>
</tr>
<tr>
<td>15</td>
<td>HB_7seg</td>
<td>b segment</td>
</tr>
<tr>
<td>16</td>
<td>HC_7seg</td>
<td>c segment</td>
</tr>
<tr>
<td>17</td>
<td>HD_7seg</td>
<td>d segment</td>
</tr>
<tr>
<td>19</td>
<td>HE_7seg</td>
<td>e segment</td>
</tr>
<tr>
<td>21</td>
<td>HF_7seg</td>
<td>f segment</td>
</tr>
<tr>
<td>23</td>
<td>HG_7seg</td>
<td>g segment</td>
</tr>
<tr>
<td>43</td>
<td>HDP_7seg</td>
<td>dp segment</td>
</tr>
<tr>
<td>38</td>
<td>A_7seg</td>
<td>Decoder outputs for segments in low order display (a)</td>
</tr>
<tr>
<td>39</td>
<td>B_7seg</td>
<td>b segment</td>
</tr>
<tr>
<td>40</td>
<td>C_7seg</td>
<td>c segment</td>
</tr>
<tr>
<td>47</td>
<td>D_7seg</td>
<td>d segment</td>
</tr>
<tr>
<td>49</td>
<td>E_7seg</td>
<td>e segment</td>
</tr>
<tr>
<td>53</td>
<td>F_7seg</td>
<td>f segment</td>
</tr>
<tr>
<td>55</td>
<td>G_7seg</td>
<td>g segment</td>
</tr>
<tr>
<td>20</td>
<td>DP_7seg</td>
<td>dp segment</td>
</tr>
<tr>
<td>29</td>
<td>LSBIT_out</td>
<td>Least significant PRN bit</td>
</tr>
<tr>
<td>30</td>
<td>BIN6_out</td>
<td>PRN bit</td>
</tr>
<tr>
<td>31</td>
<td>BIN5_out</td>
<td>PRN bit</td>
</tr>
<tr>
<td>32</td>
<td>BIN4_out</td>
<td>PRN bit</td>
</tr>
<tr>
<td>33</td>
<td>BIN3_out</td>
<td>PRN bit</td>
</tr>
<tr>
<td>34</td>
<td>BIN2_out</td>
<td>PRN bit</td>
</tr>
<tr>
<td>36</td>
<td>BIN1_out</td>
<td>PRN bit</td>
</tr>
<tr>
<td>37</td>
<td>MSBIT_out</td>
<td>Most significant PRN bit</td>
</tr>
</tbody>
</table>

Table II. LCA Device Pins Used and Their Description

Conclusion
From the PRN Generator design, the advantages of using the LCA device in such an application were shown. The configurability of the LCA device makes it very versatile. The M2064 was capable of replacing several parts that normally would be needed to implement this design. The availability of the macros also helped considerably in the design implementation. It is always possible to modify certain features in this design if needed, such as the clock frequency or the size of the PRN generated, by simply re-routing certain lines in the LCA device. These features make the use of the LCA device very desirable. This design file is available from Monolithic Memories upon request. Please ask for XDES16.LCA.

References
1. Nadia Sachs, "Pseudo-Random-Number Generator (a Disguised PAL)," Monolithic Memories Application Note AN-118.
2. LCA device Macrocell Library Book, Monolithic Memories Inc.
64K Deep FIFO - Dynamic RAM Controller is Implemented in the M2018 LCA Device

Karen Spesard and Chris Jay

Abstract
First-in, first-out (FIFO) buffers are used extensively in interface and communication systems where it is necessary to provide temporary storage between two asynchronously operating devices. For relatively shallow FIFOs, up to 128 locations deep, dedicated register-based FIFOs are the best solution. For medium and deep organizations, up to 64K deep, the register architecture would be unsuitable because of the high package count required for implementation. Also, with a large number of registered FIFO devices, power dissipation could be very high and lead to system reliability problems. Using the high-storage density of RAM and controlling it as a FIFO (in other words, a FIFO-RAM Controller) solves the problem of a high package count in medium to large FIFO arrays.

The two types of RAM to be considered are static RAM (SRAM) and dynamic RAM (DRAM). SRAMs usually require more board space to produce large memory arrays because their packages are larger than DRAM packages. As a result, SRAMs may be used for medium-sized FIFO organizations, from 128 bytes to 8K bytes. For large FIFO arrays, SRAM devices occupy too much board space. DRAMs, used as stand-alone memory cells require the support of more components to handle multiplexing and refresh, whereas SRAMs can be used without that support. To address this issue, a low-chip-count, low-cost DRAM solution (FIFO-DRAM Controller) has been developed for large FIFO buffers in the M2018 Logic Cell™ Array (LCA device). The LCA device addresses the DRAM memory chips as a FIFO array and provides the interface and refresh control signals to the DRAMs.

The LCA device, a high-density programmable CMOS device, has been programmed to perform all of the necessary logic functions for a large FIFO - DRAM Controller. It can control 64K X 4, X 8, X 16, X 32 (and so on) DRAMs. The M2018 design handles the refresh, read and write functions as well as hand-shake activity to external circuits. Status flags, such as FIFO full and empty, are also provided to the two asynchronous transmitter and receiver circuits. In addition, since the LCA circuit is reconfigurable, the design can be modified as needed to meet specific design requirements.
64K Deep FIFO - Dynamic RAM Controller is Implemented in the M2018 LCA Device

Karen Spesard and Chris Jay

Introduction
Data communication often requires buffering of large amounts of information between asynchronously operating devices along a data channel. For instance, in a video teleconferencing system, one Mbyte of data per video image (1K x 1K pixels) is generated. After compression, 32 Kbytes of each image must be passed to a buffer to wait for transmission along the data channel. The next image is then free to be processed by the system. For optimal performance, first-in, first-out (FIFO) buffers can be effectively used to hold the data in temporary storage sites between the transmitter and receiver nodes. The data can be stored either in a stack of registers organized as a FIFO, or a RAM controlled as a FIFO. For very large FIFO organizations, however, the use of inexpensive RAM devices is the only practical alternative. It keeps the overall system size to a minimum which will, in effect, reduce the overall system cost.

Dynamic RAM (DRAM) devices, when controlled, can be used as a temporary buffer. Though relatively inexpensive and small in size, compared with static RAM (SRAM) devices, stand-alone DRAMs require more complex interface and refresh control circuitries. As a result, more components could be required in DRAM systems. To reduce the overall chip count, a Logic Cell Array (LCA device) has been programmed to perform as a 64K x 4, x 8, x 16, x 32, (and so on) FIFO-DRAM Controller. The Controller allows the DRAM to function as a FIFO by providing the control circuitry necessary for operation.

With the design implemented in the M2018 LCA device, minor changes in the design can be implemented quickly and easily due to the device's re-programmability feature. For example, if the type of DRAM or any of its parameters had to be changed for any reason, the original LCA device can accommodate the necessary logic modification.

The LCA device provides an intelligent approach to designing circuits in an efficient and timely manner. It can speed up the design process significantly (to just a few days) with low-cost user-friendly software tools that do not require a non-recurring expense (NRE), as gate arrays often do. As a result, many products can be introduced quickly and economically. The LCA device can automatically load itself and is field programmable and reconfigurable. Therefore, it can be used for system development, for existing design modifications and for volume production. This application note describes the design methodology used for the development of the Controller in the LCA device.

![Diagram](image.png)

Figure 1. A Typical DRAM Interface Using the FIFO-DRAM Controller in the M2018 LCA Device
64K Deep FIFO - Dynamic RAM Controller is Implemented in the M2018 LCA Device

The FIFO-DRAM Controller

The FIFO-DRAM Controller in the LCA device, together with an array of two DRAMs and two DRAM drivers, comprises a FIFO memory. (See Figure 1.) The Controller handles the row and column address multiplexing by applying a RAS before CAS cycle for memory read and write operations. Refresh timing, however, is applied as a CAS before RAS cycle, which takes precedence over read/write activity. The DRAMs used for this application must have on-chip refresh counters. The µPD41464 64K x 4 DRAMs manufactured by NEC were used in this application because they have a CAS before RAS internal address refresh mode. Thus, no refresh counter was needed in the design of the FIFO-DRAM Controller. The Controller in the LCA device also provides for access and refresh timing via the control signals, RAS, CAS, OE, and WE, and provides for read/write status flags.

The block diagram of the controller is shown in Figure 2. The only controller inputs are the request-to-read (REQRD) and request-to-write (REQWR) signals. These signals are active LOW and come from some external logic or a microprocessor. They drive the control circuitry section of the device, which generates the CAS and RAS signals, among others. The FIFO-DRAM Controller in the LCA device also consists of an address generation section and a buffer status section. Two internal 16-bit counters and 24 2:1 multiplexers generate the addresses for the DRAM array. A 16-bit up/down counter generates the status information for the three status flags: full, empty, and half-full.
The Control Circuitry

The control circuitry provides the ready-to-read (ROY READ) and ready-to-write (ROY WRITE) signals for the system. Other signals include the row/column select (ROW/COL SELECT) signal for multiplexing the addressed data, the enable access (ENAC) signal for clocking the status counter, and the read and write grant signals for the three 16-bit counters. It also provides the four active low signals which directly interface with the DRAM: the row address strobe (RAS), the column address strobe (CAS), the write enable (WE), and the output enable (OE) signals.

The logic used for generating each of the control signals is shown in Figure 3. Much of this logic was derived from the published input signal specifications of the DRAM. For example, the RAS (A), ROW/COL SELECT (B), and CAS (C) logic was created from the write cycle, read cycle, and CAS before RAS refresh cycle timing waveforms published in the NEC µPD41464 datasheet. Samples of these timing cycles are given in Figures 4, 5, and 6. The state diagrams were then produced from these waveforms as in Figure 7A. Next, the state excitation maps or Karnaugh maps for each signal were constructed. Reducing the logic for each map and “OR”ing the enable access and enable refresh cycles together, produced the appropriate registered states as in Figures 7B, 7C, and 7D. The logic for the OE and WE signals were generated in a similar manner.

To resolve simultaneous read, write, and refresh requests, arbitration logic was added. This was done while creating logic for the other control outputs. The logic designed in the controller gives the refresh request highest priority and the read request the lowest priority. (Refresh requests should have the highest priority because data integrity must be maintained. Write requests have the next highest priority because data is typically held on the data bus for a specific period of time and must be written before being lost.) Therefore, the read grant signal will not go HIGH until refresh and/or write cycle requests already pending have been completed. Likewise, the write grant signal will not go HIGH until a pending refresh cycle request has been completed. Also, when a refresh cycle is requested, both the RRDY READ and RRDY WRITE signals will be held LOW until the refresh cycle has been finished. This insures that any read and/or write requests already in queue will be completed first. The timing diagram illustrating the refresh and write priority is shown in Figure 8.

The request-to-read and request-to-write registers are reset after every read and write operation, respectively. Accordingly, the refresh register is also reset after every refresh operation. When no requests are pending, a register “sets” or holds the RAS, ROW/COL SELECT, and CAS signals HIGH. The signals are now ready for the next request.

Figure 3. Control Circuitry for the FIFO-DRAM Controller
1. The request to write \( \overline{REQWR} \) line transitions LOW to enable an active write cycle. An active LOW transition starts the write process. The ready RDY WRITE output goes LOW to indicate that a current write cycle is in progress and no further writes should be attempted until it goes HIGH again.

2. The first active HIGH transition of the system clock sets the ROW address outputs from the write counter to the address output pins.

3. The second clock rising edge enables the active LOW transition of the RAS output to the DRAM array.

4. The third clock edge switches an internal address multiplexer which sets up a valid column address output on the input to the memory address lines. This signal is internally gated with the request to write flag to produce an early LOW active write output signal to the DRAM devices.

5. The fourth clock edge strobes the \( \overline{CAS} \) output with the WE input LOW for a valid write. The \( \overline{OE} \) input can be either a HIGH or LOW during this write cycle.

6. The internal state machine controlling \( \overline{RAS} \) and \( \overline{CAS} \) activity holds the WE LOW for one and a half clock cycles and the RAS and \( \overline{CAS} \) line LOW for two clock cycles. The GAS and RAS lines are taken inactive simultaneously. The ready write signal, RDY WRITE goes HIGH to indicate that another write cycle may commence.

Note: The frequency of the system clock is determined by the selection of external components which are configured to an internal oscillator. Details of this are shown in Figure 20.
1. The request to read REQRD input transitions LOW to enable an active read cycle. The ready to read output, RDY READ, from the FIFO DRAM Controller goes LOW to indicate that a read cycle is in progress and no further read cycles should be requested until the read cycle is completed.

The timing of row address valid, active RAS, column address valid and active CAS is identical to that shown in Figure 4. The only difference in the timing is that the WE line stays inactive HIGH and the OE signal is gated active LOW one clock period after the LOW transition of RAS.
1. The RFSH CLOCK is driven active LOW to initiate a CAS before RAS refresh cycle. Ready to Read and Ready to Write Controller outputs are driven LOW to allow an uninterrupted DRAM refresh.
2. The CAS output goes LOW after the first clock edge.
3. The RAS output goes LOW following the second clock edge.
4. The RAS and CAS outputs go inactive after the third clock edge and RDY WRITE and RDY READ go HIGH to indicate that read and write operations may recommence.
64K Deep FIFO - Dynamic RAM Controller is Implemented in the M2018 LCA Device

Figure 7a. State Diagrams for Read and Write Access Enable (ENAC) and Refresh Enable (RFSH) where A = RAS Signal, B = ROW/COLUMN ADDRESS SELECT Signal, and C = CAS Signal

Figure 7b. State Excitation Map for RAS (A) Signal and Corresponding Equation

Figure 7c. State Excitation Map for ROW/COLUMN ADDRESS SELECT (B) Signal and Corresponding Equation

Figure 7d. State Excitation Map for CAS (C) Signal and Corresponding Equation

1. Figure 7a shows the truth tables for the controlling state machine within the FIFO DRAM controller. Two tables should be considered, one for access, read and write activity, and one for DRAM refreshing. The Enable access ENAC and enable refresh RFSH are mutually exclusive events such that \( \neg \text{RFSH} \) may be considered as ENAC and \( \neg \text{ENAC} \) as RFSH. When ENAC is TRUE (1) an access cycle is taking place, and RFSH will be FALSE (0). Refreshing takes place when RFSH is TRUE and ENAC is FALSE. The Karnaugh map shown in Figure 7b represents the state excitation map for the RAS output during access and refresh cycles. A logic one entry represents an active condition and a logic zero a passive state. The Greek letter theta represents a "don't care" state and can be included in minimization considerations. For the map shown in Figure 7b, minimization yields:

\[
\begin{align*}
\text{ENAC} = 1, & \quad A := -A'B'C + RFSH \times C \quad \text{.......................... 1} \\
\text{RFSH} = 1, & \quad A := -A'B'C + C \quad \text{.......................... 2} \\
\text{now, combining 1 and 2;} & \quad A := -A'B'C + RFSH \times C \quad \text.......................... 3 \\
& \quad \text{because} \\
\text{ENAC} + \text{RFSH} = 1. & \quad A := -A'B'C + RFSH \times C \quad \text{.......................... 4} \\
\text{substituting the values of RAS, ROW/COL and CAS for A, B and C respectively we get;} & \quad \text{RAS} := -\text{RAS} \times (\text{ROW/COL SEL}) \times -\text{CAS} + \text{RFSH} \times \text{CAS}
\end{align*}
\]

The equations for ROW/COL SEL and CAS are derived in a similar way.
The system and refresh clocks are generated internally with two resistor-capacitor oscillator networks each. The system clock can be designed to run as fast as 5 MHz. The refresh clock, which is the request to refresh signal, is designed to operate at 15.6 µs or 64 KHz. This is because the DRAM must be refreshed with 256 refresh cycles in a period of 4 ms. (The implementation of the oscillator network will be described in the System Clock and Refresh Request Clock Configurations section.)

**READ/WRITE Address Circuitry**

The FIFO-DRAM Controller in the LCA device is based on a FIFO architecture and consists of a read and write pointer. The addresses of these pointers are generated by two 16-bit counters and 24 2:1 multiplexers, as shown in Figure 9. When the write grant signal is activated, the first 16-bit counter is incremented. The write address is then multiplexed through to the row/column select multiplexer. As the ROW/COL SELECT signal goes HIGH, the first eight bits of the counter (the row address of the DRAM array) are transferred onto the address bus, and as the ROW/COL SELECT signal goes LOW, the second eight bits of the counter (the column address of the DRAM array) are transferred onto the address bus. An equivalent sequence also occurs when a read grant signal is activated.
Figure 9. Read/Write-Row/Column Address Generation
The Status Counter

Information about the FIFO buffer is provided by the three status flags: full, half-full, and empty, which are all active HIGH. The full and empty flags indicate overflow and underflow conditions, whereas the half-full flag gives an indication to a processor of the speed at which the buffer is being filled. It acts as a monitor rather than as a prevention flag.

The flags are constructed from the status counter, a 16-bit up/down counter shown in Figure 10. The clock input to the counter is the enable access signal that "OR"s the write grant and read grant signals. When the write grant signal is HIGH, the counter is incremented, and when the write grant signal is LOW, the counter is decremented. For example, if the count reaches 0000 Hex during a read operation, the FIFO buffer is empty, and if the count reaches FFFF Hex during a write operation, the buffer is full. If the count reaches 7FFF Hex, the buffer is half-full.

Logic Cell Array Implementation

The FIFO-DRAM Controller design was implemented in one chip: the M2018 Logic Cell Array, a high-density, programmable CMOS device. This device contains 100 Configurable Logic Blocks (CLBs) containing one register element each. The register element can be configured as a D-type flip-flop or latch, or it can be bypassed totally, supplying a strictly combinational output. The two available CLB outputs can be configured as a function of four Boolean input variables, or two functions of three input variables each.

The M2018 also contains 74 configurable input/output blocks (IOBs). Sixty-four of these blocks can be configured to perform a variety of logic functions. Each has the capability to drive an output, receive an input, clock the input into a flip-flop, or provide both input and output capability under three-state control.

Together, the CLBs and the IOBs provide 1800 usable logic gates. These gates are configured when data is loaded into the LCA device for programming — usually from an EPROM or microprocessor. For example, the configuration data file, <filename>.prm, to be programmed into an EPROM, is generated using the program, MAKEPROM (part of Monolithic Memories' XACT™ Development System), which loads the bit stream into PROM memory locations. The input to the MAKEPROM program, <filename>.bit, is generated from the MAKEBITS program which outputs the bit stream of the current design. The design is entered by either using one of the schematic capture-based systems from Daisy, Mentor Graphics®, OrCAD™, and Futurenet® or by partitioning the required logic and inserting it in a graphics environment on the IBM® PC-XT/AT® using Monolithic Memories' XACT™ LCA Editor. The LCA Editor was used to create the LCA design of the FIFO-DRAM Controller. The design implementation using CLBs and IOBs is described below.

CLB Implementation

The RAS, ROW/COL SELECT, and CAS outputs are implemented in four CLBs. The RAS output utilizes two CLBs but also includes the enable access signal (ENAC2), which is reset with part of a RAS function. Figure 11 shows the CLBs that comprise the RAS output. The COMRASB signal, in Figure 11A, is configured from a three-input combinational function (the Y output-G base) and is an input to the RAS block, in Figure 11B. This signal is "OR"ed with two more signals. The RAS block, configured as a D-type flip-flop with a "set" function, produces the RAS output.

The CLB configurations for the ROW/COL SELECT and CAS outputs are shown in Figures 12 and 13. The CLB equations correspond to the equations for each signal given in Figure 7.
The CLB configuration for the 16-bit read counter is shown in Figure 14. The first (row - read) bit, RRQ0 on output Y, is illustrated in Figure 14A. It is generated through a flip-flop and is clocked with the read select signal. The terminal count for the next bit is generated from RRBIT0, the X output. Figure 14B shows the configuration for the second bit of the read counter.

The read/write address multiplexer is designed with four Boolean input variables as in Figure 15. The RRQ0 signal (row-read) is selected if the read select signal is active HIGH, and the RWQ0 signal (row-write) is selected if the write select signal is active HIGH. This implementation is combinational and has only one output.

The row/column address multiplexer is designed with a CLB internal multiplexer base, FGM, as in Figure 16. When the ROW/COL SELECT signal is HIGH, the ROW address, MA0, is selected, and when the ROW/COL SELECT signal is LOW, the COLUMN address, MB0, is selected. This last multiplexer is registered and outputs the address that is output to the DRAM.
64K Deep FIFO - Dynamic RAM Controller is Implemented in the M2018 LCA Device

**IOB Implementation**

An example of an IOB configured to receive data and drive inputs is shown in Figure 18A for the write request (WRR) block. An IOB configured as an output buffer for the RAS signal is shown in Figure 18B. The placement of the IOBs, like the CLBs, was optimized for the best circuit layout.

![Figure 18a. The Input IOB Configuration Used for the Write Request Signal](image)

![Figure 18b. The Output IOB Configuration Used for the RAS Signal](image)

Figure 18. Two IOB Configurations Used in the FIFO-RAM Controller Design

**Figure 17. Two CLBs which Produce the Third and Fourth Bits of the Status Counter**

The up/down status counter implementation is shown in Figure 17A. The second status counter bit is produced from the Y output, a registered function of input C2X, C2Y and the feedback Q. The flip-flop clock is ENAC, the DRAM access signal. The X output is a combinational function of C2X and Q. The third bit is produced from a registered equation as shown in Figure 17B.

![Figure 17a. The Third Bit of the Status Counter](image)

![Figure 17b. The Fourth Bit of the Status Counter](image)
**System Clock and Refresh Request Clock Configurations**

The system and refresh request clocks were designed with two general purpose oscillator networks. Each oscillator was built using two IOBs, one CLB, and two external resistor/capacitor networks — R1, C1, and R2, C2. The IOBs and CLBs were configured by calling up the dedicated macro, GOSC, from Monolithic Memories’ Macrocell Library, available as part of the schematic capture entry package or the XACT EditLCA entry package. The LCA implementation of the relaxation oscillator is shown in Figure 19. Here, the programmable routing connections of CLB block RFSCLK and IOB blocks CQLrfs and CQrfs are shown for the refresh clock. Figure 20 illustrates the logic schematic for both the system and refresh clocks and the correct connections to the resistor/capacitor network.

The CLB and IOB configurations for the generation of the refresh clock are shown in Figure 21. Notice that in both the IOB configurations, the bidirectional three-state buffer is used. Notice also that in the CLB configuration, the output X, RFSQ, is the same as the input D. This is possible even though the function is not registered.

The calculation of the resistor/capacitor values for the clocks is given below. For an even mark/space ratio, \( R = R1 = R2 \) and \( C = C1 = C2 \). Each timing phase (1/2 of a cycle period) is given by the following formula:

- \( T_1 = 0.35 (C1 \cdot R1 \cdot 2) \) for TTL voltage thresholds, and
- \( T_2 = 0.75 (C2 \cdot R2 \cdot 2) \) for CMOS voltage thresholds.

The general expression for the calculation becomes:

\[
T = N \cdot ((R1 \cdot C1) + (R2 \cdot C2))
\]

where \( N \) is 0.35 for TTL and 0.75 for CMOS.

The resistor and capacitor values chosen for the system clock are \( R1 = R2 = 30 \) ohms and \( C1 = C2 = 0.01 \) microfarads. These components are connected to pins 11 and 13 and result in a frequency of 5 MHz. The values chosen for the refresh request clock are \( R1 = R2 = 2.2 \) Kohms and \( C1 = C2 = 0.01 \) microfarad. They are connected to pins 24 and 28 and result in a frequency of approximately 64 KHz. The GOSC macro IOBs can be connected to any pins as long as they are not connected to pins dedicated to configuring the LCA device. Dedicated configuration pins cannot be loaded with components such as capacitors because they could prevent the LCA device from reading valid data by corrupting hold and setup times.

**Design Considerations**

The circuit diagram of the FIFO-DRAM Controller in the LCA device is shown in Figure 22. This implementation used all 100 CLBs available in the M2018 device. The three columns of CLBs, on the left, contain the status counter. The next seven columns of CLBs contain the address counters and the multiplexers, and the two bottom rows of CLBs contain the control circuitry.

The placement of the blocks are positioned so that routing delays between the blocks can be minimized. Long line interconnects are used frequently for signals which would have to travel the length or breadth of the chip. These lines were also used for signals that must have minimal skew between destination points. For more information on routing, please refer to Chapter 9 of the LCA Design and Applications Handbook.

**Summary**

For DRAM designs, a FIFO-DRAM Controller was efficiently implemented in a single CMOS M2018 LCA device. The controller, which enables the DRAM to function as a FIFO, allows large amounts of data to be held in temporary storage. The design can be modified quickly and easily with the LCA device because it is configurable and reprogrammable. Configuration of the LCA device is discussed in the LCA Applications Note 182.

The FIFO-DRAM Controller design is available upon request. The design file and bit file will be provided for configuring the LCA device. Please ask for design XDES10.LCA.

**References**

NEC Electronics Inc. µPD41464 65,536 x 4-Bit Dynamic NMOS Ram Datasheet, January 1987

Monolithic Memories, Inc., FIFO-RAM Controller 57/674219 Datasheet, September 1986
Figure 19. LCA Implementation of the Relaxation Oscillator with the CLB/IOB View of the External Routing Connections

Figure 20. GOSC Macro Logic Schematic for System and Refresh Clocks

Figure 21. CLB and IOB Configurations for the Refresh Clock
Figure 22. FIFO-DRAM Controller Circuit Implementation in the LCA Device
Configuring the LCA™ from the PC Bus
By Robert Botchek of Trantor Systems Ltd. and Chris Jay of AMD

ABSTRACT
The Logic Cell™ Array (LCA) is a high density programmable device based on a complex arrangement of static RAM cells. The device must go through an initialization and configuration cycle each time power is applied. This cycle must occur before the LCA can function as a logic unit or subsystem. The configuration time is small, ranging from 17 to 35 milliseconds for the M2000 series of devices, and when the device is fully functional no re-configuration is necessary provided power to the device is maintained.

There are a number of modes of configuration, each suited to a particular device application. This application note gives detailed information on configuring the LCA device from the IBM PC® bus, choosing one of the five configuration modes available. Configuring the LCA device directly from the PC bus presents numerous advantages to the PC adapter card designer. The direct link between the PC bus and the LCA enhances debugging and testing, and reduces the product's time to market. The concept of soft programmability (based on the LCA's SRAM design) significantly reduces the development cycle of a PC product using the LCA. Once complete, the configuration software can exist in ROM and be called each time the system boots, so PC cards containing LCA devices can be configured in a manner transparent to the user. The interface requires both software and hardware considerations. A high level language program is written to perform data code conversion, and assembly language programs supervise the actual LCA downloading and programming cycle. The hardware interface to the LCA is achieved with a low-cost PAL16L8 device. A description of hardware and software design considerations is given in the following application note.
Configuring the LCA from the PC Bus
By Robert Botchek of Trantor Systems LTD. and Chris Jay of AMD

INTRODUCTION
The Logic Cell Array (LCA) is a very high density programmable device. The 2000 series consists of two devices, the M2064 and the M2018. The M2064 consists of an eight-by-eight matrix of programmable Configurable Logic Blocks (CLBs) with fifty-eight programmable Input/Output Blocks (IOBs) to handle a variety of input/output functions. The M2018 has a ten-by-ten matrix of CLBs with seventy-four IOBs. Both devices have a complex array of programmable interconnect which is used to connect the logic blocks and input/output functions. The M3000 series was developed from the 2000 series and is suitable for even more dense logic architectures. The 3020 device is a development of the 2064 having an eight-by-eight array of more complex logic blocks. The IOBs and interconnect are also more complex in this new generation of programmable gate array circuits. This application note applies equally well to the configuration of 3000 series and 2000 series devices.

These high density devices require good software support tools to assist the designer in achieving a successful design with rapid turn-around, a benefit well known to the engineer familiar with Programmable Logic Devices; PLDs. Most manufacturers of PLDs support their products with at least one software package, and as complexity of programmable logic increases there is a need for more sophisticated computer-based tools. The LCA device is probably the most complex PLD on the market today, but fortunately there exists a wide repertoire of software support packages to provide the logic systems designer with rapid design entry and logic verification. In addition, conversion software provides a bridge from the finished design into raw configuration data which in turn is suitable for downloading and configuring the device. LCA device design entry is well supported in the PC environment with a wide range of CAE tools. The XACT™ software is designed to run on a PC XT/AT, for the 2000 series of LCA products only, and PC/AT for both 2000 and 3000 family of devices. Many packages for schematic entry and simulation also exist as software support for the LCA product, and will run in the PC environment.

The route from design entry to a configuration bit stream is a relatively fast process. Thus, even if a number of reprogramming cycles are needed to prove a design, the overall process remains comparatively short.

CONFIGURATION MODES
There are five LCA configuration modes. These are listed in Table 1 along with corresponding LCA mode select inputs M0-M2. For the specific application of configuring the LCA from the PC bus the slave mode is used. In this mode, for a single LCA device, only three pins take part in the configuration process. This can be the deciding factor in using the slave mode because some of the IOBs have a dual function of address and data assignment in the master low and high modes. During configuration these IOBs might need isolation from external logic. IOB intensive applications would favor the slave mode to avoid the additional time and space penalty of designing in additional logic buffers to perform this isolation.

Of the three pins used, two are required for handshake and one for data transmission. The data is set up at the DIN input to the LCA and clocked into the device by applying a rising clock edge to the CCLK input. Each configuration bit is synchronously loaded in this manner at a rate determined by the PC interface. The remaining handshake pin is the Done−Program pin, when LOW the LCA is in configuration mode and when HIGH the configuration process has been completed and the LCA device is functionally operational.

The slave mode of configuration can also be used effectively for chaining multiple LCA designs. The DOUT pin from a preceding LCA device can be fed directly to the DIN pin of a succeeding LCA so two or more devices can be configured. Waveforms in Figure 3 show the timing requirements for DIN, DOUT and CCLK.

M2018 CONFIGURATION FILE

Figure 1. Data Stream Format
Configuring the LCA from the PC Bus

<table>
<thead>
<tr>
<th>Mode Pin</th>
<th>Mode Selected</th>
</tr>
</thead>
<tbody>
<tr>
<td>M0 M1 M2</td>
<td></td>
</tr>
<tr>
<td>0 0 0</td>
<td>Master serial</td>
</tr>
<tr>
<td>0 0 1</td>
<td>Master low</td>
</tr>
<tr>
<td>0 1 1</td>
<td>Master high</td>
</tr>
<tr>
<td>1 0 1</td>
<td>Peripheral</td>
</tr>
<tr>
<td>1 1 1</td>
<td>Slave</td>
</tr>
</tbody>
</table>

Table 1. Five Configuration Modes Truth Table

In the slave mode configuration, the data transfer occurs over a single data line, data 0 in this case. When data is valid the clock rising edge synchronizes the loading of data into the LCA device. The done/program pin may be monitored for end of configuration. This circuit may be used for microcomputers, microprocessors and interface adapters, but in this case the PC system bus is used.

PC CONFIGURATION HARDWARE

The LCA Applications Handbook (10098A) describes a number of hardware arrangements whereby configuration data may be downloaded serially to the LCA device. It is also supported with a download cable which is included with the XACT development system. The cable permits communication from a PC to the LCA through a parallel port. However, this method of downloading configuration data is not practical for an LCA device mounted on a card that is plugged into the IBM PC bus. This system uses the bus as a medium for configuration data transmission. Although the option for using the download cable has not been precluded from the interface described here.

A summary of the four condition codes is given in Table 2. For condition code 0, \(<C1, C0>=<0, 0>\), the PAL device is in an idle mode. This is the mode preceding and following configuration. For condition code 1 the PAL asserts the D-P output as the trigger placing the LCA device in configuration mode. Condition code 2 directs the PAL to toggle -RESET for each subsequent write to Base Port + 2. DPEN enables the D-P PAL output and is latched from D5 on the same I/O write cycle.

In the slave mode the CCLK pin is enabled as an input. Data set up at the DIN line is clocked into the LCA on the rising edge of the clock pulse. For the purposes of chaining LCA devices, data can be passed to the DOUT line but delayed by one clock cycle. Note that this data is synchronized to the falling edge of the clock. The configuration process is not complete until three additional clocks are appended to the pulse train. That is three more than the total number of configuration bits.

For all speed grades of the device the data setup and hold times are identical. A minimum figure of zero nanoseconds for setup and 40 nanoseconds for hold. The worst case figure for valid data at the DOUT pin is 65 nanoseconds after the falling edge of the clock.

Figure 7 is a schematic of the actual hardware used to drive the LCA device during configuration. The schematic shows PC bus signals involved in the process and the hardware used to decode them. A 74ALS520 decodes the PC address (set by SW1-SW7) for an I/O read/write cycle and a PAL16L8 decodes commands sent by download software (described later). Alternatively, a 74LS688 or equivalent could be used in place of the 74ALS520 but external pull-up resistors would be required on the inputs. Wired as shown, eight consecutive addresses will match as far as the 74ALS520 is concerned (e.g., 320H to 327H). The first of these eight addresses is termed the Base Port. Figure 8 shows the port addressing assignment. The port interface was required to work in a specific application that required a large decode range so the interface had a dual function. The port interface configuration was a biproduct of a real design.

Although the PAL16L8 (for which complete PAL design specification equations may be found in Appendix 7) is not a registered device, its outputs may be fed back such that latching can be achieved. This technique is used to store control information sent by configuration software. The C, and C1 outputs from the PAL16L8 are latched condition codes where C, and C1 store the data on D, and D,, respectively, during an I/O write cycle to Base Port + 2. DPEN enables the D-P PAL output and is latched from D5 on the same I/O write cycle.

In the slave mode configuration, the data transfer occurs over a single data line, data 0 in this case. When data is valid the clock rising edge synchronizes the loading of data into the LCA device. The done/program pin may be monitored for end of configuration. This circuit may be used for microcomputers, microprocessors and interface adapters, but in this case the PC system bus is used.

In the slave mode configuration, the data transfer occurs over a single data line, data 0 in this case. When data is valid the clock rising edge synchronizes the loading of data into the LCA device. The done/program pin may be monitored for end of configuration. This circuit may be used for microcomputers, microprocessors and interface adapters, but in this case the PC system bus is used.

Figure 3. Slave Mode Timing

In the slave mode the CCLK pin is enabled as an input. Data set up at the DIN line is clocked into the LCA on the rising edge of the clock pulse. For the purposes of chaining LCA devices, data can be passed to the DOUT line but delayed by one clock cycle. Note that this data is synchronized to the falling edge of the clock. The configuration process is not complete until three additional clocks are appended to the pulse train. That is three more than the total number of configuration bits.

For all speed grades of the device the data setup and hold times are identical. A minimum figure of zero nanoseconds for setup and 40 nanoseconds for hold. The worst case figure for valid data at the DOUT pin is 65 nanoseconds after the falling edge of the clock.

Figure 7 is a schematic of the actual hardware used to drive the LCA device during configuration. The schematic shows PC bus signals involved in the process and the hardware used to decode them. A 74ALS520 decodes the PC address (set by SW1-SW7) for an I/O read/write cycle and a PAL16L8 decodes commands sent by download software (described later). Alternatively, a 74LS688 or equivalent could be used in place of the 74ALS520 but external pull-up resistors would be required on the inputs. Wired as shown, eight consecutive addresses will match as far as the 74ALS520 is concerned (e.g., 320H to 327H). The first of these eight addresses is termed the Base Port. Figure 8 shows the port addressing assignment. The port interface was required to work in a specific application that required a large decode range so the interface had a dual function. The port interface configuration was a biproduct of a real design.

Although the PAL16L8 (for which complete PAL design specification equations may be found in Appendix 7) is not a registered device, its outputs may be fed back such that latching can be achieved. This technique is used to store control information sent by configuration software. The C, and C1 outputs from the PAL16L8 are latched condition codes where C, and C1 store the data on D, and D,, respectively, during an I/O write cycle to Base Port + 2. DPEN enables the D-P PAL output and is latched from D5 on the same I/O write cycle.

A summary of the four condition codes is given in Table 2. For condition code 0, \(<C1, C0>=<0, 0>\), the PAL device is in an idle mode. This is the mode preceding and following configuration. For condition code 1 the PAL asserts the the D-P output as the trigger placing the LCA device in configuration mode. Condition code 2 directs the PAL to toggle -RESET for each subsequent write to Base Port + 2. DPEN enables the D-P PAL output and is latched from D5 on the same I/O write cycle.

Figure 7 is a schematic of the actual hardware used to drive the LCA device during configuration. The schematic shows PC bus signals involved in the process and the hardware used to decode them. A 74ALS520 decodes the PC address (set by SW1-SW7) for an I/O read/write cycle and a PAL16L8 decodes commands sent by download software (described later). Alternatively, a 74LS688 or equivalent could be used in place of the 74ALS520 but external pull-up resistors would be required on the inputs. Wired as shown, eight consecutive addresses will match as far as the 74ALS520 is concerned (e.g., 320H to 327H). The first of these eight addresses is termed the Base Port. Figure 8 shows the port addressing assignment. The port interface was required to work in a specific application that required a large decode range so the interface had a dual function. The port interface configuration was a biproduct of a real design.

Although the PAL16L8 (for which complete PAL design specification equations may be found in Appendix 7) is not a registered device, its outputs may be fed back such that latching can be achieved. This technique is used to store control information sent by configuration software. The C, and C1 outputs from the PAL16L8 are latched condition codes where C, and C1 store the data on D, and D,, respectively, during an I/O write cycle to Base Port + 2. DPEN enables the D-P PAL output and is latched from D5 on the same I/O write cycle.

A summary of the four condition codes is given in Table 2. For condition code 0, \(<C1, C0>=<0, 0>\), the PAL device is in an idle mode. This is the mode preceding and following configuration. For condition code 1 the PAL asserts the the D-P output as the trigger placing the LCA device in configuration mode. Condition code 2 directs the PAL to toggle -RESET for each subsequent write to Base Port + 2. DPEN enables the D-P PAL output and is latched from D5 on the same I/O write cycle.

A summary of the four condition codes is given in Table 2. For condition code 0, \(<C1, C0>=<0, 0>\), the PAL device is in an idle mode. This is the mode preceding and following configuration. For condition code 1 the PAL asserts the the D-P output as the trigger placing the LCA device in configuration mode. Condition code 2 directs the PAL to toggle -RESET for each subsequent write to Base Port + 2. DPEN enables the D-P PAL output and is latched from D5 on the same I/O write cycle.
Configuring the LCA from the PC Bus

LCA Slave Mode Configuration.

- START -

DRIVE D/P = LOW

PULSE RESET LOW THEN HIGH

RELEASE D/P PIN

IS THE LCA DRIVING THE D/P PIN LOW?

NO

SET DATA BIT ON DIN

PULSE CCLK LOW THEN HIGH

ALL CONFIGURATION BITS SENT?

NO

PULSE THE CCLK INPUT THREE TIMES

IS THE D/P = HIGH?

NO

END OF CONFIGURATION CYCLE

Figure 4. Flow Diagram of Configuration
Configuring the LCA from the PC Bus

Figure 5. Flow Diagram of Software Packages, GAP

<table>
<thead>
<tr>
<th>C0</th>
<th>C1</th>
<th>Code</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Releases D/-P for normal operation</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Assert D/-P Low</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>2</td>
<td>Toggle RESET mode</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>3</td>
<td>Toggle CCLK mode</td>
</tr>
</tbody>
</table>

Table 2. PAL Condition Codes

After asserting D/-P (LOW) and toggling -RESET (condition codes 1 and 2) the software should read from Base Port + 2. During this read the PAL will drive the state of the D/-P onto bit 0 of the PC data bus. This is done through the DOUT pin which is enabled only during reads from the I/O address Base Port + 3. An additional output, active LOW-LEN is also asserted at this time, allowing another on-board latch to drive data, such as switch settings, onto the bus. If the state of the D/-P pin is not 0 (LOW) then the LCA has failed to enter the configuration mode. Likewise, after sending the entire configuration bit stream and an additional three dummy bits (as required by the LCA) the software reads from Base Port + 2 to check that D/-P has been allowed to return HIGH, this indicates that the LCA has terminated the configuration process.

Timing considerations for this procedure are shown in Figures 9 and 10. Figure 9 shows a single I/O write cycle. The valid I/O address is put onto the bus, and decoded by the address decoder circuitry shown in Figure 7. The trailing (positive) edge of -IOW is used to latch condition bits. Also, in condition 2, CCLK follows -IOW during writes to Base Port + 3. Thus, the rising edge of CCLK corresponds to the rising edge of -IOW. This ensures that data will be latched by the LCA only when it is valid (write data is not guaranteed to be valid at the leading edge of -IOW).

Figure 6. PAL16L8 Pinout Diagram

The C0 and C1 outputs from the PAL16L8 are latching outputs. Both C0 and C1 are addressed into the address baseport +2. The data lines D0 and D1 are routed to C0 and C1 respectively during an I/O write operation. The one of four condition codes shown in Table 2 reflects the current status of the PAL during its interface activity with the LCA device.

As shown, SD0 on the PC bus is connected directly to DIN on the LCA through an in-line SPST switch. This switch should normally be closed, and need not be present at all in a production layout. It was added to allow the download cable, included with XACT, to function properly if required. If the switch is opened and the PAL removed, the download cable may be connected directly to the D/-P, -RESET, CCLK, and DIN pins and will interface directly through the cable.

BIT STREAM FORMAT AND CONVERSION

The format of the configuration bit stream used to program the LCA M2018 is shown in Figure 1. The bit stream starts with four dummy bits (1111), followed by a four-bit preamble code (0010), a 24-bit length count and another four dummy bits. The length count indicates the total number of bits in the bit stream, including the header just described. This number will be loaded into an internal counter in the LCA device allowing it to synchronize the loading of data during the configuration process. The actual configuration process is always serial, even during parallel configuration modes, internal serialization takes place in the LCA device.

The usual design entry technique uses the XACT design editor to create the logic design. The XACT conversion software then generates a bit pattern of the design that can be loaded directly into the LCA device. XACT can produce the bit stream in several different binary and ASCII formats. In this application the need to produce the bit stream in a format amenable to inclusion in an assembly language program dictated that the RAWBITS format be used. The RAWBITS output, placed in a file with the extension "RBT," is ASCII. (Appendix 1 shows a portion of an "RBT" file.) In general, one ASCII '0' or '1' is used to represent each bit of the configuration data. This data is not packed so it is not an efficient way of generating data for storage but it is suitable for loading into the LCA in real time.
Assembly language modules tend to define data in terms of bytes or words. For this reason, a Pascal program, BITCON.PAS, was written (see Appendix 2 for a complete listing). BITCON filters the "RBT" file and produces an assembly language include file (given the extension "BLB") which defines the configuration bit stream in terms of define byte directives acceptable to the Microsoft MASM™ assembler. This has the effect of packing the bit stream. For the sake of discussion the packed bit stream will be referred to as a byte stream. Additionally, BITCON counts the bits in the stream and the bytes used to hold the stream and defines two words at the beginning of the "BLB" file for these quantities. A portion of a typical "BLB" file may be found in Appendix 3. The net result is a structure which, once assembled into a main program, may be manipulated easily by machine language modules. Further, the assembled byte stream requires only 1.5K to 2K depending on the device being configured. Thus, the byte stream and associated software may easily be placed in a 4Kx8 or 8Kx8 ROM.

**Hardware Configuration**

**LCA Programming**

---

![Port Assignment](image)

![Circuit Implementation](image)

---

**Figure 8. Port Assignment**

**Figure 7. Circuit Implementation of PC BUS to LCA**
Configuring the LCA from the PC Bus

Note: During bus write cycles, write data becomes valid after -IOW has been asserted. Data can be registered on the rising edge of -IOW.

Figure 9. Single WRITE Cycle. Waveform

Notes: 1. The CCLK must not remain low longer than 5 microseconds or LCA timing will be violated.
2. The D/P pin is sampled after all the configuration bits + three additional bits have been sent. If the D/P pin is high then configuration was successful.

Figure 10. Configuration Cycle. Waveform
CONFIGURATION SOFTWARE

To perform the writing of configuration data to the LCA, the driver software was written in assembly language. High level languages such as 'C' or Pascal could be used, but assembly language was chosen because it is more efficient when considering the space constraints of a ROM. Three programs were written to interface to the LCA device;

- GAP.ASM Gate Array Program. See Appendix 4.
- PGMLCA.ASM Program LCA. See Appendix 5.
- DOWNLCA.ASM Download LCA. See Appendix 6.

Figure 4 shows a flow chart of a standard configuration cycle and Figure 5 shows the route taken from GAP to the programmed LCA device. The configuration driver may be partitioned into two halves: one generic and one hardware specific. The first half is implemented in a module called PGMLCA.ASM, which sequences through the configuration steps and decomposes the byte stream into the original configuration bit stream, while the second module DOWNLCA.ASM controls the bit manipulation required by the configuration hardware. Neither module carries the byte stream, it is assembled as part of a parent module whose job it is to invoke the actual configuration process. This is the function of a demonstration program GAP.ASM which displays some messages and calls the PGMLCA module, passing a pointer to the byte stream.

The byte stream is concatenated to the end of the GAP.ASM file as an include file. Any file that has been converted to byte stream "BLB" can be downloaded to the LCA device by reassembling and linking GAP. The programs GAP.ASM, PGMLCA.ASM and DOWNLCA.ASM are written for Microsoft MASM version 5.0. A few utility routines in the library GAPLIB.LIB must also be linked to GAP but are not required by PGMLCA and DOWNLCA.

PGMLCA and DOWNLCA may just as easily be linked with a different parent and placed in ROM. This would be the production method for configuration used in the PC adapter card. The program in the ROM might perform a functional test at boot time to determine if the LCA is already programmed. If it is not, the PGMLCA module may be invoked by passing it a pointer to the byte stream. The entire process need only occur during the initial power on or cold boot, and takes less than a second to execute.

Looking at the modules in more detail, DOWNLCA interfaces to the PAL and provides three functions to PGMLCA. These include placing the LCA in the program mode, sending the LCA configuration bits and placing the LCA in the normal operation mode. As shown in the module listing, only a few port I/O instructions are used. The DOWNLCA program also checks to make sure that the LCA device enters and leaves the program mode at the correct times and reports this status to PGMLCA.

PGMLCA, sequences configuration by requesting program mode, sending configuration bits, and leaving the program mode. As discussed earlier, PGMLCA has the additional task of unpacking the byte stream that was originally packed by BITCON.

This partitioning allows the replacement of the DOWNLCA module with a different module suitable for supporting a different download hardware interface, without changing PGMLCA or BITCON. For example, the software for a download module to support the download cable of the development system could be generated. If the download cable is used, SW8 in Figure 7 must be switched to open.

CONCLUSION

Programming the LCA directly from the PC bus is a straightforward matter requiring a minimum of extra hardware. Once the hardware is breadboarded, the designer uses XACT to produce a RAWBITS file, which is converted by BITCON to an assembly language include file. This include file is then assembled as part of a parent program which is linked to the support modules PGMLCA and DOWNLCA. PGMLCA directs the configuration process through DOWNLCA which manages the specifics of the PAL-based interface.

The hardware interface may be easily adjusted to suit multiple LCA designs and the specific needs of other PC adapter cards or may be modified with a minimum of effort to support other microcomputer architectures. Likewise, BITCON is easily modified to produce include files for different assemblers. PGMLCA and DOWNLCA are also small modules which may be modified or ported as needed.

There are other advantages to this hardware and software scheme. Since the LCA configuration data is carried in software, which might be placed in ROM, an MS-DOS device driver, or even an application program, the realm of software updates is extended into the realm of hardware. At one end of the spectrum a vendor might supply hardware timing fixes or optimizations on diskette. At the other, the LCA could be designed as a generic logic block, whose function is dictated by the application software. In fact, at Trantor Systems a number of these capabilities are being exploited now in products incorporating such elements as RAM controllers and SCSI interfaces. Future LCA devices available from AMD, with even higher densities and faster speed grades will increase the scope of designs for which the part is appropriate.

SOFTWARE AVAILABILITY

The programs and PAL equations described in this application note, along with the binary library required for relinking GAP, are available on an MS-DOS 360K 5.25-inch diskette from:

Trantor Systems, Ltd.
33447 Western Avenue
Union City, CA 94587
(415) 489-3731

The charge per diskette is $25. Additional shipping charges may be necessary.
- APPENDIX 1 -

RAW BITS CONFIGURATION FILE.

XACT LCA DESIGN.LCA 2018NL68
File design.rbt
22:15:17 DEC 10, 1987
22:15:17 DEC 10, 1987
Source
Version
Produced by XACT version 1.30
11110010000000000100010111010110111
01111111110100111111011111111111110111101100111111100111111100111111111111111111

192 LINES OF RAW BIT CONFIGURATION DATA

Appendix 1. Raw Bit Listing
BitCon is a bit conversion program which takes as its input the
"*.rbt" file produced by the makebits command in the gate array
development system and produces an assembly language file defining
the bit stream.

The "*.rbt" file contains a text prolog indicating the design name
and the time/date of creation. The file then contains a number
of lines containing ascii '1's and '0's which represent the bit
stream. The first line of this stream contains the bit stream
prolog, '1111', which BitCon uses to identify the bit stream.

BitCon packs the bit stream into bytes where the highest order
bit in a byte corresponds to the first encountered bit in the
bit stream and the first byte corresponds to the first eight
bits of the bit stream, and so forth.

The output file has the form:

; text prolog created by makebits
dw length_of_bit_stream_in_bits
dw length_of_bit_stream_in_bytes
db byte_0,byte_1,...,byte_7
db byte_8,byte_9,...,byte_15
...  
...  
...  
...  
db ...,byte_n

If the number of bits is not an even multiple of eight then then
only the highest order bits of the last byte will be valid.

The output file has the filetype ".blb" (for Bit LiBrary) and may
be included in an assembly language program for assembly.

history:

12-09-87 RCB  first cut
12-11-87 RCB  emit ';' instead of ':' in third line of
our portion of the prolog (1.0b)
12-12-87 RCB  place the number of bits we counted into the
24-bit length field of the stream to ensure that
the two are the same (1.0c)
01-04-88 RCB  make release version for ap. note (1.1a)
01-26-88 RCB  more of mod. on 01-04-88 (1.1b)

const
title = 'BitCon: .rbt -> .blb Filter, Version 1.1b';
Configuring the LCA from the PC Bus

copyright = 'Copyright (c) 1987, Trantor Systems, Ltd.';

max_byte = 8191;           { max bytes in byte stream - 1 }
stream_prolog = '1111';    { ascii form of bit stream prolog }
max_bytes_per_line = 8;    { max bytes defined per line in output file }

intype = '.rbt';          { input filetype }
outtype = '.blb';         { output filetype }

type
  st = string [132];

var
  byte_stream: array [0..max_byte] of byte;
  bit_length: integer;
  byte_length: integer;

  rbt_file: text;
  blb_file: text;
  current_line: st;

{ convert the byte argument to a three-digit hex number (includes leading zero). also add a trailing 'h'. }

function hex (value: byte): st;

function nibble (value: byte): st;
begin
  nibble := copy ('0123456789abcdef', value + 1, 1);
end;

begin
  hex := '0' + nibble (value div 16) + nibble (value mod 16) + 'h';
end;

{ if the filename doesn't have a filetype, append the specified one. if there is a filetype, replace it with the specified one. }

function fnm (filename: st; filetype: st): st;
begin
  if pos ('.', filename) = 0 then
    fnm := concat (filename, filetype)
  else
    fnm := concat (copy (filename, 1, pos ('.', filename) - 1), filetype
end;

{ copy lines from the prolog of the .rbt file to the prolog of the .blb file until the bit stream prolog is found. leave the first line of the bit stream in current_line. }
procedure read_prolog;
begin
  readln (rbt_file, current_line);
  while (not eof (rbt_file)) and
    (copy (current_line, 1, length (stream_prolog)) <> stream_prolog
     writeln (blb_file, ';', '^I', current_line);
   readln (rbt_file, current_line);
end;
writeln (blb_file);
writeln (blb_file, ';', '^I', 'Translated by:');
writeln (blb_file, ';', '^I', title);
writeln (blb_file, ';', '^I', copyright);
writeln (blb_file);
end;

{ read the bit stream and construct a byte stream in memory. keep a count
  of the number of bits and the number of bytes. we assume that the first
  line of the bit stream is already in the variable current_line. }

procedure read_bit_stream;
var
  cur_bit: byte;
  their_length: integer;

procedure pack_bits;
var
  char_index: integer;

begin
  for char_index := 1 to length (current_line) do begin
    bit_length := bit_length + 1;
    if cur_bit = 7 then
      byte_stream [byte_length] := 0;
      byte_stream [byte_length] := byte_stream [byte_length] or
      ((ord (current Line [char_index]) - ord ('0')) shl cur_bit);
      if cur_bit > 0 then
        cur_bit := cur_bit - 1
      else begin
        cur_bit := 7;
        byte_length := byte_length + 1;
      end;
    end;
  end;

begin
  bit_length := 0;
  byte_length := 0;
  cur_bit := 7;
  pack_bits;
  while not eof (rbt_file) do begin
    readln (rbt_file, current_line);
    pack_bits;
  end;
  if cur_bit <> 7 then
byte_length := byte_length + 1;
if their_length <> bit_length then begin
   writeln ('Fixing up bit stream length...
   writeln ('Old length= •,their_length,' bits');
   byte_stream [2] := (bit_length shr 8) and $ff;
end;
end;

{ write_byte_stream formats the byte_stream just created by read_bit_str
 a bit length count and byte length count preceed the byte stream. }

procedure write_byte_stream;
var
   count: integer;
begin
   writeln (blb_file, ^I, 'dw', ^I, bit_length, ^I, ',# of bits in stream
   writeln (blb_file, ^I, 'dw', ^I, byte_length, ^I, ',# of bytes to hold
   for count := 0 to byte_length - 1 do begin
      if count mod max_bytes_per_line = 0 then begin
         writeln (blb_file);
         write (blb_file, ^I, 'db', ^I);
      end;
      if count mod max_bytes_per_line <> 0 then
         write (blb_file, •, T);
      write (blb_file, hex (byte_stream [count]));
   end;
   writeln (blb_file);
   writeln (blb_file);
end;

begin { main }
   writeln (title);
   writeln (copyright);
   if paramstr (1) = '' then begin
      writeln;
      writeln ('Usage: bitcon bitfile 1 );
      writeln;
      writeln ('Where "bitfile" is a "rbit" file produced by');
      writeln ('makebits. BitCon will produce an output file,');
      writeln ('"bitfile.blb," which contains an assembly');
      writeln ('language representation of the bit stream.');
      writeln;
   end
   else begin
      writeln;
      assign (rbt_file, fnm (paramstr (1), intype));
      {$I-}
      reset (rbt_file);
      if iresult <> 0 then begin
         writeln ('Unable to open file "', fnm (paramstr (1), intype), '".');
      end
   end
begin { main }
   writeln (title);
   writeln (copyright);
   if paramstr (1) = '' then begin
      writeln;
      writeln ('Usage: bitcon bitfile 1 );
      writeln;
      writeln ('Where "bitfile" is a "rbit" file produced by');
      writeln ('makebits. BitCon will produce an output file,');
      writeln ('"bitfile.blb," which contains an assembly');
      writeln ('language representation of the bit stream.');
      writeln;
   end
   else begin
      writeln;
      assign (rbt_file, fnm (paramstr (1), intype));
      {$I-}
      reset (rbt_file);
      if iresult <> 0 then begin
         writeln ('Unable to open file "', fnm (paramstr (1), intype), '".');
      end
   end
begin { main }
   writeln (title);
   writeln (copyright);
   if paramstr (1) = '' then begin
      writeln;
      writeln ('Usage: bitcon bitfile 1 );
      writeln;
      writeln ('Where "bitfile" is a "rbit" file produced by');
      writeln ('makebits. BitCon will produce an output file,');
      writeln ('"bitfile.blb," which contains an assembly');
      writeln ('language representation of the bit stream.');
      writeln;
   end
   else begin
      writeln;
      assign (rbt_file, fnm (paramstr (1), intype));
      {$I-}
      reset (rbt_file);
      if iresult <> 0 then begin
         writeln ('Unable to open file "', fnm (paramstr (1), intype), '".');
      end
   end
begin { main }
   writeln (title);
   writeln (copyright);
   if paramstr (1) = '' then begin
      writeln;
      writeln ('Usage: bitcon bitfile 1 );
      writeln;
      writeln ('Where "bitfile" is a "rbit" file produced by');
      writeln ('makebits. BitCon will produce an output file,');
      writeln ('"bitfile.blb," which contains an assembly');
      writeln ('language representation of the bit stream.');
      writeln;
   end
   else begin
      writeln;
      assign (rbt_file, fnm (paramstr (1), intype));
      {$I-}
      reset (rbt_file);
      if iresult <> 0 then begin
         writeln ('Unable to open file "', fnm (paramstr (1), intype), '".');
      end

halt;
end;
writeln ('Reading ", fnm (paramstr (1), intype), '"');
assign (blb_file, fnm (paramstr (1), outtype));
rewrite (blb_file);
if ioresult <> 0 then begin
  writeln ('Unable to create file ", fnm (paramstr (1), outtype), "');
  halt;
end;
writeln ('Copying prolog...');
read_prolog;
if not eof (rbt_file) then begin
  writeln ('Reading bit stream...');
  read_bit_stream;
  writeln ('Bit stream = ',bit_length, ' bits');
  writeln (' = ',byte_length, ' bytes');
  writeln ('Writing bit stream...');
  write_byte_stream;
end
else
  writeln ('Input file ended prematurely.');
close (blb_file);
close (rbt_file);
writeln ('File ", fnm (paramstr (1), outtype), " produced.');
end;
end.
- APPENDIX 3 -
LISTING OF FILE AFTER CONVERSION BY BITCON

; XACT LCA DESIGN.LCA 2018NL68
; File design.rbt
; 22:15:17 DEC 10, 1987
; 22:15:17 DEC 10, 1987
; Source
; Version
; Produced by XACT version 1.30

; Translated by:
; bitcon: .rbt -> .blb filter, version 1.0b
; Copyright (c) 1987, Trantor Systems, Ltd.

dw 17876 ;# of bits in stream
dw 2235 ;# of bytes to hold stream
db 0f2h, 000h, 045h, 0d4h, 0f7h, 0ffh, 04fh 0dfh
db 0efh, 0ffh, 0efh, 067h, 0f3h, 0f3h,0ffh, 0feh

• • •
193 LINES OF COMPRESSED CODE
• • •
• • •
db 0bbh, 0bfh, 0ffh, 0ffh, 0ffh, 0ffh, 0ffh
db 0eefh, 0ffh, 0ffh

Appendix 3. Listing of <file>.blb
Configuring the LCA from the PC Bus

APPENDIX 4

GAP.asm

GAP takes the byte stream generated by BitCon (which, in turn, took its input from MAKEBITS in the LCA development system) and downloads it to the gate array. GAP itself only displays signon messages and statistics. It then passes a pointer to a "byte stream" (a packed configuration bit stream) which the PGMLCA module decodes.

GAP is only intended for debugging and demonstration. The gate array programming modules, on the other hand, are intended for production use. Invoke GAP with:

A>gap

Invoking GAP without the hardware described in the ap. note shouldn't have any ill effect. However, be careful that no other card occupies port address 328h-32fh for which this demo. has been "hard-wired."

MASM 5.0 may be used to assemble this module. It must then be linked to the other modules.

History:

12-11-87 RCB first (1.0a)
01-26-88 RCB make mods. for ap. note release (1.1a)

Copyright (C) 1988, Trantor Systems, Ltd.
All rights reserved.

Externals and Defs.

pgm_gate_array is an entry in the pgmlca module. this routine sequences the programming phases.

extrn pgm_gate_array:near

dsp_str and dsp_num are utility routines to display an ASCIIZ string and a decimal number, respectively.

extrn dsp_str:near
extrn dsp_num:near
Configuring the LCA from the PC Bus

```
prog_title equ 'GAP: Gate Array Programmer, version 1.1
prog_copyright equ 'Copyright (c) 1987, Tranter Systems, Lt

false equ 0
true equ not false
cr equ 0dh
lf equ 0ah
eof equ 1ah
null equ 0
dos equ 21h
dos_program_terminate equ 4ch
combase equ 100h

ok_ret_code equ 0 ;program return codes
bad_ret_code equ 1

;-----------------------------------------------------------------------
; COM file header and program entry
;-----------------------------------------------------------------------

code segment para public
assume cs:code,ds:code,es:code,ss:code

start: org combase
jmp main

signon: db cr,prog_title,cr,lf
db prog_copyright,cr,lf,lf,null,eof

stack:

main proc

mov ax,cs
mov ds,ax
mov es,ax
cli
mov ss,ax
lea sp,stack
sti

lea dx,signon ;signon
call dsp_str
lea dx,pgm_msg ;now programming...
call dsp_str

lea di,gate_array_code ;di -> bit stream structure

; the bit stream structure consists of 3 fields: a word count
; of the bits in the bit stream, a word count of the bytes needed
; to store the bit stream, and an array of bytes of the length
; indicated by the previous (second) field.
```

3-141
mov  ax,[di] ; show bit length
call  dsp_num
lea  dx,bit_msg
call  dsp_str
mov  ax,[di + 2] ; show byte length
call  dsp_num
lea  dx,byte_msg
call  dsp_str
call  pgm_gate_array ; es:di -> bit stream structure
lea  dx,ok_pgm_msg ; cy indicates error upon return
mov  al,ok_ret_code
jnc  done
lea  dx,bad_pgm_msg ; show error
mov  al,bad_ret_code
done:
   call  dsp_str
mov  ah,dos_program_terminate ; al is still the return
int  dos

main  endp

pgm_msg:    db  'Programming gate array...\r\n\n',cr,lf,null
bit_msg:    db  ' bits in stream.\r\n\n',cr,lf,null
byte_msg:    db  ' bytes in stream.\r\n\n',cr,lf,null
ok_pgm_msg:  db  'Gate array programmed.\r\n\n',cr,lf,null
bad_pgm_msg:  db  'Programming failure.\r\n\n',cr,lf,null

;----------------------------------------------------------------------
; "Byte stream"
; The ".BLB" file containing the "byte stream" (packed
; configuration bit stream) which was produced from the ".RBT"
; file bit BitCon is included here.
;----------------------------------------------------------------------
gate_array_code:  include dummy.blb
code  ends
end  start
;
end of file
APPENDIX 5

DOWNLCA.asm

DOWNLCA contains the hardware specific code for downloading a configuration bit stream to the LCA using the Tranter configuration PAL interface.

The PAL interface gives us direct control over the D/-P, -RESET, and CCLK pins on the LCA.

To place the LCA in program mode we set the D/-P low and toggle reset. We then release the D/-P pin and check to see that the LCA is still driving it low, signifying that it entered program mode.

The CCLK pin is normally held high and is pulsed low as each configuration bit is sent. Each configuration bit is sent on SD0 (bit 0 of the PC's data bus). Thus, the rising edge of CCLK occurs at the end of the write cycle. This is necessary as the PC doesn't drive write data until after the leading edge of the write signal.

After the configuration bit stream has been sent we check to see if the LCA allowed D/-P to go high, signifying the end of configuration.

This module may be placed in rom if so desired.

History:

12-11-87 RCB first
01-26-88 RCB make mods. for ap. note release
04-11-88 RCB release dp pin after toggling reset

Copyright (C) 1988, Tranter Systems, Ltd.
All rights reserved.

Publics and Defs.

Public program_lca ;program/normal entry
Public send_lca_bit ;send bit entry

LCA programming codes passed between caller and program_lca entry point.
Configuring the LCA from the PC Bus

lca_func_normal  equ 0
lca_func_program equ 1
srl_rsc_dta     equ 3 ;rsc data port (bi-directional)
srl_dta_port    equ 3 ;board data port (out)

; This PAL configuration interface was designed into an existing
; port mapping scheme. For demo purposes, the base port to which
; the card containing the LCA responds is defined as an equate.
; The ports which control configuration are defined as offsets
; from this base port.

base_port       equ 328h
configCtlPort   equ base_port + 2
configDtaPort   equ base_port + 3

; Control port bit assignments. The configuration PAL latches
; cl, c0, and dpen during writes to the ctl port. The config. PAL
; drives data onto SDO during reads from this port.

ctlBit record   cl:1,c0:1,dpen:1,clt_unused:5
statBit record  stat_unused:7,dp:1

; Control bits cl and c0 set PAL modes. The function implied
; by a given mode doesn't take effect until a subsequent write
; to the config_dta_port (this scheme eliminates spiking on
; the control lines).

mode_idle       equ 0 ;configuration PAL idle
mode_program    equ mask c0 + mask dpen ;set pgm mode
mode_reset      equ mask cl + mask dpen ;toggle reset
mode_reset_only equ mask cl ;"" without dp
mode_cclk       equ mask cl + mask c0 ;send configuration bits

;-----------------------------------------------------------------------
; module entry
;-----------------------------------------------------------------------

code segment byte public
assume cs:code

;-----------------------------------------------------------------------

program_lca

; input: al = program/normal function code
; output: nc = function ok
; cy = function failed

; we support two functions: set program mode, set normal mode.
; when we go to program mode we also pulse the lca's reset.
; when going to normal mode we check to make sure that the lca
; has allowed d/-p to go high, indicating programming finished.
Configuring the LCA from the PC Bus

;
; saves all registers
;
-----------------------------------------------------------------------
program_lca proc

push ax
push dx

mov dx,config_ctl_port ;dx -> srl board control port

cmp al,lca_func_normal ;go to normal operation?
jz go_normal

Program mode
;
1. set program mode
2. toggle reset
3. check status of d/-p
4. go to cclk mode

mov al,mode_program ;set program mode and assert d/-
out dx,al
inc dx
out dx,al
dec dx
mov al,mode_reset ;assert d/-p and enable -reset
out dx,al
inc dx
out dx,al
dec dx
mov al,mode_reset_only ;stay in reset mode but stop
out dx,al

in al,dx ;get status of d/-p pin
test al,mask dp ;bit should be low if in pgm mod
stc
jnz program_done

mov al,mode_cclk ;enable cclk for configuration b
out dx,al
clc
jmp short program_done

Normal mode
;
1. set PAL to idle mode
2. check d/-p to make sure lca took it high
3. also output a zero to base port to disable all funcs.

go_normal:
mov al,mode_idle ;shut-down programming PAL
out dx,al

3-145
Configuring the LCA from the PC Bus

inc dx ;dx -> board dta port
out dx,al ;any write shuts down PA

; We write a 0 to the base port to disable all board functions.
; This is necessitated by the particular board and not by the
; demands of the configuration architecture.

mov dx,base_port
xor al,al
out dx,al

; check the d/-p pin

mov dx,config_ctl_port
in al,dx ;get board status
test al,mask dp ;check d/-p, should be high
jnz program_done
stc

program_done:
pop dx
pop ax
ret

program_lca endp

;-----------------------------------------------------------------------
send lea bit
; input: al, bit 0 = bit of configuration data
; output: nc = bit sent ok
cy = error
; send a bit of configuration data to the lea.
; this routine must not be called unless the lea has been placed
; in program mode by the program_lca routine.
; saves all regs.
;-----------------------------------------------------------------------

send_lca_bit proc
push dx

mov dx,config_dta_port ;send the bit, the pal
out dx,al ;will toggle cclk

clc ;for now we have no handshake
pops dx ;on each bit so we can"t determi
ret ;whether or not an error occurre

send_lca_bit endp

code ends

end

; end of file
PGMLCA: Gate array programming module

PGMLCA.asm

PGMLCA sequences the phases of LCA programming. In general these phases include:

- place LCA in program mode, toggle reset
- check that the LCA entered program mode
- send the configuration bit stream, one bit at a time
- place the LCA in normal mode
- check that the LCA is in normal mode

PGMLCA may be placed in ROM, a DOS device driver, or other program. The caller passes a far pointer to a "byte stream", a packed configuration bit stream. The byte stream has the structure:

- word # of bits in stream (N)
- word # of bytes used to store stream (M)
- byte [0..M-1] M bytes holding packed bit stream

PGMLCA uses another module, DOWNLCA, to perform hardware-dependent functions such as sending bits and setting program/normal mode.

History:

- 12-11-87 RCB first
- 01-26-88 RCB make mods. for ap. note release

Copyright (C) 1988, Tranter Systems, Ltd.
All rights reserved.

Publics, Externals, and Defs.

public  pgm_gate_array ;our entry

; program_lca places the LCA in program/normal mode and reports the success or failure of the function. send_lca_bit sends individual bits to the LCA.

extrn  program_lca:near
extrn  send_lca_bit:near
Configuring the LCA from the PC Bus

lea programming codes passed between us and the program_lca entry point.

lea_func_normal equ 0
lea_func_program equ 1

module entry (pgm_gate_array)

input: es:di -> bit stream structure
es:[di] = word, bit stream length in bits
es:[di+2] = word, bytes used to hold stream
es:[di+4] -> array of bytes holding stream

output: nc = programming ok
cy = unable to program lca

saves all regs

code segment byte public
assume cs:code

pgm_gate_array proc
push ax
push bx
push cx
push di

mov al,lea_func_program ;set lca to programming mode
call program_lca
jc pgm_error

mov cx,word ptr es:[di] ;cx = number of bits to send
add di,4 ;es:di -> byte array

pgm_byte:
mov bl,8 ;8 bits/byte
mov al,byte ptr es:[di] ;al = packed array of bits ;bit 7 is first to be sent
inc di

pgm_bit:
jcxz pgm_done
dec cx
rol al,1 ;al, bit 0, is bit to send
push ax
and al,1 ;mask bit
call send_lca_bit ;and send
pop ax
jc pgm_error ;couldn't send bit
dec bl
jnz pgm_bit
jmp pgm_byte

3-148
Configuring the LCA from the PC Bus

pgm_done:
;          the LCA requires that three additional bits be sent after
;          the configuration bit stream in order to complete configuration.
call     send_lca_bit
         call     send_lca_bit
         call     send_lca_bit
         mov     al,lca_func_normal         ;set lca to normal operation
         call     program_lca
         jnc     program_lca

pgm_error:
          stc         ;set error return code

pgm_finished:
          pop     di
          pop     cx
          pop     bx
          pop     ax
          ret

pgm_gate_array   endp

code    ends
end

;          end of file
Configuring the LCA from the PC Bus

APPENDIX 7

; title LCA Programming PAL
pattern config
revision B
author Robert Botchek
company Trantor Systems, Ltd
date January 26, 1988
chip config pal1618

bdsel a0 a1 a2 iow ior d5 d6 d7 gnd
nc /reset /dpen /cl /c0 /len /dpout /dp /cclk vcc

equations

; c1 and c0 are latching outputs which are used as function selects.
; they are latched during a write to baseport+2. the meaning of the
; function selects are defined:
;
; c1 c0 code function
; ------- -------
; 0 0 0 releases d/-p for normal lca operation
; 0 1 1 assert lca program (d/-p low)
; 1 0 2 toggle -reset mode
; 1 1 3 toggle cclk mode
;
; c1 and c0 will glitch during latching and so should not be used
; as direct inputs to a combinatorial output.

begin

cl = /bdsel * /a2 * a1 * /a0 * /iow * d7
    + bdsel * cl
    + a2 * cl
    + /a1 * cl
    + a0 * cl
    + iow * cl
cl.trst = vcc

c0 = /bdsel * /a2 * a1 * /a0 * /iow * d6
    + bdsel * c0
    + a2 * c0
    + /a1 * c0
    + a0 * c0
    + iow * c0
c0.trst = vcc

; dpen latches similarly to c1 and c0. when asserted it enables the
; dp pin.

dpen = /bdsel * /a2 * a1 * /a0 * /iow * d5
    + bdsel * dpen
    + a2 * dpen
    + /a1 * dpen
    + a0 * dpen
    + iow * dpen

end
Configuring the LCA from the PC Bus

dpen.trst = vcc

; dp drives the d/-p input on the LCA. When at vcc, the LCA operates
; normally (assuming it has been programmed). When at gnd, the LCA
; is in a program mode.
;
; d/-p is latched during functions 1 and 2 of (<c1,c0> = <0,1> or
; <c1,c0> = <1,0>) and any write to baseport+3 is given. An assertion
; of d/-p also enables the d/-p output.

dp = /bdsel * /a2 * a1 * a0 * /iow * /cl * c0
    + /bdsel * /a2 * a1 * a0 * /iow * cl * /c0
    + bdsel * dp
    + a2 * dp
    + /a1 * dp
    + /a0 * dp
    + iow * dp
dp.trrst = dpen

; reset drives the -reset line on the LCA. It is asserted only during
; a write to baseport+3 when function code 2 is selected.

reset = /bdsel * /a2 * a1 * a0 * /iow * cl * /c0
reset.trrst = vcc

; cclk is the configuration clock used by the LCA to latch incoming
; configuration data. The LCA latches data on the rising edge of cclk.
; We keep cclk high all the time and only lower it during a write to
; baseport+3 when function code 3 is selected. Thus, at the end of
; the write cycle the data will be latched.
;
; Note: Data is written to baseport+3, not baseport+2. This simplifies
; the timing of the cclk enable and the data output.

cclk = /bdsel * /a2 * a1 * a0 * /iow * cl * c0
cclk.trrst = vcc

; len enables the board status latch onto the PC's data bus, it also
; enables the dpout output (below).
;
; Board status includes the condition of the LCA's done/-program
; (d/-p) pin, etc.

len = /bdsel * /a2 * a1 * /a0 * /ior
len.trrst = vcc

; dpout drives data onto the PC's data bus during a read from base
; port+2 as enabled by len. Dpout indicates program mode when high.

dpout = /dp
dpout.trrst = len
# Table of Contents Section 4
## Product Information

<table>
<thead>
<tr>
<th>Section 4 Product Information</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Logic Cell™ Array M2064/M2018</td>
<td>4-3</td>
</tr>
<tr>
<td>3000 Series Family of Programmable Gate Arrays</td>
<td>4-43</td>
</tr>
<tr>
<td>LCA-MDS21</td>
<td></td>
</tr>
<tr>
<td>XACT Design Editor System</td>
<td>4-116</td>
</tr>
<tr>
<td>LCA-MDS22</td>
<td></td>
</tr>
<tr>
<td>P-SILOS Simulator</td>
<td>4-119</td>
</tr>
<tr>
<td>LCA-MDS23</td>
<td></td>
</tr>
<tr>
<td>Automatic Design Implementation</td>
<td>4-120</td>
</tr>
<tr>
<td>LCA-MDS24, LCA-MDS26, LCA-MDS27</td>
<td></td>
</tr>
<tr>
<td>XACTOR In-Circuit Emulator</td>
<td>4-121</td>
</tr>
<tr>
<td>LCA-MDS31/LCA-MDS33/LCA-MDS34/LCA-MDS35</td>
<td></td>
</tr>
<tr>
<td>Schematic Design Entry Interface for Futurenet, Daisy, Mentor, OrCAD</td>
<td>4-122</td>
</tr>
<tr>
<td>LCA-MDS151/LCA-MDS152</td>
<td></td>
</tr>
<tr>
<td>PGA Development System/PGA Design Entry System</td>
<td>4-124</td>
</tr>
<tr>
<td>LCA-MDS135</td>
<td></td>
</tr>
<tr>
<td>OrCAD/SDT III PGA Design Entry System and Interface</td>
<td>4-134</td>
</tr>
<tr>
<td>LCA-MEK01</td>
<td></td>
</tr>
<tr>
<td>Logic Cell Array Evaluation Kit</td>
<td>4-141</td>
</tr>
</tbody>
</table>
Logic Cell™ Array
M2064/M2018

Features/Benefits
- CMOS programmable Logic Cell Array (LCA) for replacement of standard logic
- Completely reconfigurable by the user in the final system
- High performance equivalent to TTL SSI/MSI
  - 33 MHz flip-flop toggle rate (-33 speed grade)
  - 50 MHz flip-flop toggle rate (-50 speed grade)
  - 70 MHz flip-flop toggle rate (-70 speed grade)
- User-configurable logic functions, interconnect and I/O for maximum flexibility
- 64/100 user-configurable Logic Blocks (CLBs) providing usable gate equivalency of up to 1200/1800 gates
- 58/74 individually-configurable I/O pins allowing any mix of inputs, outputs or bidirectional signals (68/84-pin package)
- User-selectable TTL or HCMOS input threshold levels
- Multiple configuration modes for greatest flexibility and ease-of-use
- Verification feature allows user to check configuration data
- User-selectable security feature prevents read-back of configuration data
- Read-back of internal register states for system debug
- On-chip clock oscillator and clock buffer circuits provide flexible internal and external clocking functions
- Master reset of all internal register elements in addition to user-configurable Reset and/or Set control of individual CLB storage elements
- Complete development system support

General Description
The Logic Cell Array (LCA) is a high-density CMOS-integrated circuit available from Monolithic Memories. Its user-programmable architecture is made up of three types of configurable elements: Input/Output Blocks, Logic Blocks and Interconnect. The designer can define individual I/O blocks for interface to external circuitry, define logic blocks to implement logic functions and define interconnection network to compose larger scale logic functions. The XACT™ Development system provides interactive graphic design capture and automatic routing. Both logic simulation and in-circuit emulation are available for design verification.

The Logic Cell Array is available in a variety of logic capacities, package styles, temperature ranges and speed grades.

<table>
<thead>
<tr>
<th>PART NUMBER</th>
<th>LOGIC CAPACITY (USABLE GATES)</th>
<th>CONFIGURABLE LOGIC BLOCKS</th>
<th>USER I/Os</th>
<th>CONFIGURATION PROGRAM (BITS)</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2064</td>
<td>1200</td>
<td>64</td>
<td>58</td>
<td>12040</td>
</tr>
<tr>
<td>M2018</td>
<td>1800</td>
<td>100</td>
<td>74</td>
<td>17880</td>
</tr>
</tbody>
</table>

The Logic Cell Array's logic functions and interconnections are determined by data stored in internal static memory cells. On-chip logic provides for automatic loading of configuration data at power-up. The program data can reside in an EEPROM, EPROM or ROM on the circuit board or on a floppy disk or hard disk. The program can be loaded in a number of modes to accommodate various system requirements.

Package Availability

<table>
<thead>
<tr>
<th>PART NUMBER</th>
<th>48-PIN PLASTIC DIP N48</th>
<th>68-PIN PLCC NL68</th>
<th>68-PIN PGA P68</th>
<th>84-PIN PLCC NL84</th>
<th>84-PIN PGA P84</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2064</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>M2018</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
</tbody>
</table>

Ordering Information

<table>
<thead>
<tr>
<th>PART NUMBER</th>
<th>NUMBER OF PINS</th>
<th>PACKAGE TYPE</th>
<th>TEMPERATURE RANGE</th>
</tr>
</thead>
<tbody>
<tr>
<td>M2064-70 C NL 84</td>
<td>48 (48 Pins)</td>
<td>NL = Pin Molded Chip Carrier</td>
<td>C = Commercial</td>
</tr>
<tr>
<td>M2018</td>
<td>68 (68 Pins)</td>
<td>P = Pin Grid Array</td>
<td>M = Military</td>
</tr>
</tbody>
</table>

XILINX™, XACT™, XACTOR™, Logic Cell™ Array and Logic Processor™ are trademarks of XILINX Inc.
IBM® is a registered trademark of International Business Machines Corporation.
PC™, PC-AT™ and PC-XT™ are trademarks of International Business Machines Corporation.
P-SILOS™ is a trademark of SimuCad Corporation.
MS-DOS™ is a trademark of Microsoft Corporation.
Portions of this Data Sheet reproduced with the permission of XILINX Inc.
Pin Description

PWRDWN
An active low power-down input stops all internal activity to minimize VCC power and puts all output buffers in a high-impedance state. Configuration is retained, however, internal storage elements are Reset. When the PWRDWN pin returns HIGH, the device returns to operation with the same sequence of reset, buffer enable and DONE, PROGRAM as at the completion of configuration.

M0, RTRIG
As Mode 0, this input and M1, M2 are sampled before the start of configuration to establish the configuration mode to be used.

As a read trigger, an input transition to a HIGH, after configuration is complete, will initiate a readback of configuration and storage element data. This operation may be limited to a single request, or be inhibited altogether, by selecting the appropriate readback option when generating the bit stream.

M1, RDATA
As Mode 1, this input and M0, M2 are sampled before the start of configuration to establish the configuration mode to be used.

As an active-low read data; after configuration is complete, this pin is the output of the readback data.

M2
As Mode 2, this input and M0, M1 are sampled before the start of configuration to establish the configuration, mode to be used. After configuration, this pin becomes a user-programmable I/O.

HDC
High during configuration is held at a HIGH level by the LCA until after configuration. It is intended to be available as a control indication that configuration is not complete. After configuration, this pin is a user I/O.

LDC
Low during configuration is held at a LOW level by the LCA until after configuration. It is intended to be available as a control indication that configuration is not complete. It is particularly useful in master mode as a LOW enable for an EPROM. After configuration, this pin is a user I/O. If used as a LOW EPROM enable, it should be programmed as a HIGH after configuration.

RESET
This is an active-low input which has three functions. Prior to the start of configuration, a LOW input will delay the start of the configuration process. An internal circuit senses the application of power and begins a minimal time-out cycle on the order of 100 ms. When the time-out and RESET are complete, the levels of the "M" mode lines are sampled and configuration begins. If RESET is asserted during a configuration, the LCA is reinitialized and will restart the configuration at the termination of RESET. If RESET is asserted after configuration is complete, it will provide an asynchronous reset of all IOB and CLB storage elements of the LCA.

DONE, PROG
The DONE open drain output is configurable with or without a pull-up resistor of about 3 KΩ. At the completion of configuration, the circuitry of the LCA becomes active in a synchronous order and one configuration clock cycle later DONE is asserted. Once configuration is done, a HIGH-to-LOW transition of this program pin will cause an initialization of the LCA and start a reconfiguration if that mode is selected in the current configuration.

XTL1
This user I/O pin may be configured to operate as the output of an amplifier usable with an external crystal and bias circuitry to form an oscillator.

XTL2
This user I/O pin may be configured to operate as the input of an amplifier usable with an external crystal and bias circuitry to form an oscillator.

CCLK
During configuration, configuration clock is an output of an LCA in either master or peripheral mode. LCAs in slave mode use it as a clock input. During a readback operation, it is an input clock for the configuration data being output.

DOUT
This user I/O pin is used during configuration to output serial configuration data out for daisy-chained slaves' data in.

DIN
This user I/O pin is used as serial data in during slave or peripheral configuration. This pin is D0 in master configuration mode.

CSO, CS1, CS2, WRT
These four inputs represent a set of signals, three active low and one active high, which are used in the peripheral mode to control configuration data entry. The assertion of all four generates a LOW CCLK and shifts DOUT data. The removal of any assertion clocks in the DIN data present and causes a HIGH CCLK. In master mode, these pins become part of the parallel configuration byte (D4, D3, D2, D1). After configuration is complete, they are user-programmed I/O.

RCLK
During master mode configuration, this pin represents a read clock of an external memory device. After configuration is complete, this pin becomes a user-programmed I/O.

D0-D7
This set of eight pins represents the parallel configuration data byte for the master mode. After configuration is complete, they are user-programmed I/O.

A0-A15
This set of sixteen pins presents an address output for an external configuration memory during master mode. After configuration is complete, they are user-programmed I/O. A12 through A15 are not available in packages with less than sixty-eight pins.

I/O
A pin which may be programmed by the user to be input and/or output following configuration. Some of these pins present a high-impedance pull-up or perform other functions before configuration is complete.
**Functional Description**

The general structure of a Logic Cell Array is shown in Figure 1. The elements of the array include three categories of user-programmable elements: I/O Blocks, Configurable Logic Blocks and Programmable Interconnections. The I/O Blocks provide an interface between the logic array and the device package pins. The Configurable Logic Blocks perform user-specified logic functions, and the interconnect resources are programmed to form networks that carry logic signals among blocks.

Configuration of the Logic Cell Array is established through a distributed array of memory cells. The XACT development system generates the program used to configure the Logic Cell Array. The Logic Cell Array includes logic to implement automatic configuration.

![Figure 1. Logic Cell Array Structure](image)

**Configuration Memory**

The configuration of the Monolithic Memories' Logic Cell Array is established by programming memory cells which determine the logic functions and interconnections. The memory loading process is independent of the user logic functions.

The static memory cell used for the configuration memory in the Logic Cell Array has been designed specifically for high reliability and noise immunity. Based on this design, integrity of the LCA configuration memory is assured even under adverse conditions. Compared with other programming alternatives, static memory provides the best combination of high density, high performance, high reliability and comprehensive testability. As shown in Figure 2, the basic memory cell consists of two CMOS inverters plus a pass transistor used for writing data to the cell. The cell is only written during configuration and only read during readback. During normal operation the pass transistor is "off" and does not affect the stability of the cell. This is quite different from the normal operation of conventional memory devices, in which the cells are continuously read and written.

The outputs \( Q \) and \( \bar{Q} \) control pass-transistor gates directly. The absence of sense amplifiers and the output capacitive load provide additional stability to the cell. Due to the structure of the configuration memory cells, they are not affected by extreme power supply excursions or very high levels of alpha particle radiation. In reliability testing no soft errors have been observed, even in the presence of very high doses of alpha radiation.
Input/Output Block

Each user-configurable I/O block (IOB) provides an interface between the external package pin of the device and the internal logic. Each I/O block includes a programmable input path and a programmable output buffer. It also provides input clamping diodes to provide protection from electrostatic damage, and circuits to protect the LCA from latch-up due to input currents. Figure 3 shows the general structure of the I/O block.

The input buffer portion of each I/O block provides threshold detection to translate external signals applied to the package pin to internal logic levels. The input buffer threshold of the I/O blocks can be programmed to be compatible with either TTL (1.4 V) or CMOS (2.2 V) levels. The buffered input signal drives both the data input of an edge-triggered D-type flip-flop and one input of a two-input multiplexer. The output of the flip-flop provides the other input to the multiplexer. The user can select either the direct input path or the registered input, based on the content of the memory cell controlling the multiplexer. The I/O blocks along each edge of the die share common clocks. The flip-flops are reset during configuration as well as by the active-low chip RESET input.

Output buffers in the I/O blocks provide 4-mA drive for high fan-out CMOS or TTL-compatible signal levels. The output data (driving I/O block pin 0) is the data source for the I/O block output buffer. Each I/O block output buffer is controlled by the contents of two configuration memory cells which turn the buffer ON or OFF or select logical three-state buffer control. The user may also select the output buffer three-state control (I/O block pin TS). When this I/O block output control signal is HIGH (a logic “1”) the buffer is disabled and the package pin is high-impedance.
Configurable Logic Block

An array of Configurable Logic Blocks (CLBs) provides the functional elements from which the user's logic is constructed. The logic blocks are arranged in a matrix in the center of the device. The M2064 has sixty-four such blocks arranged in an eight-row by eight-column matrix. The M2018 has one hundred logic blocks arranged in a ten by ten matrix. Each logic block has a combinatorial logic section, a storage element, and an internal routing and control section. Each CLB has four general-purpose inputs; A, B, C and D; and a special clock input (K), which may be driven from the interconnect adjacent to the block. Each CLB also has two outputs, X and Y, which may drive interconnect networks. Figure 4 shows the resources of a Configurable Logic Block.

The logic block combinatorial logic uses a table look-up memory to implement Boolean functions. This technique can generate any logic function of up to four variables with a high-speed sixteen-bit memory. The propagation delay through the combinatorial network is independent of the function generated. Each block can perform any function of four variables or any two functions of three variables each. The variables may be selected from among the four inputs and the block's storage element output "Q". Figure 5 shows various options which may be specified for the combinatorial logic.
If the single four-variable configuration is selected (Option 1),
the F and G outputs are identical. If the two-function
alternative is selected (Option 2), logic functions F and G may
be independent functions of three variables each. The three
variables can be selected from among the four logic block
inputs and its storage element output Q. A third form of the
combinatorial logic (Option 3) is a special case of the two­
function form in which the B input dynamically selects between
the two function tables providing a single merged logic function
output. This dynamic selection allows some five-variable
functions to be generated from the four block inputs and
storage element Q. Combinatorial functions are restricted in
that one may not use both its storage element output Q and the
input variable of the logic block pin D in the same function.

If used, the storage element in each Configurable Logic Block
(Figure 6) can be programmed to be either an edge-sensitive
D-type flip-flop or a level-sensitive D latch. The clock or enable
for each storage element can be selected from:
• The special-purpose clock input K
• The general-purpose input C
• The combinatorial function G

The two block outputs, X and Y, can be driven by either the
combinatorial functions, F or G, or the storage element output
Q (Figure 4). Selection of the outputs is completely
interchangeable and may be made to optimize routing
efficiencies of the networks interconnecting the logic blocks
and I/O blocks.

Programmable Interconnect
Programmable interconnection resources in the Logic Cell Array
provide routing paths to connect inputs and outputs of the I/O
and logic blocks into desired networks. All interconnections
are composed of metal segments, with programmable
switching points provided to implement the necessary routing.
Three types of resources accommodate different types of
networks:
• General purpose interconnect
• Long lines
• Direct connection

General-Purpose Interconnect
General-purpose interconnect, as shown in Figure 7a, is
composed of four horizontal metal segments between the rows
and five vertical metal segments between the columns of logic
and I/O blocks. Each segment is only the "height" or "width" of
a logic block. Where these segments would cross at the
intersections of rows and columns, switching matrices are
provided to allow interconnections of metal segments from the
adjoining rows and columns. Switches in the switch matrices
and on block outputs are specially designed transistors, each
controlled by a configuration bit.
Logic block output switches provide contacts to adjacent general interconnect segments and therefore to the switching matrix at each end of those segments. A switch matrix can connect an interconnect segment to other segments to form a network. Figure 7a shows the general interconnect used to route a signal from one logic block to three other logic blocks. As shown, combinations of closed switches in a switch matrix allow multiple branches for each network. The inputs of the logic or I/O blocks are multiplexers that can be programmed with configuration bits to select an input network from the adjacent interconnect segments. Since the switch connections to block inputs are undirectional (as are block outputs) they are usable only for input connections. The development system software provides automatic routing of these interconnections. Interactive routing is also available for design optimization. This is accomplished by selecting a network and then toggling the states of the interconnect points by selecting them with the "mouse". In this mode, the connections through the switch matrix may be established by selecting pairs of matrix pins. The switching matrix combinations are indicated in Figure 7b.

Special buffers within the interconnect area provide periodic signal isolation and restoration for higher general interconnect fan-out and better performance. The repowering buffers are bidirectional, since signals must be able to propagate in either direction on a general interconnect segment. Direction controls are automatically established by the Logic Cell Array development system software. Repowering buffers are provided only for the general-purpose interconnect since the direct and long-line resources do not exhibit the same R-C delay accumulation. The Logic Cell Array is divided into nine sections with buffers automatically provided for general interconnect at the boundaries of these sections. These boundaries can be viewed with the development system. For routing within a section, no buffers are used. The delay calculator of the XACT development system automatically calculates and displays the block, interconnect and buffer delays for any selected paths.
Long Lines

Long lines, shown in Figure 8a, run both vertically and horizontally the height or width of the interconnect area. Each vertical interconnection column has two long lines; each horizontal row has one, with an additional long line adjacent to each set of I/O blocks. The long lines bypass the switch matrices and are intended primarily for signals that must travel a long distance or must have minimum skew among multiple destinations.

A global buffer in the Logic Cell Array is available to drive a single signal to all B and K inputs of logic blocks. Using the global buffer for a clock provides a very low skew, high fan-out synchronized clock for use at any or all of the logic blocks. At each block, a configuration bit for the K input to the block can select this global line as the storage element clock signal. Alternatively, other clock sources can be used.

A second buffer below the bottom row of the array drives a horizontal long line which, in turn, can drive a vertical long line in each interconnection column. This alternate buffer also has low skew and high fan-out capability. The network formed by this alternate buffer's long lines can be selected to drive the B, C or K inputs of the logic blocks. Alternatively, these long lines can be driven by a logic or I/O block on a column-by-column basis. This capability provides a common, low-skew clock or control line within each column of logic blocks. Interconnections of these long lines are shown in Figure 8b.

Figure 8a. Long Line Interconnect
Figure 8b. M2064 Long Lines, I/O Clocks, I/O Direct Interconnect
Direct Interconnect

Direct interconnect, shown in Figure 9, provides the most efficient implementation of networks between adjacent logic or I/O blocks. Signals routed from block to block by means of direct interconnect exhibit minimum interconnect propagation and use minimum interconnect resources. For each CLB, the X output may be connected directly to the C or D inputs of the CLB above and to the A or B inputs of the CLB below it. The Y output can use direct interconnect to drive the B input of the block immediately to its right. Where logic blocks are adjacent to I/O blocks, direct connect is provided to the I/O block input (I) on the left edge of the die, the output (O) on the right edge, or both on I/O blocks at the top and bottom of the die. Direct interconnections of I/O blocks with CLBs are shown in Figure 8b.

Figure 9. Direct Interconnect

Crystal Oscillator

An internal high-speed inverting amplifier is available to implement an on-chip crystal oscillator. It is associated with the auxiliary clock buffer in the lower right corner of the die. When configured to drive the auxiliary clock buffer, two special adjacent user I/O blocks are also configured to connect the oscillator amplifier with external crystal oscillator components, as shown in Figure 10. This circuit becomes active before configuration is complete in order to allow the oscillator to stabilize. Actual internal connection is delayed until completion of configuration. The feedback resistor R1 between output and input, biases the amplifier at threshold. It should be as large a value as practical to minimize loading on the crystal. The inverter of the amplifier, along with the R-C networks and crystal, produces the 360-degree phase shift of the Pierce oscillator.

A series resistor R2 may be included to add to the amplifier output impedance when needed for phase-shift control or crystal resistance matching or to limit the amplifier input swing to control clipping at large amplitudes. Excess feedback voltage may be adjusted by the ratio of C2/C1. The amplifier is designed to be used over the range from 1 MHz up to one-half the specified CLB toggle frequency. Use at frequencies below 1 MHz may require individual characterization with respect to a series resistance. Operation at frequencies above 20 MHz generally requires a crystal to operate in a third overtone mode, in which the fundamental frequency must be suppressed by the R-C networks. When the amplifier does not drive the auxiliary buffer, these I/O blocks and their package pins are available for general user I/O.
**Power**

**Power Distribution**

Power for the LCA is distributed through a grid to achieve high noise immunity and isolation between logic and I/O. For packages having more than forty-eight pins, two VCC pins and two ground pins are provided (see Figure 11). Inside the LCA, a dedicated VCC and ground ring surrounding the logic array provides power to the I/O drivers. An independent matrix of VCC and ground lines supplies the interior logic of the device. This power distribution grid provides a stable supply and ground for all internal logic, providing the external package power pins are appropriately decoupled. Typically a 0.1-µF capacitor connected between the VCC and ground pins near the package will provide adequate decoupling.

Output buffers capable of driving the specified 4-mA loads under worst-case conditions may be capable of driving 25 to 30 times that current in a best case. Noise can be reduced by minimizing external load capacitance and reducing simultaneous output transitions in the same direction. It may also be beneficial to locate heavily-loaded output buffers near the ground pads. Multiple VCC and ground pin connections are required for package types which provide them.
Power Dissipation

The Logic Cell Array exhibits the low power consumption characteristic of CMOS ICs. Only quiescent power is required for the LCA configured for CMOS input levels. The TTL input level configuration option requires additional power for level shifting. The power required by the static memory cells which hold the configuration data is very low and may be maintained in a power-down mode.

Typically most of power dissipation is produced by capacitive loads on the output buffers, since the power per output is 25 \( \mu \text{W/pF/MHz} \). Another component of I/O power is the DC loading on each output pin. For any given system, the user can calculate the power requirement based on the resistive loading of the devices driven by the Logic Cell Array.

Internal power supply dissipation is a function of clock frequency and the number of nodes changing on each clock. In an LCA the fraction of nodes changing on a given clock is typically low (10-20%). For example, in a 16-bit binary counter, the average clock produces a change in slightly less than two of the sixteen bits. In a 4-input AND gate there will be two transitions in sixteen states. Typical global clock buffer power is about 3 mW/MHz for the M2064 and 4 mW/MHz for the M2018. With a "typical" load of three general interconnect segments, each CLB output requires about 0.4 mW/MHz of its output frequency. Graphs of power versus operating frequency are shown in Table 1.

![Graph showing power dissipation vs frequency](image)

Table 1. Typical LCA Power Consumption by Element

<table>
<thead>
<tr>
<th>Element Description</th>
<th>Power Consumption (mW/MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 I/O OUTPUT (50pF)</td>
<td>0.4</td>
</tr>
<tr>
<td>20 CLB OUTPUTS</td>
<td>3 LOCAL SEGMENTS EACH</td>
</tr>
<tr>
<td>GLOBAL CLOCK BUFFER</td>
<td>3mW/MHz</td>
</tr>
<tr>
<td>1.25 mW/MHz</td>
<td>1 I/O OUTPUT (50pF)</td>
</tr>
<tr>
<td>0.4 mW/MHz</td>
<td>1 CLB OUTPUT</td>
</tr>
</tbody>
</table>

4-14
Programming

Configuration data to define the function and interconnection within a Logic Cell Array are loaded automatically at power-up or upon command. Several methods of automatically loading the required data are designed into the Logic Cell Array and are determined by logic levels applied to mode selection pins at configuration time. The form of the data may be either serial or parallel, depending on the configuration mode. The programming data are independent of the configuration mode selected. The state diagram of Figure 12 illustrates the configuration process.

Input thresholds for user I/O pins can be selected to be either TTL-compatible or CMOS-compatible and remain in that state until the LCA begins operation. If the user has selected CMOS compatibility, the input thresholds are changed to CMOS levels during configuration.

Figure 12. Configuration State Diagram

Figure 13 shows the specific data arrangement for the M2064 device. Future products will use the same data format to maintain compatibility between different devices of the Monolithic Memories' product line, but they will have different sizes and numbers of data frames. For the M2064 configuration requires 12,038 bits for each device. For the M2018, the configuration of each device requires 17,878 bits. The M2064 uses 160 configuration data frames and the M2018 uses 197.

Figure 13. M2064 Configuration Data Arrangement
The configuration bit stream begins with preamble bits, a preamble code and a length count. The length count is loaded into the control logic of the Logic Cell Array and is used to determine the completion of the configuration process. When configuration is initiated, a 24-bit length counter is set to 0 and begins to count the total number of configuration clock cycles applied to the device. When the current length count equals the loaded length count, the configuration process is complete. Two clocks before completion, the internal logic becomes active and is reset. On the next clock, the inputs and outputs become active as configured and consideration should be given to avoid configuration signal contention. (Attention must be paid to avoid contention on pins which are used as inputs during configuration and become outputs in operation.) On the last configuration clock, the completion of configuration is signalled by the release of the DONE, PROG pin of the device as the device begins operation. This open-drain output can be AND-tied with multiple Logic Cell Arrays and used as an active-high READY or active-low, RESET, to other portions of the system. High during configuration (HDC) and low during configuration (LDC), are released one CCLK cycle before DONE is asserted. In master mode configurations, it is convenient to use LDC as an active-low EPROM chip enable.

As each data bit is supplied to the LCA, it is internally assembled into a data word. As each data word is completely assembled, it is loaded in parallel into one word of the internal configuration memory array. The last word must be loaded before the current length count compare is true. If the configuration data are in error, e.g., PROM address lines swapped, the LCA will not be ready at the length count and the counter will cycle through an additional complete count prior to configuration being “done”.

Figure 14 shows the selection of the configuration mode based on the state of the mode pins M0 and M1. These package pins are sampled prior to the start of the configuration process to determine the mode to be used. Once configuration is DONE and subsequent operation has begun, the mode pins may be used to perform data readback, as discussed later. An additional mode pin, M2, must be defined at the start of configuration. This package pin is a user-configurable I/O after configuration is complete.

### Initialization Phase

When power is applied, an internal power-on-reset circuit is triggered. When VCC reaches the voltage at which the LCA begins to operate (2.5 to 3 Volts), the chip is initialized, outputs are made high-impedance and a time-out is initiated to allow time for power to stabilize. This time-out (15 to 35 ms) is determined by a counter driven by a self-generated, internal sampling clock that drives the configuration clock (CCLK) in master configuration mode. This internal sampling clock will vary with process, temperature and power supply over the range of 0.5 to 1.5 MHz. LCAs with mode lines set for master mode will time-out of their initialization using a longer counter (60 to 140 ms) to assure that all devices, which it may be driving in a daisy chain, will be ready. Configuration using peripheral or slave modes must be delayed long enough for this initialization to be completed.

The initialization phase may be extended by asserting the active-low external RESET. If a configuration has begun, an assertion of RESET will initiate an abort, including an orderly clearing of partially loaded configuration memory bits. After about three clock cycles for synchronization, initialization will require about 160 additional cycles of the internal sampling clock (197 for the M2018) to clear the internal memory before another configuration may begin. The same is true of a configured part in which the reconfigurable control bit is set. When a HIGH-to-LOW transition on the DONE, PROG package pin is detected, thereby initiating a reprogram, the configuration memory is cleared. This insures an orderly configuration in which no internal signal conflicts are generated during the loading process.

### Master Mode

In master mode, the Logic Cell Array automatically loads the configuration program from an external memory device. Figure 15a shows an example of the master mode connections required. The Logic Cell Array provides sixteen address outputs and the control signals RCLK (read clock), HDC (high during configuration) and LDC (low during configuration) to execute read cycles from the external memory. Parallel eight-bit data words are read and internally serialized. As each data word is read, the least significant bit of each byte, normally DO, is the next bit in the serial stream.

Addresses supplied by the Logic Cell Array can be selected by the mode lines to begin at address 0 and incremented to read the memory (master low mode), or they can begin at address FFFF Hex and be decremented (master high mode). This capability is provided to allow the Logic Cell Array to share external memory with another device, such as a microprocessor. For example, if the processor begins its execution from low memory, the Logic Cell Array can load itself from high memory and enable the processor to begin execution once configuration is completed. The DONE, PROG output pin can be used to hold the processor in a Reset state until the Logic Cell Array has completed the configuration process.

The master serial mode uses serial configuration data, synchronized by the rising edge of RCLK, as in Figure 15b.
Peripheral Mode

Peripheral mode provides a simplified interface through which the device may be loaded as a processor peripheral. Figure 16 shows the peripheral mode connections. Processor write cycles are decoded from the common assertion of the active-low write strobe (WRT), and two active-low and one active-high chip selects (CS0, CS1, CS2). If all these signals are not available, the unused inputs should be driven to their respective active levels. The Logic Cell Array will accept one bit of the configuration program on the data input (DIN) pin for each processor write cycle. Data is supplied in the serial sequence described earlier.

Since only a single bit from the processor data bus is loaded per cycle, the loading process involves the processor reading a byte or word of data, writing a bit of the data to the Logic Cell Array, shifting the word and writing a bit until all bits of the word are written, then continuing in the same fashion with the next word, etc. After the configuration program has been loaded, an additional three clocks (a total of three more than the length count) must be supplied in order to complete the configuration process. When more than one device is being used in the system, each device can be assigned a different bit in the processor data bus, and multiple devices can be loaded on each processor write cycle. This "broadside" loading method provides a very easy and time-efficient method of loading several devices.
Slave Mode

Slave mode, Figure 17, provides the simplest interface for loading the Logic Cell Array configuration. Data is supplied in conjunction with a synchronizing clock. For each LOW-to-HIGH input transition of configuration clock (CCLK), the data present on the data input (DIN) pin is loaded into the internal shift register. Data may be supplied by a processor or by other special circuits. Slave mode is used for downstream devices in a daisy-chain configuration. The data for each slave LCA are supplied by the preceding LCA in the chain, and the clock is supplied by the lead device, which is configured in master or peripheral mode. After the configuration program has been loaded, an additional three clocks (a total of three more than the length count) must be supplied in order to complete the configuration process.
Daisy Chain

The daisy-chain programming mode is supported by Logic Cell Array in all programming modes. In master mode and peripheral mode, the LCA can act as a source of data and control for slave devices. For example, Figure 18 shows a single device in master mode, with two devices in slave mode. The master mode device reads the external memory and begins the configuration loading process for all of the devices.

The data begin with a preamble and a length count which is supplied to all devices at the beginning of the configuration. The length count represents the total number of cycles required to load all of the devices in the daisy chain. After loading the length count, the lead device will load its configuration data while providing a HIGH DOUT to downstream devices. When the lead device has been loaded and the current length count has not reached the full value, memory access continues. Data bytes are read and serialized by the lead device. The data are passed through the lead device and appear on the data out (DOUT) pin in serial form. The lead device also generates the configuration clock (CCLK) to synchronize the serial output data. A master mode device generates an internal CCLK of eight times the EPROM address rate, while a peripheral mode device produces CCLK from the chip select and write strobe timing.

![Diagram of Daisy Chain](image)

Figure 18. Master Mode with Daisy Chain

Operation

When all of the devices have been loaded and the length count is complete, a synchronous start-up of operation is performed. On the clock cycle following the end of loading, the internal logic begins functioning in the reset state. On the next CCLK, the configured output buffers become active to allow signals to stabilize. The next CCLK cycle produces the DONE condition. The length count control of operation allows a system of multiple Logic Cell Arrays to begin operation in a synchronized fashion. If the crystal oscillator is used, it will begin operation before configuration is complete to allow time for stabilization before it is connected to the internal circuitry.
Special Features
In addition to the normal user logic functions and interconnect, the configuration data include control for several special functions:

- Input thresholds
- Readback thresholds
- Reprogram enable
- DONE pull-up resistor

Each of these functions is controlled by a portion of the configuration program generated by the XACT Development System.

Input Thresholds
During configuration, all input thresholds are TTL level. During configuration input thresholds are established as specified, either TTL or CMOS. The PWRDN input threshold is an exception; it is always a CMOS level input. The TTL threshold option requires additional power for threshold shifting.

Readback
After a Logic Cell Array has been programmed, the configuration program may be read back from the device. Readback may be used for verification of configuration and as a method of determining the state of internal logic nodes during debugging. In applications in which the verification is not used, it may be desirable to limit access to the configuration data. Three readback options are provided: 'on command', 'only once', and 'never'. If 'on command readback' is selected, the device will respond to all readback requests. If 'readback once' is selected, the device will respond only to the first readback request after programming is complete. Subsequent readback requests will be ignored. If 'readback never' is selected, the device will not respond to a readback command.

Readback is accomplished without the use of any of the user I/O pins; only M0, M1, and CCLK pins are used. An initiation of readback is produced by a LOW-to-HIGH transition of the M0, RTRIG (read trigger) pin. Once the readback command has been given, CCLK is cycled to read back each data bit in a format similar to loading. After two dummy bits, the first data frame is shifted out, in inverted sense, on the M1, RDATA (read data) pin. All data frames must be read back to complete the process and return the mode select and CCLK pins to their normal functions.

In addition to the configuration program, the readback includes the current state of each of the internal logic block storage elements, and the state of the input (I) connection pin on each I/O block. This state information is used by the Logic Cell Array development system In-Circuit Emulator to provide visibility into the internal operation of the logic while the system is operating. To read back a uniform time sample of all storage elements it may be necessary to inhibit the system clock.

Reprogram
The configuration memory of the Logic Cell Array may be rewritten while the device is in the user's system, if that option is selected when the LCA is configured. If another programming cycle is to be initiated, the dual function package pin DONE, PROG must be given a HIGH-to-LOW transition. Sensitivity to noise is reduced, by confirming the HIGH-to-LOW transition over two to three cycles using the LCA's internal sampling oscillator. When a reprogram command is recognized, all internal logic and connectivity definitions are erased and the I/O package pins are forced to a high impedance condition. The device returns to the initialization state. Reprogram control is often implemented with an external open collector driver which pulls DONE, PROG LOW. Once it recognizes a stable request, the Logic Cell Array will hold a LOW until the new configuration has been completed. Whether or not the reprogram request is maintained, the Logic Cell Array will begin operation upon completion of configuration.

DONE Pull-up
The DONE, PROG pin is an open drain I/O that indicates programming status. As an input, it initiates a reprogram operation. An optional internal pull-up resistor may be enabled.

Battery Backup
Because the control store of the Logic Cell Array is a CMOS static memory, its cells require only a very low standby current for data retention. In some systems, this low data retention current characteristic facilitates preserving configurations in the event of a primary power loss. The Logic Cell Array has built in power-down logic which, when activated, will disable normal operation of the device and retain only the configuration data. All internal operation is suspended and output buffers are placed in their high-impedance state.

Power-down data retention is possible with a simple battery-backup circuit because the power requirement is extremely low. For retention at 2.0 V, the required current is typically on the order of 0.5 mA. Screening of this parameter is available. To force the Logic Cell Array into the power-down state, the user must pull the PWRDWN pin low and continue to supply a retention voltage to the VCC pins of the package. When normal power is restored, VCC is elevated to its normal operating voltage and PWRDWN is returned to a HIGH. The Logic Cell Array resumes operation with the same internal sequence that occurs at the conclusion of configuration. Internal I/O and logic block storage elements will be reset, the outputs will become enabled and then the DONE, PROG pin will be released. No configuration programming is involved.

Performance
The high performance of the Logic Cell Array results from its patented architectural features and from the use of an advanced high-speed CMOS manufacturing process. Performance may be measured in terms of minimum propagation times for logic elements.

Flip-flop loop delays for the I/O block and logic block flip-flops are about 3 ns. This short delay provides very good performance under asynchronous clock and data conditions. Short loop delays minimize the probability of a metastable condition which can result from assertion of the clock during data transitions. Because of the short loop delay characteristic in the Logic Cell Array, the I/O block flip-flops can be used very effectively to synchronize external signals applied to the device. Once synchronized in the I/O block, the signals can be used internally without further consideration of their clock relative timing, except as it applies to the internal logic and routing path delays.
Device Performance
The single parameter which most accurately describes the overall performance of the Logic Cell Array is the maximum toggle rate for a logic block storage element configured as a toggle flip-flop. The configuration for determining the toggle performance of the Logic Cell Array is shown in Figure 19. The clock for the storage element is provided by the global clock buffer and the flip-flop output Q is fed back through the combinatorial logic to form the data input for the next clock edge. Using this arrangement, flip-flops in the Logic Cell Array can be toggled at clock rates from 33-70 MHz, depending on the speed grade used.

Actual Logic Cell Array performance is determined by the critical path speed, including both the speed of the logic and storage elements in that path, and the speed of the particular network routing. Figure 20 shows a typical system logic configuration of two flip-flops with an extra combinatorial level between them. Depending on speed grade, system clock rates to 35 MHz are practical for this logic. To allow the user to make the best use of the capabilities of the device, the delay calculator in the XACT Development System determines worst-case path delays using actual impedance and loading information.

![Figure 19. Logic Block Configuration for Toggle Rate Measurement](image)

![Figure 20. Typical Logic Path](image)
Logic Block Performance

Logic Block propagation times are measured from the interconnect point at the input of the combinatorial logic to the output of the block in the interconnect area. Combinatorial performance is independent of logic function because of the table look-up based implementation. Timing is different when the combinatorial logic is used in conjunction with the storage element. For the combinatorial logic function driving the data input of the storage element, the critical timing is data set-up relative to the clock edge provided to the storage element. The delay from the clock source to the output of the logic block is critical in the timing of signals produced by storage elements. The loading on a logic block output is limited only by the additional propagation delay of the interconnect network. Performance of the logic block is a function of supply voltage and temperature, as shown in Figures 21 and 22.

Interconnect Performance

Interconnect performance depends on the routing resource used to implement the signal path. As discussed earlier, direct interconnect from block to block provides a minimum delay path for a signal.

The single metal segment used for long lines exhibits low resistance from end to end, but relatively high capacitance. Signals driven through a programmable switch will have the additional impedance of the switch added to their normal drive impedance.

General-purpose interconnect performance depends on the number of switches and segments used, the presence of the bidirectional repowering buffers and the overall loading on the signal path at all points along the path. In calculating the worst-case delay for a general interconnect path, the delay calculator portion of the XACT development system accounts for all of these elements. As an approximation, interconnect delay is proportional to the summation of totals of local metal segments beyond each programmable switch. In effect, the delay is a sum of R-C delays each approximated by an R times the total C it drives. The R of the switch and the C of the interconnect are functions of the particular device performance grade. For a string of three local interconnects, the approximate delay at the first segment, after the first switch resistance, would be three units; an additional two delay units after the next switch plus an additional delay after the last switch in the chain. The interconnect R-C chain terminates at each repowering buffer. Nearly all of the capacitance is in the interconnect metal and switches; the capacitance of the block inputs is not significant. Figure 23 shows an estimation of this delay.
**Development System**

To support designers using the Logic Cell Array, Monolithic Memories provides a basic development system with several options for additional productivity. The XACT system provides the following:

- Graphic-driven design entry
- Schematic entry
- Interactive timing delay calculations
- Macrocell library support, both for standard Monolithic Memories supplied functions and user-defined functions
- Design entry checking for consistency and completeness
- Automatic design documentation generation
- Automatic placement and routing
- Simulation interface support, including automatic netlist (circuit description) and timing extraction
- In-circuit emulation for multiple devices

The host system on which the XACT system operates is an IBM™ PC-XT™ or PC-AT™ or compatible system with MS-DOS™ 2.1 or higher. Color graphics is required as well as 640 K bytes of internal RAM (an Expanded Memory Specification (EMS) card with 256 K bytes of memory is required for the M2018). A complete system requires one parallel I/O port and two serial ports and a mouse.

For more detailed information of the XACT Development System, please refer to Logic Cell Array Development System Datasheet.
## M2064/M2018

### Table 2a. M2064 Pin Assignments

<table>
<thead>
<tr>
<th>48-PIN DIP</th>
<th>68-PIN PLCC</th>
<th>68-PIN PGA</th>
<th>Configuration Mode: (&lt;M2: M1: M0&gt;)</th>
<th>User Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>Slave (&lt;1:1:1&gt;)</td>
<td>Peripheral (&lt;1:0:1&gt;)</td>
</tr>
<tr>
<td>1</td>
<td>B6</td>
<td></td>
<td>GND</td>
<td>A13 (O)</td>
</tr>
<tr>
<td>2</td>
<td>A6</td>
<td></td>
<td></td>
<td>A6 (O)</td>
</tr>
<tr>
<td>1</td>
<td>B5</td>
<td></td>
<td></td>
<td>A12 (O)</td>
</tr>
<tr>
<td>4</td>
<td>A5</td>
<td></td>
<td>&lt;HIGH&gt;</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>B4</td>
<td></td>
<td></td>
<td>A7 (O)</td>
</tr>
<tr>
<td>3</td>
<td>A4</td>
<td></td>
<td></td>
<td>A11 (O)</td>
</tr>
<tr>
<td>4</td>
<td>B3</td>
<td></td>
<td></td>
<td>A8 (O)</td>
</tr>
<tr>
<td>5</td>
<td>A3</td>
<td></td>
<td></td>
<td>A10 (O)</td>
</tr>
<tr>
<td>6</td>
<td>A2</td>
<td></td>
<td></td>
<td>A9 (O)</td>
</tr>
<tr>
<td>7</td>
<td>B2</td>
<td></td>
<td>PWRDWN (I)</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>A1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>C2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>C1</td>
<td></td>
<td>&lt;HIGH&gt;</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>D1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>E2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>F2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>F1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>G2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>H1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>J2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>K1</td>
<td></td>
<td>M1 (HIGH)</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>L1</td>
<td></td>
<td>M1 (LOW)</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>K2</td>
<td></td>
<td>M1 (HIGH)</td>
<td>RDATA (O)</td>
</tr>
<tr>
<td>20</td>
<td>L2</td>
<td></td>
<td>M1 (LOW)</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>K3</td>
<td></td>
<td>M0 (HIGH)</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>L3</td>
<td></td>
<td>M0 (LOW)</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>K4</td>
<td></td>
<td>LDC (LOW)</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>L4</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>K5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>L5</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

\(<HIGH>\) is high impedance with a 20 to 50-KΩ internal pull-up resistor during configuration.

(continued on next page)
<table>
<thead>
<tr>
<th>48-PIN DIP</th>
<th>68-PIN PLCC</th>
<th>68-PIN PGA</th>
<th>CONFIGURATION MODE: &lt;M2: M1: M0&gt;</th>
<th>USER OPERATION</th>
</tr>
</thead>
<tbody>
<tr>
<td>24</td>
<td>35</td>
<td>K6</td>
<td>SLAVE &lt;1:1:1&gt;</td>
<td>GND</td>
</tr>
<tr>
<td></td>
<td>36</td>
<td>L6</td>
<td>PERIPHERAL &lt;1:0:1&gt;</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>37</td>
<td>K7</td>
<td>MASTER-HIGH &lt;1:1:0&gt;</td>
<td></td>
</tr>
<tr>
<td></td>
<td>38</td>
<td>L7</td>
<td>MASTER-LOW &lt;1:0:0&gt;</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>39</td>
<td>K8</td>
<td></td>
<td>I/O</td>
</tr>
<tr>
<td>27</td>
<td>40</td>
<td>L8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>41</td>
<td>K9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>42</td>
<td>L9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>43</td>
<td>L10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>31</td>
<td>44</td>
<td>K10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>45</td>
<td>K11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>33</td>
<td>46</td>
<td>J10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>34</td>
<td>48</td>
<td>H10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>35</td>
<td>50</td>
<td>G10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>36</td>
<td>51</td>
<td>G11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>37</td>
<td>54</td>
<td>E10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>38</td>
<td>56</td>
<td>D10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>39</td>
<td>57</td>
<td>D11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>40</td>
<td>58</td>
<td>C10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>41</td>
<td>59</td>
<td>C11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>42</td>
<td>60</td>
<td>B11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>43</td>
<td>61</td>
<td>B10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>44</td>
<td>62</td>
<td>A10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>45</td>
<td>63</td>
<td>B9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>46</td>
<td>64</td>
<td>A9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>47</td>
<td>66</td>
<td>A8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>48</td>
<td>68</td>
<td>A7</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<HIGH> is high impedance with a 20 to 50-KΩ internal pull-up resistor during configuration.

Table 2a. M2064 Pin Assignments (continued)
### Table 2b. M2018 Pin Assignments (continued on next page)

<table>
<thead>
<tr>
<th>68-PIN PLCC</th>
<th>68-PIN PGA</th>
<th>84-PIN PLCC</th>
<th>84-PIN PGA</th>
<th>CONFIGURATION MODE: &lt;M2: M1: M0&gt;</th>
<th>USER OPERATION</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Slave &lt;1:1:1&gt;</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Peripheral &lt;1:0:1&gt;</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Master-High &lt;1:1:0&gt;</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Master-Low &lt;1:0:0&gt;</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>B6</td>
<td>1</td>
<td>C6</td>
<td>GND</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>A6</td>
<td>2</td>
<td>A6</td>
<td></td>
<td>A13 (O)</td>
</tr>
<tr>
<td>3</td>
<td>B5</td>
<td>5</td>
<td>C5</td>
<td>&lt;HIGH&gt;</td>
<td>A6 (O)</td>
</tr>
<tr>
<td>4</td>
<td>A5</td>
<td>6</td>
<td>A4</td>
<td></td>
<td>A12 (O)</td>
</tr>
<tr>
<td>5</td>
<td>B4</td>
<td>7</td>
<td>B4</td>
<td></td>
<td>A7 (O)</td>
</tr>
<tr>
<td>6</td>
<td>A4</td>
<td>8</td>
<td>A3</td>
<td></td>
<td>A11 (O)</td>
</tr>
<tr>
<td>7</td>
<td>B3</td>
<td>9</td>
<td>A2</td>
<td></td>
<td>A8 (O)</td>
</tr>
<tr>
<td>8</td>
<td>A3</td>
<td>10</td>
<td>B3</td>
<td></td>
<td>A10 (O)</td>
</tr>
<tr>
<td>9</td>
<td>A2</td>
<td>11</td>
<td>A1</td>
<td></td>
<td>A9 (O)</td>
</tr>
<tr>
<td>10</td>
<td>B2</td>
<td>12</td>
<td>B2</td>
<td>PWRDWN (I)</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>B1</td>
<td>13</td>
<td>C2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>C2</td>
<td>14</td>
<td>B1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>C1</td>
<td>15</td>
<td>C1</td>
<td>&lt;HIGH&gt;</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>D2</td>
<td>16</td>
<td>D2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>D1</td>
<td>17</td>
<td>D1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>E2</td>
<td>18</td>
<td>E3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>E1</td>
<td>19</td>
<td>E2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>F2</td>
<td>20</td>
<td>F2</td>
<td>VCC</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>F1</td>
<td>21</td>
<td>F3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>G2</td>
<td>22</td>
<td>G3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>G1</td>
<td>23</td>
<td>G1</td>
<td>&lt;HIGH&gt;</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>H2</td>
<td>24</td>
<td>H1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>H1</td>
<td>25</td>
<td>H2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>J2</td>
<td>26</td>
<td>J1</td>
<td>RDATA (O)</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>J1</td>
<td>27</td>
<td>J2</td>
<td>M1 (HIGH)</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>K1</td>
<td>28</td>
<td>L1</td>
<td>M0 (HIGH)</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>K2</td>
<td>29</td>
<td>K2</td>
<td>M2 (HIGH)</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>L2</td>
<td>30</td>
<td>K3</td>
<td>HDC (HIGH)</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>K3</td>
<td>31</td>
<td>L2</td>
<td>&lt;HIGH&gt;</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>L3</td>
<td>32</td>
<td>L4</td>
<td>LDC (LOW)</td>
<td></td>
</tr>
<tr>
<td>31</td>
<td>K4</td>
<td>33</td>
<td>L4</td>
<td>&lt;HIGH&gt;</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>L4</td>
<td>34</td>
<td>K5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>33</td>
<td>K5</td>
<td>35</td>
<td>K5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>34</td>
<td>L5</td>
<td>36</td>
<td>L5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>35</td>
<td>L5</td>
<td>37</td>
<td>K6</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<HIGH> is high impedance with a 20 to 50-KΩ internal pull-up resistor during configuration
<table>
<thead>
<tr>
<th>68-PIN PLCC</th>
<th>68-PIN PGA</th>
<th>84-PIN PLCC</th>
<th>84-PIN PGA</th>
<th>CONFIGURATION MODE: (&lt;M2: M1: M0&gt;)</th>
<th>USER OPERATION</th>
</tr>
</thead>
<tbody>
<tr>
<td>35</td>
<td>K6</td>
<td>43</td>
<td>J6</td>
<td>GND</td>
<td>I/O</td>
</tr>
<tr>
<td>36</td>
<td>L6</td>
<td>45</td>
<td>L7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>37</td>
<td>K7</td>
<td>46</td>
<td>K7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>38</td>
<td>L7</td>
<td>47</td>
<td>L6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>39</td>
<td>K8</td>
<td>49</td>
<td>K8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>40</td>
<td>L8</td>
<td>50</td>
<td>L9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>41</td>
<td>K9</td>
<td>51</td>
<td>L10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>42</td>
<td>L9</td>
<td>52</td>
<td>K9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>43</td>
<td>L10</td>
<td>53</td>
<td>L11</td>
<td></td>
<td>XT2 or I/O</td>
</tr>
<tr>
<td>44</td>
<td>K10</td>
<td>54</td>
<td>K10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>45</td>
<td>K11</td>
<td>55</td>
<td>J10</td>
<td></td>
<td>PROG (1)</td>
</tr>
<tr>
<td>46</td>
<td>J10</td>
<td>56</td>
<td>K11</td>
<td></td>
<td>XTL1 or I/O</td>
</tr>
<tr>
<td>47</td>
<td>J11</td>
<td>57</td>
<td>J11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>48</td>
<td>H10</td>
<td>58</td>
<td>H10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>49</td>
<td>H11</td>
<td>60</td>
<td>F10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>50</td>
<td>G10</td>
<td>62</td>
<td>G11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>51</td>
<td>G11</td>
<td>63</td>
<td>G9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>52</td>
<td>F10</td>
<td>64</td>
<td>F9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>53</td>
<td>F11</td>
<td>65</td>
<td>F11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>54</td>
<td>E10</td>
<td>66</td>
<td>E11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>55</td>
<td>E11</td>
<td>68</td>
<td>E9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>56</td>
<td>D10</td>
<td>70</td>
<td>D10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>57</td>
<td>D11</td>
<td>71</td>
<td>C11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>58</td>
<td>C10</td>
<td>72</td>
<td>B11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>59</td>
<td>C11</td>
<td>73</td>
<td>C10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>60</td>
<td>B11</td>
<td>74</td>
<td>A11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>61</td>
<td>B10</td>
<td>75</td>
<td>B10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>62</td>
<td>A10</td>
<td>76</td>
<td>B9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>63</td>
<td>B9</td>
<td>77</td>
<td>A10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>64</td>
<td>A9</td>
<td>78</td>
<td>A9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>65</td>
<td>B8</td>
<td>79</td>
<td>B8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>66</td>
<td>A8</td>
<td>80</td>
<td>A8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>67</td>
<td>B7</td>
<td>81</td>
<td>B6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>68</td>
<td>A7</td>
<td>84</td>
<td>C7</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

\(<\text{HIGH}>\) is high impedance with a 20 to 50-K\(\Omega\) internal pull-up resistor during configuration

Table 2b. M2018 Pin Assignments (continued)
Absolute Maximum Ratings*

Supply voltage $V_{CC}$ ................................................................. $-0.5$ V to $7$ V
Power down $V_{CC}$ ........................................................................ $2$ V to $7$ V
Input voltage .................................................................................. $-0.5$ V to $V_{CC}$ $0.5$ V
Voltage applied to three-state output .................................................. $-0.5$ V to $V_{CC}$ $0.5$ V
Storage temperature range ............................................................... $-65^\circ$ C to $+150^\circ$ C
Lead temperature (soldering, 10 seconds) ........................................... $260^\circ$ C

* Stresses beyond those listed under “Absolute Maximum Ratings” may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those listed under “Recommended Operating Conditions” is not implied. Exposure to “Absolute Maximum Ratings” conditions for extended periods of time may affect device reliability.

Operating Conditions

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>PARAMETER</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{CC}$</td>
<td>Supply voltage relative to GND</td>
<td>4.75</td>
<td>5.25</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>$V_{IH}$</td>
<td>High level input voltage—TTL configuration</td>
<td>2.0</td>
<td>$V_{CC}$</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>$V_{IL}$</td>
<td>High level input voltage—CMOS configuration</td>
<td>0.7 $V_{CC}$</td>
<td>$V_{CC}$</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>$I_{IT}$</td>
<td>Low level input voltage—TTL configuration</td>
<td>0</td>
<td>0.8</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>$I_{IC}$</td>
<td>Low level input voltage—CMOS configuration</td>
<td>0</td>
<td>0.2 $V_{CC}$</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>$I_{IT}$</td>
<td>Input leakage current—TTL configuration</td>
<td>$\pm 10$</td>
<td></td>
<td>$\mu$A</td>
<td></td>
</tr>
<tr>
<td>$I_{IC}$</td>
<td>Input leakage current—CMOS configuration</td>
<td>$\pm 10$</td>
<td></td>
<td>$\mu$A</td>
<td></td>
</tr>
<tr>
<td>$I_{OZ}$</td>
<td>Three-state output off current ($V_{CC} = 5.5$ V)</td>
<td>$\pm 10$</td>
<td></td>
<td>$\mu$A</td>
<td></td>
</tr>
<tr>
<td>$T_{OP}$</td>
<td>Operating free-air temperature</td>
<td>0</td>
<td>70</td>
<td>$^\circ$C</td>
<td></td>
</tr>
</tbody>
</table>

Electrical Characteristics Over Operating Conditions

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>PARAMETER</th>
<th>TEST CONDITION</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{OH}$</td>
<td>High level output voltage</td>
<td>$V_{CC} = 4.75$ V</td>
<td>$I_{OH} = -4.0$ mA</td>
<td>3.86</td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>$V_{OL}$</td>
<td>Low level output voltage</td>
<td>$V_{CC} = 4.75$ V</td>
<td>$I_{OL} = 4.0$ mA</td>
<td>0.32</td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>$I_{CCO}$</td>
<td>Quiescent operating power supply current</td>
<td>CMOS inputs</td>
<td>$V_{CC} = 5.0$ V</td>
<td>5</td>
<td></td>
<td>mA</td>
</tr>
<tr>
<td>$I_{CCP}$</td>
<td>TTL inputs</td>
<td>$V_{CC} = 5.0$ V</td>
<td>10</td>
<td></td>
<td>mA</td>
<td></td>
</tr>
</tbody>
</table>

Power On Timing

The LCAs contain on-chip reset timing logic for power-up operation. To insure proper master mode system operation, $V_{CC}$ must rise from $2.0$ V to minimum specification level in 10 ms or less. For other modes, initiation of configuration must be delayed for 60 ms after $V_{CC}$ reaches the minimum specified level.
### Switching Characteristics — General

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>DESCRIPTION</th>
<th>-33 Min</th>
<th>-33 Max</th>
<th>-50 Min</th>
<th>-50 Max</th>
<th>-70 Min</th>
<th>-70 Max</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>t_VMR (\textcircled{1})</td>
<td>V\textsubscript{CC} setup (2.0 V)</td>
<td>150</td>
<td>150</td>
<td>150</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>t_MR (\textcircled{1})</td>
<td>M2, M1, M0 setup</td>
<td>60</td>
<td>60</td>
<td>60</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>t_RM (\textcircled{1})</td>
<td>M2, M1, M0 hold</td>
<td>60</td>
<td>60</td>
<td>60</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>t_MRW (\textcircled{1})</td>
<td>Width (LOW)</td>
<td>150</td>
<td>150</td>
<td>150</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>t_PGW (\textcircled{1})</td>
<td>Program width (LOW)</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td></td>
<td></td>
<td></td>
<td>µS</td>
</tr>
<tr>
<td>t_PGI (\textcircled{1})</td>
<td>Initialization</td>
<td></td>
<td>7</td>
<td>7</td>
<td>7</td>
<td></td>
<td></td>
<td>µS</td>
</tr>
<tr>
<td>t_CLH (\textcircled{1})</td>
<td>Clock (HIGH)</td>
<td>12</td>
<td>8</td>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>t_CLL (\textcircled{1})</td>
<td>Clock (LOW)</td>
<td>12</td>
<td>8</td>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>t_PS (\textcircled{1})</td>
<td>Setup to V\textsubscript{CC}</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>t_PH (\textcircled{1})</td>
<td>Hold from V\textsubscript{CC}</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>V\textsubscript{PD}</td>
<td>Power Down</td>
<td>2.0</td>
<td>2.0</td>
<td>2.0</td>
<td></td>
<td></td>
<td></td>
<td>V</td>
</tr>
</tbody>
</table>

Notes:
1. V\textsubscript{CC} must rise from 2.0 Volts to V\textsubscript{CC} minimum in less than 10 ms for master mode.
2. RESET timing relative to power-on and valid mode lines (M0, M1, M2) is relevant only when RESET is used to delay configuration.
3. Minimum CLOCK widths for the auxiliary buffer are 1.25 times the t\_CLH·t\_CLL.

---

![Diagram of timing](image-url)
## Switching Characteristics — CLB

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>DESCRIPTION</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td><em>(t)</em></td>
<td>Logic input to output</td>
<td>ns</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Combinatorial</td>
<td>20</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Transparent latch</td>
<td>25</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Additional for Q through F or G to out</td>
<td>13</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>To output</td>
<td>20</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Logic input Transparent latch</td>
<td>25</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Logic input setup</td>
<td>12</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Logic input hold</td>
<td>0</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>To output</td>
<td>25</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Logic input setup</td>
<td>12</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Logic input hold</td>
<td>6</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>To output</td>
<td>37</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Logic input setup</td>
<td>6</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Logic input hold</td>
<td>9</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Input A or D to out</td>
<td>25</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Through F or G to out</td>
<td>37</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Master Reset pin to out</td>
<td>35</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Separation of set/reset</td>
<td>17</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Set/reset pulse-width</td>
<td>12</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Flip-flop toggle rate</td>
<td>33</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Clock HIGH</td>
<td>12</td>
</tr>
<tr>
<td><em>(t)</em></td>
<td>Clock LOW</td>
<td>12</td>
</tr>
</tbody>
</table>

Note: All switching characteristics apply to all valid combinations of process, temperature and supply.

### Cross Reference Guide

<table>
<thead>
<tr>
<th>XILINX</th>
<th>MMI</th>
<th>V&lt;sub&gt;CC&lt;/sub&gt;</th>
<th>F&lt;sub&gt;MAX&lt;/sub&gt;</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>MIN</td>
<td>MAX</td>
</tr>
<tr>
<td>XC2064-1</td>
<td>M2064-1</td>
<td>4.5 V</td>
<td>5.5 V</td>
</tr>
<tr>
<td>XC2064-2</td>
<td>M2064-20</td>
<td>4.75 V</td>
<td>5.25 V</td>
</tr>
<tr>
<td>XC2064-33</td>
<td>M2064-33</td>
<td>4.75 V</td>
<td>5.25 V</td>
</tr>
<tr>
<td>XC2064-50</td>
<td>M2064-50</td>
<td>4.75 V</td>
<td>5.25 V</td>
</tr>
<tr>
<td>XC2064-70</td>
<td>M2064-70</td>
<td>4.75 V</td>
<td>5.25 V</td>
</tr>
<tr>
<td>XC2018-33</td>
<td>M2018-33</td>
<td>4.75 V</td>
<td>5.25 V</td>
</tr>
<tr>
<td>XC2018-50</td>
<td>M2018-50</td>
<td>4.75 V</td>
<td>5.25 V</td>
</tr>
<tr>
<td>XC2018-70</td>
<td>M2018-70</td>
<td>4.75 V</td>
<td>5.25 V</td>
</tr>
</tbody>
</table>
Switching Characteristics CLB

INPUT (A,B,C,D)

OUTPUT (X,Y) (COMBINATORIAL)

OUTPUT (X,Y) (TRANSPARENT LATCH)

CLOCK (K)

CLOCK (C)

CLOCK (G)

OUTPUT (VIA FF)

SET/RESET DIRECT (A,D)

SET/RESET DIRECT (F,G)

CLOCK (ANY SOURCE)

1. T_{LO}
2. T_{ITO}
3. T_{ICK}
4. T_{CKI}
5. T_{ICD}
6. T_{CDI}
7. T_{ICI}
8. T_{CII}
9. T_{CKO}
10. T_{CCO}
11. T_{CIO}
12. T_{RIO}
13. T_{RLQ}
14. T_{CH}
15. T_{CL}
## Switching Characteristics — IOB

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>DESCRIPTION</th>
<th>-33</th>
<th>-50</th>
<th>-70</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>MIN</td>
<td>MAX</td>
<td>MIN</td>
<td>MAX</td>
</tr>
<tr>
<td>$t_{PD}$</td>
<td>Pad (package pin) to input (direct)</td>
<td>12</td>
<td>8</td>
<td>6</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{LI}$</td>
<td>I/O Clock to input (storage)</td>
<td>20</td>
<td>15</td>
<td>11</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{PL}$</td>
<td>I/O Clock to pad-input setup</td>
<td>12</td>
<td>8</td>
<td>6</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{LP}$</td>
<td>I/O Clock to pad-input hold</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{LU}$</td>
<td>I/O Clock pulse width</td>
<td>12</td>
<td>9</td>
<td>7</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>I/O Clock frequency</td>
<td>33</td>
<td>50</td>
<td>70</td>
<td>MHz</td>
</tr>
<tr>
<td>$t_{OP}$</td>
<td>Output to pad (output enabled)</td>
<td>15</td>
<td>12</td>
<td>9</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{THZ}$</td>
<td>Three-state to pad begin hi-Z</td>
<td>25</td>
<td>20</td>
<td>15</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{TON}$</td>
<td>Three-state to pad end hi-Z</td>
<td>25</td>
<td>20</td>
<td>15</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{RI}$</td>
<td>RESET to input (storage)</td>
<td>40</td>
<td>30</td>
<td>25</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{RC}$</td>
<td>RESET to input clock</td>
<td>35</td>
<td>25</td>
<td>20</td>
<td>ns</td>
</tr>
</tbody>
</table>

Note: Timing is measured at 0.5 $V_{CC}$ levels with 50 pF output load.

---

**Diagram: Switching Characteristics**

- **PAD (PACKAGE PIN)**
- **OUTPUT SIGNAL**
- **INPUT (DIRECT)**
- **(I/O CLOCK)**
- **INPUT (REGISTERED)**
- **RESET**

- $t_{PD}$
- $t_{LI}$
- $t_{PL}$
- $t_{LP}$
- $t_{LU}$
- $t_{OP}$
- $t_{THZ}$
- $t_{TON}$
- $t_{RI}$
- $t_{RC}$

- $V_{OH} - 0.5 \, V$
- $V_{OL} + 0.5 \, V$

---

**Graphical Representation**

- Timing intervals are depicted with notation and specified values.
Switching Characteristics — Programming — Master Mode

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>DESCRIPTION</th>
<th>-33</th>
<th>-50</th>
<th>-70</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>tARC</td>
<td>From address invalid</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>tRAC</td>
<td>To address valid</td>
<td>200</td>
<td>200</td>
<td>200</td>
<td>ns</td>
</tr>
<tr>
<td>tDRC</td>
<td>To data setup</td>
<td>60</td>
<td>60</td>
<td>60</td>
<td>ns</td>
</tr>
<tr>
<td>tRCD</td>
<td>To data hold</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>tRCH</td>
<td>RCLK HIGH</td>
<td>600</td>
<td>600</td>
<td>600</td>
<td>ns</td>
</tr>
<tr>
<td>tRCL</td>
<td>RCLK LOW</td>
<td>4.0</td>
<td>4.0</td>
<td>4.0</td>
<td>µs</td>
</tr>
</tbody>
</table>

Notes:
1. CCLK and DOUT timing are the same as for slave mode.
2. At power up, VCC must rise from 2.0 V to VCC minimum in less than 10 ms.
## Switching Characteristics — Programming — Slave Mode

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>DESCRIPTION</th>
<th>-33</th>
<th>-50</th>
<th>-70</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>MIN</td>
<td>MAX</td>
<td>MIN</td>
<td>MAX</td>
</tr>
<tr>
<td>tcco</td>
<td>CCLK to DOUT</td>
<td>65</td>
<td>65</td>
<td>65</td>
<td></td>
</tr>
<tr>
<td><em>DCC</em></td>
<td>CCLK DIN setup</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td><em>CCD</em></td>
<td>CCLK DIN hold</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>ns</td>
</tr>
<tr>
<td><em>CCH</em></td>
<td>CCLK HIGH time</td>
<td>0.25</td>
<td>0.25</td>
<td>0.25</td>
<td>µs</td>
</tr>
<tr>
<td><em>CCL</em></td>
<td>CCLK LOW time</td>
<td>0.25</td>
<td>5.0</td>
<td>0.25</td>
<td>5.0</td>
</tr>
<tr>
<td>FCQ</td>
<td>CCLK frequency</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>MHz</td>
</tr>
</tbody>
</table>

Note: Configuration must be delayed at least 40 ms after Vee minimum.

![Diagram of timing relationships](image-url)
### Switching Characteristics — Programming — Peripheral Mode

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>DESCRIPTION</th>
<th>MIN</th>
<th>MAX</th>
<th>MIN</th>
<th>MAX</th>
<th>MIN</th>
<th>MAX</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{CA} )</td>
<td>Active (last active input to first inactive)</td>
<td>0.25</td>
<td>5.0</td>
<td>0.25</td>
<td>5.0</td>
<td>0.25</td>
<td>5.0</td>
<td>( \mu )S</td>
</tr>
<tr>
<td>( t_{CI} )</td>
<td>Inactive (first inactive input to last active)</td>
<td>0.25</td>
<td>0.25</td>
<td>0.25</td>
<td>0.25</td>
<td>0.25</td>
<td>0.25</td>
<td>( \mu )S</td>
</tr>
<tr>
<td>( t_{CCC} )</td>
<td>CCLK(^2)</td>
<td>75</td>
<td>75</td>
<td>75</td>
<td>75</td>
<td>75</td>
<td>75</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{DC} )</td>
<td>DIN setup</td>
<td>35</td>
<td>35</td>
<td>35</td>
<td>35</td>
<td>35</td>
<td>35</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{CD} )</td>
<td>DIN hold</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>ns</td>
</tr>
</tbody>
</table>

Notes:
1. Peripheral mode timing determined from last control signal of the logical AND of (CS0, CS1, CS2, WRT) to transition to active or inactive state.
2. CCLK and DOUT timing are the same as for slave mode.
3. Configuration must be delayed at least 40 ms after \( V_{CC} \) minimum.

### Switching Characteristics — Program Readback

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>DESCRIPTION</th>
<th>-33</th>
<th>-50</th>
<th>-70</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{DR} )</td>
<td>PROG setup</td>
<td>300</td>
<td>300</td>
<td>300</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{RT} )</td>
<td>RTRIG HIGH</td>
<td>250</td>
<td>250</td>
<td>250</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{RTC} )</td>
<td>RTRIG setup</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{CRD} )</td>
<td>RDATA delay</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>100</td>
</tr>
</tbody>
</table>

Notes:
1. CCLK and DOUT timing are the same as for slave mode.
2. DONE/PROG output/input must be HIGH (device programmed) prior to a positive transition of RTRIG (M0).
Switching Test Load

![Diagram of switch test load](image)

Note: CL includes probe and jig capacitance.

CL = 50 pF
RL = 1K

Design Aids
Designing with the Logic Cell Array is similar to using conventional MSI elements or gate array macrocells. The first step is to partition the desired logic design into Logic Blocks and I/O blocks, usually based on shared input variables or efficient use of flip-flop and combinatorial logic. Following a plan for placement of the blocks, the design information may be entered using the interactive Graphic Design Editor. The design information includes both the functional specifications for each block and a definition of the interconnection networks. A macrocell library provides a simplified entry of commonly used logic functions. As an alternative to interactive block placement and configuration, a schematic may be created using elements from the macrocell library. Automatic placement and routing is available for either method of design entry. After routing the interconnections, various checking stages and processing of that data are performed to ensure that the design is correct. Design changes may be implemented in minutes. The design file is used to generate the programming data which can be downloaded directly into an LCA in the target system and operated. The program information may be used to program PROM, EPROM or ROM devices, or stored in some other media as needed by the final system.

Design verification may be accomplished by using the Xilinx XACTOR™ In-Circuit Emulation System directly in the target system and/or the P-Silos™ logic simulator.

Recommended Sockets
The following sockets, with matching hole patterns, are available for PLCC devices.

<table>
<thead>
<tr>
<th>DESCRIPTION</th>
<th>VENDOR</th>
<th>PART NUMBER</th>
</tr>
</thead>
<tbody>
<tr>
<td>PCB solder tail, tin plate</td>
<td>AMP</td>
<td>821574-1</td>
</tr>
<tr>
<td>Surface mount, tin plate</td>
<td>AMP</td>
<td>821542-1</td>
</tr>
<tr>
<td>PCB solder tail, tin plate</td>
<td>Burndy*</td>
<td>QILE68P-410T</td>
</tr>
<tr>
<td>PCB solder tail, tin plate</td>
<td>Midland-Ross*</td>
<td>709-2000-068-4-1-1</td>
</tr>
<tr>
<td>PCB solder tail, tin plate</td>
<td>Methode*</td>
<td>213-068-001</td>
</tr>
<tr>
<td>Surface mount, tin plate</td>
<td>Methode*</td>
<td>213-068-002</td>
</tr>
<tr>
<td>PCB solder tail, tin plate</td>
<td>AMP</td>
<td>821573-1</td>
</tr>
<tr>
<td>Surface mount, tin plate</td>
<td>AMP</td>
<td>821546-1</td>
</tr>
<tr>
<td>PCB solder tail, tin plate</td>
<td>Burndy*</td>
<td>QILE84P-410T</td>
</tr>
<tr>
<td>PCB solder tail, tin plate</td>
<td>Midland-Ross*</td>
<td>709-2000-084-4-1-1</td>
</tr>
<tr>
<td>PCB solder tail, tin plate</td>
<td>Methode*</td>
<td>213-084-001</td>
</tr>
<tr>
<td>Surface mount, tin plate</td>
<td>Methode*</td>
<td>213-084-002</td>
</tr>
</tbody>
</table>

* Sockets will plug into pin-grid array (PGA) wire-wrap sockets for breadboard use.
M2064/18 PLCC SOCKET PIN ASSIGNMENT
WIRING REFERENCE. BOTTOM VIEW.

<table>
<thead>
<tr>
<th>Pin</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>A1</td>
<td>0</td>
</tr>
<tr>
<td>A0</td>
<td>1</td>
</tr>
<tr>
<td>A2</td>
<td>2</td>
</tr>
<tr>
<td>A15</td>
<td>3</td>
</tr>
<tr>
<td>A14</td>
<td>4</td>
</tr>
<tr>
<td>A6</td>
<td>5</td>
</tr>
<tr>
<td>A7</td>
<td>6</td>
</tr>
<tr>
<td>A8</td>
<td>7</td>
</tr>
<tr>
<td>A9</td>
<td>8</td>
</tr>
<tr>
<td>GND</td>
<td>9</td>
</tr>
<tr>
<td>D1</td>
<td>10</td>
</tr>
<tr>
<td>D2</td>
<td>11</td>
</tr>
<tr>
<td>VCC</td>
<td>12</td>
</tr>
<tr>
<td>D4</td>
<td>13</td>
</tr>
<tr>
<td>D5</td>
<td>14</td>
</tr>
<tr>
<td>XTAL</td>
<td>15</td>
</tr>
<tr>
<td>DO/DIN</td>
<td>16</td>
</tr>
<tr>
<td>DOUT</td>
<td>17</td>
</tr>
<tr>
<td>CCLK</td>
<td>18</td>
</tr>
<tr>
<td>D6</td>
<td>19</td>
</tr>
</tbody>
</table>

FOR EASE OF Wiring, AND PIN IDENTIFICATION, THE BOTTOM VIEW OF THE PLCC IS SHOWN ALONG WITH KEY PIN ASSIGNMENTS, SUCH AS ADDRESS, DATA, MODE, POWER AND CRYSTAL OSCILLATOR INPUTS.
Package Drawing

48N Molded DIP
(9/16" x 2 13/32")

Notes:
1. Lead material tolerances are for tin plate finish only. Solder dip finish adds 2-10 mils thickness to all lead tip dimensions.
2. Both version 1 and version 2 configurations are manufactured interchangeably.
3. Ejector pin marks on version 1 are optional.
Package Drawing
68NL Molded Chip Carrier
(.950"x.950")

UNLESS OTHERWISE SPECIFIED:
ALL DIMENSIONS MIN.-MAX. IN INCHES
ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS
ALL TOLERANCES ARE ± .007 INCHES

10760A
Package Drawing

84NL Plastic Leaded Chip Carrier
(1.154" x 1.154")

UNLESS OTHERWISE SPECIFIED:
ALL DIMENSIONS MIN.-MAX. IN INCHES
ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS
ALL TOLERANCES ARE ± .007 INCHES
Package Drawing

68P Ceramic Pin Grid Array

UNLESS OTHERWISE SPECIFIED:
ALL DIMENSIONS MIN.-MAX. IN INCHES
ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS
ALL TOLERANCES ARE ± .007 INCHES

10765A
Package Drawings

84P Ceramic Pin Grid Array

UNLESS OTHERWISE SPECIFIED:
ALL DIMENSIONS MIN.-MAX. IN INCHES
ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS
ALL TOLERANCES ARE ± .007 INCHES
3000 SERIES FAMILY OF PROGRAMMABLE GATE ARRAYS

PRELIMINARY

DISTINCTIVE CHARACTERISTICS

- Second generation user-programmable gate array
- Flexible array architecture
- High performance (50, 70 MHz)
- Improved interconnection resources
- Density of up to 9000 gates
- 100% factory pre-tested
- Selectable configuration modes
- 100% compatibility with AMD PGA development tools
- Standard PROM file interface
- Off the shelf availability

GENERAL DESCRIPTION

The AM 3000 Series Logic Cell™ Array (LCA) is a high-performance, second generation user-programmable gate array. The array contains three types of configurable elements that are customized in accordance with the user-defined system design; a perimeter of Input/Output Blocks (IOBs), a core array of Configurable Logic Blocks (CLBs), and interconnection resources.

The final configuration of the three main programmable elements is determined by the user and easily implemented by AMD user-programmable gate array design tools.

AMD's development tools let users produce a complete design, from schematic capture through device customization, on an IBM PC-AT or compatible computer. LCA macro libraries and interface software are also available to support schematic capture and simulation on popular CAE workstations.

PRODUCT SELECTOR GUIDE

<table>
<thead>
<tr>
<th>BASIC ARRAY</th>
<th>LOGIC CAPACITY (USABLE GATES)</th>
<th>CONFIGURABLE LOGIC BLOCKS</th>
<th>USER I/Os</th>
<th>PROGRAM DATA (BITS)</th>
</tr>
</thead>
<tbody>
<tr>
<td>M3020</td>
<td>2000</td>
<td>64</td>
<td>64</td>
<td>14779</td>
</tr>
<tr>
<td>M3090</td>
<td>9000</td>
<td>320</td>
<td>144</td>
<td>64160</td>
</tr>
</tbody>
</table>
BLOCK DIAGRAM

I/O Blocks

Three-State Buffers with Access to Horizontal Long Lines

Configurable Logic Blocks

Interconnection Area

CONFIGURATION MEMORY
ORDERING INFORMATION

Further information is available from AMD franchised distributors or from the nearest AMD sales representative. Part numbers are composed as follows:

\[
\text{Am3020 - 70CNL84} \\
\begin{array}{llll}
3020 & (2000 \text{ Gates, 58 IOBs}) & NL68 & = 68 \text{ Pin PLCC} \\
3090 & (9000 \text{ Gates, 144 IOBs}) & NL84 & = 84 \text{ Pin PLCC} \\
& & P84 & = 84 \text{ Pin PGA} \\
& & P175 & = 175 \text{ Pin PGA} \\
50 & (50 \text{ MHz Toggle}) & C & = \text{Commercial} \\
70 & (70 \text{ MHz Toggle}) & M & = \text{Military}
\end{array}
\]

ARCHITECTURE

Functional Description

The perimeter of configurable IOBs provides a programmable interface between the internal logic array and the device package pins. The array of CLBs performs user-specified logic functions. The interconnection are programmed to form networks, carrying logic signals among blocks. This is analogous to printed circuit board traces connecting MSI/SSI packages.

The logic functions of these blocks are determined by programmed look-up tables. Functional options are performed by program-controlled multiplexers. Interconnecting networks between blocks are composed of metal segments joined by program-controlled pass transistors. These LCA functions are activated by a configuration bit stream that is loaded into an internal, distributed array of configuration memory cells. The configuration bit stream is loaded into the LCA device at power-up and can be reloaded on command. The LCA device includes logic and control signals for automatic or passive configuration. Configuration data can be either bit serial or byte parallel. The XACT LCA Development System generates the configuration bit stream used to configure the LCA device. The memory loading process is independent of the user logic functions.

Configuration Memory

The static memory cell used for the LCA’s configuration memory has been designed specifically for high reliability and noise immunity, ensuring integrity even under adverse conditions. Static memory provides the best combination of high density, high performance, high reliability, and comprehensive testability. As shown below, the basic memory cell consists of two CMOS inverters and a pass transistor, which is used for writing and reading cell data. The cell is only written during configuration and only read during readback. During normal operation, the pass transistor is off and does not affect the stability of the cell. This is quite different from the operation of conventional memory devices, in which the cells are frequently read and re-written.
A static configuration memory cell is loaded with one bit of the configuration bit stream and controls one data selection in the LCA device. The memory cell outputs $Q$ and $\overline{Q}$ use full Ground and Vcc levels and provide continuous, direct control. The additional capacitive load, together with the absence of address decoding and sense amplifiers, gives the cell high stability.

Due to the structure of the configuration memory cells, they are not affected by extreme power supply excursions or very high levels of alpha particle radiation. No soft errors have been observed in reliability testing, even in the presence of very high doses of alpha radiation.

The method of loading the configuration data is selectable. Two methods use serial data, while three use byte-wide data. The internal configuration logic uses framing information, which is embedded in the configuration data by the XACT LCA Development System, to direct memory cell loading. The serial data framing and length count preamble provide synchronous, serial, or daisy-chained compatibility with various AMD programmable gate arrays.

**Input/Output Blocks**

Each user-configurable IOB, shown below, provides an interface between the device's external package pin and the internal user logic. Each IOB includes both registered and direct input paths and each provides a programmable three-state output buffer that can be driven by a registered or direct output signal. Configuration options allow a choice of polarity on the output and three-state control signals, a controlled slew rate, and a high impedance pull-up. Each input circuit provides input clamping diodes for electrostatic protection, and circuits to inhibit latch-up produced by input currents.
The input buffer portion of each IOB provides threshold detection to translate external signals applied to the package pin to internal logic levels. The global input-buffer threshold of the IOBs can be programmed for TTL or CMOS voltage levels. The buffered input signal drives the data input of a storage element that can be configured as a positive edge-triggered D flip-flop, or a level-transparent latch.

Clock/load signals, IOB pin .ik, can be chosen from either of two available metal lines along each die edge. I/O storage elements are reset during configuration or by the active low chip ~RESET input. Both direct input signals, from IOB pin.q, are available.

For reliable operation, inputs should have transition times less than 100 ns and should not be left undriven, or floating. Unused CMOS input-pin circuits can be at threshold and produce oscillations. This produces additional power dissipation and system noise. A typical hysteresis of about 50 mV reduces input noise sensitivity. Each user IOB includes a programmable high impedance pull-up resistor that
can be selected by the bit stream and which provides a constant HIGH for undriven pins. Although the LCA device provides circuitry for input protection against electrostatic discharge, normal CMOS handling precautions should be observed.

Loop delays for the IOB and logic block flip-flops are about 3 ns. This increases reliability, especially for asynchronous clock and data conditions. Short loop delays minimize the probability of a metastable condition, which can result from assertion of the clock during data transitions. Because of the short loop delay in LCA devices, the flip-flops can be used to synchronize external signals applied to the device. Once synchronized in the IOB, the signals can be used internally without regard to their clock-relative timing, except as it applies to the internal logic and routing path delays.

Output buffers of the IOBs provide CMOS-compatible 4 mA source-or-sink drive for high fan-out CMOS or TTL compatible signal levels. The network driving IOB pin .o becomes the registered or direct data source for the output buffer. The three-state control signal, IOB pin .ts, can control output activity. An open-drain type output can be obtained by using the same signal for driving the output and three-state signal nets, so that the buffer output is enabled only for a LOW.

The configuration memory cells, shown in the figure above, control the optional output register and logical signal inversion, as well as the three-state and slew rate configuration bits. A choice of two clocks is available on each die edge. All user inputs are programmed for TTL or CMOS thresholds.

The IOB includes input and output storage elements and the following I/O options selected by configuration memory cells.

- Logical inversion of the output is controlled by one configuration bit per IOB.
- Logical three-state control of each IOB output buffer is determined by the states of the configuration data bits that turn the buffer on/off or select the output buffer three-state control interconnection, pin .ts. When this IOB output control signal is HIGH, or logic 1, the buffer is disabled and the package pin is high impedance. Inversion of the buffer three-state control logic sense, output enable, is controlled by an additional configuration data bit.
- Direct or registered output is selectable for each IOB. The register uses a positive-edge, clocked flip-flop. The clock source, IOB pin .ok, can be supplied by either of two metal lines, which are available along each die edge. Each of these lines is driven by an invertible buffer.
- Increased output transition speed can be selected to satisfy critical nets. Slower transitions reduce capacitive load peak currents of non-critical outputs and minimize system noise.
- A high impedance pull-up resistor can be used to prevent floating, unused inputs.

The following table summarizes the I/O options.

<table>
<thead>
<tr>
<th>INPUTS</th>
<th>OUTPUTS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Direct</td>
<td>Direct/registered</td>
</tr>
<tr>
<td>Flip-flop/latch</td>
<td>Inverted/true</td>
</tr>
<tr>
<td>CMOS/TTL threshold (chip inputs)</td>
<td>Full speed/slew limited</td>
</tr>
<tr>
<td>Pull-up resistor</td>
<td>Optional three-state control</td>
</tr>
</tbody>
</table>
Configurable Logic Blocks

CLBs are the functional elements from which the user's logic is constructed. The logic blocks are arranged in a matrix within the perimeter of IOBs. The 3020 has 64 such blocks arranged in eight rows and eight columns. The XACT LCA Development System compiles the configuration data, which defines the operation and interconnection of each block. Users can define CLBs and their interconnecting networks by automatic translation from a schematic capture logic diagram or, optionally, by installing library or user macros.

Each CLB has a combinational logic section, two flip-flops, and an internal control section. As shown in the following figure, there are five logic inputs (.a, .b, .c, .d, and .e), a common clock input (.k), an asynchronous direct reset input (.rd), and a clock enable (.ec). All can be driven from the interconnection resources adjacent to the blocks. Each CLB also has two outputs (.x and .y) that can drive interconnection networks.

Data input for either flip-flop within a CLB is supplied from the F or G function outputs of the combinational logic, or the direct data input, .di. Both flip-flops in each CLB share the active HIGH
asynchronous reset (.rd), which is dominant over clocked inputs. All flip-flops are reset by the active LOW chip input, ~RESET, or during the configuration process. The flip-flops share the clock enable (.ec), which, when LOW, recirculates the present states of the flip-flops and inhibits response to the data-in or combinational function inputs on a CLB. The user can enable these control inputs and select their sources. The user also can select the clock net input (.k) and its active sense in each logic block. This programmable inversion eliminates the need to route both phases of a clock signal throughout the device. Flexible routing allows use of common or individual CLB clocking.

The combinational logic portion of the CLB uses a 32-by-1 look-up table to perform Boolean functions. Variables selected from the five logic inputs and two internal block flip-flops are used as table address inputs. The combinational propagation delay through the network is independent of the logic function generated and is spike free for changes in single input variables.

This technique can generate a single function of five variables, as shown below.

It can also generate any two logic functions of up to four variables each.
It can also generate some functions of seven variables, as shown in the next figure.

The partial functions of six or seven variables are generated by the input variable, \( e \), which dynamically selects between two functions of four different variables. For the two functions of four variables each, the independent results, \( F \) and \( G \), can be used as data inputs to either flip-flop or either logic block output. For the single function of five variables and merged functions of six or seven variables, the \( F \) and \( G \) outputs are identical. Symmetry of the \( F \) and \( G \) functions and the flip-flops helps optimize the routing of the networks connecting the logic blocks and IOBs.

The next figure shows a modulo 8 binary counter with parallel enable. It uses one CLB of each type.
Programmable Interconnections

Programmable interconnection resources in the LCA device provide routing paths to connect inputs and outputs of the I/O and logic blocks into logical networks. Interconnections between blocks are composed of two-layer grid of metal segments. Specially designed pass transistors, each controlled by a configuration bit, form programmable interconnect points (PIPs) and switching matrices used to implement the necessary connections between selected metal segments and block pins. The figure below provides an example of a routed net.
The XACT LCA Development System automatically routes these interconnections. Interactive routing using Editnet can also be done to optimize the design. The inputs of the logic or IOB are multiplexers that can be programmed to select an input network from the adjacent interconnection segments.

**Note:** The switch connections to block inputs are usable only for input connection, and not for routing, because they are unidirectional (as are block outputs).

The following figure illustrates routing access to logic block input variables, control inputs, and block outputs.
Three types of metal resources are available for network interconnections.

- General Purpose Interconnection
- Direct Connection
- Long Lines

**General Purpose Interconnections**

A general purpose interconnection, as shown below, consists of a grid of five horizontal and five vertical metal segments located between the rows and columns of logic and I/O Blocks. These segments can be connected through switch matrices to form networks for CLB and IOB inputs and outputs.

Each segment is the height or width of a logic block. Switching matrices join the ends of these segments and allow programmed interconnections between the metal grid segments of adjoining rows and columns. The switches of an unprogrammed device are all non-conducting. The connections through the switch matrix can be made by automatic routing, or by using Editnet to select the desired pairs of matrix pins that are to be connected or disconnected. The legitimate switching matrix combinations for each pin are shown in the next figure.
Special buffers in the general interconnection areas provide periodic signal isolation and restoration, thus improving performance of lengthy nets. The interconnection buffers can propagate signals in either direction on a general interconnection segment. These bidirectional buffers are above and to the right of the switching matrices. The other PIPs adjacent to the matrices are gateways to and from long lines.

The XACT LCA Development System automatically defines the buffer direction based on the location of the interconnection network source. The delay calculator of the XACT LCA Development System automatically calculates and displays the block, interconnection, and buffer delays for the selected paths. It can also generate the simulation net list with a worst-case delay model.

**Direct Interconnections**

A direct interconnection, shown below, provides the most efficient implementation of networks between adjacent logic or IOBs. The .x and .y outputs of each CLB have single contact, direct access to inputs of adjacent CLBs.
Signals routed from block to block by direct interconnection show minimum interconnection propagation and use no general interconnection resources. For each CLB, the .x output can be connected directly to the .b input of the CLB to its right, and to the .c input of the CLB to its left. The .y output can use a direct interconnection to drive the .d input of the block above, and the .a input of the block below.

Direct interconnection should be used to maximize the speed of high performance portions of logic. Where logic blocks are adjacent to IOBs, a direct connection is provided alternately to the IOB inputs (.i) and outputs (.o) of the left, top, and bottom edges of the die. The right edge provides alternate direct input and output of CLBs and IOBs. Direct interconnections of IOBs and CLBs are shown in the next figure.
Long Lines

Long lines, which bypass the switch matrices, are intended primarily for signals that must travel a long distance, or that must have minimum skew among multiple destinations. Long lines, shown below, run the height or width of the interconnection area. Each interconnection column has three vertical long lines, and each interconnection row has two horizontal long lines. Two additional long lines are adjacent to the outer sets of switching matrices. The outermost are connectible half-length lines.

Horizontal and vertical long lines provide high fan-out, low-skew signal distribution in each row and column. The global buffer in the upper left die corner drives a common line throughout the LCA device. The programmable interconnection of long lines is provided at the edges of the routing area. Long lines can be driven by a CLB or IOB output on a column-by-column basis. This provides a common low skew control or clock line within each column of logic blocks. Interconnections of these long lines are shown in the following figure. Isolation buffers are provided at each input to a long line and are enabled automatically by the XACT LCA Development System when a connection is made.
Horizontal Long Line
Three-State Buffers

*Four Outer Long Lines Are Connectible Half-Length Lines

I/O Block Clock Nets (2 Per Die Edge)
A buffer in the upper left corner of the LCA chip drives a global net available to all .k inputs of logic blocks. Using the global buffer for a clock signal provides a skew free, high fan-out, synchronized clock for use at any, or all, of the I/O and logic blocks. Three-state buffers let you use horizontal long lines to form wired-AND and multiplexed busses. Configuration bits for the .k input to each logic block can select this global line or another routing resource as the clock source for its flip-flops. This net can also be programmed to drive the die edge clock lines for IOB use. An enhanced speed, CMOS threshold direct access to this buffer is available at the second pad from the top of the left die edge.

A buffer in the lower right corner of the array drives a horizontal long line, which can drive programmed connections to a vertical long line in each interconnection column. This alternate buffer also is low skew and high fan-out. The network formed by this alternate buffer's long lines can be selected to drive the .k inputs of the logic blocks. The CMOS threshold, high-speed access to this buffer is at the third pad from the bottom of the right die edge.

**Internal Busses**

A pair of three-state buffers are located adjacent to each CLB. These let logic drive the horizontal long lines. Logical operation of the three-state buffer controls lets them implement wide multiplexing functions. Any three-state buffer input can be selected to drive the horizontal long line bus by applying a low logic level on its three-state control line, as shown in the next figure.

\[
Z = D_A \cdot \overline{A} + D_B \cdot \overline{B} + D_C \cdot \overline{C} + \ldots + D_N \cdot \overline{N}
\]

Three-state buffers make a Multiplexer for which the selection is accomplished by the buffer three-state signal.

The user must avoid contention resulting from multiple drivers with opposing logic levels. Control of the three-state input by the same signal that drives the buffer input creates an open drain wired-AND function. A logical HIGH on both buffer inputs creates a high impedance with no contention. A logical LOW enables the buffer to drive the long line low, as shown below.
Three-state buffers make a Wired-AND function. When all the three-state lines are HIGH (high impedance), the pull-up resistor(s) provide the HIGH output. The buffer inputs are driven by the control signals or a LOW.

Pull-up resistors are available at each end of the long line to provide a HIGH output when all connected buffers are non-conducting. These buffers allow fast, wide gating, optimum speed, and efficient routing of high fan-out signals. The following figure shows three-state buffers, long lines, and pull-up resistors.
Crystal Oscillator

The previous figure also shows the location of an internal high-speed inverting amplifier that can be used as an on-chip crystal oscillator. It is associated with the auxiliary buffer in the lower right corner of the die. When the oscillator is configured as a signal source, two special user IOBs are also configured to connect the oscillator amplifier with external crystal oscillator components, as shown below.

When activated by selecting an output network for its buffer, the crystal oscillator inverter uses two of the package pins and external components to make an oscillator. An optional divide-by-two mode is available to ensure symmetry.

A divide-by-two option is available to assure symmetry. The oscillator circuit becomes active before configuration is complete so the oscillator can stabilize. Actual internal connection is delayed until completion of configuration. In the preceding figure the feedback resistor, R1, between output and input biases the amplifier at threshold. The value should be as large as practical to minimize loading the
crystal. The inversion of the amplifier, together with the R-C networks and an AT cut series resonant crystal, produce the 360 degree phase shift of the Pierce oscillator. A series resistor, R2, can be included to increase the amplifier output impedance. This may be needed for phase shift control or crystal resistance matching, or to limit the amplifier input swing to control clipping at large amplitudes.

Excess feedback voltage can be corrected by the ratio of C2/C1. The amplifier can be used from 1 MHz to one-half the specified CLB toggle frequency. Used at frequencies below 1 MHz, the amplifier may require individual characterization with respect to a series resistance. Crystal oscillators operating at frequencies above 20 MHz usually require a crystal that operates in a third overtone mode, in which the fundamental frequency must be suppressed by the R-C networks. When the oscillator inverter is not used, these IOBs and their package pins are available for general user I/O.

**PROGRAMMING**

**Initialization**

An internal power-on reset circuit is triggered when power is applied. When Vcc reaches the voltage at which portions of the LCA device begin to operate (2.5 to 3 V), the programmable I/O output buffers are disabled and a high impedance pull-up resistor is provided for the user I/O pins. A time-out delay is initiated to let the power supply voltage stabilize. During this time, the power-down mode is inhibited. The initialization state time-out (about 20 to 30 ms) is determined by a 14-bit counter driven by a self-generated, internal timer. This nominal 1 MHz timer is subject to variations as a result of process, temperature, and power supply from 0.5 to 1.5 MHz. As shown in the following table, five configuration modes are available, as determined by the input levels of three mode pins M0, M1, and M2.

<table>
<thead>
<tr>
<th>M0</th>
<th>M1</th>
<th>M2</th>
<th>CLOCK</th>
<th>MODE</th>
<th>DATA</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>output</td>
<td>Master</td>
<td>Bit Serial</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>output</td>
<td>Master</td>
<td>Byte Wide (0000 up)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>output</td>
<td>Master</td>
<td>Byte Wide (FFFF down)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>input</td>
<td>Peripheral</td>
<td>Byte Wide</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>input</td>
<td>Slave</td>
<td>Bit Serial</td>
</tr>
</tbody>
</table>

In master configuration modes, the LCA device becomes the source of the configuration clock (CCLK). The beginning of configuration of devices using peripheral or slave modes must be delayed until they are initialized. An LCA device with mode lines selecting a master configuration mode extends its initialization state using four times the delay (80 to 120 ms). This ensures that all daisy-chained slave devices it may be driving will be ready. The next figure shows the sequence of states.
At the end of initialization, the LCA device enters the clear state, in which it clears the configuration memory. The active LOW, open-drain initialization signal, RDY/~INIT, indicates completion of the initialization and clear states. The LCA device tests for the absence of an external active LOW ~RESET before it makes a final sample of the mode lines and enters the configuration state. An external wired-AND of one or more ~INIT pins can be used to control configuration by the assertion of the active LOW ~RESET of a master mode device or to signal a processor that the LCA devices are not yet initialized.

If a configuration has begun, re-asserting ~RESET for at least three internal timer cycles is recognized, and the LCA device will abort the program, clearing the partially loaded configuration memory words. The LCA device will then re-sample ~RESET and the mode lines before re-entering the configuration state.

The configuration bit stream is initiated again when a configured LCA device senses a HIGH to LOW transition on the DONE/~PROG package pin. The LCA device returns to the clear state, in which the configuration memory is cleared and mode lines re-sampled, as for an aborted configuration. The complete configuration bit stream is cleared and loaded during each configuration cycle.

Length count control lets a system of multiple LCA devices, of various sizes, begin synchronized operation. The configuration bit stream generated by the MakePROM software of the XACT LCA Development System begins with a preamble of 11110010. This is followed by a 24-bit length count representing the total number of configuration clocks needed to complete loading of the configuration program(s). The data framing is shown in the following figure.
All LCA devices connected in series read and shift preamble and length count in on positive, and out on negative, configuration clock edges. An LCA device that has received the preamble and length count then presents a HIGH Data Out until it has intercepted the appropriate number of data frames. When the configuration memory of an LCA device is full and the length count does not compare, the LCA device shifts any additional data through in the same way it did for preamble and length count.

When the LCA configuration memory is full and the length count compares, the LCA device executes a synchronous start-up sequence and becomes operational, as shown below.
Two CCLK cycles after the completion of loading configuration data, the user I/O pins are enabled as configured. As selected in MAKEBITS, the internal user-logic reset is released either one clock cycle before, or one clock cycle after the I/O pins become active. A similar timing selection is programmable for the DONE/~PROG output signal. DONE/~PROG can also be programmed to be an open drain or to include a pull-up resistor to accommodate wired ANDing. High During Configuration (HDC) and Low During Configuration (LDC) are two user I/O pins driven active when an LCA is initializing, clearing, or configuring. These pins and the DONE/~PROG commands provide signals for control of external logic signals such as reset, bus enable, or PROM enable during configuration. For parallel master configuration modes, these signals provide PROM enable control and let the data pins be shared with user logic signals.

User I/O inputs can be programmed for either TTL or CMOS compatible thresholds. At power-up, all inputs have TTL thresholds and can change to CMOS thresholds at the completion of configuration, if the user has selected CMOS thresholds. The threshold of ~PWRDWN and the direct clock inputs are fixed at the CMOS level.

If the crystal oscillator is used, it will begin operation before configuration is completed; this allows time for stabilization before the oscillator is connected to the internal circuitry.
Configuration Data

Configuration data to define the function and interconnection within an LCA device are loaded from an external storage at power-up and, if not inhibited, on a reprogram signal. Several methods of automatic and controlled loading of the required data are designed into the LCA device. Logic levels applied to mode selection pins at the start of configuration determine the method to be used. See the mode selection table above.

The format of the data can be either bit-serial or byte-parallel, depending on the configuration mode. Various AMD programmable gate arrays will have different sizes and numbers of data frames. To maintain compatibility between various device types of the AMD product line, the 3000 series LCA devices use formats compatible with the 2000 series. For the 3020, configuration requires 14779 bits, arranged in 197 data frames, for each device. An additional 36 bits are used in header, as shown in the previous figure. The specific data format for each device is produced by the MAKEBITS command of the XACT LCA Development System.

One or more of these files can then be combined and appended to a length count preamble and be transformed into a PROM format file by the MAKE PROM command of the XACT LCA Development System. An exception to the compatibility of the devices is that a 2000 series device cannot be used as the master for a 3000 series device if their DONE or RESET are programmed to occur after their outputs become active. The TIE option of MAKEBITS causes the unused block outputs to be defined as constant LOW levels that are used to drive the unused routing and block resources. Resources that might not be accessible to unused block outputs will then be added to FLAGNET, non-critical user nets. NORESTORE will retain the results of TIE for timing analysis with QUERYNET, before RESTORE returns the design to the untied condition. TIE can be omitted for quick breadboard iterations where a few additional mA of ICC are acceptable.

The configuration bit stream begins with HIGH preamble bits, a four-bit preamble code, and a 24-bit length count. When configuration is initiated, a counter in the LCA device is set to 0 and begins to count the total number of configuration clock cycles applied to the device. As each configuration data frame is supplied to the LCA device, it is internally assembled into a data word. As each data word is completely assembled, it is loaded in parallel into one word of the internal configuration memory array. The configuration loading process is completed when the current length count equals the loaded length count, and the required configuration bit stream data frames have been written. Internal user flip-flops are held reset during configuration.

Two user-programmable pins are defined in the unconfigured LCA device. HDC and LDC, as well as DONE/~PROG, can be used as external control signals during configuration. In master mode configurations it is convenient to use LDC as an active-LOW EPROM Chip Enable. After the last configuration data-bit is loaded and the length count compares, the user I/O pins become active. Options in the MAKEBITS software allow timing choices of one clock earlier or later for the timing of the end of the internal logic reset and the assertion of the DONE signal. The open-drain DONE/~PROG output can be AND-tied with multiple LCA devices and used as an active HIGH READY, an active LOW PROM enable, or a RESET to other portions of the system.

Master Mode

In master mode, the LCA device automatically loads configuration data from an external memory device. There are three master modes that use the internal timing source to time the incoming data supplying the
configuration clock (CCLK). Serial master mode uses serial configuration data supplied to data-in (DIN) from a synchronous serial source such as the AMD Serial Configuration PROM (Am1736) shown below.

The one-time-programmable Am1736 Serial Configuration PROM supports automatic loading of configuration programs up to 36K bits. Multiple devices can be cascaded to support additional LCA devices. An early DONE inhibits the Am1736 data output one CCLK cycle before the LCA I/O becomes active.
Master LOW and master HIGH modes automatically use parallel data supplied to the D0-D7 pins in response to the 16-bit address generated by the LCA device. The next figure shows an example of the parallel master mode connections required. The LCA HEX starting address is 0000 and increments for master LOW mode. It is FFFF and decrements for master HIGH mode. These two modes provide address compatibility with microprocessors beginning execution from opposite ends of memory.

For master HIGH or LOW, data bytes are read in parallel by each read clock (RCLK) and internally serialized by the configuration clock. As each data byte is read, the least significant bit of the next byte, D0, becomes the next bit in the internal serial configuration word. One master mode LCA device can be used to interface the configuration program-store and pass additional concatenated configuration data to additional LCA devices in a serial daisy-chain fashion. CCLK is provided for the slaved devices and their serialized data is supplied from DOUT to DIN - DOUT to DIN, etc.

Configuration data are loaded automatically from an external byte wide PROM. An early DONE inhibits the PROM outputs a CCLK before the LCA I/O becomes active.
GENERAL-PURPOSE USER I/O PINS

EPROM (2K x 8 or Larger)

* FOR OPTIONAL SLAVE MODE LCAs IN A DAISY CHAIN
Peripheral Mode

Peripheral mode provides a simplified interface through which the device can be loaded byte-wide, as a processor peripheral. The next figure shows the peripheral mode connections. Processor write cycles are decoded from the common assertion of the active LOW Write Strobe (~WRT), and two active LOW and one active HIGH Chip Selects (~CS0, ~CS1, CS2). If all these signals are not available, the unused inputs should be driven to their respective active levels. The LCA device accepts one byte of configuration data on the D0-D7 inputs for each selected processor write cycle. Each byte of data is loaded into a buffer register.

The LCA device generates a configuration clock from the internal timing generator and serializes the parallel input data for internal framing or for succeeding slaves on Data Out (DOUT). An output HIGH on the READY/~BUSY pin indicates completion of loading for each byte and that the input register is ready for a new byte. As with master modes, peripheral mode can also be used as a lead device for a daisy-chain of slave devices.
CONTROL SIGNALS  ADDRESS  DATA  BUS  BUS

ADDRESS DECODE LOGIC

D0-7

+5V

M0  M1  PWR
DWN

D0-7  CCLK

CS0

CS1  ALL
CS2  OTHER
WS  PINS
RDY/BUSY
INIT
VPP
RESET

GENERAL-PURPOSE USER I/O PINS

FOR OPTIONAL SLAVE MODE LCAs IN A DAISY CHAIN
Slave Mode

Slave mode provides a simple interface for loading the LCA device configuration, as shown below. Data are supplied in conjunction with a synchronizing input clock. Bit-serial data configuration are read at rising edge of the CCLK. Data on DOUT are provided on the falling edge of CCLK.

Most slave mode applications are in daisy-chain configurations in which the data input are supplied by the previous LCA's data out, while the clock is supplied by a lead device in master or peripheral mode. Data can also be supplied by a processor or other special circuits.

Daisy-Chain

The AMD XACT LCA Development System is used to create a composite configuration bit stream for selected LCA devices. This configuration includes the following:
A preamble
A length count for the total bit stream
Multiple concatenated data programs
A postamble
An additional fill bit per device in the serial chain

After loading and passing on the preamble and length count to a possible daisy-chain, a lead device will load its configuration data frames while providing a HIGH DOUT to possible down-stream devices as shown below. In this figure, all are configured from the common EPROM source. The slave mode device ~INIT signals delay the master device configuration until they are initialized. A well defined termination of SYSTEM RESET is needed when controlling multiple LCA devices.

Loading continues until the current length count has reached the full value. The additional data are passed through the lead device and appear on the DOUT pin in serial form. The lead device also
generates the CCLK to synchronize the serial output data and data in of LCA devices further attached. Data are read in on DIN of slave devices by the positive edge of CCLK and shifted out the DOUT on the negative edge of CCLK. A parallel master mode device uses its internal timing generator to produce an internal CCLK of eight times its EPROM address rate, while a peripheral mode device produces a burst of eight CCLKs for each chip select and write-strobe cycle. The internal timing generator continues to operate for general timing and synchronization of inputs in all modes.

SPECIAL CONFIGURATION FUNCTIONS

The configuration data include control over several special functions, in addition to the normal user logic functions and interconnections.

- Input thresholds
- Readback enable
- DONE pull-up resistor
- DONE timing
- RESET timing
- Oscillator frequency divided-by-two

Each of these functions is controlled by configuration data bits selected as part of the normal XACT LCA Development System bit-stream generation process.

Input Thresholds

Prior to the completion of configuration, all LCA input thresholds are TTL compatible. Upon completion of configuration, the input thresholds become either TTL or CMOS compatible, as programmed. The use of the TTL threshold option requires some additional supply current for threshold shifting. The exception is the threshold of the \(-PWRDWN\) input and direct clocks that always have a CMOS input. Prior to the completion of configuration, the user I/O pins have a high impedance pull-up. The configuration bit stream can be used to enable the IOB pull-up resistors in the operational mode to act either as an input load or to avoid a floating input on an otherwise unused pin.

Readback

The contents of an LCA device can be read back if it has been programmed with a bit stream in which the Readback option has been enabled. Readback can be used for verification of configuration, as well as a method of determining the state of internal logic nodes during debugging with the XACTOR In-Circuit debugger. There are three options in generating the configuration bit stream.

- **Never** inhibits the Readback capability.
- **One-time** inhibits Readback after one Readback has been executed to verify the configuration.
- **On-command** permits unrestricted use of Readback.
Readback is done without the use of any of the user I/O pins; only M0, M1, and CCLK are used. The initiation of readback is produced by a LOW to HIGH transition of the M0/RTRIG (Read Trigger) pin. Once the READBACK command has been given, the input CCLK is driven by external logic to read back each data bit in a format similar to loading. After two dummy bits, the first data frame is shifted out, in inverted sense, on the M1/-RDATA (Read Data) pin. All data frames must be read back to complete the process and return the mode select and CCLK pins to their normal functions.

The readback data includes the current state of each internal logic block storage element, and the state of the .i and .ri connection pins on each IOB. These data are imbedded into unused configuration bit positions during readback. This state information is used by the XACT LCA Development System In-Circuit Verifier to provide visibility into the internal operation of the logic while the system is operating. To readback a uniform time-sample of all storage elements it may be necessary to inhibit the system clock.

Reprogram

To initiate a reprogramming cycle, the dual function package pin DONE/~PROG must transition from HIGH to LOW. To reduce noise sensitivity, the input signal is filtered for two cycles of the LCA's internal timing generator. When reprogram begins, the user programmable I/O output buffers are disabled, and high impedance pull-ups are provided for the package pins. The device returns to the clear state and clears the configuration memory before it is initialized.

Reprogram control is often exercised using an external open collector driver that pulls DONE/~PROG LOW. Once it recognizes a stable request, the LCA device holds a LOW until the new configuration has been completed. Even if the reprogram request is externally held LOW beyond the configuration period, the LCA device will begin operation upon completion of configuration.

DONE Pull-up

DONE/~PROG is an open drain I/O pin indicating that the LCA device is operational. An optional internal pull-up resistor can be enabled by the user of the XACT LCA Development System when MakeBits is executed. The DONE/~PROG pins of multiple LCA devices in a daisy-chain can be connected to indicate all are DONE or to direct them to reprogram.

DONE Timing

By a selection in the MakeBits program, the timing of the DONE status signal can be controlled to occur one CCLK cycle before, or one cycle after, the timing of outputs are activated. This is shown below. This facilitates control of external functions such as a PROM enable or holding a system in a wait state.
RESET Timing

As with DONE timing, the timing of the release of the internal RESET can be controlled by a selection in the MakeBits program. It then occurs one CCLK cycle before, or one cycle after, the timing of outputs are enabled, as shown above. This reset maintains all user-programmable flip-flops and latches in a zero state during configuration.

Crystal Oscillator Division

A selection in the MakeBits software lets the user incorporate a dedicated divide-by-two flip-flop in the crystal oscillator function. This helps ensure a symmetrical timing signal. Although the frequency stability of crystal oscillators is high, the symmetry of the waveform can be affected by bias or feedback drive.
Device Performance

The high performance of the LCA device is due in part to the manufacturing process, which is similar to that used for high-speed CMOS static memories. Performance can be measured in terms of minimum propagation times for logic elements. The parameter that traditionally describes the overall performance of a gate array is the toggle frequency of a flip-flop. The configuration for determining the toggle performance of the LCA device is shown below. The flip-flop output Q is fed back through the combinational logic as ~Q to form the toggle flip-flop.

![Diagram of flip-flop configuration](image)

Actual LCA device performance is determined by the timing of critical paths, including both the fixed timing for the logic and storage elements in that path, as well as the timing associated with the network routing. Examples of internal worst-case timing are included in the performance data to let the user to make the best use of the device's capabilities. The XACT LCA Development System timing calculator, or LCA generated simulation models, should be used to calculate worst-case paths by using actual impedance and loading information. The following figure shows a variety of elements used involved in determining system performance.
The speed of internal elements is determined by differential measurements of package pins. The performance of a user's design can be predicted by the XACT LCA Development System delay calculator.
Actual measurement of internal timing is not practical; often only the sum of component timing is relevant, as in the case of input to output. The relationship between input and output timing is arbitrary; only the total determines performance. Timing components of internal functions can be determined by measuring the differences at the pins of the package. A synchronous logic function with a clock-to-block output, and a block-input to clock set-up, is capable of higher speed operation than a logic configuration of two synchronous blocks with an extra combinational block level between them. System clock rates to 60% of the toggle frequency are practical for logic in which there is an extra combinational level located between synchronized blocks. This permits implementation of functions of up to 25 variables. The use of the wired-AND is also available for wide, high-speed functions.

**Logic Block Performance**

Logic block performance is expressed as the propagation time from the interconnection point at the input of the combinational logic, to the output of the block in the interconnection area. Combinational performance is independent of the specific logic function, which is based on look-up tables.

The only parameter for all logic functions is the Logic Input to Output delay. For combinational logic used in conjunction with the storage element, however, there are two critical parameters. First, for the combinational logic function driving the data input of the storage element, the critical timing is data setup relative to the clock edge provided to the flip-flop. Second, for the signals then produced by the storage elements, the critical timing is the Clock to Output delay. These parameters are shown in the previous figure.

Loading of a logic block output is limited only by the resulting propagation delay of the larger interconnection network. Speed performance of the logic block is a function of the supply voltage and the temperature, as shown in the next two figures.
The following figure shows the change in speed performance as a function of temperature. The variation is normalized for 30° C, 70° C, 85° C, and 125° C.

The following figure shows how the speed performance of a CMOS device increases with Vcc within the operating range.
Interconnection Performance

Interconnection performance depends on the routing resource used for the signal path. As discussed earlier, direct interconnection from block to block provides a fast path for a signal. The single metal segment used for long lines exhibits low resistance from end to end, but relatively high capacitance. Signals driven through a programmable switch will have the additional impedance of the switch added to their normal drive impedance.

General purpose interconnection performance depends on the number of switches and segments used, the presence of the bidirectional re-powering buffers, and the loading at all points on the signal path. In calculating the worst-case timing for a general interconnection path, the timing calculator portion of the XACT LCA Development System takes all of these elements into account.

As an approximation, interconnection timing is proportional to the summation of totals of local metal segments beyond each programmable switch. In effect, the time is a sum of R-C time, each approximated by an R times the total C it drives. The R of the switch and the C of the interconnection are functions of the particular device performance grade.

For a string of three local interconnections, the approximate time at the first segment (after the first switch resistance) would be three units; after the next switch there are an additional two units; and there is an additional unit after the last switch in the chain. The interconnection R-C chain terminates at each re-powering buffer. The capacitance of the block inputs is not significant; the capacitance is in the interconnection metal and switches, as shown in the following figure.
Power Distribution

Power for the LCA device is distributed through a grid to achieve high noise immunity and isolation between the logic and I/O. Inside the LCA device, a dedicated Vcc and ground ring surrounding the logic array provide power to the I/O drivers, as shown below. An independent matrix of Vcc and ground lines supplies the interior logic of the device. This power distribution grid provides a stable supply and ground for all internal logic; this assumes that the external package power pins are all connected and appropriately decoupled. Usually, a 0.1 \( \mu F \) capacitor connected near the Vcc and ground pins of the package will provide adequate decoupling.

Output buffers capable of driving the specified 4 mA loads under worst-case conditions can be capable of driving 25 to 30 times that current in a best case. Noise can be reduced by minimizing external load capacitance and reducing simultaneous output transitions in the same direction. Also, it may be beneficial to locate heavily loaded output buffers near the ground pads. The IOB output buffers have a slew-limited mode that should be used where output rise and fall times are not speed critical. A lower AC drive current reduces transition and supply noise without a corresponding reduction in DC drive. A maximum of 32 simultaneously switching outputs is allowed.
Power Dissipation

The LCA device exhibits the low power consumption characteristic of CMOS ICs. For any design, the user can use the figure below to calculate the total power requirement based on the sum of the external and internal capacitive and DC loads. The total chip power is the sum of Vcc•Icco, plus internal and external values of capacitive charging currents and resistive loads.

The configuration options of TTL chip input threshold requires power for the threshold reference. The power required by the static memory cells holding the configuration data is very low and can be maintained in a power-down mode.
Usually, most power dissipation is produced by external capacitive loads on the output buffers. The load- and frequency-dependent power is 25 µW/pF/MHz per output. Another component of I/O power is the DC loading on each output pin by LCA-driven devices.

Internal power dissipation is a function of the number and size of the nodes, and the frequency at which they change. In an LCA device, the fraction of nodes changing on a given clock is typically low (10-20%). For example, in a large binary counter, the average clock cycle produces changes equal to one CLB output at the clock frequency. In a 4-input AND gate, there will be two transitions in 16 states. Typical global clock buffer power is about 3 mW/MHz. The internal capacitive load is more a function of interconnection than fanout. With typical load of three general interconnection segments, each CLB output requires about 0.4 mW/MHz of its output frequency.

\[
\text{Total power} = V_{cc} \cdot I_{cc0} + \text{external (DC + capacitive)} + \text{internal (CLB + IOB + Long Line + pull-up)}
\]

Because the control storage of the LCA device is CMOS static memory, its cells require a very low standby current for data retention. In some systems, this characteristic can be used as a method of preserving configurations in the event of a primary power loss. The LCA device has built in power-down logic that, when activated, will disable normal operation of the device and retain only the configuration data. All internal operation is suspended and output buffers are placed in a high impedance state with no pull-ups. Power-down data retention is possible with a simple battery-backup circuit because the power requirement is extremely low. For retention at 2.4 V, the required current is typically on the order of 50 nA.

To force the LCA device into the power-down state, the user must pull the ~PWRDWN pin LOW and continue to supply a retention voltage to the Vcc pins of the package. When normal power is restored, Vcc is increased to its normal operating voltage and ~PWRDWN is returned to HIGH. The LCA device resumes operation with the same internal sequence that occurs at the conclusion of configuration. Internal I/O and logic block storage elements will be reset, the outputs will become enabled, and the DONE/~PROG pin will be released. No configuration programming is required.

When the power supply is removed from a CMOS device, it is possible to supply some power from an input signal. The conventional electrostatic input protection is provided by diodes to the supply and ground. A positive voltage applied to an input or output will cause the positive protection diode to conduct and drive the power pin. This condition can produce invalid power conditions and should be avoided. A large series resistor can be used to limit the current, or a bi-polar buffer can be used to isolate the input signal.

**DEVELOPMENT SYSTEMS**

To implement your system application on the LCA device, AMD provides a wide host of software packages. These packages are primarily IBM-PC/AT based and allow the entire programmable gate array design cycle to be completed inexpensively and quickly at the system designer’s desk. The packages provide the following capabilities.

- Schematic capture
- PALASM™ Boolean entry
- Large number of predefined macro library elements
- Automatic logic conversion and reduction
- Logic and electrical rule checking
• Logic partitioning
• Automatic placement and routing
• Interactive timing calculator
• Logic and timing simulation interfaces
• Automatic design documentation
• Interactive design editing and optimization
• PROM programmer format output capabilities
• In-system design verification for multiple arrays

The XACT LCA Design Editor is hosted on an IBM-PC/AT system with DOS 3.0 or higher. The system requires 640K bytes of internal RAM, 1.5 MBytes of extended memory, color graphics, and a mouse. The complete system requires one parallel I/O port and two serial ports for the mouse and in-system emulator.

Design Entry

Design entry can be accomplished with popular schematic editors. Popular engineering workstations such as Daisy or Mentor are also supported. Additionally, designs can be entered and configured manually with the XACT Design Editor, or through Boolean expressions via PALASM programmable logic language.

The following figure shows a partial sample of a entering a design via schematic capture.
Design Implementation

Following design entry, logic designs can be automatically converted, reduced, partitioned, placed, and routed with the Automatic Design Implementation (ADI) software packages. For those designs that are not completely automatic, the XACT Design Editor can be used to manually complete or optimize the design. Following layout, various design and electrical rules are checked automatically by the software, producing a valid design file. This file contains all the programming data used to download directly into
an LCA device in the user's target system. The programming information can be used to program PROM, EPROM, or ROM devices, or stored in other media, as needed by the final system.

Design Verification

Design verification can be accomplished by using the AMD XACTOR In-System Emulator directly in the target system. Also, the ADI packages provide output data that can be accepted by popular simulators such as P-SILOS for complete logic and timing simulation. If design changes are required, the changes can be implemented in minutes at the designer's desk.

PIN DESCRIPTIONS

~PWRDWN

An active LOW power down input stops all internal activity to minimize Vcc power and puts all output buffers in a high impedance state. Configuration is retained, however, internal storage elements are Reset. When the ~PWRDWN pin returns HIGH, the device returns to operation with the same sequence of Reset, buffer enable, and DONE/~PROGRAM as at the completion of configuration.

M 0

As Mode 0, this input and M1 M2 are sampled before the start of configuration to establish the configuration mode to be used.

or

RTRIG

As a Read Trigger, after configuration is complete, an input transition to a HIGH will initiate a Readback of configuration and storage element data by CCLK. This operation can be limited to a single request, or can be inhibited altogether, by selecting the appropriate readback option when generating the bit stream.

M 1

As Mode 1, this input, M0, and M2 are sampled before the start of configuration to establish the configuration mode.

or
As an active LOW Read Data, this pin is the output of the readback data after configuration is complete.

M2

As Mode 2 this input, M0, and M1 are sampled before the start of configuration to establish the configuration mode. After configuration, this pin becomes a user-programmable I/O pin.

HDC

High During Configuration is held at a HIGH level by the LCA device until after configuration. It is intended to be available as a control indication that configuration is not completed. After configuration, this pin is a user I/O pin.

LDC

Low During Configuration is held at a LOW level by the LCA device until after configuration. It is intended to be available as a control indication that configuration is not completed. It is particularly useful in master mode as a LOW enable for an EPROM. After configuration, this pin is a user I/O pin. If used as a LOW EPROM enable, it would need to be programmed as a HIGH after configuration.

~INIT

This is active LOW open collector output is held LOW during the power stabilization and internal clearing of the configuration memory. It can be used to indicate status to a configuring microprocessor or, as a wired-AND of several slave mode devices, a hold-off signal for a master mode device. After configuration, this pin becomes a user programmable I/O pin.

~RESET

This active LOW input has three functions. Prior to the start of configuration, a LOW input will delay the start of configuration. An internal circuit senses the application of power and begins a minimal time-out cycle. When the time-out and ~RESET are complete, the levels of the M lines are sampled and configuration begins. If ~RESET is asserted during a configuration, the LCA device is re-initialized and will restart the configuration at the termination of ~RESET. If ~RESET is asserted after configuration is complete, it will provide an asynchronous reset of all IOB and CLB storage elements of the LCA device.

DONE

The DONE output is configurable as an open drain with or without a pull-up resistor. At the completion of configuration, the circuitry of the LCA device becomes active in a synchronous order, and DONE can be programmed to occur one cycle before or after.
Once configuration is completed, a HIGH-to-LOW transition of this pin will cause an initialization of the LCA device and start a reconfiguration.

**XTL1**

This user I/O pin can be configured to operate as the output of an amplifier usable with an external crystal and bias circuitry.

**XTL2**

This user I/O pin can be configured to operate as the input of an amplifier usable with an external crystal and bias circuitry.

**CCLK**

During configuration, Configuration Clock is an output of an LCA device in master mode or peripheral mode. LCA devices in slave mode use it as a clock input. During a Readback operation, it is an input clock for the configuration data being output.

**DOUT**

This user I/O pin is used during configuration to output serial configuration data for the Data In of daisy-chained slaves.

**DIN**

This user I/O pin is used as serial Data In during slave or master serial configuration. This pin is D0 in master or peripheral configuration mode.

**~CS0, ~CS1, CS2, ~WRT**

These four inputs represent a set of signals, three active LOW and one active HIGH, which are used in peripheral mode to control configuration data entry. The assertion of all four generates a write to the internal data buffer. The removal of any assertion results in the present data of D0-D7 being clocked in.

**~RCLK**

During master parallel mode configuration, this pin represents a read of an external memory device.

**RDY/~BUSY**

During peripheral parallel mode configuration, this pin indicates when the chip is ready for another byte of data to be written to it. After configuration is complete, this pin becomes a user-programmed I/O pin.
D0-D7

This set of eight pins represents the parallel configuration byte for the parallel master and peripheral modes. After configuration is complete, they are user-programmable I/O pins.

A0-A15

This set of 16 pins presents an address output for a configuration EPROM during master parallel mode. After configuration is complete, they are user-programmable I/O pins.

I/O

A pin that, after configuration, can be programmed by the user to be an input and/or output pin. Some of these pins present a high impedance pull-up or perform other functions before configuration is complete.
### APPENDIX A: TABLES AND DIAGRAMS

#### Table 2a. 3000 Family Configuration Pin Assignments

<table>
<thead>
<tr>
<th>SLAVE &lt;1:1&gt;</th>
<th>MASTER-LOW &lt;1:1&gt;</th>
<th>MASTER-HIGH &lt;1:1&gt;</th>
<th>MASTER-SER &lt;0:0&gt;</th>
<th>PERIPHERAL &lt;1:0&gt;</th>
<th>PLCC</th>
<th>PLCC</th>
<th>PGA</th>
<th>PGA</th>
<th>USER OPERATION</th>
</tr>
</thead>
<tbody>
<tr>
<td>PWR DWN (I)</td>
<td>PWR DWN (I)</td>
<td>PWR DWN (I)</td>
<td>PWR DWN (I)</td>
<td>PWR DWN (I)</td>
<td>68</td>
<td>64</td>
<td>84</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>M0 (HIGH)</td>
<td>M0 (LOW)</td>
<td>M2 (HIGH)</td>
<td>M2 (LOW)</td>
<td>M1 (LOW)</td>
<td>26</td>
<td>32</td>
<td>33</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>HDC (HIGH)</td>
<td>HDC (LOW)</td>
<td>HDC (HIGH)</td>
<td>HDC (LOW)</td>
<td>HDC (HIGH)</td>
<td>28</td>
<td>34</td>
<td>35</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>HDC (LOW)</td>
<td>HDC (LOW)</td>
<td>HDC (HIGH)</td>
<td>HDC (LOW)</td>
<td>HDC (HIGH)</td>
<td>30</td>
<td>36</td>
<td>37</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>INIT*</td>
<td>INIT*</td>
<td>INIT*</td>
<td>INIT*</td>
<td>INIT*</td>
<td>34</td>
<td>42</td>
<td>43</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>RESET (I)</td>
<td>RESET (I)</td>
<td>RESET (I)</td>
<td>RESET (I)</td>
<td>RESET (I)</td>
<td>44</td>
<td>54</td>
<td>55</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DONE</td>
<td>DONE</td>
<td>DONE</td>
<td>DONE</td>
<td>DONE</td>
<td>45</td>
<td>55</td>
<td>56</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DATA 7 (I)</td>
<td>DATA 7 (I)</td>
<td>DATA 7 (I)</td>
<td>DATA 7 (I)</td>
<td>DATA 7 (I)</td>
<td>46</td>
<td>56</td>
<td>57</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DATA 6 (I)</td>
<td>DATA 6 (I)</td>
<td>DATA 6 (I)</td>
<td>DATA 6 (I)</td>
<td>DATA 6 (I)</td>
<td>47</td>
<td>57</td>
<td>58</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DATA 5 (I)</td>
<td>DATA 5 (I)</td>
<td>DATA 5 (I)</td>
<td>DATA 5 (I)</td>
<td>DATA 5 (I)</td>
<td>48</td>
<td>58</td>
<td>59</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DATA 4 (I)</td>
<td>DATA 4 (I)</td>
<td>DATA 4 (I)</td>
<td>DATA 4 (I)</td>
<td>DATA 4 (I)</td>
<td>49</td>
<td>59</td>
<td>60</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DATA 3 (I)</td>
<td>DATA 3 (I)</td>
<td>DATA 3 (I)</td>
<td>DATA 3 (I)</td>
<td>DATA 3 (I)</td>
<td>50</td>
<td>60</td>
<td>61</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DATA 2 (I)</td>
<td>DATA 2 (I)</td>
<td>DATA 2 (I)</td>
<td>DATA 2 (I)</td>
<td>DATA 2 (I)</td>
<td>51</td>
<td>61</td>
<td>62</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DATA 1 (I)</td>
<td>DATA 1 (I)</td>
<td>DATA 1 (I)</td>
<td>DATA 1 (I)</td>
<td>DATA 1 (I)</td>
<td>52</td>
<td>62</td>
<td>63</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DATA 0 (I)</td>
<td>DATA 0 (I)</td>
<td>DATA 0 (I)</td>
<td>DATA 0 (I)</td>
<td>DATA 0 (I)</td>
<td>53</td>
<td>63</td>
<td>64</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>RDY/BUSY (I)</td>
<td>RDY/BUSY (I)</td>
<td>CCLK</td>
<td>CCLK</td>
<td>CCLK</td>
<td>54</td>
<td>64</td>
<td>65</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DIN (I)</td>
<td>DIN (I)</td>
<td>DATA 0 (I)</td>
<td>DATA 0 (I)</td>
<td>DATA 0 (I)</td>
<td>55</td>
<td>65</td>
<td>66</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>DOUT (Q)</td>
<td>DOUT (Q)</td>
<td>DOUT (Q)</td>
<td>DOUT (Q)</td>
<td>DOUT (Q)</td>
<td>56</td>
<td>66</td>
<td>67</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>CCLK</td>
<td>CCLK</td>
<td>CCLK</td>
<td>CCLK</td>
<td>CCLK</td>
<td>57</td>
<td>67</td>
<td>68</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>W(S) (I)</td>
<td>A0</td>
<td>A0</td>
<td>A0</td>
<td>A0</td>
<td>58</td>
<td>68</td>
<td>69</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td>CS2 (I)</td>
<td>A1</td>
<td>A1</td>
<td>A1</td>
<td>A1</td>
<td>59</td>
<td>69</td>
<td>70</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td></td>
<td>A2</td>
<td>A2</td>
<td>A2</td>
<td>A2</td>
<td>60</td>
<td>70</td>
<td>71</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td></td>
<td>A3</td>
<td>A3</td>
<td>A3</td>
<td>A3</td>
<td>61</td>
<td>71</td>
<td>72</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td></td>
<td>A4</td>
<td>A4</td>
<td>A4</td>
<td>A4</td>
<td>62</td>
<td>72</td>
<td>73</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td></td>
<td>A5</td>
<td>A5</td>
<td>A5</td>
<td>A5</td>
<td>63</td>
<td>73</td>
<td>74</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td></td>
<td>A6</td>
<td>A6</td>
<td>A6</td>
<td>A6</td>
<td>64</td>
<td>74</td>
<td>75</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td></td>
<td>A7</td>
<td>A7</td>
<td>A7</td>
<td>A7</td>
<td>65</td>
<td>75</td>
<td>76</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td></td>
<td>A8</td>
<td>A8</td>
<td>A8</td>
<td>A8</td>
<td>66</td>
<td>76</td>
<td>77</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
<tr>
<td></td>
<td>A9</td>
<td>A9</td>
<td>A9</td>
<td>A9</td>
<td>67</td>
<td>77</td>
<td>78</td>
<td>175</td>
<td>10 B2 B2 PWR DWN (I)</td>
</tr>
</tbody>
</table>

- **Note:** Pin assignments of "PGA Footprint" PLCC sockets and PGA packages are not electrically identical.

- **Note:** Represents a 50k to 100k ohm pull-up during configuration
- **Note:** Init is an open drain output during configuration
Table 2b. 3000 Family 68-Pin PLCC Pinouts

<table>
<thead>
<tr>
<th>PLCC Pin Numbers</th>
<th>PLCC Pin Numbers 3020</th>
<th>PLCC Pin Numbers 3020</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>-PWRODN</td>
<td>44</td>
</tr>
<tr>
<td>11</td>
<td>IO</td>
<td>45</td>
</tr>
<tr>
<td>12</td>
<td>IO</td>
<td>46</td>
</tr>
<tr>
<td>13</td>
<td>I/O*</td>
<td>47</td>
</tr>
<tr>
<td>14</td>
<td>IO</td>
<td>48</td>
</tr>
<tr>
<td>15</td>
<td>IO</td>
<td>49</td>
</tr>
<tr>
<td>16</td>
<td>IO</td>
<td>50</td>
</tr>
<tr>
<td>17</td>
<td>IO</td>
<td>51</td>
</tr>
<tr>
<td>18</td>
<td>VCC</td>
<td>52</td>
</tr>
<tr>
<td>19</td>
<td>I/O*</td>
<td>53</td>
</tr>
<tr>
<td>20</td>
<td>IO</td>
<td>54</td>
</tr>
<tr>
<td>21</td>
<td>I/O*</td>
<td>55</td>
</tr>
<tr>
<td>22</td>
<td>IO</td>
<td>56</td>
</tr>
<tr>
<td>23</td>
<td>IO</td>
<td>57</td>
</tr>
<tr>
<td>24</td>
<td>IO</td>
<td>58</td>
</tr>
<tr>
<td>25</td>
<td>M1--RDATA</td>
<td>59</td>
</tr>
<tr>
<td>26</td>
<td>M0--RTRIG</td>
<td>60</td>
</tr>
<tr>
<td>27</td>
<td>M2-I/O</td>
<td>61</td>
</tr>
<tr>
<td>28</td>
<td>HDC-I/O</td>
<td>62</td>
</tr>
<tr>
<td>29</td>
<td>IO</td>
<td>63</td>
</tr>
<tr>
<td>30</td>
<td>~LDC-I/O</td>
<td>64</td>
</tr>
<tr>
<td>31</td>
<td>IO</td>
<td>65</td>
</tr>
<tr>
<td>32</td>
<td>IO</td>
<td>66</td>
</tr>
<tr>
<td>33</td>
<td>IO</td>
<td>67</td>
</tr>
<tr>
<td>34</td>
<td>~INIT-I/O</td>
<td>68</td>
</tr>
<tr>
<td>35</td>
<td>GND</td>
<td>1</td>
</tr>
<tr>
<td>36</td>
<td>IO</td>
<td>2</td>
</tr>
<tr>
<td>37</td>
<td>IO</td>
<td>3</td>
</tr>
<tr>
<td>38</td>
<td>IO</td>
<td>4</td>
</tr>
<tr>
<td>39</td>
<td>IO</td>
<td>5</td>
</tr>
<tr>
<td>40</td>
<td>IO</td>
<td>6</td>
</tr>
<tr>
<td>41</td>
<td>IO</td>
<td>7</td>
</tr>
<tr>
<td>42</td>
<td>IO</td>
<td>8</td>
</tr>
<tr>
<td>43</td>
<td>XTL2-I/O</td>
<td>9</td>
</tr>
</tbody>
</table>

*6 Unbonded IOBs 3020

The default configuration of IOBs is input with pull-up. This can be used to prevent an undefined pad level for unbonded or unused IOBs.
# Table 2c. 3000 Family 84-Pin PLCC and PGA Pinouts

<table>
<thead>
<tr>
<th>PLCC Pin Number</th>
<th>PLCC Pin Number</th>
<th>PGA Pin Number</th>
<th>PGA Pin Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>12</td>
<td>B2</td>
<td>3020</td>
<td>3020</td>
</tr>
<tr>
<td>13</td>
<td>C2</td>
<td>3030</td>
<td>3030</td>
</tr>
<tr>
<td>14</td>
<td>B1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>15</td>
<td>C1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>16</td>
<td>D2</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>17</td>
<td>D1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>18</td>
<td>E3</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>19</td>
<td>E2</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>20</td>
<td>E1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>21</td>
<td>F2</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>22</td>
<td>F3</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>23</td>
<td>G3</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>24</td>
<td>G1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>25</td>
<td>G2</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>26</td>
<td>F1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>27</td>
<td>H1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>28</td>
<td>H2</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>29</td>
<td>J1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>30</td>
<td>K1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>31</td>
<td>J2</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>32</td>
<td>L1</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>33</td>
<td>K2</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>34</td>
<td>K3</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>35</td>
<td>L2</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>36</td>
<td>L3</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>37</td>
<td>K4</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>38</td>
<td>L4</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>39</td>
<td>J5</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>40</td>
<td>K5</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>41</td>
<td>L5</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>42</td>
<td>K6</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>43</td>
<td>J6</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>44</td>
<td>J7</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>45</td>
<td>L7</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>46</td>
<td>K7</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>47</td>
<td>L6</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>48</td>
<td>L8</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>49</td>
<td>K8</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>50</td>
<td>L9</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>51</td>
<td>L10</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>52</td>
<td>K9</td>
<td>3020</td>
<td>3030</td>
</tr>
<tr>
<td>53</td>
<td>L11</td>
<td>3020</td>
<td>3030</td>
</tr>
</tbody>
</table>

The default configuration of IOBs is input with pull-up. This can be used to prevent an undefined pad level for unbonded or unused IOBs.
<table>
<thead>
<tr>
<th>PGA Pin Number</th>
<th>PGA Pin Number</th>
<th>PGA Pin Number</th>
<th>PGA Pin Number</th>
<th>PGA Pin Number</th>
<th>PGA Pin Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>B2</td>
<td>D13</td>
<td>I/O</td>
<td>R14</td>
<td>DONE--PG</td>
<td>R3</td>
</tr>
<tr>
<td>D4</td>
<td>B14</td>
<td>M1--RDATA</td>
<td>N13</td>
<td>D7-1/O</td>
<td>N4</td>
</tr>
<tr>
<td>B3</td>
<td>C14</td>
<td>VSS</td>
<td>T14</td>
<td>XTAL1-I/O</td>
<td>R2</td>
</tr>
<tr>
<td>C4</td>
<td>B15</td>
<td>M0--RTRIG</td>
<td>P13</td>
<td>I/O</td>
<td>P3</td>
</tr>
<tr>
<td>B4</td>
<td>D14</td>
<td>VCC</td>
<td>R13</td>
<td>I/O</td>
<td>N3</td>
</tr>
<tr>
<td>A4</td>
<td>C15</td>
<td>M2-1/O</td>
<td>T13</td>
<td>I/O</td>
<td>P2</td>
</tr>
<tr>
<td>D5</td>
<td>E14</td>
<td>HDC-I/O</td>
<td>N12</td>
<td>I/O</td>
<td>M8</td>
</tr>
<tr>
<td>C5</td>
<td>B16</td>
<td>I/O</td>
<td>P12</td>
<td>D6-I/O</td>
<td>R1</td>
</tr>
<tr>
<td>B6</td>
<td>D15</td>
<td>I/O</td>
<td>R12</td>
<td>I/O</td>
<td>N2</td>
</tr>
<tr>
<td>A6</td>
<td>C16</td>
<td>I/O</td>
<td>T12</td>
<td>I/O</td>
<td>P1</td>
</tr>
<tr>
<td>C6</td>
<td>D16</td>
<td>~LDC-I/O</td>
<td>P11</td>
<td>I/O</td>
<td>N1</td>
</tr>
<tr>
<td>D6</td>
<td>F14</td>
<td>I/O</td>
<td>N11</td>
<td>I/O</td>
<td>L3</td>
</tr>
<tr>
<td>B7</td>
<td>F16</td>
<td>I/O</td>
<td>P10</td>
<td>I/O</td>
<td>L1</td>
</tr>
<tr>
<td>D7</td>
<td>G14</td>
<td>I/O</td>
<td>T10</td>
<td>I/O</td>
<td>K2</td>
</tr>
<tr>
<td>A7</td>
<td>G15</td>
<td>I/O</td>
<td>T9</td>
<td>I/O</td>
<td>K1</td>
</tr>
<tr>
<td>A8</td>
<td>G16</td>
<td>I/O</td>
<td>R9</td>
<td>D4-I/O</td>
<td>J1</td>
</tr>
<tr>
<td>C8</td>
<td>H15</td>
<td>~INIT-I/O</td>
<td>P9</td>
<td>I/O</td>
<td>J2</td>
</tr>
<tr>
<td>D8</td>
<td>VSS</td>
<td>H14</td>
<td>VCC</td>
<td>N9</td>
<td>VCC</td>
</tr>
<tr>
<td>D9</td>
<td>VCC</td>
<td>J14</td>
<td>VSS</td>
<td>N8</td>
<td>VSS</td>
</tr>
<tr>
<td>C9</td>
<td>IO</td>
<td>J15</td>
<td>I/O</td>
<td>P8</td>
<td>D3-I/O</td>
</tr>
<tr>
<td>B9</td>
<td>IO</td>
<td>J16</td>
<td>I/O</td>
<td>R8</td>
<td>~CS1-I/O</td>
</tr>
<tr>
<td>A9</td>
<td>IO</td>
<td>K16</td>
<td>I/O</td>
<td>T8</td>
<td>I/O</td>
</tr>
<tr>
<td>A10</td>
<td>IO</td>
<td>K15</td>
<td>I/O</td>
<td>T7</td>
<td>I/O</td>
</tr>
<tr>
<td>D10</td>
<td>IO</td>
<td>K14</td>
<td>I/O</td>
<td>N7</td>
<td>I/O</td>
</tr>
<tr>
<td>C10</td>
<td>IO</td>
<td>L16</td>
<td>I/O</td>
<td>P7</td>
<td>I/O</td>
</tr>
<tr>
<td>B10</td>
<td>IO</td>
<td>L15</td>
<td>I/O</td>
<td>R7</td>
<td>D2-I/O</td>
</tr>
<tr>
<td>A11</td>
<td>IO</td>
<td>M16</td>
<td>I/O</td>
<td>T6</td>
<td>I/O</td>
</tr>
<tr>
<td>B11</td>
<td>IO</td>
<td>M15</td>
<td>I/O</td>
<td>R6</td>
<td>I/O</td>
</tr>
<tr>
<td>D11</td>
<td>IO</td>
<td>L14</td>
<td>I/O</td>
<td>N6</td>
<td>I/O</td>
</tr>
<tr>
<td>C11</td>
<td>IO</td>
<td>N16</td>
<td>I/O</td>
<td>P6</td>
<td>I/O</td>
</tr>
<tr>
<td>A12</td>
<td>IO</td>
<td>P16</td>
<td>I/O</td>
<td>T5</td>
<td>I/O</td>
</tr>
<tr>
<td>B12</td>
<td>IO</td>
<td>N15</td>
<td>I/O</td>
<td>R5</td>
<td>D1-I/O</td>
</tr>
<tr>
<td>C12</td>
<td>IO</td>
<td>R16</td>
<td>I/O</td>
<td>P5</td>
<td>ROY--BUSY--RCLK-I/O</td>
</tr>
<tr>
<td>D12</td>
<td>IO</td>
<td>M14</td>
<td>I/O</td>
<td>N5</td>
<td>I/O</td>
</tr>
<tr>
<td>A13</td>
<td>IO</td>
<td>P15</td>
<td>XTAL2-I/O</td>
<td>T4</td>
<td>I/O</td>
</tr>
<tr>
<td>B13</td>
<td>IO</td>
<td>N14</td>
<td>VSS</td>
<td>R4</td>
<td>I/O</td>
</tr>
<tr>
<td>C13</td>
<td>IO</td>
<td>R15</td>
<td>~RESET</td>
<td>P4</td>
<td>I/O</td>
</tr>
<tr>
<td>A14</td>
<td>IO</td>
<td>P14</td>
<td>VCC</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The default configuration of IOBs is input with pull-up. This can be used to prevent an undefined pad level for unboned or unused IOBs. Pins A2, A3, A15, A16, T1, T2, T3, T15 and T16 are not connected. Pin A1 does not exist.
### PARAMETRICS

**Absolute Maximum Ratings**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCC</td>
<td>Supply voltage relative to GND</td>
<td>-0.5</td>
<td>7.0</td>
<td>V</td>
</tr>
<tr>
<td>VIN</td>
<td>Input voltage with respect to GND</td>
<td>-0.5</td>
<td>VCC + 0.5</td>
<td>V</td>
</tr>
<tr>
<td>VTS</td>
<td>Voltage applied to three-state output</td>
<td>-0.5</td>
<td>VCC + 0.5</td>
<td>V</td>
</tr>
<tr>
<td>VSTG</td>
<td>Storage temperature (ambient)</td>
<td>-65</td>
<td>+150</td>
<td>°C</td>
</tr>
<tr>
<td>TSOL</td>
<td>Maximum soldering temperature (10 sec @ 1/16 in.)</td>
<td>+260</td>
<td></td>
<td>°C</td>
</tr>
<tr>
<td>TJ</td>
<td>Junction temperature plastic</td>
<td>+125</td>
<td></td>
<td>°C</td>
</tr>
<tr>
<td>TJ</td>
<td>Junction temperature ceramic</td>
<td>+150</td>
<td></td>
<td>°C</td>
</tr>
</tbody>
</table>

*Note: Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those listed under Recommended Operating Conditions is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time may affect device reliability.

**RECOMMENDED OPERATING CONDITIONS**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCC</td>
<td>Supply voltage relative to GND</td>
<td>0°C</td>
<td>70°C</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>Supply voltage relative to GND</td>
<td>-40°C</td>
<td>85°C</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>Supply voltage relative to GND</td>
<td>-55°C</td>
<td>125°C</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>High-level input voltage — TTL configuration</td>
<td>2.0</td>
<td>VCC</td>
<td>V</td>
</tr>
<tr>
<td>VIL</td>
<td>Low-level input voltage — TTL configuration</td>
<td>0</td>
<td>0.8</td>
<td>V</td>
</tr>
<tr>
<td>VHC</td>
<td>High-level input voltage — CMOS configuration</td>
<td>.7VCC</td>
<td>VCC</td>
<td>V</td>
</tr>
<tr>
<td>VILC</td>
<td>Low-level input voltage — CMOS configuration</td>
<td>0</td>
<td>.2VCC</td>
<td>V</td>
</tr>
<tr>
<td>TIN</td>
<td>Input signal transition time</td>
<td>250</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>ELECTRICAL CHARACTERISTICS OVER OPERATING CONDITIONS</td>
<td>MIN</td>
<td>MAX</td>
<td>UNITS</td>
<td></td>
</tr>
<tr>
<td>------------------------------------------------------</td>
<td>-----</td>
<td>-----</td>
<td>-------</td>
<td></td>
</tr>
<tr>
<td>( V_{OH} ) High-level output voltage (@ ( I_{OH} = -4.0 \text{ ma} ) ( V_{CC} ) min) Commercial</td>
<td>3.86</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>( V_{OL} ) Low-level output voltage (@ ( I_{OL} = 4.0 \text{ ma} ) ( V_{CC} ) min)</td>
<td>0.32</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>( V_{OH} ) High-level output voltage (@ ( I_{OH} = -4.0 \text{ ma} ) ( V_{CC} ) min) Industrial</td>
<td>3.76</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>( V_{OL} ) Low-level output voltage (@ ( I_{OL} = 4.0 \text{ ma} ) ( V_{CC} ))</td>
<td>0.37</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>( V_{OH} ) High-level output voltage (@ ( I_{OH} = -4.0 \text{ ma} ) ( V_{CC} ) min) Military</td>
<td>3.7</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>( V_{OL} ) Low-level output voltage (@ ( I_{OL} = 4.0 \text{ ma} ) ( V_{CC} ))</td>
<td>0.4</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>( I_{CCPD} ) Power-down supply current (( V_{CC} = 5.0 \text{ V} ) @ 70°C)</td>
<td>500</td>
<td></td>
<td>( \mu \text{A} )</td>
<td></td>
</tr>
<tr>
<td>( I_{CCO} ) Quiescent LCA supply current in addition to ( I_{CCPD} )</td>
<td>500</td>
<td></td>
<td>( \mu \text{A} )</td>
<td></td>
</tr>
<tr>
<td>CMOS chip thresholds</td>
<td>500</td>
<td></td>
<td>( \mu \text{A} )</td>
<td></td>
</tr>
<tr>
<td>TTL chip thresholds</td>
<td>10</td>
<td></td>
<td>mA</td>
<td></td>
</tr>
<tr>
<td>( i_{IL} ) Leakage Current Commercial/Industrial Temperature</td>
<td>-10</td>
<td>+10</td>
<td>( \mu \text{A} )</td>
<td></td>
</tr>
<tr>
<td>Leakage Current Military -55°C to 125°C</td>
<td>-20</td>
<td>+20</td>
<td>( \mu \text{A} )</td>
<td></td>
</tr>
<tr>
<td>( C_{IN} ) Input capacitance (sample tested)</td>
<td>10</td>
<td></td>
<td>pF</td>
<td></td>
</tr>
<tr>
<td>( I_{RIN} ) Pad pull-up (when selected) @ ( V_{IN} = 0\text{V} ) (sample tested)</td>
<td>0.02</td>
<td>0.17</td>
<td>mA</td>
<td></td>
</tr>
<tr>
<td>( I_{RLL} ) Horizontal long line pull-up (when selected) @ logic LOW</td>
<td>0.4</td>
<td>3.4</td>
<td>mA</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. Based on a 3020, \( I_{CCPD} \) ratio for 3090, 5.0
2. With no output current loads, no active input or long line pull-up resistors, all package pins at \( V_{CC} \) or GND, and the LCA configured with a MAKEBITS "tie" option. See LCA power chart for additional activity dependent operating component.
CLB SWITCHING CHARACTERISTIC GUIDELINES

CLB OUTPUT (X,Y) (COMBINATORIAL)

CLB INPUT (A,B,C,D,E)

CLB CLOCK

CLB INPUT (DIRECT IN)

CLB INPUT (ENABLE CLOCK)

CLB OUTPUT (FLIP-FLOP)

CLB INPUT (RESET DIRECT)

CLB OUTPUT (FLIP-FLOP)
CLB SWITCHING CHARACTERISTIC GUIDELINES (Continued)

Testing of the switching characteristic guidelines is modeled after testing specified by MIL-M-38510/605. Devices are 100% functionally tested. Benchmark timing patterns are used to provide correlation to the switching characteristic guideline values. Actual worst-case timing is provided by the XACT Timing calculator or Simulation modeling.

### CLB Logic Input

<table>
<thead>
<tr>
<th>Speed Grade</th>
<th>Description</th>
<th>Symbol</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLB Logic input</td>
<td>Combinatorial</td>
<td>1 Tilo</td>
<td>14</td>
<td>9</td>
<td>ns</td>
</tr>
<tr>
<td>Reset direct</td>
<td>CLB output</td>
<td>9 Trio</td>
<td>15</td>
<td>10</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Reset Direct width*</td>
<td>13 TRPW</td>
<td>10</td>
<td>7</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Master Rest pin to CLB out</td>
<td>TMRO</td>
<td>35</td>
<td>25</td>
<td>ns</td>
</tr>
</tbody>
</table>

#### CLB K Clock input

<table>
<thead>
<tr>
<th>Speed Grade</th>
<th>Description</th>
<th>Symbol</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLB K Clock input</td>
<td>To CLB output</td>
<td>8 TCKO</td>
<td>12</td>
<td>8</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Additional for Q returning</td>
<td>TQLO</td>
<td>11</td>
<td>7</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>through F or G to CLB out</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Logic-input setup</td>
<td>TCK</td>
<td>12</td>
<td>8</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Logic-input hold</td>
<td>TCKI</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Data In setup</td>
<td>TDICK</td>
<td>8</td>
<td>5</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Data In hold</td>
<td>TCKDI</td>
<td>6</td>
<td>4</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Enable Clock setup</td>
<td>TECK</td>
<td>10</td>
<td>7</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Enable Clock hold</td>
<td>TCKEO</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Clock (high)*</td>
<td>TGH</td>
<td>9</td>
<td>7</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Clock (low)*</td>
<td>TCL</td>
<td>9</td>
<td>7</td>
<td>ns</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Speed Grade</th>
<th>Description</th>
<th>Symbol</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Flip-flop Toggle rate</td>
<td>Q through F/G to flip-flop</td>
<td>FCLK</td>
<td>50</td>
<td>70</td>
<td>MHz</td>
</tr>
</tbody>
</table>

* These timing limits are based on calculations.

The speed of block input is a function of interconnect.

### BUFFER (Internal) SWITCHING CHARACTERISTIC GUIDELINES

<table>
<thead>
<tr>
<th>Speed Grade</th>
<th>Description</th>
<th>Symbol</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Clock Buffer**</td>
<td>GCLK, ACLK</td>
<td>GCLK</td>
<td>9</td>
<td>6</td>
<td>ns</td>
</tr>
<tr>
<td>TBUF**</td>
<td>Data to Output</td>
<td>8</td>
<td>5</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td>(Long line buffer)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Three-state to Output</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Single pull-up resistor</td>
<td>34</td>
<td>22</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Pair of pull-up resistors</td>
<td>17</td>
<td>11</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>Bi-directional</td>
<td>BIDI</td>
<td></td>
<td>6</td>
<td>4</td>
<td>ns</td>
</tr>
</tbody>
</table>

** Timing is based on the 3020, for other devices see XACT timing calculator.
Testing of the switching characteristic guidelines is modeled after testing specified by MIL-M-38510/605. Devices are 100% functionally tested. Benchmark timing patterns are used to provide correlation to the switching characteristic guideline values. Actual worst-case timing is provided by the XACT Timing calculator or Simulation modeling.

<table>
<thead>
<tr>
<th>Speed Grade</th>
<th>Description</th>
<th>Symbol</th>
<th>Min</th>
<th>Max</th>
<th>-50</th>
<th>-70</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pad (package pin)</td>
<td>To input (direct CLKIN)</td>
<td>TPDC 3</td>
<td>5</td>
<td>10</td>
<td>3</td>
<td>7</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>To input (direct)</td>
<td>TPID 3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>I/O Clock</td>
<td>To I/O RI input (FF)</td>
<td>TRRI 4</td>
<td>10</td>
<td>18</td>
<td>7</td>
<td>13</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>I/O pad-input setup</td>
<td>TPICK 1</td>
<td>30</td>
<td>15</td>
<td>20</td>
<td>10</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>I/O pad-input hold</td>
<td>TIKPI 2</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>To I/O pad (fast)</td>
<td>TOKPC 7</td>
<td>15</td>
<td>10</td>
<td>18</td>
<td>13</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>I/O pad output setup</td>
<td>TOCK 5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>I/O pad output hold</td>
<td>TOKO 6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Clock (high)</td>
<td>TOH 11</td>
<td>9</td>
<td>0</td>
<td>25</td>
<td>8</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>Clock (low)</td>
<td>TOIOL 12</td>
<td>9</td>
<td>0</td>
<td>7</td>
<td>7</td>
<td>ns</td>
</tr>
<tr>
<td>Output</td>
<td>To pad (enabled fast)</td>
<td>TOPF 10</td>
<td>14</td>
<td>12</td>
<td>14</td>
<td>10</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>To pad (enabled slow)</td>
<td>TOPS 10</td>
<td>33</td>
<td>20</td>
<td>33</td>
<td>25</td>
<td>ns</td>
</tr>
<tr>
<td>Three-state</td>
<td>To pad begin hi-Z (fast)</td>
<td>TTSHZ 9</td>
<td>12</td>
<td>8</td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td>To pad valid (fast)</td>
<td>TTSSON 8</td>
<td>20</td>
<td>14</td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>Master Reset</td>
<td>To input RI</td>
<td>TRRI 13</td>
<td>45</td>
<td>30</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>To output (FF)</td>
<td>TRPO 15</td>
<td>55</td>
<td>37</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. Timing is measured at pin threshold, with 50 pF external capacitive loads (incl. test fixture). Typical fast mode output rise/fall times are 5 ns and will increase approximately 2%/pF. A maximum total external capacitive load for simultaneous fast mode switching in the same direction is 500 pF per power/ground pin pair.

2. Voltage levels of unused (bonded and unbonded) pads must be valid logic levels. Each can be configured with the internal pull-up resistor or alternatively configured as a driven output or driven from an external source.
GENERAL LCA SWITCHING CHARACTERISTICS

**Notes:**
1. VCC must rise from 2.0 Volts to VCC minimum in less than 10 ms for master modes.
2. RESET timing relative to valid mode lines (M0, M1, M2) is relevant when ~RESET is used to delay configuration.
3. ~PWRDWN transitions must occur during operational VCC levels.
### Master Serial Mode Switching Characteristics Guidelines

**Diagram:**
- CCLK (OUTPUT)
- SERIAL DATA IN
- SERIAL DOUT (OUTPUT)

### Table:

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-50</th>
<th>-70</th>
</tr>
</thead>
<tbody>
<tr>
<td>Data In setup</td>
<td>T_DSKC</td>
<td>60</td>
<td>60</td>
</tr>
<tr>
<td>Data In-Hold</td>
<td>T_CKDS</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Units: ns

**Notes:**
1. At power-up, VCC must rise from 2.0 V to VCC min. in less than 10 ms, otherwise delay configuration using ~RESET until VCC is valid.
2. Configuration can be controlled by holding ~RESET low with or until after the ~INIT of all daisy-chain slave mode devices is HIGH.
3. Master serial mode timing is based on slave mode testing.
MASTER PARALLEL MODE PROGRAMMING SWITCHING CHARACTERISTIC GUIDELINES

Testing of the switching characteristic guidelines is modeled after testing specified by MIL-M-38510/605. Devices are 100% functionally tested. Benchmark timing patterns are used to provide correlation to the switching characteristic guideline values. Actual worst-case timing is provided by the XACT Timing calculator or Simulation modeling.

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-50</th>
<th>-70</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>RCLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>To address valid</td>
<td>T(_{\text{RAC}})</td>
<td>0</td>
<td>200</td>
<td>ns</td>
</tr>
<tr>
<td>To data setup</td>
<td>T(_{\text{DRC}})</td>
<td>60</td>
<td>60</td>
<td>ns</td>
</tr>
<tr>
<td>To data hold</td>
<td>T(_{\text{RCD}})</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>RCLK high</td>
<td>T(_{\text{RCH}})</td>
<td>600</td>
<td>600</td>
<td>ns</td>
</tr>
<tr>
<td>RCLK low</td>
<td>T(_{\text{RCL}})</td>
<td>4.0</td>
<td>4.0</td>
<td>(\mu)s</td>
</tr>
</tbody>
</table>

Notes:
1. At power-up, \(V_{\text{CC}}\) must rise from 2.0 V to \(V_{\text{CC min}}\) in less than 10 ms, otherwise delay configuration using ~RESET until \(V_{\text{CC}}\) is valid.
2. Configuration can be controlled by holding ~RESET low with or until after the ~INIT of all daisy-chain slave mode devices is HIGH.
PERIPHERAL MODE PROGRAMMING SWITCHING CHARACTERISTICS

**CS1/CS0**

**CS2**

**WRT**

**D0-D7**

**CCLK**

**RDY/BUSY**

**DOUT**

---

**Table**

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-50</th>
<th>-70</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>-Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>WRT Low</td>
<td>1</td>
<td>TCA</td>
<td>0.5</td>
<td>0.5</td>
</tr>
<tr>
<td>DIN setup</td>
<td>2</td>
<td>TDC</td>
<td>60</td>
<td>60</td>
</tr>
<tr>
<td>DIN hold</td>
<td>3</td>
<td>TCD</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Ready/Busy</td>
<td>4</td>
<td>TWRB</td>
<td>60</td>
<td>60</td>
</tr>
<tr>
<td>RDY</td>
<td>5</td>
<td>TRBWT</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**Notes:**

1. Configuration must be delayed until the ~INIT of all LCAs is HIGH.
2. Time from end of WRT to CCLK cycle for the new byte of data depends on completion of previous byte processing and the phase of the internal timing generator for CCLK.
3. CCLK and DOUT timing is tested in slave mode.
SLAVE MODE PROGRAMMING SWITCHING CHARACTERISTICS

DIN

BIT N

BIT N + 1

1 T_{DCD}

2 T_{CCD}

CCLK

3 T_{CCH}

4 T_{CCO}

DOUT

(OUTPUT)

BIT N - 1

BIT N

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-50</th>
<th>-70</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCLK</td>
<td></td>
<td>Min</td>
<td>Max</td>
<td></td>
</tr>
<tr>
<td>To DOUT</td>
<td>3 T_{CCO}</td>
<td>100</td>
<td>100</td>
<td>ns</td>
</tr>
<tr>
<td>DIN setup</td>
<td>1 T_{DCD}</td>
<td>60</td>
<td>60</td>
<td>ns</td>
</tr>
<tr>
<td>DIN hold</td>
<td>2 T_{CCD}</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>High time</td>
<td>4 T_{CCH}</td>
<td>0.5</td>
<td>0.5</td>
<td>µs</td>
</tr>
<tr>
<td>Low time</td>
<td>5 T_{CCO}</td>
<td>5.0</td>
<td>5.0</td>
<td>µs</td>
</tr>
<tr>
<td>Frequency</td>
<td>F_{CC}</td>
<td>1</td>
<td>1</td>
<td>MHz</td>
</tr>
</tbody>
</table>

Note: Configuration must be delayed until the INIT of all LCAs is HIGH.
PROGRAM READBACK SWITCHING CHARACTERISTICS

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-50 Min</th>
<th>-50 Max</th>
<th>-70 Min</th>
<th>-70 Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>RTRIG</td>
<td>1 TRTH</td>
<td>250</td>
<td>250</td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>CCLK (1)</td>
<td>2 TRTCC</td>
<td>10</td>
<td>10</td>
<td>100</td>
<td>100</td>
<td>µs</td>
</tr>
<tr>
<td>RDATA (OUTPUT)</td>
<td>3 TCCRD</td>
<td>100</td>
<td>100</td>
<td></td>
<td></td>
<td>ns</td>
</tr>
</tbody>
</table>

Notes:
1. CCLK and DOUT timing are the same as for slave mode.
2. RETRIG (M0 positive transition) shall not be done until after one clock following active I/O pins.
3. Readback should not be initiated until configuration is complete.
The following sockets, with matching hole patterns, are available for PLCC devices.

<table>
<thead>
<tr>
<th>Description</th>
<th>Vendor</th>
<th>Part Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>PCB solder tail, tin plate</td>
<td>AMP</td>
<td>821574-1</td>
</tr>
<tr>
<td>Surface mount, tin plate</td>
<td>AMP</td>
<td>821542-1</td>
</tr>
<tr>
<td>PCB solder tail, tin plate*</td>
<td>Burndy</td>
<td>QILE68P-410T</td>
</tr>
<tr>
<td>PCB solder tail, tin plate*</td>
<td>Midland-Ross</td>
<td>709-2000-068-4-1-1</td>
</tr>
<tr>
<td>PCB solder tail, tin plate*</td>
<td>Methode</td>
<td>213-068-001</td>
</tr>
<tr>
<td>Surface mount, tin plate</td>
<td>Methode</td>
<td>213-068-002</td>
</tr>
</tbody>
</table>

*Sockets will plug into pin-grid array wire-wrap sockets for breadboard use. However, the physical translation of pins in a PLCC socket does not result in electrical equivalence to the pin locations of a PGA package.
Pin No. 1 Identifier

Seating Plane

PIN SPACING
.050 TYPICAL

LEAD CO-PANARITY ± 0.002 IN

ALL OTHER DIMENSIONS ARE
IN INCHES ± 0.005

68-Pin PLCC Package

$\Theta_{JA} = 35-40^\circ C/W$
DIMENSIONS ARE IN INCHES

\[ \Theta_{JA} = 35-40^\circ \text{C/W} \]

**NOTE:** INDEX PIN MAY OR MAY NOT BE ELECTRICALLY CONNECTED TO PIN C2

84-Pin PGA Package
84-Pin PLCC Package

\( \Theta_{JA} = 35-40^\circ C/W \)

PIN SPACING

.050 TYPICAL
WE10 METALIC HEAT SINK ELECTRICALLY CONNECTED TO VCC

\[ \Theta_{JA} = 25-30 \, ^\circ\text{C/W} \]
\[ \Theta_{JC} = 0.5-1.0 \, ^\circ\text{C/W} \]

WE10 METALIC HEAT SINK ELECTRICALLY CONNECTED TO VCC

PIN KOVAR

.006 R. TYP.

.180 ±.002 DIA.

.016 REF.

.050 DIA.

.005 REF.

.060 ±.006

175-Pin PGA Package
LCA-MDS21 XACT Design Editor System

Features

- Runs on an IBM® PC-XT™ or compatible computer
- Complete basic system for designing with Logic Cell Arrays
- Interactive graphical design editor
- Simplified definition, placement and interconnection capability for logic design and implementation
- Macro library of 113 standard logic family equivalents
- Utility for user-defined macros
- Boolean equation or Karnaugh map alternatives to specify logic functions
- Point-to-point timing calculations for critical path analysis
- Automatic design consistency checking for connectivity and design violations
- Documentation support with hardcopy output of logic and physical configuration information
- Download cable to transfer configuration programs from personal computer to LCA in target system
- Compatible hardware and software options to enhance design productivity
- File formatter for EPROM programmer

General

The XACT Design Editor provides users with a complete design and development system for specification and implementation of designs using Monolithic Memories' Logic Cell Arrays. Functional definition of Configurable Logic Blocks (CLBs), Input/Output Blocks (IOBs) and interconnection is performed with a menu-driven interactive graphics editor. An automatic router greatly reduces the effort to interconnect logic.

Designs are captured with a graphics-based design editor using either a mouse for menu-driven entry, or a keyboard for command-driven entry. Functions are specified by CLB and IOB definitions plus their interconnections. The macro library and user-defined macros enable the user to easily implement complex functions.

The check for logic connectivity and design rule violation is easily performed. All unused internal nodes are automatically configured to minimize power dissipation.

Interactive point-to-point timing delay calculation is provided for timing analysis and critical path determination. This ability enables the user to quickly identify and correct timing problems while the design is in progress.

Automatic generation of similar input netlist files with timing parameters simplifies the use of P-SILOS for logic and timing simulation.

The XACT Design Editor includes hardcopy generation to document a design and automatically track design changes. Logic Cell Array configuration programs can be automatically translated into standard EPROM programming bit pattern formats.

A download cable included with XACT is useful for transferring configuration programs serially from the PC workstation to a Logic Cell Array installed in a system. During product development and debug this capability can be used to save the time required to write a modified configuration program into an EPROM.

Monolithic Memories provides ongoing support for XACT users. For the first year, software updates are included. After that the user may purchase the LCA-MSC21 Annual Support Agreement to continue to receive the latest software releases. XACT users also receive Monolithic Memories' technical information, which includes information about Logic Cell Arrays and PAL® devices, as well as software updates and application notes for designers. In addition, Monolithic Memories provides comprehensive field and factory support.

System Requirements

Minimum System Configuration

IBM PC-XT, PC-AT or compatible computer with:

- MS-DOS™ 2.1 or higher
- 1M Bytes RAM
- 1 Diskette Drive
- 10-MB Hard Disk
- IBM compatible Color Graphic Adapter and Display
- 1 Serial Interface Port
- 1 Parallel Interface Port
- Mouse System™, Microsoft® or compatible mouse

Design Editor with Routed Design
**XACT Macro Library**

### General CLBs

- **GADD**  Adder  1
- **GCOMP** Compare  1
- **GEQGT** Equal or Greater  1
- **GMAJ** Majority  1
- **GMux** 2-to-1 Mux  1
- **GPAR** Parity  1
- **GXOR** Exclusive-OR  1
- **GXOR2** Dual Exclusive-OR  1
- **GXTL** Crystal Oscillator  0 + 2 IOB
- **GOSC** Low Frequency  1 + 2 IOB
  Resistor-Capacitor Oscillator

### Pads IOBs

- **PIN**  Input Pad  1
- **PINQ**  Input Pad with Storage  1
- **PIO**  Input/Output Pad  1
- **PIOQ**  Input/Output Pad with Input Storage  1
- **PIOC**  Input/Output Pad with 'Open Collector'  1
- **PIOQC**  Input/Output Pad with Input Storage, 'Open Collector'  1
- **POUT**  Output Pad  1
- **POUTC**  Output Pad with 'Open Collector'  1
- **POUTZ**  Output Pad with 3-State Control  1
- **PREG**  Output Pad with Input Storage  1

### Latches CLBs

- **LD**  Data Latch  1
- **LC-rd**  Data Latch with ResetDir  1
- **LC-sd**  Data Latch with SetDir  1
- **LD-rcd**  Data Latch with SetDir, ResetDir  1
- **LDM**  Data Latch with 2-Input Data Mux  1
- **LDM-rd**  Data Latch with 2-Input Data Mux, ResetDir  1
- **LDM-sd**  Data Latch with 2-Input Data Mux, SetDir  1

### Flip-Flops CLBs

- **FD**  D Flip-Flop  1
- **FDR**  D Flip-Flop with Reset  1
- **FDS**  D Flip-Flop with Set  1
- **FD-rd**  D Flip-Flop with ResetDir  1
- **FD-sd**  D Flip-Flop with SetDir  1
- **FD-srd**  D Flip-Flop with SetDir, ResetDir  1
- **FDC**  D Flip-Flop with ClkEna  1
- **FDCR**  D Flip-Flop with ClkEna, Reset  1
- **FDCS**  D Flip-Flop with ClkEna, Set  1
- **FDM**  D Flip-Flop 2-Input Data Mux  1
- **FDMR**  D Flip-Flop 2-Input Data Mux, Reset  1
- **FDMS**  D Flip-Flop 2-Input Data Mux, Set  1
- **FDM-rcd**  D Flip-Flop 2-Input Data Mux, ResetDir  1
- **FDM-sd**  D Flip-Flop 2-Input Data Mux, SetDir  1
- **FSR**  Set-Reset Flip-Flop with Set Dominate  1
- **FRS**  Set-Reset Flip-Flop with Reset Dominate  1
- **FJK**  J-K Flip Flop  1
- **FJKS**  J-K Flip Flop with Synchronous Set  1
- **FJK-rd**  J-K (Set-Reset) Flip Flop with ResetDir  1
- **FJK-sd**  J-K (Set-Reset) Flip Flop with SetDir  1
- **FJK-srd**  J-K (Set-Reset) Flip Flop with SetDir, ResetDir  1
- **FT0**  Self Toggle Flip-Flop  1
- **FTDR**  Self Toggle Flip-Flop with Reset  1
- **FT**  Toggle Flip-Flop  1
- **FTP**  Toggle Flip-Flop with ParEna  1
- **FTP-rd**  Toggle Flip-Flop with ParEna, ResetDir  1
- **FTS**  Toggle Flip-Flop with Set  1
- **FT2**  2-Input Toggle Flip-Flop  1
- **FT2R**  2-Input Toggle Flip-Flop with Reset  1

### Decoders CLBs

- **D2-4**  1-of-4 Decoder  2
- **D2-4E**  1-of-4 Decoder, with Ena  2
- **74-139**  1-of-4 Single Decoder with Low Output, Ena  4
- **D3-8**  1-of-8 Decoder  5
- **D3-8E**  1-of-8 Decoder with Ena  6
- **74-138**  1-of-8 Decoder with Enables, Low Output  7
- **74-42**  1-of-10 Decoder with Low Output  8

### Multiplexers CLBs

- **M3-1**  3-to-1 Mux  2
- **M3-1E**  3-to-1 Mux with Ena  2
- **M4-1**  4-to-1 Mux  3
- **M4-1E**  4-to-1 Mux with Ena  3
- **74-352**  4-to-1 Mux with Low Output, Ena  3
- **M8-1**  8-to-1 Mux  7
- **M8-1E**  8-to-1 Mux with Ena  7
- **74-151**  8-to-1 Mux with Ena  7
  Complementary Outputs
- **74-152**  8-to-1 Mux with Low Output  7
## XACT Macro Library

### Registers

<table>
<thead>
<tr>
<th>Data Registers</th>
<th>CLBs</th>
</tr>
</thead>
<tbody>
<tr>
<td>RD4 4-Bit Data Register</td>
<td>4</td>
</tr>
<tr>
<td>RD8 8-Bit Data Register</td>
<td>8</td>
</tr>
<tr>
<td>REBCR 8-Bit Data Register with ClkEna, Reset</td>
<td>8</td>
</tr>
</tbody>
</table>

### Serial to Parallel

| RS4 4-Bit Shift Register  | 4    |
| 74-195 4-Bit Serial to Parallel | 5   |
| Shift Register with ParEna, Reset | 5 |
| 74-194 4-Bit Bidirectional Shift Register with ClkEna, ParEna, ResetDir | 12 |
| RS8 8-Bit Shift Register  | 8    |
| RSBCR 8-Bit Shift Register with ClkEna, Reset | 8 |
| RSBR 8-Bit Shift Register with Reset | 8 |
| 74-164 8-Bit Serial to Parallel Shift Register with ResetDir | 8 |

### Counters

#### Modulo 2

| C2BCR 1-Bit Binary Counters with ClkEna, Reset | 1    |
| C2BC-rd 1-Bit Binary Counters with ClkEna, ResetDir | 1 |
| C2BP 1-Bit Binary Counters with ParEna | 1 |
| C2BR 1-Bit Binary Counters with Reset | 1 |
| C2BR-rd 1-Bit Binary Counters with ResetDir | 1 |

#### Modulo 4

| C4BCP 2-Bit Binary Counters with ClkEna, ParEna | 3    |
| C4BCR 2-Bit Binary Counters with ClkEna, Reset | 2    |
| C4BC-rd 2-Bit Binary Counters with ClkEna, ResetDir | 2 |
| C4JCR 2-Bit Johnson Counters with ClkEna, Reset | 2 |

#### Modulo 6

| C6JCR 3-Bit Johnson Counter with ClkEna, Reset | 3 |

#### Modulo 8

| C8BCP 3-Bit Binary Counters with ClkEna, ParEna | 5 |
| C8BCR 3-Bit Binary Counters with ClkEna, Reset | 4 |
| C8BC-rd 3-Bit Binary Counters with ClkEna, ResetDir | 4 |
| C8JCR 3-Bit Johnson Counters with ClkEna, Reset | 4 |

#### Modulo 10

| C10BC-rd 4-Bit BCD Counter with ClkEna, ResetDir | 4 |
| C10BCP-rd 4-Bit BCD Counter with ClkEna, ParEna, ResetDir | 7 |
| 74-160 4-Bit BCD Counter with ClkEna, ParEna, ResetDir | 8 |
| C10BP-rd 4-Bit BCD Counter with ParEna, ResetDir | 6 |
| C10JCR 5-Bit Johnson Counter with ClkEna, Reset | 5 |

#### Modulo 12

| C12JCR 6-Bit Johnson Counter with ClkEna, Reset | 6 |

#### Modulo 16

| C16BA-rd 4-Bit Binary Ripple Counter with ResetDir | 4 |
| C16BC-rd 4-Bit Binary Counter with ClkEna, ResetDir | 4 |
| C16BCPR 4-Bit Binary Counter with ClkEna, ParEna, Reset | 10 |
| C16BCP-rd 4-Bit Binary Counter with ClkEna, ParEna, ResetDir | 6 |
| 74-161 4-Bit Binary Counter with ResetDir | 8 |
| C16BP-rd 4-Bit Binary Counter with ParEna, ResetDir | 5 |
| C16BUD-rd 4-Bit Binary Up-Down Counter with ParEna, ResetDir | 8 |
| C16JCR 8-Bit Johnson Counter with ClkEna, Reset | 8 |

#### Modulo 256

| C256FC-rd 8-Bit Modulo 256 Feedback Shift Register with ClkEna, ResetDir | 9 |

---

4-118
LCA-MDS22 P-SILOS Simulator

Features
- Event-driven logic and timing simulator
- Logic network input automatically generated by XACT Design Editor
- Control and observation of any physical circuit node
- Multiple file input for vectors and commands
- Interactive or batch mode operation
- Output available in printed or tabular formats
- Runs on an IBM PC-XT, PC-AT or compatible personal computer

General
P-SILOS is a powerful PC-based simulator that provides event-driven logic and timing simulation of Logic Cell Array designs. Simulation is particularly useful for testing logic or logic segments as well as for verifying critical timing over worst case power supply, temperature and process conditions.

Simulation is useful in several stages of the design cycle. After design entry, simulation may be used to debug logic in an unplaced and unrouted design. This saves design time because logic errors can be detected and corrected prior to final placement and routing. After a circuit has been placed, routed, and then fully debugged using in-circuit emulation, worst case timing may be verified. This enables the user to select the correct Logic Cell Array speed for a particular application.

Network inputs for Logic Cell Array designs are automatically created by the Simgen utility in the XACT system. The network includes logic and routing delay parameters and setup and hold times based upon the selected speed grade operating under worst case conditions. Simulation stimuli are created with a set of clock statements or with an input pattern for either pad inputs or internal nodes. Simulation results are available in tabular, plotted, and graphic formats. This flexibility makes debugging easy for both the circuit function and timing.

System Requirements
Minimum System Configuration
IBM PC-XT, PC-AT or compatible computer with:
- MS-DOS 2.1 or higher
- 640 K Bytes RAM
- 1 Diskette Drive
- 10-MB Hard Disk
- 1 Parallel Interface Port

Refer to the MDS21 XACT Design Editor Product Datasheet for additional equipment required for systems which will also run the XACT Design Editor.

P-SILOS Waveform Output
LCA-MDS23

Automatic Design Implementation

Distinctive Characteristics

- Automatic elimination of disabled and unused logic
- Automatic partitioning of the schematic into LCA resources.
- Automatic placement and routing of logic to minimize design cycle time
- User control over placement of logic blocks
- User specification of critical paths
- May be used in conjunction with schematic capture or with the XACT Design Editor
- Runs on an IBM PC/AT or compatible personal computer

General Description

The automatic logic reduction and partitioning software included with the Automatic Design Implementation package eliminates unused and redundant logic, then partitions the schematic into LCA physical resources, logic and I/O blocks. Automated reduction and partitioning allows designers to immediately determine the programmable gate array size required, during design definition and entry.

The Automatic Design Implementation package enhances the productivity of designers using Programmable Gate Arrays by reducing design placement and routing time, whether the design logic is entered from a schematic capture package or from the XACT Design Editor.

Designs that are developed incrementally can also take advantage of automatic placement and routing. Partial LCA layouts can be locked in place while additions to the design are automatically placed and routed, or the design can be completely rearranged to yield a new placement.

The automatic placement and routing program is extremely flexible. Through placement directives, the user can control the placement process to achieve the best placement for a particular design. Routing resources can be specified to minimize clock skews and signal delays for critical paths. The result is faster product development.
LCA-MDS24, LCA-MDS26, LCA-MDS27
XACTOR In-Circuit Emulator

Features
- Real-time in-circuit emulation in user's target system
- Concurrent emulation of up to four devices
- Readback and display of Logic Cell Array internal storage element states
- Device status display with automatic update of asynchronous events
- Control and I/O pin isolation from target system
- Support for daisy chain programming of up to seven devices in a daisy chain
- On-chip crystal oscillator support during emulation
- Support for multiple device and package types
- Runs on an IBM PC-XT, PC-AT or compatible personal computer

General
The XACTOR real-time in-circuit emulator provides interactive target-system emulation of up to four Logic Cell Arrays from the host PC system. In-circuit emulation provides a powerful productivity enhancement to simulation, providing capabilities to verify functionality in the target system at full speed with all other circuits and system software.

The emulation system is composed of a microcomputer-based controller (LCA-MDS24), and from one to four universal emulation pods (LCA-MDS26), each with a package-specific emulation header (LCA-MDS27). One universal emulation pod is included with the system. The controller is connected to the host PC through a serial port and provides local storage of configuration programs, control of individual device configurations and control of the isolation of the pod device(s) from the target system. The user can set the state and isolation for each of the control signals to provide debugging of target hardware. Four general I/O pins are available to provide test points which may also be isolated from the target system.

Target Logic Cell Arrays can be programmed individually or in a daisy chain. Daisy chains of up to seven devices may be supported from any of the four pods. Individual device isolation and configuration is controlled with mouse or keyboard commands and may be supplemented with user-defined setup files for easy system debugging.

Readback of device configuration may be performed on command for verification of the configuration process and interrogation of the internal states. The state of all internal storage elements is displayed after readback has been performed. Status displays showing the state of all isolation switches and control signal states are provided. The status display includes automatic reporting of asynchronous status changes in the target system.

Universal In-Circuit Emulator Pod (LCA-MDS26)
Additional pods may be connected to the XACTOR in-circuit emulator controller, up to a maximum of four pods per control-
LCA-MDS31/LCA-MDS33/LCA-MDS34/LCA-MDS35

Schematic Design Entry Interface for FutureNet, Daisy, Mentor, OrCAD

Distinctive Characteristics

- Use of familiar design entry methodology through the choice of schematic entry package.
- Macro library of over 100 TTL and standard logic family equivalents.
- User-control of flagging critical paths for later use of Automatic Design Implementation (LCA-MDS23).
- Output compatibility with other parts of the PGA Development System software.

General Description

The Schematic Design Entry Interfaces are software packages specifically designed to enable users of FutureNet, Daisy, Mentor and OrCAD workstations to create Logic Cell Array designs using the design entry editors supplied with their schematic capture software.

The user creates a design file on the workstation with the LCA symbol library. A conversion routine automatically eliminates unused and disabled logic and converts the design file into a format that can be read by other PGA Development System tools.

Product Selector Guide

<table>
<thead>
<tr>
<th>Product Number</th>
<th>Product Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCA-MDS31</td>
<td>FutureNet DASH Schematic Entry Interface and LCA Library</td>
</tr>
<tr>
<td>LCA-MDS33</td>
<td>Daisy Schematic Entry Interface and LCA Library</td>
</tr>
<tr>
<td>LCA-MDS34</td>
<td>Mentor Schematic Entry Interface and LCA Library</td>
</tr>
<tr>
<td>LCA-MDS35</td>
<td>OrCAD Schematic Entry Interface and LCA Library</td>
</tr>
</tbody>
</table>

Publication # Rev. Amendment
10849 A /0
Issue date: June 1988

4-122
PGA Design Cycle

The PGA Development System tools include software for all phases of the PGA design cycle. The diagram below indicates the design tasks needed to complete a PGA design and the corresponding software products used to complete the tasks.

<table>
<thead>
<tr>
<th>DESIGN TASK</th>
<th>SOFTWARE PACKAGE</th>
</tr>
</thead>
<tbody>
<tr>
<td>DESIGN ENTRY</td>
<td>OrCAD (LCA-MDS-35), MENTOR (LCA-MDS34), DAISY (LCA-MDS33), FUTURENET (LCA-MDS31), SCHEMATIC INTERFACES</td>
</tr>
<tr>
<td>LOGIC VERIFICATION (optional)</td>
<td>PC-SILOS (LCA-MDS22)</td>
</tr>
<tr>
<td>AUTOMATIC PARTITION, PLACE AND ROUTE</td>
<td>AUTOMATIC DESIGN IMPLEMENTATION (LCA-MDS23)</td>
</tr>
<tr>
<td>DESIGN OPTIMIZATION</td>
<td>XACT DESIGN EDITOR, DELAY CALCULATOR (LCA-MDS21)</td>
</tr>
<tr>
<td>TIMING VERIFICATION (optional)</td>
<td>PC-SILOS (LCA-MDS22)</td>
</tr>
<tr>
<td>IN-CIRCUIT DESIGN VERIFICATION</td>
<td>XACT PROM FORMATTER, DOWNLOAD CABLE (LCA-MDS21), XACTOR IN-CIRCUIT EMULATOR (LCA-MDS28)</td>
</tr>
</tbody>
</table>
LCA-MDS151/LCA-MDS152
PGA Development System/PGA Design Entry System

Distinctive Characteristics

- Complete systems for entry and implementation of Programmable Gate Array designs.
- Includes OrCAD Schematic Design Tools and Schematic Design Interface (LCA-MDS135) and Automatic Design Implementation (LCA-MDS23). LCA-MDS151 also includes XACT PGA Design Editor (LCA-MDS21).
- Schematic editor provides hierarchical PGA design capability.
- LCA macro library of over 100 TTL and standard family equivalents.
- Automatic logic reduction and partitioning removes unused and disabled logic.
- Automatic placement and routing minimizes design cycle time.
- PGA Design Editor provides interactive physical editing, timing calculator and design consistency checking.
- Download cable transfers configuration bitstreams directly from the PC to the PGA during design debugging.
- Runs on an IBM PC-AT or compatible computer.

General Description

The PGA Development System offers complete capabilities for schematic entry and implementation of Programmable Gate Array design. Packaged together are the OrCAD SDT III Schematic Design Entry software, Automatic Design Implementation and the PGA Design Editor. The general purpose OrCAD schematic editor provides powerful design entry and documentation capabilities. An extensive macro library of TTL and standard logic equivalents is included. Designers can implement their own macro functions as desired. Designs can be entered in a true hierarchical structure to manage the complexity of large designs. In addition, designers can flag critical timing paths to ensure critical signals are routed with minimum delay.

The Automatic Design Implementation software eliminates unused and redundant logic, then partitions the schematic into LCA resources, logic and I/O blocks.

Automated reduction and partitioning allows designers to immediately determine the programmable gate array size required, during design definition and entry. Automatic placement and routing can be used to arrange logic blocks and calculate routes.

Designers can interactively document, design-check and edit the resulting physical design with the graphics-based XACT Design Editor. A built-in timing calculator permits point-to-point timing calculations for critical path analysis.

When a design is ready for debugging or production, the design is compiled in to an LCA configuration program using the XACT Design Editor. During design debug, designers can save time by using the download cable to transfer the configuration program from the PC directly into an LCA under development in a system.

Product Selector Guide

<table>
<thead>
<tr>
<th>PRODUCT NUMBER</th>
<th>PRODUCT NAME</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCA-MDS151</td>
<td>Programmable Gate Array Development System</td>
</tr>
<tr>
<td></td>
<td>(Includes LCA-MDS21, LCA-MDS23, LCA-MDS135)</td>
</tr>
<tr>
<td>LCA-MDS152</td>
<td>Programmable Gate Array Design Entry System</td>
</tr>
<tr>
<td></td>
<td>(Includes LCA-MDS23, LCA-MDS135)</td>
</tr>
</tbody>
</table>

Publication #  Rev. Amendment
10850          A /0
Issue date: June 1988
The PGA Development System tools include software for all phases of the PGA design cycle. The diagram below indicates the design tasks needed to complete a PGA design and the corresponding software products used to complete the tasks.

<table>
<thead>
<tr>
<th>DESIGN TASK</th>
<th>SOFTWARE PACKAGE</th>
</tr>
</thead>
<tbody>
<tr>
<td>DESIGN ENTRY</td>
<td>OrCAD (LCA-MDS-35), MENTOR (LCA-MDS34), DAISY (LCA-MDS33), FUTURENET (LCA-MDS31), SCHEMATIC INTERFACES</td>
</tr>
<tr>
<td>LOGIC VERIFICATION (optional)</td>
<td>PC-SILOS (LCA-MDS22)</td>
</tr>
<tr>
<td>AUTOMATIC PARTITION, PLACE AND ROUTE</td>
<td>AUTOMATIC DESIGN IMPLEMENTATION (LCA-MDS23)</td>
</tr>
<tr>
<td>DESIGN OPTIMIZATION</td>
<td>XACT DESIGN EDITOR, DELAY CALCULATOR (LCA-MDS21)</td>
</tr>
<tr>
<td>TIMING VERIFICATION (optional)</td>
<td>PC-SILOS (LCA-MDS22)</td>
</tr>
<tr>
<td>IN-CIRCUIT DESIGN VERIFICATION</td>
<td>XACT PROM FORMATTER, DOWNLOAD CABLE (LCA-MDS21), XACTOR IN-CIRCUIT EMULATOR (LCA-MDS28)</td>
</tr>
</tbody>
</table>
Symbol Library

Each schematic interface package includes the LCA library, which must be used when entering designs to be implemented in an AMD Programmable Gate Array. The library contains both combinational logic primitives and macros. Primitives represent the lowest level of logic symbols. Macros are logic functions implemented by the use of primitives and/or other macros. The following table lists the functions that are available in the four interface libraries. An X denotes that the function is available in the LCA library for that interface. If the function is available under a different macro name, that name appears in the column instead of an X.

<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
<th>FutureNet</th>
<th>Daisy</th>
<th>Mentor</th>
<th>OrCAD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Buffers:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ACLK</td>
<td>Alternate clock buffer</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>GCLK</td>
<td>Global clock buffer</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>BUF1</td>
<td>Buffer</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>INV1</td>
<td>Inverter</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND Gates:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AND2</td>
<td>2-input AND gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND2B</td>
<td>2-input AND gate; all inputs inverted</td>
<td>AND20</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND2B1</td>
<td>2-input AND gate; 1 input inverted</td>
<td>AND201</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND3</td>
<td>3-input AND gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND3B</td>
<td>3-input AND gate; all inputs inverted</td>
<td>AND30</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND3B1</td>
<td>3-input AND gate; 1 input inverted</td>
<td>AND301</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND3B2</td>
<td>3-input AND gate; 2 inputs inverted</td>
<td>AND302</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND4</td>
<td>4-input AND gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND4B</td>
<td>4-input AND gate; all inputs inverted</td>
<td>AND40</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND4B1</td>
<td>4-input AND gate; 1 input inverted</td>
<td>AND401</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND4B2</td>
<td>4-input AND gate; 2 inputs inverted</td>
<td>AND402</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND4B3</td>
<td>4-input AND gate; 3 inputs inverted</td>
<td>AND403</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>AND5</td>
<td>5-input AND gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AND5B</td>
<td>5-input AND gate, all inputs inverted</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AND5B1</td>
<td>5-input AND gate; 1 input inverted</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AND5B2</td>
<td>5-input AND gate; 2 inputs inverted</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AND5B3</td>
<td>5-input AND gate; 3 inputs inverted</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AND5B4</td>
<td>5-input AND gate; 4 inputs inverted</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NAND Gates:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NAND2</td>
<td>2-input NAND gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>NAND2B</td>
<td>2-input NAND gate; all inputs inverted</td>
<td>NAND20</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>NAND2B1</td>
<td>2-input NAND gate; 1 input inverted</td>
<td>NAND201</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>NAND3</td>
<td>3-input NAND gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>NAND3B</td>
<td>3-input NAND gate; all inputs inverted</td>
<td>NAND30</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>NAND3B1</td>
<td>3-input NAND gate; 1 input inverted</td>
<td>NAND301</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>NAND3B2</td>
<td>3-input NAND gate; 2 inputs inverted</td>
<td>NAND302</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>Name</td>
<td>Description</td>
<td>FutureNet</td>
<td>Daisy</td>
<td>Mentor</td>
<td>OrCAD</td>
</tr>
<tr>
<td>--------</td>
<td>--------------------------------------------------</td>
<td>-----------</td>
<td>-------</td>
<td>--------</td>
<td>-------</td>
</tr>
<tr>
<td>NAND4</td>
<td>4-input NAND gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NAND4B</td>
<td>4-input NAND gate; all inputs inverted</td>
<td>NAND40</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NAND4B1</td>
<td>4-input NAND gate; 1 input inverted</td>
<td>NAND401</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NAND4B2</td>
<td>4-input NAND gate; 2 inputs inverted</td>
<td>NAND402</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NAND4B3</td>
<td>4-input NAND gate; 3 inputs inverted</td>
<td>NAND403</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NAND5</td>
<td>5-input NAND gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NAND5B</td>
<td>5-input NAND gate; all inputs inverted</td>
<td>NAND50</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NAND5B1</td>
<td>5-input NAND gate; 1 input inverted</td>
<td>NAND501</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NAND5B2</td>
<td>5-input NAND gate; 2 inputs inverted</td>
<td>NAND502</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NAND5B3</td>
<td>5-input NAND gate; 3 inputs inverted</td>
<td>NAND503</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NAND5B4</td>
<td>5-input NAND gate; 4 inputs inverted</td>
<td>NAND504</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR2</td>
<td>2-input NOR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NOR2B</td>
<td>2-input NOR gate; all inputs inverted</td>
<td>NOR20</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR2B1</td>
<td>2-input NOR gate; 1 input inverted</td>
<td>NOR201</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR3</td>
<td>3-input NOR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NOR3B</td>
<td>3-input NOR gate; all inputs inverted</td>
<td>NOR30</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR3B1</td>
<td>3-input NOR gate; 1 input inverted</td>
<td>NOR301</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR3B2</td>
<td>3-input NOR gate; 2 inputs inverted</td>
<td>NOR302</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR4</td>
<td>4-input NOR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NOR4B</td>
<td>4-input NOR gate; all inputs inverted</td>
<td>NOR40</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR4B1</td>
<td>4-input NOR gate; 1 input inverted</td>
<td>NOR401</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR4B2</td>
<td>4-input NOR gate; 2 inputs inverted</td>
<td>NOR402</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR4B3</td>
<td>4-input NOR gate; 3 inputs inverted</td>
<td>NOR403</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR5</td>
<td>5-input NOR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NOR5B</td>
<td>5-input NOR gate; all inputs inverted</td>
<td>NOR50</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR5B1</td>
<td>5-input NOR gate; 1 input inverted</td>
<td>NOR501</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR5B2</td>
<td>5-input NOR gate; 2 inputs inverted</td>
<td>NOR502</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR5B3</td>
<td>5-input NOR gate; 3 inputs inverted</td>
<td>NOR503</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>NOR5B4</td>
<td>5-input NOR gate; 4 inputs inverted</td>
<td>NOR504</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR2</td>
<td>2-input OR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OR2B</td>
<td>2-input OR gate; all inputs inverted</td>
<td>OR20</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR2B1</td>
<td>2-input OR gate; 1 input inverted</td>
<td>OR201</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR3</td>
<td>3-input OR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OR3B</td>
<td>3-input OR gate; all inputs inverted</td>
<td>OR30</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR3B1</td>
<td>3-input OR gate; 1 input inverted</td>
<td>OR301</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR3B2</td>
<td>3-input OR gate; 2 inputs inverted</td>
<td>OR302</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR4</td>
<td>4-input OR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OR4B</td>
<td>4-input OR gate; all inputs inverted</td>
<td>OR40</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR4B1</td>
<td>4-input OR gate; 1 input inverted</td>
<td>OR401</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR4B2</td>
<td>4-input OR gate; 2 inputs inverted</td>
<td>OR402</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR4B3</td>
<td>4-input OR gate; 3 inputs inverted</td>
<td>OR403</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>OR5</td>
<td>5-input OR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OR5B</td>
<td>5-input OR gate; all inputs inverted</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OR5B1</td>
<td>5-input OR gate; 1 input inverted</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Name</td>
<td>Description</td>
<td>FutureNet</td>
<td>DAISY</td>
<td>Mentor</td>
<td>OrCAD</td>
</tr>
<tr>
<td>---------------</td>
<td>--------------------------------------</td>
<td>-----------</td>
<td>-------</td>
<td>--------</td>
<td>-------</td>
</tr>
<tr>
<td><strong>OR Gates (con't.):</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OR5B2</td>
<td>5-input OR gate; 2 inputs inverted</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>OR5B3</td>
<td>5-input OR gate; 3 inputs inverted</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>OR5B4</td>
<td>5-input OR gate; 4 inputs inverted</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
<tr>
<td><strong>Exclusive OR/NOR Gates:</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>XOR2</td>
<td>2-input XOR gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>XOR3</td>
<td>3-input XOR gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>XOR4</td>
<td>4-input XOR gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>XOR5</td>
<td>5-input XOR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>XNOR2</td>
<td>2-input XNOR gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>XNOR3</td>
<td>3-input XNOR gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>XNOR4</td>
<td>4-input XNOR gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>XNOR5</td>
<td>5-input XNOR gate</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>General:</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GADD</td>
<td>Adder</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>GCCOMP</td>
<td>Compare</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>GEOGT</td>
<td>Equal or greater-than comparator</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>GMAJ</td>
<td>4-to-1 majority gate</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>GMUX</td>
<td>2-to-1 mux</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>GXTL</td>
<td>Crystal oscillator</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>GLTGT</td>
<td>Less-than and greater-than comparator</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GPAR</td>
<td>Parity</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>GXOR</td>
<td>Exclusive-or</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Input/Output buffers and Pads:</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IBUF</td>
<td>Input buffer</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>OBUF</td>
<td>Output buffer</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>OBUFZ</td>
<td>Output buffer with 3-state control</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>INFF</td>
<td>IOB configured as a flip-flop</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>OSC</td>
<td>Oscillator</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>INLAT</td>
<td>IOB configured as an input latch</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>BPAD</td>
<td>Bi-directional pad</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>IPAD</td>
<td>Input pad</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>UPAD</td>
<td>Unbonded pad</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>OPAD</td>
<td>Output pad</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>OUTFF</td>
<td>Outputflip-flop</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>OUTFFZ</td>
<td>Output flip-flop with 3-state control</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TBUF</td>
<td>Internal 3-state driver</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Latches:</strong></td>
<td></td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>LD</td>
<td>Data latch with load input</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>LDFD</td>
<td>Data latch with load input and reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>LDSD</td>
<td>Data latch with load input and set direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>LDSRD</td>
<td>Data latch with load input, reset and set direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>LDM</td>
<td>Data latch with 2-input data multiplexer</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>LDMRD</td>
<td>Data latch with 2-input data multiplexer and reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>Name</td>
<td>Description</td>
<td>FutureNet</td>
<td>DAISY</td>
<td>MENTOR</td>
<td>OrCAD</td>
</tr>
<tr>
<td>---------</td>
<td>-----------------------------------------------------------------------------</td>
<td>-----------</td>
<td>-------</td>
<td>--------</td>
<td>-------</td>
</tr>
<tr>
<td>LDMSD</td>
<td>Data latch with 2-input data multiplexer and set direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>DLAT</td>
<td>Data latch with set direct and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>LRS</td>
<td>Data latch with set and reset</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Flip-Flops:</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DFF</td>
<td>Positive edge-triggered D flip-flop</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>FD</td>
<td>D flip-flop with one data line</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDR</td>
<td>D flip-flop with reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDS</td>
<td>D flip-flop with reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDRD</td>
<td>D flip-flop with reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDSD</td>
<td>D flip-flop with set direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDSDRD</td>
<td>D flip-flop with set and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>PDFF</td>
<td>D flip-flop with positive edge clock</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>NDFF</td>
<td>D flip-flop with negative edge clock</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FDC</td>
<td>D flip-flop with clock enable</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDCR</td>
<td>D flip-flop with clock enable and reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDCS</td>
<td>D flip-flop with clock enable and set</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDM</td>
<td>D flip-flop with 2-input data multiplexer</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDMR</td>
<td>D flip-flop with 2-input data multiplexer and reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDMS</td>
<td>D flip-flop with 2-input data multiplexer and set</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDMRD</td>
<td>D flip-flop with 2-input data multiplexer and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDMSD</td>
<td>D flip-flop with 2-input data multiplexer and set direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FDCRD</td>
<td>D flip-flop with clock enable and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>DFF1</td>
<td>D flip-flop with set and reset direct</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FSR</td>
<td>Set and reset flip-flop with set dominant over reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FRS</td>
<td>Set and reset flip-flop with reset dominance over set</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FJK</td>
<td>J-K flip-flop</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FJKS</td>
<td>J-K flip-flop with synchronous set</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FJKRD</td>
<td>J-K flip-flop with reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FJKSD</td>
<td>J-K flip-flop with set direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FJKSRD</td>
<td>J-K flip-flop with set and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FT0</td>
<td>Self-toggle flip-flop</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FTO</td>
<td>Self-toggle flip-flop with reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FT0AD</td>
<td>2-input toggle flip-flop with reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FT</td>
<td>Toggle flip-flop</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FTP</td>
<td>Toggle flip-flop with parity enable</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FTPRD</td>
<td>Toggle flip-flop with parity enable and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FTR</td>
<td>Toggle flip-flop with reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FTRD</td>
<td>2-input toggle flip-flop</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>FTS</td>
<td>Toggle flip-flop with set</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>NAME</td>
<td>DESCRIPTION</td>
<td>FUTURE</td>
<td>NET</td>
<td>DAISY</td>
<td>MENTOR</td>
</tr>
<tr>
<td>--------</td>
<td>--------------------------------------------------</td>
<td>--------</td>
<td>-----</td>
<td>-------</td>
<td>--------</td>
</tr>
<tr>
<td>Flip-flops (cont.)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FT2</td>
<td>2-input toggle flip-flop</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FT2R</td>
<td>2-input toggle flip-flop with reset</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Decoders:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>D2_4</td>
<td>1-of-4 decoder</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>D2_4E</td>
<td>1-of-4 decoder with enable</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>74_139</td>
<td>1-of-4 single decoder with low output and enable</td>
<td>X</td>
<td>X</td>
<td>$74_139</td>
<td>X</td>
</tr>
<tr>
<td>D3_8</td>
<td>1-of-8 decoder</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>D3_8E</td>
<td>1-of-8 decoder with enable</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>74_138</td>
<td>1-of-8 decoder with enables and low output</td>
<td>X</td>
<td>X</td>
<td>$74_138</td>
<td>X</td>
</tr>
<tr>
<td>74_42</td>
<td>1-of-10 decoder with low output</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Multiplexers:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>M3_1</td>
<td>3-to-1 multiplexer</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>M3_1E</td>
<td>3-to-1 multiplexer with enable</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>M4_1</td>
<td>4-to-1 multiplexer</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>M4_1E</td>
<td>4-to-1 multiplexer with enable</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>74_352</td>
<td>4-to-1 multiplexer with low output and enable</td>
<td>X</td>
<td>X</td>
<td>$74_352</td>
<td>X</td>
</tr>
<tr>
<td>M4_2</td>
<td>4-to-2 multiplexer</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>M8_1</td>
<td>8-to-1 multiplexer</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>M8_1E</td>
<td>8-to-1 multiplexer with enable</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>74_151</td>
<td>8-to-1 multiplexer with enable and complementary outputs</td>
<td>X</td>
<td>X</td>
<td>$74_151</td>
<td>X</td>
</tr>
<tr>
<td>74_152</td>
<td>8-to-1 multiplexer with low output</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Registers:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RD4</td>
<td>4-bit data register with clock</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RD8</td>
<td>8-bit data register with clock</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RD8CR</td>
<td>8-bit data register with clock enable and reset</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS4</td>
<td>4-bit shift register with clock</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS8</td>
<td>8-bit shift register</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS8CR</td>
<td>8-bit shift register with clock enable and reset</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>74_194</td>
<td>4-bit bidirectional shift register with clock, parity enable and reset direct</td>
<td>X</td>
<td>X</td>
<td>$74_194</td>
<td>X</td>
</tr>
<tr>
<td>74_195</td>
<td>4-bit serial-to-parallel shift register with clock, parity enable and reset direct</td>
<td>X</td>
<td>X</td>
<td>$74_195</td>
<td>X</td>
</tr>
<tr>
<td>RS8PR</td>
<td>8-bit shift register with clock, parity enable, and reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>RS8R</td>
<td>8-bit shift register with clock and reset</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>74_164</td>
<td>8-bit serial-to-parallel shift register with clock and reset direct</td>
<td>X</td>
<td>X</td>
<td>$74_164</td>
<td>X</td>
</tr>
<tr>
<td>RD4RD</td>
<td>4-bit data register with clock and reset direct</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RD8RD</td>
<td>8-bit data register with clock and reset direct</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS4C</td>
<td>4-bit shift register with clock enable</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS4CR</td>
<td>4-bit shift register with clock enable and reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS4CRD</td>
<td>4-bit shift register with clock enable and reset direct</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS4RD</td>
<td>4-bit shift register with reset direct</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

4-130
<table>
<thead>
<tr>
<th>NAME</th>
<th>DESCRIPTION</th>
<th>FutureNet</th>
<th>DAISY</th>
<th>MENTOR</th>
<th>OrCAD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Registers (con't.)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS8C</td>
<td>8-bit shift register with clock enable</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>RS8CRD</td>
<td>8-bit shift register with clock enable and reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>RS8RD</td>
<td>8-bit shift register with reset direct</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Counters:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C2BCR</td>
<td>1-bit binary counter with clock and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C2BCRD</td>
<td>1-bit binary counter with clock and reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C2BP</td>
<td>1-bit binary counter with clock and parity enable</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>C2BR</td>
<td>1-bit binary counter with clock and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C2BRD</td>
<td>1-bit binary counter with reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C2BCP</td>
<td>1-bit binary counter with clock and parity enable</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>C2BCPRD</td>
<td>1-bit binary counter with clock, parity enable and reset direct</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>C4BCP</td>
<td>2-bit binary counter with clock and parity enable</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C4BCR</td>
<td>2-bit binary counter with clock enable and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C4BCRD</td>
<td>2-bit binary counter with clock enable and reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C4JCR</td>
<td>2-bit Johnson counter with clock enable and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C4JXCR</td>
<td>2-bit expandable Johnson counter with clock enable and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C4JXCRD</td>
<td>2-bit expandable Johnson counter with clock enable and reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C4JXRD</td>
<td>2-bit expandable Johnson counter with reset direct</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>C6JCR</td>
<td>3-bit Johnson counter with clock enable and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C8JCR</td>
<td>4-bit Johnson counter with clock enable and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C8BCPRD</td>
<td>8-bit binary counter with clock, parity enable and reset direct</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>C10BCRD</td>
<td>4-bit BCD counter with clock enable and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C10BCPRD</td>
<td>4-bit BCD counter with clock, parity enable, and reset direct</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>74_160</td>
<td>4-bit BCD counter with clock, parity enable, and reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>$74_160 X</td>
</tr>
<tr>
<td>C10BPRD</td>
<td>4-bit BCD counter with clock, parity enable, and reset direct</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C10JCR</td>
<td>5-bit Johnson counter with clock enable and reset</td>
<td></td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
</tbody>
</table>

4-131
<table>
<thead>
<tr>
<th>NAME</th>
<th>DESCRIPTION</th>
<th>FutureNet</th>
<th>Daisy</th>
<th>Mentor</th>
<th>OrCAD</th>
</tr>
</thead>
<tbody>
<tr>
<td>C12JCR</td>
<td>6-bit Johnson counter with clock enable and reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C16BAR3</td>
<td>4-bit binary ripple counter with clock and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C16BCRD</td>
<td>4-bit binary counter with clock enable and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C16BCPR</td>
<td>4-bit binary counter with clock, parity enable, and reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C16BCPRD</td>
<td>4-bit binary counter with clock, parity enable, and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C16BCP</td>
<td>4-bit binary counter with clock, parity enable</td>
<td>X</td>
<td>X</td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>74_161</td>
<td>4-bit binary counter with clock and reset direct</td>
<td>X</td>
<td></td>
<td>$74_161</td>
<td>X</td>
</tr>
<tr>
<td>74_162</td>
<td>4-bit binary counter with reset</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>74_163</td>
<td>4-bit binary counter with reset</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>C16BPRD</td>
<td>4-bit binary up counter with clock, parity enable, and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C16BUDRD</td>
<td>4-bit up-down counter with clock, parity enable, and reset direct</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C16JCR</td>
<td>8-bit Johnson counter with clock enable and reset</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>C256FCRD</td>
<td>8-bit modulo 256 feedback shift register with clock enable and reset direct</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>C256BCP</td>
<td>8-bit binary counter with clock, parity enable</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>C256BCPR</td>
<td>8-bit binary counter with clock, parity enable, and reset direct</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>C256BCR</td>
<td>8-bit binary counter with clock enable and reset</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>C256BCRD</td>
<td>8-bit binary counter with clock enable and reset</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
</tbody>
</table>

**Flags:**

<table>
<thead>
<tr>
<th>Abbreviation</th>
<th>Description</th>
<th>FutureNet</th>
<th>Daisy</th>
<th>Mentor</th>
<th>OrCAD</th>
</tr>
</thead>
<tbody>
<tr>
<td>C</td>
<td>Critical signal flag</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>L</td>
<td>Longline signal flag</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>N</td>
<td>Non-critical signal flag</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>X</td>
<td>Explicit signal flag</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>D</td>
<td>External debug net signal flag</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>K</td>
<td>K pin for clock</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>G</td>
<td>G pin for clock</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>I</td>
<td>Input (C) pin for clock</td>
<td>X</td>
<td></td>
<td></td>
<td>X</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
<th>FutureNet</th>
<th>Daisy</th>
<th>Mentor</th>
<th>OrCAD</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLB</td>
<td>CLB primitive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IOS</td>
<td>IOB primitive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PIN</td>
<td>Input pad</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>POUT</td>
<td>Output pad</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>POUTZ</td>
<td>Output pad with 3-state control</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PBUF</td>
<td>Buffered input</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PINQ</td>
<td>Input pad with storage</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PIO</td>
<td>Input/output pad</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Name</td>
<td>Description</td>
<td>FutureNet</td>
<td>Daisy</td>
<td>Mentor</td>
<td>OrCAD</td>
</tr>
<tr>
<td>--------------</td>
<td>------------------------------------------------</td>
<td>-----------</td>
<td>-------</td>
<td>--------</td>
<td>-------</td>
</tr>
<tr>
<td>IOB Primitives (cont.)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PREG</td>
<td>Output pad with input storage</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>PIOQ</td>
<td>Input/output pad with input storage</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>IOFF</td>
<td>IOB configured as a flip-flop</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>Resistors:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>Pullup</td>
<td>Pullup resistor</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Programmable Gate Array Software**

<table>
<thead>
<tr>
<th>Part Number</th>
<th>Product Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCA-MDS21</td>
<td>XACT LCA Development System</td>
</tr>
<tr>
<td>LCA-MDS22</td>
<td>P-Silos Simulator</td>
</tr>
<tr>
<td>LCA-MDS23</td>
<td>Automatic Design Implementation</td>
</tr>
<tr>
<td>LCA-MDS24</td>
<td>XACTOR In-Circuit Emulator</td>
</tr>
<tr>
<td>LCA-MDS26</td>
<td>XACTOR Universal POD</td>
</tr>
<tr>
<td>LCA-MDS27</td>
<td>XACTOR POD Header</td>
</tr>
<tr>
<td>LCA-MDS31</td>
<td>FutureNet Schematic Interface and LCA Library</td>
</tr>
<tr>
<td>LCA-MDS33</td>
<td>Daisy Schematic Interface and LCA Library</td>
</tr>
<tr>
<td>LCA-MDS34</td>
<td>Mentor Schematic Interface and LCA Library</td>
</tr>
<tr>
<td>LCA-MDS35</td>
<td>OrCAD Schematic Interface and LCA Library</td>
</tr>
<tr>
<td>LCA-MDS135</td>
<td>OrCAD Schematic Entry Software, Interface and LCA Library (Includes LCA-MDS35)</td>
</tr>
<tr>
<td>LCA-MDS151</td>
<td>LCA Bundled Development System</td>
</tr>
<tr>
<td></td>
<td>(Includes LCA-MDS21, LCA-MDS23, and LCA-MDS135)</td>
</tr>
<tr>
<td>LCA-MDS152</td>
<td>LCA Bundled Design Entry Package</td>
</tr>
<tr>
<td></td>
<td>(Includes LCA-MDS23 and LCA-MDS135)</td>
</tr>
</tbody>
</table>
LCA-MDS135

OrCAD/SDT III PGA Design Entry System and Interface

Distinctive Characteristics

- PGA design entry via the OrCAD/SDT III Schematic Editor
- Easy schematic creation using simple keyboard or mouse commands
- Fast graphical editing
- Powerful keyboard macros simplify schematic capture
- More than 200 hierarchical levels help manage design complexity
- Compatible with both 2000 and 3000 series LCAs
- Extensive SSI/MSI library contains over 3600 components
- LCA library of over 100 macros, with TTL and standard family equivalents
- Pop-up menus
- User control for flagging critical paths for the LCA-MDS23 Automatic Design Implementation program
- Includes OrCAD/SDT III Schematic Editor and LCA libraries and interface.
- Runs on an IBM PC/AT or compatible personal computer

General Description

Schematic entry and automatic partitioning of Programmable Gate Array designs shortens logic reduction and product development times. Complex designs can be specified schematically and quickly implemented for in-circuit design verification.

Developed specifically to run on IBM personal computers and compatibles, OrCAD/SDT supports most of the popular graphics boards and printers. This gives you the flexibility to use standard equipment rather than special proprietary hardware. OrCAD/SDT also includes an array of sophisticated utility programs, including schematic output, net list, design check and bill of materials. Other helpful features include rubberbanding of wires and buses, on-line part browsing, auto panning of worksheet, string searching, visible grids.

The AMD version of ORCAD/SDT III includes a complete library of gates and macros that designers can use to enter their LCA schematics. The AMD library provides the logic, I/O, and macro symbols to be used in the schematic. An AMD conversion utility, part of the Automatic Design Implementation package (LCA-MDS 23), automatically eliminates unused and disabled logic, then partitions the schematic into a Logic Cell Array design.
Symbol Library

The OrCAD schematic interface package includes the LCA library, which must be used when entering designs to be implemented in an AMD Programmable Gate Array. The library contains both combinatorial logic primitives and macros. Primitives represent the lowest level of logic symbols. Macros are logic functions implemented by the use of primitives and/or other macros. The following table lists the functions that are available in the OrCAD interface library. Note that some functions are available for the 3000 family only.

<table>
<thead>
<tr>
<th>NAME</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>Buffers:</td>
<td></td>
</tr>
<tr>
<td>ACLK</td>
<td>Alternate clock buffer</td>
</tr>
<tr>
<td>GCLK</td>
<td>Global clock buffer</td>
</tr>
<tr>
<td>BUF1</td>
<td>Buffer</td>
</tr>
<tr>
<td>INV1</td>
<td>Inverter</td>
</tr>
<tr>
<td>AND Gates:</td>
<td></td>
</tr>
<tr>
<td>AND2</td>
<td>2-input AND gate</td>
</tr>
<tr>
<td>AND2B</td>
<td>2-input AND gate; all inputs inverted</td>
</tr>
<tr>
<td>AND2B1</td>
<td>2-input AND gate; 1 input inverted</td>
</tr>
<tr>
<td>AND3</td>
<td>3-input AND gate</td>
</tr>
<tr>
<td>AND3B</td>
<td>3-input AND gate; all inputs inverted</td>
</tr>
<tr>
<td>AND3B1</td>
<td>3-input AND gate; 1 input inverted</td>
</tr>
<tr>
<td>AND3B2</td>
<td>3-input AND gate; 2 inputs inverted</td>
</tr>
<tr>
<td>AND4</td>
<td>4-input AND gate</td>
</tr>
<tr>
<td>AND4B</td>
<td>4-input AND gate; all inputs inverted</td>
</tr>
<tr>
<td>AND4B1</td>
<td>4-input AND gate; 1 input inverted</td>
</tr>
<tr>
<td>AND4B2</td>
<td>4-input AND gate; 2 inputs inverted</td>
</tr>
<tr>
<td>AND4B3</td>
<td>4-input AND gate; 3 inputs inverted</td>
</tr>
<tr>
<td>AND5</td>
<td>5-input AND gate</td>
</tr>
<tr>
<td>AND5B</td>
<td>5-input AND gate; all inputs inverted</td>
</tr>
<tr>
<td>AND5B1</td>
<td>5-input AND gate; 1 input inverted</td>
</tr>
<tr>
<td>AND5B2</td>
<td>5-input AND gate; 2 inputs inverted</td>
</tr>
<tr>
<td>AND5B3</td>
<td>5-input AND gate; 3 inputs inverted</td>
</tr>
<tr>
<td>AND5B4</td>
<td>5-input AND gate; 4 inputs inverted</td>
</tr>
<tr>
<td>NAND Gates:</td>
<td></td>
</tr>
<tr>
<td>NAND2</td>
<td>2-input NAND gate</td>
</tr>
<tr>
<td>NAND2B</td>
<td>2-input NAND gate; all inputs inverted</td>
</tr>
<tr>
<td>NAND2B1</td>
<td>2-input NAND gate; 1 input inverted</td>
</tr>
<tr>
<td>NAND3</td>
<td>3-input NAND gate</td>
</tr>
<tr>
<td>NAND3B</td>
<td>3-input NAND gate; all inputs inverted</td>
</tr>
<tr>
<td>NAND3B1</td>
<td>3-input NAND gate; 1 input inverted</td>
</tr>
<tr>
<td>NAND3B2</td>
<td>3-input NAND gate; 2 inputs inverted</td>
</tr>
<tr>
<td>NAND4</td>
<td>4-input NAND gate</td>
</tr>
<tr>
<td>NAND4B</td>
<td>4-input NAND gate; all inputs inverted</td>
</tr>
<tr>
<td>NAND4B1</td>
<td>4-input NAND gate; 1 input inverted</td>
</tr>
<tr>
<td>NAND4B2</td>
<td>4-input NAND gate; 2 inputs inverted</td>
</tr>
<tr>
<td>Name</td>
<td>Description</td>
</tr>
<tr>
<td>-------------</td>
<td>--------------------------------------------------</td>
</tr>
<tr>
<td><strong>NAND Gates (cont.):</strong></td>
<td></td>
</tr>
<tr>
<td>NAND4B3</td>
<td>4-input NAND gate; 3 inputs inverted</td>
</tr>
<tr>
<td>NAND5</td>
<td>5-input NAND gate</td>
</tr>
<tr>
<td>NAND5B</td>
<td>5-input NAND gate; all inputs inverted</td>
</tr>
<tr>
<td>NAND5B1</td>
<td>5-input NAND gate; 1 input inverted</td>
</tr>
<tr>
<td>NAND5B2</td>
<td>5-input NAND gate; 2 inputs inverted</td>
</tr>
<tr>
<td>NAND5B3</td>
<td>5-input NAND gate; 3 inputs inverted</td>
</tr>
<tr>
<td>NAND5B4</td>
<td>5-input NAND gate; 4 inputs inverted</td>
</tr>
<tr>
<td><strong>NOR Gates:</strong></td>
<td></td>
</tr>
<tr>
<td>NOR2</td>
<td>2-input NOR gate</td>
</tr>
<tr>
<td>NOR2B</td>
<td>2-input NOR gate; all inputs inverted</td>
</tr>
<tr>
<td>NOR2B1</td>
<td>2-input NOR gate; 1 input inverted</td>
</tr>
<tr>
<td>NOR3</td>
<td>3-input NOR gate</td>
</tr>
<tr>
<td>NOR3B</td>
<td>3-input NOR gate; all inputs inverted</td>
</tr>
<tr>
<td>NOR3B1</td>
<td>3-input NOR gate; 1 input inverted</td>
</tr>
<tr>
<td>NOR3B2</td>
<td>3-input NOR gate; 2 inputs inverted</td>
</tr>
<tr>
<td>NOR4</td>
<td>4-input NOR gate</td>
</tr>
<tr>
<td>NOR4B</td>
<td>4-input NOR gate; all inputs inverted</td>
</tr>
<tr>
<td>NOR4B1</td>
<td>4-input NOR gate; 1 input inverted</td>
</tr>
<tr>
<td>NOR4B2</td>
<td>4-input NOR gate; 2 inputs inverted</td>
</tr>
<tr>
<td>NOR4B3</td>
<td>4-input NOR gate; 3 inputs inverted</td>
</tr>
<tr>
<td>NOR5</td>
<td>5-input NOR gate</td>
</tr>
<tr>
<td>NOR5B</td>
<td>5-input NOR gate; all inputs inverted</td>
</tr>
<tr>
<td>NOR5B1</td>
<td>5-input NOR gate; 1 input inverted</td>
</tr>
<tr>
<td>NOR5B2</td>
<td>5-input NOR gate; 2 inputs inverted</td>
</tr>
<tr>
<td>NOR5B3</td>
<td>5-input NOR gate; 3 inputs inverted</td>
</tr>
<tr>
<td>NOR5B4</td>
<td>5-input NOR gate; 4 inputs inverted</td>
</tr>
<tr>
<td><strong>OR Gates:</strong></td>
<td></td>
</tr>
<tr>
<td>OR2</td>
<td>2-input OR gate</td>
</tr>
<tr>
<td>OR2B</td>
<td>2-input OR gate; all inputs inverted</td>
</tr>
<tr>
<td>OR2B1</td>
<td>2-input OR gate; 1 input inverted</td>
</tr>
<tr>
<td>OR3</td>
<td>3-input OR gate</td>
</tr>
<tr>
<td>OR3B</td>
<td>3-input OR gate; all inputs inverted</td>
</tr>
<tr>
<td>OR3B1</td>
<td>3-input OR gate; 1 input inverted</td>
</tr>
<tr>
<td>OR3B2</td>
<td>3-input OR gate; 2 inputs inverted</td>
</tr>
<tr>
<td>OR4</td>
<td>4-input OR gate</td>
</tr>
<tr>
<td>OR4B</td>
<td>4-input OR gate; all inputs inverted</td>
</tr>
<tr>
<td>OR4B1</td>
<td>4-input OR gate; 1 input inverted</td>
</tr>
<tr>
<td>OR4B2</td>
<td>4-input OR gate; 2 inputs inverted</td>
</tr>
<tr>
<td>OR4B3</td>
<td>4-input OR gate; 3 inputs inverted</td>
</tr>
<tr>
<td>OR5</td>
<td>5-input OR gate</td>
</tr>
<tr>
<td>OR5B</td>
<td>5-input OR gate; all inputs inverted</td>
</tr>
<tr>
<td>OR5B1</td>
<td>5-input OR gate; 1 input inverted</td>
</tr>
<tr>
<td>OR5B2</td>
<td>5-input OR gate; 2 inputs inverted</td>
</tr>
<tr>
<td>OR5B3</td>
<td>5-input OR gate; 3 inputs inverted</td>
</tr>
<tr>
<td>OR5B4</td>
<td>5-input OR gate; 4 inputs inverted</td>
</tr>
</tbody>
</table>

4-136
<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Exclusive OR/NOR Gates:</strong></td>
<td></td>
</tr>
<tr>
<td>XOR2</td>
<td>2-input XOR gate</td>
</tr>
<tr>
<td>XOR3</td>
<td>3-input XOR gate</td>
</tr>
<tr>
<td>XOR4</td>
<td>4-input XOR gate</td>
</tr>
<tr>
<td>XOR5</td>
<td>5-input XOR gate</td>
</tr>
<tr>
<td>XNOR2</td>
<td>2-input XNOR gate</td>
</tr>
<tr>
<td>XNOR3</td>
<td>3-input XNOR gate</td>
</tr>
<tr>
<td>XNOR4</td>
<td>4-input XNOR gate</td>
</tr>
<tr>
<td>XNOR5</td>
<td>5-input XNOR gate</td>
</tr>
<tr>
<td><strong>General:</strong></td>
<td></td>
</tr>
<tr>
<td>GADD</td>
<td>Adder</td>
</tr>
<tr>
<td>GCOMP</td>
<td>Compare</td>
</tr>
<tr>
<td>GEQGT</td>
<td>Equal or greater-than comparator</td>
</tr>
<tr>
<td>GMAJ</td>
<td>4-to-1 majority gate</td>
</tr>
<tr>
<td>GMUX</td>
<td>2-to-1 mux</td>
</tr>
<tr>
<td>GXTL</td>
<td>Crystal oscillator</td>
</tr>
<tr>
<td>GLTGT</td>
<td>Less-than and greater-than comparator</td>
</tr>
<tr>
<td><strong>Input/Output buffers and Pads:</strong></td>
<td></td>
</tr>
<tr>
<td>IBUF</td>
<td>Input buffer</td>
</tr>
<tr>
<td>OBUF</td>
<td>Output buffer</td>
</tr>
<tr>
<td>OBUFZ</td>
<td>Output buffer with 3-state control</td>
</tr>
<tr>
<td>INFF</td>
<td>IOB configured as a flip-flop</td>
</tr>
<tr>
<td>OSC</td>
<td>Oscillator</td>
</tr>
<tr>
<td>INLAT</td>
<td>IOB configured as an input latch</td>
</tr>
<tr>
<td>BPAD</td>
<td>Bi-directional pad</td>
</tr>
<tr>
<td>IPAD</td>
<td>Input pad</td>
</tr>
<tr>
<td>UPAD</td>
<td>Unbonded pad</td>
</tr>
<tr>
<td>OPAD</td>
<td>Output pad</td>
</tr>
<tr>
<td>OUTFF</td>
<td>Output flip-flop</td>
</tr>
<tr>
<td>OUTFFZ</td>
<td>Output flip-flop with 3-state control</td>
</tr>
<tr>
<td>TBUF</td>
<td>Internal 3-state driver</td>
</tr>
<tr>
<td><strong>Latches:</strong></td>
<td></td>
</tr>
<tr>
<td>LD</td>
<td>Data latch with load input</td>
</tr>
<tr>
<td>LDRD</td>
<td>Data latch with load input and reset direct</td>
</tr>
<tr>
<td>LDSD</td>
<td>Data latch with load input and set direct</td>
</tr>
<tr>
<td>LDSRD</td>
<td>Data latch with load input, reset and set direct</td>
</tr>
<tr>
<td>LDM</td>
<td>Data latch with 2-input data multiplexer</td>
</tr>
<tr>
<td>LDMRD</td>
<td>Data latch with 2-input data multiplexer and reset direct</td>
</tr>
<tr>
<td>LDMSD</td>
<td>Data latch with 2-input data multiplexer and set direct</td>
</tr>
<tr>
<td>DLAT</td>
<td>Data latch with set direct and reset direct</td>
</tr>
<tr>
<td>LRS</td>
<td>Data latch with set and reset</td>
</tr>
<tr>
<td><strong>Flip-Flops:</strong></td>
<td></td>
</tr>
<tr>
<td>DFF</td>
<td>Positive edge-triggered D flip-flop</td>
</tr>
<tr>
<td>FD</td>
<td>D flip-flop with one data line</td>
</tr>
<tr>
<td>FDR</td>
<td>D flip-flop with reset</td>
</tr>
<tr>
<td>NAME</td>
<td>DESCRIPTION</td>
</tr>
<tr>
<td>------------</td>
<td>-----------------------------------------------------------------------------</td>
</tr>
<tr>
<td>FDS</td>
<td>D flip-flop with set</td>
</tr>
<tr>
<td>FDRD</td>
<td>D flip-flop with reset direct</td>
</tr>
<tr>
<td>FDSRD</td>
<td>D flip-flop with set and reset direct</td>
</tr>
<tr>
<td>FDC</td>
<td>D flip-flop with clock enable</td>
</tr>
<tr>
<td>FDSR</td>
<td>D flip-flop with clock enable and reset</td>
</tr>
<tr>
<td>FDSC</td>
<td>D flip-flop with clock enable and set</td>
</tr>
<tr>
<td>FDM</td>
<td>D flip-flop with 2-input data multiplexer</td>
</tr>
<tr>
<td>FDMR</td>
<td>D flip-flop with 2-input data multiplexer and reset</td>
</tr>
<tr>
<td>FDMS</td>
<td>D flip-flop with 2-input data multiplexer and set</td>
</tr>
<tr>
<td>FDMRD</td>
<td>D flip-flop with 2-input data multiplexer and reset direct</td>
</tr>
<tr>
<td>FDMRSD</td>
<td>D flip-flop with 2-input data multiplexer and set direct</td>
</tr>
<tr>
<td>FDCRD</td>
<td>D flip-flop with clock enable and reset direct</td>
</tr>
<tr>
<td>FSR</td>
<td>Set and reset flip-flop with set dominant over reset</td>
</tr>
<tr>
<td>FRD</td>
<td>Set and reset flip-flop with reset dominance over set</td>
</tr>
<tr>
<td>JF</td>
<td>J-K flip-flop</td>
</tr>
<tr>
<td>FJIKS</td>
<td>J-K flip-flop with synchronous set</td>
</tr>
<tr>
<td>FJIKRD</td>
<td>J-K flip-flop with reset direct</td>
</tr>
<tr>
<td>FJIKSD</td>
<td>J-K flip-flop with set direct</td>
</tr>
<tr>
<td>FJKS</td>
<td>J-K flip-flop with reset direct</td>
</tr>
<tr>
<td>FJKSRD</td>
<td>J-K flip-flop with set and reset direct</td>
</tr>
<tr>
<td>FTR</td>
<td>Self-toggle flip-flop</td>
</tr>
<tr>
<td>FTO</td>
<td>Self-toggle flip-flop with reset</td>
</tr>
<tr>
<td>FT0RD</td>
<td>2-input toggle flip-flop with reset direct</td>
</tr>
<tr>
<td>FT</td>
<td>Toggle flip-flop</td>
</tr>
<tr>
<td>FTP</td>
<td>Toggle flip-flop with parity enable</td>
</tr>
<tr>
<td>FTPRD</td>
<td>Toggle flip-flop with parity enable and reset direct</td>
</tr>
<tr>
<td>FTR</td>
<td>Toggle flip-flop with reset</td>
</tr>
<tr>
<td>FTS</td>
<td>Toggle flip-flop with set</td>
</tr>
<tr>
<td>FT2</td>
<td>2-input toggle flip-flop</td>
</tr>
<tr>
<td>FT2R</td>
<td>2-input toggle flip-flop with reset</td>
</tr>
<tr>
<td>D2_4</td>
<td>1-of-4 decoder</td>
</tr>
<tr>
<td>D2_4E</td>
<td>1-of-4 decoder with enable</td>
</tr>
<tr>
<td>74_139</td>
<td>1-of-4 single decoder with low output and enable</td>
</tr>
<tr>
<td>D3_8</td>
<td>1-of-8 decoder</td>
</tr>
<tr>
<td>D3_8E</td>
<td>1-of-8 decoder with enable</td>
</tr>
<tr>
<td>74_138</td>
<td>1-of-8 decoder with enables and low output</td>
</tr>
<tr>
<td>74_42</td>
<td>1-of-10 decoder with low output</td>
</tr>
<tr>
<td>M3_1</td>
<td>3-to-1 multiplexer</td>
</tr>
<tr>
<td>M3_1E</td>
<td>3-to-1 multiplexer with enable</td>
</tr>
<tr>
<td>M4_1</td>
<td>4-to-1 multiplexer</td>
</tr>
<tr>
<td>M4_1E</td>
<td>4-to-1 multiplexer with enable</td>
</tr>
<tr>
<td>74_352</td>
<td>4-to-1 multiplexer with low output and enable</td>
</tr>
<tr>
<td>M4_2</td>
<td>4-to-2 multiplexer</td>
</tr>
<tr>
<td>NAME</td>
<td>DESCRIPTION</td>
</tr>
<tr>
<td>-----------</td>
<td>--------------------------------------------------</td>
</tr>
<tr>
<td>Multiplexers: (con't.)</td>
<td></td>
</tr>
<tr>
<td>M8_1</td>
<td>8-to-1 multiplexer</td>
</tr>
<tr>
<td>M8_1E</td>
<td>8-to-1 multiplexer with enable</td>
</tr>
<tr>
<td>74_151</td>
<td>8-to-1 multiplexer with enable and complementary outputs</td>
</tr>
<tr>
<td>74_152</td>
<td>8-to-1 multiplexer with low output</td>
</tr>
<tr>
<td>Registers:</td>
<td></td>
</tr>
<tr>
<td>RD4</td>
<td>4-bit data register with clock</td>
</tr>
<tr>
<td>RD8</td>
<td>8-bit data register with clock</td>
</tr>
<tr>
<td>RD8CR</td>
<td>8-bit data register with clock enable and reset</td>
</tr>
<tr>
<td>RS4</td>
<td>4-bit shift register with clock</td>
</tr>
<tr>
<td>RS8</td>
<td>8-bit shift register</td>
</tr>
<tr>
<td>RS8CR</td>
<td>8-bit shift register with clock enable and reset direct</td>
</tr>
<tr>
<td>74_194</td>
<td>4-bit bidirectional shift register with clock, parity enable and reset direct</td>
</tr>
<tr>
<td>74_195</td>
<td>4-bit serial-to-parallel shift register with clock, parity enable and reset direct</td>
</tr>
<tr>
<td>RS8PR</td>
<td>8-bit shift register with clock, parity enable, and reset</td>
</tr>
<tr>
<td>RS8R</td>
<td>8-bit shift register with clock and reset</td>
</tr>
<tr>
<td>74_164</td>
<td>8-bit serial-to-parallel shift register with clock and reset direct</td>
</tr>
<tr>
<td>RD4RD</td>
<td>4-bit data register with clock and reset direct</td>
</tr>
<tr>
<td>RD8RD</td>
<td>8-bit data register with clock and reset direct</td>
</tr>
<tr>
<td>RS4C</td>
<td>4-bit shift register with clock enable</td>
</tr>
<tr>
<td>RS4CR</td>
<td>4-bit shift register with clock enable and reset</td>
</tr>
<tr>
<td>RS4CRD</td>
<td>4-bit shift register with clock enable and reset direct</td>
</tr>
<tr>
<td>RS4RD</td>
<td>4-bit shift register with reset direct</td>
</tr>
<tr>
<td>RS8C</td>
<td>8-bit shift register with clock enable</td>
</tr>
<tr>
<td>RS8CRD</td>
<td>8-bit shift register with clock enable and reset direct</td>
</tr>
<tr>
<td>RS8RD</td>
<td>8-bit shift register with reset direct</td>
</tr>
<tr>
<td>Counters:</td>
<td></td>
</tr>
<tr>
<td>C2BCR</td>
<td>1-bit binary counter with clock and reset</td>
</tr>
<tr>
<td>C2BCRD</td>
<td>1-bit binary counter with clock and reset direct</td>
</tr>
<tr>
<td>C2BP</td>
<td>1-bit binary counter with clock and parity enable</td>
</tr>
<tr>
<td>C2BR</td>
<td>1-bit binary counter with clock and reset</td>
</tr>
<tr>
<td>C2BRD</td>
<td>1-bit binary counter with reset direct</td>
</tr>
<tr>
<td>C2BCP</td>
<td>1-bit binary counter with clock and parity enable</td>
</tr>
<tr>
<td>C2BCPRD</td>
<td>1-bit binary counter with clock, parity enable and reset direct</td>
</tr>
<tr>
<td>C4BCP</td>
<td>2-bit binary counter with clock and parity enable</td>
</tr>
<tr>
<td>C4BCR</td>
<td>2-bit binary counter with clock enable and reset</td>
</tr>
<tr>
<td>C4BCRD</td>
<td>2-bit binary counter with clock enable and reset direct</td>
</tr>
<tr>
<td>C4JCR</td>
<td>2-bit Johnson counter with clock enable and reset</td>
</tr>
<tr>
<td>C4BPRD</td>
<td>2-bit binary counter with clock enable and reset direct</td>
</tr>
<tr>
<td>C4JX</td>
<td>2-bit shift expandable Johnson counter</td>
</tr>
<tr>
<td>C4JXCR</td>
<td>2-bit expandable Johnson counter with clock enable</td>
</tr>
<tr>
<td>C4JXCRD</td>
<td>2-bit expandable Johnson counter with clock enable and reset direct</td>
</tr>
<tr>
<td>C4JXRDRD</td>
<td>2-bit expandable Johnson counter with reset direct</td>
</tr>
<tr>
<td>C6JCR</td>
<td>3-bit Johnson counter with clock enable and reset</td>
</tr>
<tr>
<td>C8BCP</td>
<td>3-bit binary counter with clock and parity enable</td>
</tr>
<tr>
<td>C8BCR</td>
<td>3-bit binary counter with clock enable and reset</td>
</tr>
<tr>
<td>NAME</td>
<td>DESCRIPTION</td>
</tr>
<tr>
<td>--------------</td>
<td>--------------------------------------------------</td>
</tr>
<tr>
<td>Counters (con't.)</td>
<td></td>
</tr>
<tr>
<td>C8BCRD</td>
<td>3-bit binary counter with clock enable and reset direct</td>
</tr>
<tr>
<td>C8JCR</td>
<td>4-bit Johnson counter with clock enable and reset</td>
</tr>
<tr>
<td>C8BCPRD</td>
<td>8-bit binary counter with clock, parity enable and reset direct</td>
</tr>
<tr>
<td>C10BCRD</td>
<td>4-bit BCD counter with clock enable and reset direct</td>
</tr>
<tr>
<td>C10BCPRD</td>
<td>4-bit BCD counter with clock, parity enable, and reset direct</td>
</tr>
<tr>
<td>74_160</td>
<td>4-bit BCD counter with clock, parity enable, and reset direct</td>
</tr>
<tr>
<td>C10BPRD</td>
<td>4-bit BCD counter with clock, parity enable, and reset direct</td>
</tr>
<tr>
<td>C10JCR</td>
<td>5-bit Johnson counter with clock enable and reset</td>
</tr>
<tr>
<td>C12JCR</td>
<td>6-bit Johnson counter with clock enable and reset</td>
</tr>
<tr>
<td>C16BARD</td>
<td>4-bit binary ripple counter with clock and reset direct</td>
</tr>
<tr>
<td>C16BCRD</td>
<td>4-bit binary counter with clock enable and reset direct</td>
</tr>
<tr>
<td>C16BCPR</td>
<td>4-bit binary counter with clock, parity enable, and reset</td>
</tr>
<tr>
<td>C16BCPRD</td>
<td>4-bit binary counter with clock, parity enable, and reset direct</td>
</tr>
<tr>
<td>C16BCP</td>
<td>4-bit binary counter with clock, parity enable</td>
</tr>
<tr>
<td>74_161</td>
<td>4-bit binary counter with clock and reset direct</td>
</tr>
<tr>
<td>74_162</td>
<td>4-bit binary counter with reset</td>
</tr>
<tr>
<td>74_163</td>
<td>4-bit binary counter with reset</td>
</tr>
<tr>
<td>C16BPRD</td>
<td>4-bit binary up counter with clock, parity enable, and reset direct</td>
</tr>
<tr>
<td>C16BUDRD</td>
<td>4-bit binary up-down counter with clock, parity enable, and reset direct</td>
</tr>
<tr>
<td>C16JCR</td>
<td>8-bit Johnson counter with clock enable and reset</td>
</tr>
<tr>
<td>C256FCRD</td>
<td>8-bit modulo 256 feedback shift register with clock enable and reset direct</td>
</tr>
<tr>
<td>C256BCP</td>
<td>8-bit binary counter with clock, parity enable</td>
</tr>
<tr>
<td>C256BCPR</td>
<td>8-bit binary counter with clock, parity enable, and reset direct</td>
</tr>
<tr>
<td>C256BCR</td>
<td>8-bit binary counter with clock enable and reset</td>
</tr>
<tr>
<td>C256BCRD</td>
<td>8-bit binary counter with clock enable and reset direct</td>
</tr>
</tbody>
</table>

**Flags:**
- C: Critical signal flag
- L: Longline signal flag
- N: Non-critical signal flag
- X: Explicit signal flag
- K: K pin for clock
- G: G pin for clock
- I: Input (C) pin for clock

**CLB:**
- CLB: CLB primitive

**IOB:**
- IOB: IOB primitive

**Resistors:**
- Pullup: Pullup resistor
The Monolithic Memories Logic Cell Array is a high-performance CMOS user-programmable gate array. The Monolithic Memories' Logic Cell Array Evaluation Kit is a software package that provides the capability to evaluate the Logic Cell Array for new applications.

**Features**
- Design software package for IBM PC-XT, PC-AT or compatible computer
- Interactive graphics-oriented designer interface
- Simplified definition, placement and connection capability for implementation of complex logic
- Boolean equation or Karnaugh map alternatives to specify logic functions
- Macro library of 113 standard logic equivalents plus support for user-defined macros
- Point-to-point timing calculations for critical path analysis
- Automatic checking for connectivity and design consistency
- Hardcopy output of logical and physical configuration information

**General**
The Evaluation Kit can be used to enter complete designs using a subset of the XACT design editor, including the use of the Monolithic Memories macro library. Critical timing for the design can be evaluated with the timing delay calculator to evaluate the applicability of the Logic Cell Array technology to a particular design.

Functional definition of Configurable Logic Blocks (CLBs), and their internal routing, I/O Block (IOB) definitions, and interconnection are all done within an integrated graphics-oriented system. Interactive placement and automatic routing of logic and I/O elements are accomplished quickly and easily via an easy-to-learn user interface.

Designs are captured with a graphics-oriented design editor, using either a mouse or keyboard entry, driven from command or files. User functions are specified in terms of CLB definitions and interconnections. Standard logic functions from the macro library or user-defined macro capabilities can be utilized to quickly implement complex logic functions. Placement and routing can be edited easily to modify or optimize a design.

Checking of logical connectivity is performed automatically. All unused internal nodes are automatically configured to minimize power dissipation.

Interactive point-to-point timing delay calculation is provided to simplify timing analysis and critical path determination.

The Evaluation Kit includes hardcopy generation to document a design and automatically track design changes.

**System Requirements**

Minimum System Configuration
IBM PC-XT, PC-AT or compatible computer with:
- MS-DOS 2.1 or higher
- 640K Bytes RAM
- 1 Diskette Drive
- 10-MB Hard Disk
- IBM or compatible Color Graphic Adapter and Display
- 1 Serial Interface Port
- Mouse Systems, Microsoft or compatible mouse
Table of Contents Section 5
Sales Office Listing

Section 5 Sales Office Listing ................................................................................................................... 5-1
ADVANCED MICRO DEVICES' NORTH AMERICAN SALES OFFICES

ALABAMA ........................................... (205) 882-9122
ARIZONA ............................................. (602) 242-4400
CALIFORNIA .........................................
Culver City ....................................... (213) 645-1524
Newport Beach .................................... (714) 752-6262
San Diego .......................................... (619) 560-7030
San Jose ............................................ (408) 452-0500
Woodland Hills .................................. (818) 996-4155
CANADA, Ontario, Kanata ........................................... (613) 592-0060
Willowdale ....................................... (416) 224-5133
COLORADO .......................................... (303) 741-2900
CONNECTICUT ....................................... (203) 264-7800
FLORIDA, Clearwater ................................ (813) 530-9771
Ft Lauderdale ...................................... (305) 776-2001
Melbourne ......................................... (305) 729-0496
Orlando ............................................. (305) 858-0831
GEORGIA ............................................. (404) 449-7920
ILLINOIS .............................................
Chicago ............................................ (312) 773-4422
Naperville ......................................... (312) 506-9517
INDIANA .............................................. (317) 244-7207
KANSAS .............................................. (913) 451-3115

ADVANCED MICRO DEVICES' INTERNATIONAL SALES OFFICES

BELGIUM, Bruxelles ................................ (02) 771 91 42
FRANCE, Paris ........................................ (1) 49-75-10-10
WEST GERMANY, Hannover area .............. (0511) 736085
Hamburg ........................................... (040) 720380
Berlin .............................................. (030) 1226950
München ............................................ (089) 406490
Stuttgart ........................................... (0711) 62 33 77

HONG KONG ........................................
TEL ................................................. 852-5-8654255
FAX ................................................ 852-5-8654335

ITALY, Milano ..................................... (02) 3390541
TEL ................................................ 3393241
FAX ................................................ 3498000

JAPAN, Karagawa ................................... 462-47-2911
Tokyo .............................................. (03) 345-8241
TEL ................................................ 342-5196
Osaka .............................................. 06-243-3250

KOREA, Seoul ..................................... 82-2-784-7598

LATIN AMERICA ....................................
BRASIL, Sao Paulo ................................ 55-21-2574900
Sao Paulo area .................................... 55-21-2575000

UNITED KINGDOM, Manchester area .......... (061) 207-8998

NORTH AMERICAN REPRESENTATIVES

CALIFORNIA ........................................
F^ INC ............................................. (408) 988-3400
OEM ............................................... (408) 498-6688

CANADA, Burnaby, B.C. .......................... (604) 430-3680
DAVETEK MARKETING .............................
Calgary, Alberta .................................. (604) 430-3680
DRAYTEK MARKETING ............................

KENTUCKY .........................................
ELECTRONIC MARKETING CONSULTANTS, INC. ........................ (317) 253-1668

MICHIGAN .........................................
SAI MARKETING CORP ............................ (313) 750-1922

MISSOURI .........................................
LORENZ SALES .................................... (314) 997-4558

NEBRASKA .........................................
LORENZ SALES .................................... (402) 475-4660

NEW MEXICO .......................................
THORON DESERT STATES .......................... (505) 293-8555

NEW YORK .........................................
NYCOM, INC. ...................................... (315) 437-8343

OHIO ................................................
Centerville ....................................... (513) 433-6776
Columbus ......................................... (614) 885-4844
Strongsville ...................................... (216) 336-0000

IDADHO ..............................................
INTERMOUNTAIN TECH MKT ..................... (208) 888-8071

INDIANA .............................................
ELECTRONIC MARKETING CONSULTANTS, INC. ........................ (317) 253-1668

IOWA ............................................... (319) 377-4666

LORENZ SALES .................................... (913) 384-6556

LORENZ SALES .................................... (913) 384-6556

KANSAS ..............................................
LORENZ SALES .................................... (913) 384-6556

MARYLAND ......................................... (301) 796-9310
MASSACHUSETTS .................................. (617) 273-3970
MINNESOTA ........................................ (612) 938-0001
MISSOURI ......................................... (913) 451-3115
NEW JERSEY ....................................... (201) 299-0002
NEW YORK, Liverpool ............................. (312) 457-5400
Poughkeepsie ..................................... (914) 471-8180
Woodbury ......................................... (516) 346-8020

WISCONSIN ........................................
LORENZ SALES .................................... (913) 384-6556

ADVANCED MICRO DEVICES RESERVES THE RIGHT TO MAKE CHANGES IN ITS PRODUCT WITHOUT NOTICE IN ORDER TO IMPROVE DESIGN OR PERFORMANCE CHARACTERISTICS. THE PERFORMANCE CHARACTERISTICS LISTED IN THIS DOCUMENT ARE GUARANTEED BY SPECIFIC TESTS, GUARD BANDING, DESIGN AND OTHER PRACTICES COMMON TO THE INDUSTRY. FOR SPECIFIC TESTING DETAILS, CONTACT YOUR LOCAL AMD SALES REPRESENTATIVE. THE COMPANY ASSUMES NO RESPONSIBILITY FOR THE USE OF ANY CIRCUITS DESCRIBED HEREIN.