Programmable Array Logic


No part of this document may be copied or reproduced in any form or by any means without the prior written consent of Advanced Micro Devices, Inc.
The following trademarks are used to identify products in this manual:
IMOX ${ }^{\text {TM }}$ is a trademark of Advanced Micro Devices, Inc.
Chip-Pak ${ }^{\text {TM }}$ is a trademark of Advanced Micro Devices, Inc.
$S S R^{T M}$ is a trademark of Advanced Micro Devices, Inc.
PAL ${ }^{\oplus}$ and PALASM ${ }^{\oplus}$ are registered trademarks of and are used under license from Monolithic Memories, Inc.
MULTIBUS ${ }^{\circledR}$ is a registered trademark of Intel Corporation
CPIM ${ }^{\star}$ is a registered trademark of Digital Research, Inc., Pacific Grove, CA
Analytic Processing Unit ${ }^{\oplus}$ and APU ${ }^{\star}$ are registered trademarks of Computervision Corp., Bedford, MA
VAX ${ }^{\circledR}$ is a registered trademark of Digital Equipment Corporation, Maynard, MA
Z-BUS ${ }^{\text {® }}$ is a registered trademark of Zilog Corp.

Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics. The company assumes no responsibility for the use of any circuits described herein.

## a

## Advanced Micro Devices

## Programmable Array Logic Handbook

Prepared by the Product Planning and Applications Staff at Advanced Micro Devices, Inc.
Brad Kitson, Editor
Contributors:
Warren Miller, Kevin Ow-Wing, Jenny Yee, Phillip Sheu, Nick Zwick, Mark Young, Jeff Kitson, Bill Sievers, Mitch Richman

## Preface

Programmable Array Logic (PAL) devices are fuse programmable logic building blocks capable of implementing complex, high performance functions which combine the architectural flexibility of a custom design with the instant availability, multiple sourcing and low cost of standard off-the-shelf products.

Early uses of PALs were predominantly as simple SSI and MSI replacement functions where standard TTL catalog items resulted in inefficient multiple package solutions. PALs provided a denser, faster, lower power and lower cost implementation. As designers learned to exploit the freedom of structuring their own components for a specific application, more innovative and efficient uses of fuse programmable logic began to emerge. Today a single PAL package is frequently employed to create functions that would require hundreds of conventional TTL gates.

Advanced Micro Devices is the world's largest merchant supplier of TTL compatible Bipolar LSI Logic and memory products. This has been achieved by implementing innovative, high performance LSI functions with advanced process technologies, such as $I M_{M}{ }^{\text {TM }}$ oxide isolation and ultra-reliable platinum-silicide fuse structures, and supporting them with dedicated high volume manufacturing facilities. These same capabilities have now been applied to fuse programmable logic devices. The result is a line of PAL components offering industry leading performance, programming yields, quality guarantees and functional flexibility.

The AmPAL22V10, introduced in this book, represents a new generation of flexible architecture, fuse programmable logic products. Other, even more advanced, devices are in development based on the greater density and improved performance characteristics of new bipolar technologies. These will insure that programmable logic devices will continue to grow in importance as primary building blocks for advanced high performance systems.

This handbook is intended as an introduction to fuse programmable logic devices as well as a resource manual for experienced designers. If you require additional information on any of the products described in this book or our future plans in this area, please call your local Advanced Micro Devices Sales Office.

David A. Laws
Managing Director
Programmable Logic Products
"The VAX-11/730's circuit design is based on the use of PALs, which have helped reduce board area for the CPU by a factor of four and halve component costs, as compared with equivalent performance MSI.'

David A. Carlson and
Robert P. Morin
Digital Equipment Corporation
Electronics/October 6, 1982
"As time went on, however, it became clear that West had made the right choice; PALs really were the chip of the future."

Tracy Kidder
Referring to the Data General 32-bit
Eclipse MV8000 (Eagle) in
The Soul of a New Machine

## Table of Contents

Preface ..... iil
Index to Product Specifications ..... vi
AMD PAL Family Summary ..... vii

1. Introduction to Programmable Array Logic
Features of Programmable Array Logic ..... $1-1$
Advantages of AMD Programmable Array Logic ..... 1.5
A Comparison Between Programmable Logic and Other Logic Alternatives ..... 1.9
An Introduction to Programmable Logic Architecture ..... $1 \cdot 13$
PALs Aid High Performance 32-Bit CPU Design ..... 1.23
2. Product Specifications
20-Pin PAL Family ..... 2-1
AmPAL18P8 ..... 2-19
AmPAL22V10 ..... 2-29
AmPAL20EV8 ..... 2-41
Am29PL141 ..... 2-42
Am27S12A/13A, Am27S12/13 2048-Bit Generic Series Bipolar PROM ..... 2-48
Am27S18A/19A, Am27S18/19 256-Bit Generic Series Bipolar PROM ..... 2-50
Am27S20A/21A, Am27S20/21 1024-Bit Generic Series Bipolar PROM ..... 2-52
3. How to Design with PALs
Introduction to Fuse Maps and Design Examples ..... 3-2
Exclusive-OR ..... 3-7
Multiplexer ..... 3-8
Decoding/ChipSelect ..... $3-12$
Shift Registers ..... $3-16$
The Counter ..... $3-23$
4. Software Support for AMD PALs
Design Aid Software for Programmable Logic ..... 4-1
PALDESIGNSPECIFICATION ..... 4.3
5. Applications
Four-Bit Slice Registered Barrel Shifter ..... 5-1
Dynamic Memory Control State Sequencer ..... 5.9
GCR(4B-5B) Encoder/Decoder ..... $5-19$
Interfacing the 8086 ( 8088 ) to the Z-BUS ..... 5.31
An AMD PAL MULTIBUS Arbiter ..... 5-41
Am8500 to MC68000 PAL Interface ..... 5-51
The Berkeley-1 Plus-A High Performance CPU Utilizing PALs ..... 5.71
6. Testing, Programming, Reliability Information
Factory Testing of PALs ..... 6-1
Logic Verification for PALs ..... 6-3
PAL Programming ..... 6.7
AMD Programmable Array Logic Reliability ..... 6-9
7. General
Ordering Information ..... 7.1
Package Outlines7.2
[^0]
## Index to Product Specifications

AMD PROGRAMMABLE ARRAY LOGIC FAMILY
AMD Standard Speed 20-Pin PAL Family
AmPAL16R8
AmPAL16R6
AmPAL16R4
AmPAL16L8
AmPAL16H8
AmPAL16LD8
AmPAL16HD8
AMD High Speed 20-Pin PAL Family . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-1
AmPAL16R8A
AmPAL16R6A
AmPAL16R4A
AmPAL16L8A AmPAL16H8A AmPAL16LD8A AmPAL16HD8A
AMD Half Power 20-Pin PAL Family ..... 2-1
AmPAL16R8L
AmPAL16R6L AmPAL16R4L AmPAL16L8L AmPAL16H8L AmPAL16LD8L AmPAL16HD8L
AMD Advanced 20-Pin PAL Family ..... 2-19
AmPAL18P8
AMD 24-Pin PAL ..... 2-29
AmPAL22V10
AMD ECL 24-Pin PAL Family ..... 2-41
AmPAL20EV8
Other Programmable Logic Products ..... 2-42
Am29PL141 ..... 2-42
Am27S12A/13A, Am27S12/13 ..... 2-48
Am27S18A/19A, Am28S18/19 ..... 2-50
Am27S20A/21A, Am27S20/21 ..... 2-52

## Advanced Field Programmable Logic

## Features of PAL* Devices

- User customizable, high performance logic building blocks
- Custom logic patterns may be generated in minutes with PROM type programmers
- Easy to use software design aids available
- Improves performance and reduces board area and cost of existing TTL SSI/MSI designs
- Aids creation of new system architectures through interactive design techniques
- Security fuse prevents copying of logic by competitors
- Slim 20 and 24 -pin DIP packages


## Advantages of AMD PAL Devices

- IMOX ${ }^{\text {ti }}$ oxide isolated technology insures industry's fastest (12ns typ) "A" versions and fastest half-power ( 24 ns typ) " $L$ " versions
- Platinum-silicide fuses and added test words insure programming yields > 98\%
- Functional yield after programming $>99.5 \%$
- Reliability assured through more than 40 billion fuse hours of life testing with no failures
- Full AC and DC parameter testing at the factory through on-board testing circuitry
- Power-up reset simplifies state machine design
- Industry leading quality guarantees

AMD 20-Pin PAL Speed/Power Families

| Family | $\underset{\text { ns (Max) }}{t_{\text {pd }}}$ | $\begin{gathered} \mathbf{t}_{\mathbf{s}}{ }^{(1)} \\ \text { ns (Max) } \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{tco}_{\mathrm{co}^{(1)}} \\ \text { ns (Max) } \end{gathered}$ | $\begin{gathered} \operatorname{lcc}^{(2)} \\ \mathrm{mA}(\text { Max }) \end{gathered}$ | $\begin{gathered} \mathrm{IOL} \\ \mathrm{~mA}(\mathrm{Min}) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| High Speed, "A" | 25 | 20 | 15 | 155 | 24 |
| Standard | 35 | 30 | 25 | 155 | 24 |
| Half Power, "L" | 35 | 30 | 25 | 80 | 24 |

(1) Sequential functions.
(2) Combinatorial functions.

AMD PAL FUNCTIONS

| Part Number | Array Inputs | Logic | OE | Outputs | Package Pins |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 16R8 ${ }^{\text {- }}$ | Eight Dedicated Eight Feedback | Eight 8-Wide AND-OR | Dedicated | Registered Inverting | 20 |
| $16 \mathrm{R6}$ | Eight Dedicated <br> Six Feedback <br> Two Bidirectional | Six 8-Wide AND-OR | Dedicated | Registered Inverting | 20 |
|  |  | Two 7-Wide AND-OR-INVERT | Programmable | Bidirectional |  |
| 16R4 | Eight Dedicated Four Feedback Four Bidirectional | Four 8-Wide AND-OR | Dedicated | Registered Inverting | 20 |
|  |  | Four 7-Wide AND-OR-INVERT | Programmable | Bidirectional |  |
| 16L8 | Ten Dedicated Six Bidirectional | Eight 7-Wide AND-OR-INVERT | Programmable | Six Bidirectional Two Dedicated | 20 |
| 16H8 | Ten Dedicated Six Bidirectional | Eight 7-Wide AND-OR | Programmable | Six Bidirectional Two Dedicated | 20 |
| 16LD8 | Ten Dedicated Six Bidirectional | Eight 8-Wide AND-OR-INVERT | - | Dedicated | 20 |
| 16HD8 | Ten Dedicated Six Bidirectional | Eight 8-Wide AND-OR | - | Dedicated | 20 |
| 18P8 | Ten Dedicated Eight Bidirectional | Eight 8-Wide AND-OR | Programmable | Eight Bidirectional Programmable Polarity | 20 |
| 22V10 | Twelve Dedicated <br> Ten Bidirectional/ Feedback | Ten 12 (Average)-Wide AND-OR | Programmable | Ten Bidirectiona/Registered Programmable Polarity | 24 |



## Section 1

## Introduction to Programmable Array Logic

Features of Programmable Array Logic
Advantages of AMD Programmable Array Logic
A Comparison Between Programmable Logic and Other Logic Alternatives An Introduction to Programmable Logic Architecture PALs Aid High Performance 32-Bit CPU Design

# Features of Programmable Array Logic 

Flexibility

## Design Optimization

Programmable logic removes constraints placed on the designer by the available selection of fixed-function TTL SSI/MSI parts. If a desired function does not exist, the designer may need to use a large number of packages to generate it. With PALs, the designer can create a customized part for a specific application.

## Faster Design Cycle

Programmable logic offers a way to reduce design cycle time. In a typical top down design, rather than determining the specific logic required for a function immediately, the designer can simply specify that a programmable logic device will be used. This allows the architecture and interface between logic blocks to be defined before the specific details of each logic block are specified. The individual logic blocks can then be designed with a minimum number of iterations.

## Simple Prototyping and Debugging

Programmable logic greatly reduces the costs and time consuming effort associated with system design changes. Any changes because of logic errors or revisions in product specification may be easily implemented by reprogramming the device instead of rewiring or relaying out a board or making a new mask for a gate array.

## Optimized Design

System performance can be increased through the use of programmable logic. The designer has the freedom to optimize an architecture by tailoring programmable devices to implement it precisely. Thus a design may be implemented in the most efficient manner, frequently increasing performance.

## Reduced Delay

When a losic function is implemented in multiple SSI/MSI packages, the total delay incurred includes the time required for several on and off chip buffers. When the same function is implemented in a single programmable logic element, the delay per logic gate is reduced.

## Low Cost

## Reliability

## Reduces Board Space

PAL devices available today can provide logic complexity equivalent to 300 TL gates. Implementing a design in programmable logic can therefore significantly reduce the board space or the number of boards necessary to implement a given function. This results in lower system cost, or alternatively, the ability to provide more function in the same enclosure.


PAL Control Logic Fits One Megabyte of RAM onto a Single MULTIBUS Board (Am971024B)

## Reduces Inventory Cost

Programmable logic can be used to replace more than $90 \%$ of standard TTL parts. This allows the user to reduce his inventory from hundreds of different TTL devices to just a few programmable logic device types. This simplifies inventory requirements as well as easing purchasing procedures.

## Reduced Parts Count

Compared to standard TTL SSI/MSI, programmable logic reduces the number of packages necessary to implement a given function. In some cases, an entire PC board can be * eliminated. This results in increased reliability.

## Reduced Interconnections

The least reliable portions of a digital system are the connections between integrated circuit devices. Reducing the number of packages reduces the number of external connections and therefore improves the reliability.

## Support

## PALASM

Programmable logic designs may be executed through an easy to use software design tool called PALASM. The user inputs the desired logic equations and PALASM automatically generates the fuse programming information. The input file, cailed a PAL DESIGN SPECIFICATION, provides excellent documentation on each design. The output may be downloaded to a wide variety of low cost logic programmers. Logic simulation capabilities are provided in PALASM to help the designer verify the logic design. The output of the simulator can also be used to test a programmed device.

## Design Security

By programming a special "security fuse", the user can disable the fuse verify logic circuitry. This prevents unauthorized duplication of the device, while not interfering with the part's logic functionality. This makes programmable logic ideal for any application where design security is essential.

# Advantages of AMD Programmable Array Logic 

Improved Performance

## IMOX

The AMD PAL family is manufactured using Advanced Micro Devices' IMOX advanced oxide isolation process. IMOX, which has been in production for many years on high performance bipolar LSI devices such as the Am2900 family, insures the best speed/power performance PALs available in the industry.

## Higher Speed-"A" Versions

The use of IMOX technology insures high yields and therefore predictable availability of the high speed " $A$ " versions of PALs. Worst case input to output delay of 25 ns is specified with typical performance in the 10ns to 12 ns region. New generations of IMOX will provide even faster guarantees.

Half Power-"L" Version
A new family of half-power PALs, designated "L" versions, provides standard 35 ns maximum delays and full 24 mA drive capability at half the standard power. Half power PALs will directly replace standard and early ( -2 ) low power functions while enhancing system reliability and performance.

In addition, AMD standard and high speed " A " combinatorial PALs, are specified at more than $20 \%$ lower power dissipation than other manufacturer's devices.


## Flexibility

## Full Test Capability

Enhanced Line (20-pin)
In addition to the popular high volume 20 -pin PAL devices, Advanced Micro Devices offers three additional functions.

> AmPAL16H8 is an active HIGH version of the AmPAL16L8. These parts together provide the capability of implementing logic with either active HIGH or active LOW outputs. Switching logic equations from one polarity to another can achieve a significant reduction in product term usage. The AmPAL16H8 can functionally replace all other active HIGH 20-pin PALs.
> AmPAL16LD8 is an active LOW device implemented with dedicated outputs to increase the number of logical product terms to 8 per output.

AmPAL16HD8 is an active HIGH version of the AmPAL16LD8. These two functions give the capability of creating a wider range of functions in a single PAL.

## Enhanced Line (24-pin)

The AmPAL22V10 is a 24 -pin device which will allow the user to program the architecture. Each of the 10 outputs may be registered or combinatorial, active HIGH or active LOW. Variable product term distribution will permit between 8 and 16 logical product terms per output for a total of 120 . This device provides a new standard of flexibility in PAL functions.

## Power-up Reset

The registered devices in the AMD PAL family are designed to reset during system power-up. All registers will be set to zero, setting all the outputs to ones. This feature is especially valuable in simplifying state machine initialization.

## Special Test Circuitry

All AMD PALs include special test circuitry to allow thorough $A C$ and $D C$ testing of unprogrammed units prior to shipment. The test circuitry is used to insure good programming yield and to verify that devices will meet all parametric and switching specifications after programming.

## Programmability Testing

Programming circuitry testing includes tests to assure unique addressing of all fuses. The ability of circuitry in the programming path, to handle the large currents and voltages necessary to blow fuses, is also checked.

Special probing pads, high threshold voltage circuitry and test fuses are employed in programmability testing. This testing coupled with the platinum silicide fuse structure gives industry leading programming yields ( $>98 \%$ ) for all AMD PALs.

## Reliability

## Design Aid Software

DC Functional Testing
Special test circuitry, enabled by means of high voltage signals, checks functionality and DC parameters under conditions that simulate post programming operation. All circuitry and levels that can be involved in operation after programming are checked under worst case conditions.

For example, all input buffers are tested for functionality by switching them through a special path to a single output. All product term AND gates are switched and sensed for uniqueness and functionality.

## AC Testing

Similar special test circuitry permits AC switching delays through worst case paths to be measured. This provides a means to guarantee AC specifications under worst case power supply and loading conditions.

## PRELOAD for Logic Verification

AMD PALs provide the capability of loading the output registers of a PAL to any desired value during testing. PRELOAD is the only way to allow full logical verification of programmed registered PALs and thus guarantee correct logical functionality. Without PRELOAD, many device failures cannot be discovered until the device is tested as a part of the finished system.

## High Programming Yield

The proven platinum silicide fuse structure used for many years in AMD PROMs is also applied to PALs. This insures that AMD PALs consistently achieve better than $98 \%$ programming yields.

## High Reliability

This same fuse technology has demonstrated an excellent reliability history. Zero fuse failures have been generated in over 40 billion fuse hours of life testing.

## PALASM

The AMD PAL family is supported by an upgraded version of the PAL Logic Equation Assembler, PALASM. Known as AMPALASM20, this design aid software provides error checking and recovery features and the JEDEC Programmable Logic Data Transfer Format output capability. Advanced Micro Devices provides AMPALASM20 on an 8 inch CP/M floppy disk for the AMD System 8 and 29, and other popular computer systems. Advanced Micro Devices is committed to providing the continuing support necessary for programmable logic as new, faster and more complex devices become available.

## A Comparison Between Programmable Logic and Other Logic Alternatives

Today's logic designer can choose from a wide variety of im plementation alternatives. These can be classified into three basic categories: dedicated general purpose devices (hereafter called standard products), fuse programmable logic and custom integrated circuits (Figure 1).
Standard product architectures are defined by the IC manufacturer for a wide market and cannot be altered by the user. Examples of standard products are fixed instruction set

MOS microprocessors, microprogrammable LSI building blocks, and TTL and CMOS SSI/MSI devices. Custom logic on the other hand, is defined by the user for his application. Programmable logic devices fit between standard products and custom logic. The IC manufacturer defines an architecture that a user can program in his facility by blowing appropriate fuses to fit his specific application. PALs, PLAs and PROMs are examples of programmable logic.


Figure 1. Basic Categories of Digital Logic

Each of these three design alternatives offers distinct advantages and disadvantages in terms of cost, availability and architectural flexibility. Many system designs today, such as the controller board in Figure 2, incorporate all three of the design approaches to some degree. However, in order to evaluate which type is best suited for a particular function, this review will consider each approach on a stand-alone basis.

## DEDICATED GENERAL PURPOSE DEVICESSTANDARD PRODUCTS

There are five main advantages of standard products. They require little IC engineering expertise by the user, provide lowest cost for an individual device, usually have the best application support, provide the maximum logic density per device and are available off-the-shelf with no development lead time.

Development engineering effort at the IC level is minimal compared to the custom or programmable alternatives. The responsibility for design, test, and debugging is borne by the
integrated circuit manufacturer. Because the integrated circuit manufacturer is doing this on a large scale, the process is very efficient. The engineering time and investment saved by the standard product user can be utilized to do design work that is more directly profitable and in his realm of expertise.
Standard products achieve a cost reduction on an individual device basis because they are high volume products. This volume results in lower manufacturing cost and thus lower price per unit. The increased competition encouraged by alternate sourcing products also results in lower cost.

The design support available for standard products is far greater than that for custom or programmable devices. Application software (assemblers, simulators), hardware (emulators) and literature (manuals, books, application notes) make them easier to design with. Since standard products reach a much larger market, the engineering effort necessary to provide this support can be spread over a large number of units, reducing the cost. When a custom or programmable logic device is used, this support must be developed by the engineer doing the design.


Figure 2. Using PALs for state machines, a gate array for error correction, and standard products including a DMA controller chip, and an 8085 microprocessor, Data Systems Design squeezes hard-disk, floppy-disk, and mag tape controllers onto one board. (7215 Controller Board) Photo Courtesy of Data Systems Design, Inc.

Standard products are optimized for high volume production. The density of logic functions is therefore generally much greater than on custom logic (when implemented with gate arrays) or programmable logic devices. A fixed instruction set microprocessor or microprogrammable building block duplicated with gate arrays or programmable logic devices would take several packages compared to the single dedicated device.
The three potential disadvantages of standard products are non-optimality, higher system cost and lack of unique feature advantages. A standard product, by the very nature of its generality, is not ideal for anyone. It includes too much functionality for some applications and not enough for others. The architecture is seldom ideal for a particular application. Standard products also offer a limited performance selection. IC manufacturers pick a specific performance level aiming at as large a market as possible.
Due to the general purpose nature of standard products, it is difficult to achieve the lowest package count solution. Additional components are required to tailor the function to fit a specific need. Even though individual devices may be lower in price, more of them must be used, raising the cost for the total system when considering the additional PC boards, testing, power supplies, fans, etc.
Another disadvantage of standard products is the lack of competitive features and advantages. Anyone can buy them so it is difficult to differentiate one system supplier's hardware from another.

## CUSTOM LOGIC DEVICES—GATE ARRAYS

Custom logic, predominantly in the form of gate arrays today, offers the system designer important advantages over standard products. Compared to SSI/MSI implementations, reduced package count is of paramount importance. Standard LSI products provide the same benefit but force the designer to use a specific architecture. Custom logic allows the designer to implement his own architecture exactly. This freedom to develop innovative solutions to an applications problem can add a significant competitive advantage to a product.

The four main disadvantages of gate arrays are increased engineering effort, higher cost per individual device, lack of high level support tools and lower density compared to standard LSI products. Engineering effort for a gate array can significantly increase the cost of a system design. Not only must the system be designed, but the custom devices themselves must be designed, debugged and put into production. Both design tasks, chips as well as system, take similar amounts of engineering resources, possibly doubling the design effort and investment. Because of the lack of a competitive market (minimum second sourcing), custom logic devices can end up being substantially more expensive. Only
if the complete system solution can be optimized will the total cost be reduced. Another factor to be considered is the chance of design problems with a custom device. If extra iterations are necessary, or even worse a bug is discovered after a product has been released, correcting the problem can take several months or even years. These potential costs are difficult to estimate and have virtually no limit.

The third disadvantage of custom logic is the lack of high level support. Semiconductor manufacturers cannot provide significant support in the form of software, development systems, application notes, or books for a custom logic design because each device is different. The designer must document the design fully and provide enough support for the system engineer to utilize the device correctly.
Finally, a key disadvantage of gate arrays is the reduced density and therefore higher silicon cost compared to a dedicated general purpose device. They are designed by repeating a common loosely packed structure, leaving wide channels for the metal interconnect. For a given set of design rules a gate array will typically require two to five times the silicon area for the same gate count.

## PROGRAMMABLE LOGIC DEVICES

Programmable logic combines the advantages of the flexible architecture of a custom design with the off-the-shelf availability and reduced investment-engineering time and device cost-of a standard product.
Programmable logic has the fastest design cycle time of any form of custom logic. Instead of months, or years, as with semicustom or full custom designs, a programmable logic element can be defined by programming the fuses on a blank device. This process takes only seconds. This fast turnaround time allows a revolutionary interactive approach to system design. The engineer can try out a new architectural approach and evaluate it very quickly. If it does not work, a new idea can be defined, programmed and ready to evaluate in hours. The speed with which a new design approach can be explored and evaluated creates a design environment that enhances innovation.
Programmable logic devices share the same economics of high volume production as standard products and other user customizable integrated circuits such as PROMs, EPROMs and EEPROMs. As the manufacturer produces identical blank elements by the millions of units per year, low costs can be achieved. This volume market attracts multiple vendors and encourages price competition, as well as provides alternate parallel construction source security. The cost advantages of a standard product are retained with programmable logic devices, but as parts are customized, system designs may be differentiated from the competition. In fact, truly innovative designs are even patentable, further protecting a design from the competition.

The engineering effort and time needed to design, test, debug and put into production a programmable logic device is larger than the effort necessary for a standard product, but substantially less than for a custom element (Figure 3). Software tools are provided to reduce this overhead considerably. These permit designs to be specified in terms of Boolean equations. The input specification format, for the software, serves as a "data sheet" for the particular application and generates the essential documentation information. Simulation and test vector generation programs also exist to reduce the engineering effort associated with debugging and testing, both in prototyping and production environments.

Programmable logic devices available today and in the near future provide the functional equivalent of up to 250 to 500 gates. While this is an order of magnitude better than typical

SSI/MSI designs, it is less than that of advanced gate array products. However when all costs are amortized, programmable logic can still provide the lowest price form of custom logic available to most system manufacturers.
This threshold is increasing rapidly as advanced process technologies improve the effective logic complexity of programmable devices.

## SUMMARY

Programmable logic combines the strengths of the dedicated general purpose and custom logic design approaches. It provides interactive design via customizability and immediate turn-around time. This revolutionary design approach results in innovative, low cost designs, maximizing the competitive advantage of a product.


Figure 3. Relative Development Time vs Cost for Alternative Logic Implementations

## An Introduction to Programmable Logic Architecture

Programmable array logic (PAL) devices have many features in common with programmable read-only memory (PROM) and programmable logic array (PLA) devices. All three share the same basic internal AND-OR structure, but vary in allocation of logic features and amount of programmability. Figure 1 shows the basic AND-OR structure of programmable devices. It consists of two levels; the first is the AND array which accepts inputs, performs the desired

AND functions on the inputs and then outputs these functions to the second level, the OR array. The OR array combines various AND functions together producing the desired (AND-OR) outputs. This structure makes programmable devices ideal for implementing logic in Boolean sum-ofproducts form which is easily generated using logic design techniques such as Karnaugh maps.


Figure 1. Basic Programmable Logic Array Architecture

Figures 2 and 3 depict the rules for understanding the notation commonly used in logic diagrams to describe programmable logic devices. Figure 2 shows the technique for describing an AND array. All array inputs (true and complement of each device input) are shown connecting to a single input ANDgate. In reality, each array input is an input to the AND-gate. Thus an N -input device will have AND-gates with 2 N inputs. For example, the AmPAL16L8 has sixteen inputs and therefore each of its sixty-four AND-gates has thirty-two in-
puts! In a programmable AND array each row and column intersection, as shown in Figure 2, represents a fusible input connection to the AND-gate. Thus, to create an AND function, the fuses associated with undesired inputs must be blown. Figure 3 shows the technique for describing an OR array. All of the rules for the OR array are the same as for the AND, except that an OR function is being implemented instead of an AND.


Figure 2a. Programmable AND Array Logic Diagram Notation


Figure 3a. Programmable OR Array Logic Diagram Notation


Figure 2b. Programmable AND Array Logic Equivalent

03862A-10

Figure 3b. Programmable OR Array Logic Equivalent

## PROM ARCHITECTURE DESCRIPTION

Figure 4 shows the basic architecture of a PROM using the notation of Figures 2 and 3. The PROM shown has three inputs, eight memory locations (AND-gates), and four outputs. The important feature of the PROM architecture, as far as programmable logic is concerned, is that the inputs are fully decoded by a fixed AND array which drives a programmable OR array. This means that every combination of inputs is represented by a separate AND-gate. Since there are $2^{n}$ combinations possible from $n$ inputs, there are $2^{n}$ AND-gates in a PROM. For example, the PROM of Figure 4 has three inputs and because $2^{3}$ is eight, there are eight AND-gates in Figure 4.
By programming the OR array for a given output, as desired, the PROM can implement any logic function limited only by the number of inputs available. A separate, independent logic function can be implemented for each device output.
The limitation of PROMs in performing logic functions is their inability to provide the number of inputs and outputs that logic functions need. PROMs have a fixed number of inputs and a fixed number of outputs. For example, a $1 \mathrm{~K} \times 8$ PROM has ten inputs, to fully decode 1 K locations (remember that's 1024 fixed AND-gates!), and eight outputs (some PROMs have only four outputs). Unfortunately, logic functions don't come with fixed numbers of inputs and outputs. This means that a logic function requiring a total number of
inputs and outputs that is less than a device offers may not fit because it requires an allocation of inputs and outputs that doesn't fit the fixed PROM architecture. A function requiring eleven inputs and five outputs would not fit into the previously mentioned $1 \mathrm{~K} \times 8$ PROM, despite requiring fewer total inputs and outputs than the device offers.

Typical logic functions can easily have up to sixteen inputs which would require a PROM with 64K locations. Few designs could utilize 64K AND-gates. Typical output functions don't always come in four or eight bits. Data path functions tend to be wider than the path itself because functions such as parity bits, ripple carrys, and serial inputs and outputs are usually required in addition to the data inputs and outputs. Thus four or eight bit data path functions would not be well served by PROMs.

Control path functions, such as state machines, can quickly use up both inputs and outputs. Using a PROM with a register on the outputs as a state machine requires both logical inputs and state feedback inputs, while also requiring state feedback and control outputs (see Figure 5). Note that the feedback inputs and outputs are tied together using up an input and output pin for each bit of state information. Thus, when a large number of states are required, few precious input and output pins are left over.


Figure 4. PROM Array Structure


Figure 5. Registered PROM State Machine

## PAL ARCHITECTURE DESCRIPTION

The array architecture of a PAL is shown in Figure 6. The basic PAL structure is exactly the opposite of a PROM; the AND array is programmable and the OR array is fixed. This immediately removes the restriction that for $n$ inputs there are $2^{n}$ AND-gates. There are six inputs to the PAL array of Figure 6, but only eight AND-gates. Thus one of the key inefficiencies of a PROM is removed, allowing PALs to have as many inputs as needed. The fixed OR array of a PAL dedicates which OR-gate a particular AND-gate will input to. In Figure 6, two AND-gates are dedicated to each OR-gate in the array. This is the only limitation of PAL devices: the number of AND-gates required by an equation may not exceed the number provided.

PAL devices contain many additional architectural features which make them ideal for implementing logic functions. These features include programmable I/O pins, outputs with registers that internally feedback to the AND arráy, and active HIGH or active LOW outputs. Programmable I/O pins allow the PAL device to be tailored to fit the required allocation of inputs and outputs. Thus PALs effectively remove the limitation of inputs and outputs. This allows PALs to implement far more different and complex logic functions than a PROM (even one with more pins). Registered outputs with internal feedback give PALs the capability to implement state machines efficiently. Device inputs need not be sacrificed as feedback inputs as in the PROM. PALs also provide active HIGH or active LOW capability.


Figure 6. PAL Array Architecture

Logic diagrams for the bidirectional output structures of the PAL devices are shown in Figure 7. One feature of the PAL bidirectional output is the ability to program the output enable as a function of an AND-gate in the array. The output buffer may be programmed in one of three ways: as a dedicated output, a dedicated input, or a dynamically controllable input/output.
When programmed as a dedicated output, the output buffer is always enabled and the logic function is fed-back to the AND array. The feedback path allows more complex logic functions to be implemented by using two or more levels of AND-OR gating.
When programmed as a dedicated input, the AND-OR gate associated with that pin is unused, but an extra input has been created. This ability to trade-off outputs for inputs is one of the big advantages of PALs over other programmable logic devices. The designer isn't limited to a fixed number of input and output pins. The ratio may be programmed to fit the intended application.
Finally, when programmed as a dynamically controllable input/output buffer (i.e., enabled/disabled by a logical combination of one or more inputs) this pin may be utilized as an input, as well as retaining the full logical capability of the

AND-ORgate. This is especially useful in control applications (microprocessor handshaking protocols) and bus oriented data operations (data steering and data storage/manipulation). A serial input/output pin is a common example. When left shifting the pin may be a serial input, but when right shifting the pin would be a serial output. This mode provides maximum utilization of the PAL architectural resources.

A logic diagram for one of the registered outputs of a PAL device is shown in Figure 8. The most important features of this structure are the feedback path and the dedicated output enable. This output enable is common to all registers on the chip. The output register is fed-back into the array internally instead of from the output pin as in the combinatorial part. This configuration is more useful because state information is available at all times instead of only when the output is enabled, simplifying state machine design.

The availability of a common, dedicated output enable makes registered PAL devices ideal for bus oriented systems. The registered PAL can be programmed to provide data storage, operation, or steering functions, the result of which is placed on a data bus by enabling the output buffer. Since all PAL outputs have 24 mA current sinking capability, they can drive most on-board buses and many backplane buses.


Figure 7a. Active LOW Bidirectional Output


Figure 7b. Active HIGH Bidirectional Output


Figure 8. Registered Output

Figure 9 shows the active LOW and active HIGH versions of PAL dedicated outputs. The outputs are always enabled. The AND-gate previously used for this function provides an extra logical AND term in this structure. This brings the total number of AND-gates per output to eight. The feedback path from output to input is still provided, allowing for implementation of multi-level logic. The extra AND-gate makes these outputs ideal for non-bus oriented logic replacement, especially complex control signal generation, encoding and decoding.

## AMD 20-PIN PAL ARCHITECTURE

The AMD 20-pin PAL family is based on an array of over 2000 platinum-silicide fuses. These provide the logical equivalent of sixty-four, 32 -input programmable AND-gates. The array outputs feed eight, 8 -input fixed OR-gates plus associated I/O and feedback circuitry. Each device type has a unique organization of these I/O components, optimized for specific functional applications.

As any logical function can be expressed in an AND-OR, sum-of-products form, these basic elements can be programmed to satisfy a wide variety of complex custom logic requirements. Where a system architecture has been created around this PAL structure, single 20-pin packages have been used to perform functions that would each require over 300 equivalent TTL gates.
A typical member of the AMD 20-pin PAL family, the AmPAL16R4, is shown in Figure 10. This device has 16 available inputs to the fuse programmable array. Eight of these are dedicated inputs (pin numbers 1 through 9), four are feedback paths from the $\overline{\mathrm{Q}}$ outputs of the on-board registers and four are via the bidirectional input/output ports (pin numbers 12, 13, 18 and 19). It contains four 8 -wide AND-OR structures with inverting registered outputs, each AND-gate having 32 inputs. As half of the inputs are true and the other half complementary, only sixteen of them have effective logical value. A common three-state output enable line serves all four registered outputs. Four more 7-wide AND-ORINVERT structures have combinatorial outputs with threestate output enables that are programmable through the fuse array.


03862A-17

Figure 9a. Active LOW Dedicated Output


Figure 9b. Active HIGH Dedicated Output


Figure 10. Logic Diagram of AmPAL16R4

## AMD 24-PIN PAL PROGRAMMABLE LOGIC STRUCTURE

A new 24-pin device, the AmPAL22V10, allows programming of the logical function of each output separately to allow the user to select the preferred output structure. The basic output structure, or "macrocell", is shown in Figure 11 along with diagrams of the different output configurations. The
different configurations are bidirectional/active LOW, bidirectional/active HIGH, registered/active LOW, and registered/active HIGH. Thus the AmPAL22V10 can be architecturally optimized, as well as input and output optimized (as in the 20 -pin family), to fit the particular logic function precisely.



Registered/Active LOW Configuration


Registered/Active HIGH Configuration


Combinatorial/Active LOW Configuration


Combinatorial/Active HIGH Configuration

Figure 11

## PLA ARCHITECTURE DESCRIPTION

The array architecture of a PLA is shown in Figure 12. The PLA allows both the AND array and the OR array to be programmed. This gives the PLA additional logic capability over both PROMs and PALs. PLAs can be designed to incorporate the same advantages over PROMs as do PALs. PLA devices can include the same logic features which reduce limitations of too few inputs, the allocation of inputs vs outputs, registered feedback, or output polarity, although few commercially available devices actually implement them. The programmable OR array allows AND-gates to be tied to ORgates, as desired, by programming. Logic functions are limited by the total number of AND-gates allocated to all outputs instead of by the AND-gates allocated to a particular OR-gate (as in a PAL). Thus if a logic function requires a large number of AND-gates, they may be allocated to the particular OR-gate requiring them. Additionally, AND-gates may be connected (shared) to more than one OR-gate. This allows more efficient utilization of AND-gates in a PLA than in a PAL.

The disadvantages of PLAs are not quite so obvious. PLAs are inherently slower than PALs or PROMs because a given signal must pass through two programmable arrays. This can make a PLA unsuitable for many high performance applications. In practice the user can seldom take advantage of allocating a large number of AND-gates to a particular ORgate. The number of AND-gates required for a particular equation is related to the number of inputs to the equation. PLA devices have a limited number of inputs, thus the number of AND-gates required by an equation is limited. Creation of equations using a large number of AND-gates can become very difficult. Logic design techniques such as Karnaugh maps cannot handle much more than five or six inputs and computer aid for this task is not generally available. Another problem is that commercially available PLAs have fewer AND-gates than comparable PALs because of the added silicon real estate required to provide the programmable OR array. If a designer creates an equation using most of his available AND-gates, only a few may remain for the other OR-gates.

To take advantage of potential AND-gate efficiency with respect to sharing is not easy. For example, in data path applications such as a barrel shifter, individual equations are dependent upon the data line of which they are in the path (i.e., the equation for output $O_{0}$ is dependent on $D_{0}$ and $Q_{1}$ is dependent on $\mathrm{D}_{1}$, etc.). This makes sharing of AND-gates impossible. In other words, data path equations are ideally suited to the architecture of PALs. Since the critical path of most systems is the data path, and PALs are faster than PLAs, they are better suited for these applications.

## CONCLUSION

The three programmable logic architectures are represented by the PROM, PAL, and PLA devices. Although very similar in basic array architecture, they differ significantly in their ability to implement logic functions and in their applications. Each device type implements an AND-OR two-level logic array which allows implementation of logic equations in sum-of-products form. The PROM is the most limited of the three device types. While it is able to implement any logic function dependent upon its inputs, it has very few inputs to work with. The PROM also has a fixed number of inputs and outputs and does not provide any architectural features to enhance logic design capability. The PAL, on the other hand, provides significant capability to implement logic functions. The programmable AND array allows equations with many inputs. Architectural features such as programmable I/O, internal registered feedback, and choice of output polarity allow optimization of pin allocation and logic equations. The PLA provides the most flexible architecture of the three for implementation of logic equations by utilizing a programmable AND array and a programmable OR array. However, the added flexibility of the PLA can seldom be effectively utilized. Further, the inherent loss in speed performance when using a PLA is increasingly unacceptable in high performance designs.


Figure 12. PLA Array Structure

# PALs Aid High Performance 32-Bit CPU Design 

Bradford S. Kitson and B. Joshua Rosen*

The Computervision Analytic Processing Unit (APU) was designed as a very high speed 32-bit super minicomputer intended for engineering applications. PALs were used extensively in the design. Instead of just replacing TTL SSI/MSI, this design utilized PALs as customizable logic building blocks, allowing powerful logic functions to be implemented in a minimum of space. The result is a machine which is twice as fast as competitive designs without an increase in board space. This paper describes several of the APU's "second generation" PAL based applications and illustrates the type of design techniques necessary to rise above the "first generation" TTL SSI/MSI replacement philosophy.

## APPLICATION OF PALs IN THE COMPUTERVISION APU

The APU processor board set is divided into 4 modules, the Parser/Sequencer, which contains an instruction processor which fetches and decodes instructions in parallel with the execution unit; the Control Processor, which performs address and integer computations; the Floating Point Pipe, which performs both scalar and vector floating point operations; and the Cache/Address Translation Unit, which contains a 256 slot area page table entry cache and a 16 K byte memory cache.
Approximately $25 \%$ of the chips in the APU board set are PALs. PALs were chosen for three reasons: flexibility, performance, and cost.

The APU is the first implementation of Computervision's new CPU architecture. As such, many aspects of the design were subject to change as the architecture evolved. The use of PALs permitted the designers of the machine to rapidly
modify the hardware to fit the needs of this evolving architecture. In addition, new features and performance enhancements could easily be implemented with minimal impact on the development schedule.
The ability to generate a very large number of essentially custom ICs (there are over 200 different PAL codes used in the APU) resulted in a significant reduction in the processor's size while greatly enhancing its overall performance. The net result is apparent when one considers that although the APU and the Digital Equipment VAX-11/750, a gate array based machine, consume exactly the same amount of board space, the APU is more than twice as fast.
In fact, the Fortran performance of the APU is substantially faster than that of the VAX-11/780, a machine which consumes 5.2 times as much board space as the APU.

## APU FLOATING POINT PIPE

The APU floating point pipe (FPP) was designed as a very high speed arithmetic extension to the APU execution engine. Unlike other comparable machines, the floating point arithmetic unit of the APU is an integral part of the internal architecture and not an optional add on. As a result, the FPP is used not only to accelerate scalar and vector floating point arithmetic, but also to perform byte, word, double word and quad word string operations. In addition, the FPP is also used to enhance the performance of important non-floating point instructions such as Procedure Call and Return.

The FPP board uses a total of 79 PALs for both control and data path applications. The remainder of this paper focuses on two particular subunits of the APU FPP: the multiplier and the barrel shifter.

[^1]
## 3-TO-2 COUNTER

The multiplier section is the heart of the FPP. A block diagram of the .multiplier appears in Figure 1. Double precision floating point multiplication requires the calculation of a 56 -bit $\times 56$-bit product. Unfortunately, $56 \times 56$ parallel multipliers do not exist on silicon. The best cost/performance solution is to use a number of smaller multipliers to build an intermediate sized parallel multiplier and then produce a large product ( $56 \times 56$ ) in multiple cycles.
The partial product generator logic of the FPP utilizes seven Am25S558 $8 \times 8$ multiplier slices to implement an $8 \times 56$-bit
multiplication array. Each multiplier chip produces a 16 -bit product. In general, the most significant eight bits of each partial product generator must be added to the least significant eight bits of the next higher slice to generate the full 64 -bit partial product. Exceptions are the most significant and least significant eight bits. For a graphic representation see Figure 2.

This technique also requires the ability to accumulate partial products with the partial products from previous cycles. Thus each cycle must be accompanied by two additions; the partial product summation and intermediate product accumulation.


Figure 1. APU Multiplier (U.S. Patent Pending, Computervision Corp.)


03862A-27
Figure 2. 64-Bit Partial Product Generation

The most straightforward way to accomplish this task is to follow the multipliers with two levels of lookahead adders, usually 74S181s. This technique results in a nanocycle time which is approximately 3 times longer than the partial product generation time of the $8 \times 8$ multipliers. This is clearly unacceptable. This scheme can be modified, however, by adding registers between each level of logic (see Figure 3). By pipelining the multiplier in this fashion, the nanocycle time can be reduced to something near the propagation delay time of the multiplier chips plus the clock to output time of the multiplier register plus the set-up time of the intermediate result register. The disadvantages of this scheme are increased pipe latency, caused by the two extra levels of pipelining, and a high part count. Still another technique involves replacing one level of the pipe and one level of
lookahead adders with carry save adders between the partial product generators and the pipeline registers. Carry save adders are used to implement a technique called 3 -to-2 counting. As can be seen from Figure 4 any combination of 3 equally weighted bits can be recoded into a 2-bit field.

Thus it is possible to reduce the three operands generated by the multiplication process (the high and low partial products and the 64-bit intermediate product) into only two operands which may then be summed together in a single lookahead ALU. 3-to-2 recoding requires no carry propagate logic and is therefore very fast. Due to the speed of 3-to-2 counters, only one level of pipelining is required, which results in both a reduced parts count and a reduced pipe latency. The technique is ideally suited for implementation in PALs.


Figure 3. Two-Level Pipelined Multiplier Approach

| INPUTS | OUTPUTS |  |
| :---: | :---: | :---: |
| 000 | 00 |  |
| 001 | 01 |  |
| 010 | 01 |  |
| 011 | 10 | . |
| 100 | 01 |  |
| 101 | 10 |  |
| 110 | 10 |  |
| 111 | 11 | 03862A.29 |

Figure 4. 3-to-2 Counting

In the APU floating point engine, 16 AmPAL16R6s, programmed as triple 3 -to-2 counters, are used to reduce the three multiplication operands to two intermediate results (see Figure 5 for a logic diagram). The registered outputs of the PALs are connected to the input buses of the Mantissa ALU, which is also used for floating point addition and subtraction. The Mantissa ALU then calculates the next intermediate product in parallel with the partial products
calculations occurring in the $8 \times 8$ multipliers. This intermediate product and the new partial products are then recoded by the 3 -to-2 counter PALs to form the next pair of intermediate results. This process continues until the complete $56 \times 56$ product is generated. Thus without adding pipe latency, the APU is able to accumulate partial products at a rate of $8 \times 56$ bits every 112 ns, which happily coincides with the basic nanocycle time of the machine.


Figure 5. AmPAL16R6 3-to-2 Counter

## BARREL SHIFTER

The APU Barrel Shifter, commonly referred to as the "Rosen Shifter", can perform left shift, right shift and rotate operations of from 0 to 63 bits in a single microcycle. The barrel shifter is used mainly for floating point prescale and normalize operations. A block diagram of the barrel shifter and its associated control logic is shown in Figure 6. The word rotater, nibble rotater and bit shift and mask logic comprise the three stages necessary to implement the barrel shifter. The prescale, leading zero detect and mask control logic comprise the logic required to control it.

The prescale logic converts the signed difference produced by the exponent arithmetic units as a result of the comparison of the two operand exponents, into an absolute shift distance which is then used to right shift (prescale) the Mantissa of the smaller operand of a floating point add or subtract operation. The leading zero detect logic determines the left shift distance required to produce a left justified (normalized) result. The mask control logic is used to convert rotated data to shifted data by masking off the appropriate leading or tralling bits to implement right or left shifts. These three sections are implemented in PALs, but will not be discussed in detail.


Figure 6. 64-Bit "Rosen Shifter"

To implement the three level 64 -bit barrel shifter of Figure 6 in MSI requires the use of Am25S10 4-bit shifters (see Figure 7). The first level is the word rotater which performs a circular rotate of $0,16,32$ or 48 bits. Although implementation is simple, the MSI solution requires 16 packages. The second level is the nibble rotater which is essentially identical to the word rotater but is wired to rotate $0,4,8$ or 12 bits. The final stage of the barrel shifter requires not only bit rotate but also leading and trailing bit masking and sticky bit computation (i.e., the logical OR of the masked out bits). An MSI solution would require not only the 16 packages of Am25S10s, used in each of the preceding levels, but also 16 packages of AND gates, for masking, plus still another 16 packages of ANDs for the sticky bit computation. The control logic for performing the mask operation would probably require as much logic as the entire shift path. The more practical solution has
usually been to build separate left and right shifters, 48 packages apiece, and not to implement a sticky bit at all.
The PAL implementation of a 64 -bit rotater and shifter, with sticky bit computation, requires considerably fewer packages than a unidirectional MSI shifter.
The word rotater consists of 8 identical PALs programmed as two four-bit rotaters per package. The logic diagram of the word rotater is shown in Figure 8. The nibble shifter requires four Am25S10s and 8 PALs programmed as 6 -bit wide 4 place shifters. The logic diagram of a nibble shifter is shown in Figure 9. The bit shift and mask logic requires sixteen PALs in the data path and two PALs in the control path. The logic diagram for a shift and mask PAL appears in Figure 10, but some explanation is required to understand the innovative design technique used to implement it.


Figure 7. Am25S10 4-Bit Shifter


03862A-33

Flgure 8. PAL Word Rotater


Figure 9. PAL Nibble Shifter


Figure 10. PAL Bit Shift and Mask Slice

The technique used to implement the masking function required for shifting is called "nearest neighbor masking", (U.S. patent pending, Computervision Corp.). Each of the shift and mask PALs has an enable input from one of the mask control PALs. In áddition, each shift and mask PAL is also connected to the enable inputs from its left and right hand neighbors (see Figure 11). The mask control PAL input determines if all four bits from the slice should be masked off. The enables from the adjacent slice determine if a PAL is at a shift boundary. Should only one of the neighboring slices be disabled then the shift and mask PAL will mask off from 0 to 3 of the bits adjacent to the disabled slice, depending on the bit rotation distance. In this way, the 64 -bit masking operation can be implemented with only 16 control lines as opposed to at least 64 for an SSI/MSI solution.

In addition to performing the final shift and mask operation, the bit shifter PALs also compute the logical OR of the masked out bits at each slice position. These outputs are then logically ORed together to generate a sticky bit. The extra hardware required is less than two SSI packages.

The entire PAL Barrel Shifter requires 38 devices to implement 64-bit rotation, left shifting, right shifting and sticky bit accumulation. An MSI based left/right shifter, without sticky bit computation, would require a minimum of 96 parts. In addition, the logic required for implementing the prescale and normalize operations, not discussed, is also significantly reduced through the use of PALs.

## CONCLUSION

The full potential of PALs has begun to be realized with the availability of high speed devices. PALs now allow the designer to architect the device to fit the application instead of architecting the application to fit the device.

The 3-to-2 counter design example shown illustrated the implementation of a unique architecture in PALs, resulting in significant part count reduction and throughput increase over a comparable TTL solution. The barrel shifter design ex ample shown illustrated the innovative implementation of an application not previously feasible in TTL.


Figure 11. PAL "Nearest Neighbor" Interconnect

## Section 2

## Product Specifications

AMD 20-Pin PAL Family
AMD Half Power PAL Family
AmPAL22V10 Advanced Information
AmPL64S16 Advanced Information
Am27S12A/13A, Am27S12/13 2048-Bit Generic Series Bipolar PROM Am27S18A/19A, Am27S18/19 256-Bit Generic Series Bipolar PROM Am27S20A/21A, Am27S20/21 1024-Bit Generic Series Bipolar PROM

# AMD 20-Pin PAL* Family <br> 20-Pin IMOX ${ }^{\text {TM }}$ Programmable Array Logic Elements 

## DISTINCTIVE CHARACTERISTICS

- IMOX oxide isolated technology insures industry's fastest ( 12 ns typ) "A" versions and fastest half-power (25ns typ) "L" versions
- Half-power PAL devices have the same AC characteristics as the Standard PAL devices with half the power consumption
- Platinum-silicide fuses and added test words insure programming yields > 98\%
- Post Programming Functional Yields (PPFY) > 99\%
- Preload feature permits full logical verification
- Reliability assured through more than 40 billion fuse hours of life testing with no failures
- Full AC and DC parametric testing at the factory through on-board testing circuitry
- AMD's industry leading quality guarantees


## GENERAL DESCRIPTION

AMD PAL devices are high speed electrically programmable array logic elements. They utilize the familiar sum-ofproducts (AND-OR) structure ailowing users to program custom logic functions to fit most applications precisely. Typically they are a replacement for Low Power Schottky SSI/MSI logic circuits, reducing chip count by more than 5 to 1 and greatly simplifying prototyping and board layout.
Seven different devices are available, including both registered and combinatorial devices, in three different
speed and power versions. The High Speed "A" versions ( ${ }^{\text {PDD }}=25 \mathrm{~ns}$ ) run approximately $30 \%$ faster than the Standard Speed versions (tpD $=35 \mathrm{~ns}$ ) while consuming the same amount of power. The Half Power " $L$ " versions (ICC $=80 \mathrm{~mA}$ ) while running at the same speed as the Standard Speed versions consume half the power of the standard devices ( $\mathrm{I} \mathrm{CC}=155 \mathrm{~mA}$ ).

AMD PAL Speed/Power Families

| Family | $\begin{gathered} \text { tpd } \\ \text { ns (Max) } \end{gathered}$ | $\begin{gathered} \mathrm{t}_{\mathrm{s}^{(1)}} \\ \mathrm{ns}(\mathrm{Max}) \end{gathered}$ | $\begin{gathered} \mathrm{t}_{\mathrm{co}}{ }^{(1)} \\ \mathrm{ns} \text { (Max) } \end{gathered}$ | $\begin{gathered} I_{c c^{(2)}} \\ \mathrm{mA}(\text { Max }) \end{gathered}$ | $\begin{gathered} \mathrm{IOL} \\ \mathrm{~mA}(\mathrm{Min}) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| High Speed, "A" | 25 | 20 | 15 | 155 | 24 |
| Standard | 35 | 30 | 25 | 155 | 24 |
| Half Power, "L" | 35 | 30 | 25 | 80 | 24 |

(1) Sequential functions.
(2) Combinatorial functions.

AMD PAL FUNCTIONS

| Part Number | Array Inputs | Logic | OE | Outputs | Package Pins |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 16R8 | Eight Dedicated Eight Feedback | Eight 8-Wide AND-OR | Dedicated | Registered Inverting | 20 |
| 16R6 | Eight Dedicated Six Feedback Two Bidirectional | Six 8-Wide AND-OR | Dedicated | Registered Inverting | 20 |
|  |  | Two 7-Wide AND-OR-INVERT | Programmable | Bidirectional |  |
| 16R4 | Eight Dedicated Four Feedback Four Bidirectional | Four 8-Wide AND-OR | Dedicated | Registered Inverting | 20 |
|  |  | Four 7-Wide AND-OR-INVERT | Programmablé | Bidirectional |  |
| 16L8 | Ten Dedicated Six Bidirectional | Eight 7-Wide AND-OR-INVERT | Programmable | Six Bidirectional Two Dedicated | 20 |
| 16H8 | Ten Dedicated Six Bidirectional | Eight 7-Wide AND-OR | Programmable | Six Bidirectional Two Dedicated | 20 |
| 16LD8 | Ten Dedicated Six Bidirectional | Eight 8-Wide AND-OR-INVERT | - | Dedicated | 20 |
| 16HD8 | Ten Dedicated Six Bidirectional | Eight 8-Wide AND-OR | - | Dedicated | 20 |

## AMD PAL FAMILY CHARACTERISTICS

All members of the AMD PAL family have common electrical characteristics and programming procedures. All parts are produced with a fusible link at each input to the AND gate array, and connections may be selectively removed by applying appropriate* voltages to the circuit.
Initially the AND gates are connected, via fuses, to both the true and complement of each input. By selective programming of fuses the AND gates may be "connected" to only the true input (by blowing the complement fuse), to only the complement input (by blowing the true fuse), or to neither type of input (by blowing both fuses) establishing a logical "don't care." When both the true and complement fuses are left intact a logical false results on the output of the AND gate, while all fuses blown results in a logical true state. The outputs of the AND gates are connected to fixed OR gates. The only limitations imposed are the number of inputs to the AND gates (up to 16) and the number of AND gates per OR (up to 8).

All parts are fabricated with AMD's fast programming, highly reliable Platinum-Silicide Fuse technology. Utilizing an easily implemented programming algorithm, these products can be rapidly programmed to any customized pattern. Extra test words are pre-programmed during manufacturing to insure extremely high field programming yields ( $>98 \%$ ), and provide extra test paths to achieve excellent parametric correlation.

## POWER-UP RESET

The registered devices in the AMD PAL family have been designed to reset during system power-up. Following powerup, all registers will be initialized to zero, setting all the outputs to a logic 1. This feature provides extra flexibility to the designer and is especially valuable in simplifying state machine initialization.

## PRELOAD

AMD PAL devices are designed with unique PRELOAD circuitry that provides an easy method of testing registered devices for
logical functionality. PRELOAD allows any arbitrary state value to be loaded into the registered output of an AMD PAL device.

A typical functional test sequence would be to verify all possible state transitions for the device being tested. This requires the ability to set the state registers into an arbitrary "present state" value and to set the device inputs to any arbitrary "present input" value. Once this is done, the state machine is clocked into a new state, or "next state." The next state is then checked to validate the transition from the present state. In this way any state transition can be checked.

Without PRELOAD, it is difficult and in some cases impossible to load an arbitrary present state value. This can lead to logic verification sequences that are either incomplete or excessively long. Long test sequences result when the feedback from the state register "interferes" with the inputs, forcing the machine to go through many transitions before it can reach an arbitrary state value. Therefore the test sequence will be mostly state initialization and not actual testing. The test sequence becomes excessively long when a state must be reentered many times to test a wide variety of input combinations.

In addition, complete logic verification may become impossible when states that need to be tested can not be entered with normal state transitions. For example, even though necessary, the state entered when machine powers up can not be tested, because it can not be entered from the main sequence. Similarly, "forbidden" or don't care states that are not normaly entered need to be tested to ensure that they return to the main sequence.

PRELOAD eliminates these problems by providing the capability to go directly to any desired arbitrary state. Thus test sequences may be greatly shortened, and all possible states can be tested, greatly reducing test time and development costs', and guaranteeing proper in-system operation.




MAXIMUM RATINGS
(Above which the useful life may be impaired)

| Storage Temperature | -65 to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Supply Voltage to Ground Potential (Pin 20 to Pin 10) Continuous | -0.5 to +7 V |
| DC Voltage Applied to Outputs ${ }^{\prime}$ (Except During Programming) | -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \mathrm{max}$ |
| DC Voltage Applied to Outputs During Programming | 21 V |
| Output Current Into Outputs During Programming (Max Duration of 1 sec$)$ | 200 mA |
| DC Input Voltage | -0.5 to +5.5 V |
| DC Input Current | -30 to +5 mA |

## OPERATING RANGE

| Parameters | Description | Commercial |  | Military |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| $\mathrm{v}_{\mathrm{cc}}$ | Supply Voltage | 4.75 | 5.25 | 4.50 | 5.50 | V |
| $\mathrm{T}_{\mathrm{A}}$ | Operating Free Air Temperature | 0 | 75 | -55 | 125 | ${ }^{\circ} \mathrm{C}$. |
| $\mathrm{T}_{\mathrm{C}}$ | Operating Case Temperature |  |  |  | . 125 | ${ }^{\circ} \mathrm{C}$ |

ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted)

| Paramete | - Description | Test Conditions |  |  | Min | (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{IOH}^{\prime}=-3.2 \mathrm{~mA}$ | COM'L | 2.4 | 3.5 |  | Volts |
|  |  |  | $1 \mathrm{OH}=-2 \mathrm{~mA}$ | MIL |  |  |  |  |
| VOL | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{IOL}^{\prime}=24 \mathrm{~mA}$ | ${ }^{\text {COM }}$ ' |  |  | 0.50 | Volts |
|  |  |  | $\mathrm{lOL}=12 \mathrm{~mA}$ | MIL |  |  |  |  |
| $\begin{aligned} & V_{1 H} \\ & \text { (Note 2) } \end{aligned}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  | 5.5 | Volts |
| $\begin{aligned} & V_{\mathrm{IL}} \\ & \text { (Note 2) } \end{aligned}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  | 0.8 | Volts |
| IIL | Input LOW Current | $V_{C C}=M A X, V_{I N}=0.40 \mathrm{~V}$ |  |  |  | -20 | $-250$ | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.7 \mathrm{~V}$ |  |  |  |  | 25 | $\mu \mathrm{A}$ |
| $1 /$ | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1.0 | mA |
| $I_{\text {SC }}$ | Output Short Circuit Current | $V_{C C}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}($ Note 3) |  |  | -30 | -60 | -90 | mA |
| ${ }^{1} \mathrm{Cc}$ | Power Supply Current | All inputs = GND, $V_{C C}=M A X$ | 16L8, 16H8, 16HD8, 16LD8 16L8A, 16H8A, 16HD8A, 16LD8A |  |  | 110 | 155 | mA |
|  |  |  | 16L8L, 16H8L, 16HD8L, 16LD8L |  |  | 55 | 80 |  |
|  |  |  | 16R8, 16R6, 16R4 16R8A, 16R6A, 16R4A |  |  | 120 | 180 |  |
|  |  |  | 16R8L, 16R6L, |  |  | 60 | 90 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{1 N}=-18 \mathrm{~mA}$ |  |  |  | -0.9 | -1.2 | Volts |
| lozh | Output Leakage Current (Note 4) | $\begin{aligned} & V_{C C}=M A X, V_{I L}=0.8 \mathrm{~V} \\ & V_{I H}=2.0 \mathrm{~V} \end{aligned}$ | $V_{O}=2.7 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| lozl |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | $-100$ |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | $\mathrm{V}_{1 \mathrm{~N}}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5 ) |  |  |  | 6 |  | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5) |  |  |  | 9 |  |  |

Notes: 1. Typical limits are at $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. These are absolute values with respect to device ground and all overshoots due to system or tester noise are included.
3. Not more than one output should be tested at a time. Duration of the short circuit should not be more than one second. VOUT $=0.5 \mathrm{~V}$ has been chosen to avoid test problems caused by tester ground degradation.
4. I/O pin leakage is the worst case of lozx or lix (where $x=H$ or L).
5. These parameters are not $100 \%$ tested, but are periodically sampled.

SWITCHING CHARACTERISTICS OVER OPERATING RANGE (Unless otherwise noted) COMMERCIAL RANGE

| Parameters | Description | Test Conditions | A-Version |  |  | STD and L-Version |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Typ (Note 1) | Min | Max | Typ (Note 1) | Min | Max | Units |
| ${ }^{\text {t PD }}$ | Input or Feedback to Non-Registered Output 16L8, 16R6, 16R4, 16LD8, 16H8, 16HD8 | $\begin{aligned} & R_{1}=200 \\ & R_{2}=390 \end{aligned}$ | 12 |  | 25 | 17 |  | 35 | ns |
| ${ }^{\text {teA }}$ | Input to Output Enable 16L8, 16R6, 16R4, 16H8 |  | 12 |  | 25 | 17 |  | 35 | ns |
| ${ }_{\text {ter }}$ | Input to Output Disable 16L8, 16R6, 16R4, 16H8 |  | 12 |  | 25 | 17 |  | 35 | ns |
| tPZX | Pin 11 to Output Enable 16R8, 16R6, 16R4 |  | 8 |  | 20 | 12 |  | 25 | ns |
| tpxz | Pin 11 to Output Disable 16R8, 16R6, 16R4 |  | 8 |  | 20 | 12 |  | 25 | ns |
| ${ }^{\text {t }} \mathrm{CO}$ | Clock to Output 16R8, 16R6, 16R4 |  | 8 |  | 15 | 12 |  | 25 | ns |
| $\mathrm{t}_{\mathrm{s}}$ | Input or Feedback Setup Time 16R8, 16R6, 16R4 |  | 10 | 20 |  | 15 | 30 |  | ns |
| $t_{\text {H }}$ | Hold Time 16R8, 16R6, 16R4 |  | -10 | 0 |  | -10 | 0 |  | ns |
| tp | Clock Period ( $\mathrm{t}_{\mathrm{s}}+\mathrm{t}^{\text {co}}$ ) |  |  | 35 |  |  | 55 |  | ns |
| tw | Clock Width |  |  | 15 |  |  | 25 |  | ns |
| $f_{\text {MAX }}$ | Maximum Frequency |  |  |  | 28.5 |  |  | 18 | MHz |

SWITCHING CHARACTERISTICS OVER OPERATING RANGE (Unless otherwise noted) MILITARY RANGE

| Parameters | Description | Test Conaitions | A-Version |  |  | STD and L-Version |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Typ <br> (Note 1) | Min | Max | Typ <br> (Note 1) | Min | Max |  |
| ${ }^{\text {tPD }}$ | Input or Feedback to Non-Registered Output 16L8, 16R6, 16R4, 16LD8, 16H8, 16HD8 | $\begin{aligned} & R_{1}=390 \\ & R_{2}=750 \end{aligned}$ | 12 |  | 30 | 17 |  | 40 | ns |
| ${ }^{\text {t }}$ EA | Input to Output Enable 16L8, 16R6, 16R4, 16H8 |  | 12 |  | 30 | 17 |  | 40 | ns |
| $t_{\text {ER }}$ | Input to Output Disable 16L8, 16R6, 16R4, 16H8 |  | 12 |  | 30 | 17 |  | 40 | ns |
| tpzX | Pin 11 to Output Enable 16R8, 16R6, 16R4 |  | 8 |  | 25 | 12 |  | 25 | ns |
| tpxz | Pin 11 to Output Disable 16R8, 16R6, 16R4 |  | 8 |  | 25 | 12 |  | 25 | ns |
| ${ }^{\text {t }} \mathrm{CO}$ | Clock to Output 16R8, 16R6, 16R4 |  | 8 |  | 20 | 12 |  | 25 | ns |
| $\mathrm{t}_{\mathrm{s}}$ | Input or Feedback Setup Time 16R8, 16R6, 16R4 |  | 10 | 25 |  | 15 | 35 |  | ns |
| $t_{H}$ | Hold Time 16R8, 16R6, 16R4 |  | -10 | 0 |  | -10 | 0 |  | ns |
| $t_{p}$ | Clock Period ( $\mathrm{s}^{\text {+ }}$ + $\mathrm{t}_{\text {CO }}$ ) |  |  | 45 |  |  | 60 |  | ns |
| tw | Clock Width |  |  | 20 |  |  | 25 |  | ns |
| $f_{\text {max }}$ | Maximum Frequency |  |  |  | 22 |  |  | 16.5 | MHz |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. $t_{P D}$ is tested with switch $S_{1}$ closed and $C_{L}=50 \mathrm{pF}$.
3. For three-state outputs, output enable times are tested with $C_{L}=50 \mathrm{pF}$ to the 1.5 V level; $\mathrm{S}_{1}$ is open for high impedance to HIGH tests and closed for high impedance to LOW tests. Output disable times are tested with $C_{L}=5 p F$. HIGH to high impedance tests are made to an output voltage of $\mathrm{V}_{\mathrm{OH}}-0.5 \mathrm{~V}$ with $\mathrm{S}_{1}$ open; LOW to high impedance tests are made to the $\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$ level with $\mathrm{S}_{1}$ closed.

## AC TESt LOAD



## SWITCHING WAVEFORMS



KEY TO TIMING DIAGRAM

| WAVEFORM | INPUTS | OUTPUTS | WAVEFORM |
| :---: | :---: | :---: | :---: |
|  | MUST BE <br> STEADY | WILL BE <br> STEADY | INPUTS |

## PRELOAD OF REGISTERED OUTPUTS

AMD PAL registered outputs are designed with extra circuitry to allow loading each register asynchronously to either a HIGH
or LOW state. This feature simplifies testing since any initial state for the registers can be set to optimize test sequencing.
The pin levels and timing necessary to perform the PRELOAD function are detailed below:


| Level forced on registered output <br> pin during PRELOAD cycle | Output state at the <br> output pin after cycle |
| :---: | :---: |
| $V_{\text {HH }}$ | HIGH |
| OV to $V_{C C H}$ or OPEN | LOW |

## POWER-UP RESET

The registered devices in the AMD PAL family have been designed to reset during system power-up. Due to the asynchronous operation of the power-up reset and the wide range of ways $V_{C C}$ can rise to its steady state, two conditions are required to insure a valid power-up reset. These conditions are:

1. The $V_{C C}$ rise must be monotonic.
2. Following reset, the clock input must not be driven from low to high until all applicable input and feedback setup times are met.


| Parameters | Description | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{pr}}$ | Power-Up <br> Reset Time |  | 600 | 1000 | ns |
| $t_{s}$ | input or Feedback Setup Time | See Switching Characteristics |  |  |  |
| $t_{w}$ | Clock Width |  |  |  |  |




16 Array Inputs

- 8 dedicated
- 6 registered feedback
- 2 bidirectional I/O

6, 8-Wide AND-OR Structures

- Registered, inverting outputs with common dedicated output enable

2,7-Wide AND-OR-INVERT Structures

- Combinatorial outputs with programmable output enables

LOGIC DIAGRAM AmPAL16R4




## LOGIC DIAGRAM AmPAL16H8




## PROGRAMMING

Each AMD PAL fuse is programmed with a simple sequence of voltages applied to two control pins (1 and 11) and a programming voltage pulse applied to the output under programming. Addressing of the 2048 element fuse array is accomplished with normal TTL levels on eight input pins (five select the input line number and three select the product term number). $\mathrm{V}_{\mathrm{CC}}$ is maintained at a normal level throughout the programming and verify cycle - no extra high levels are required.
The necessary sequence levels for programming any fuse is shown in the Programming Waveforms. The address of each fuse in terms of Input Line Number and Product Term Line Number is defined by the Fuse Address Tables 1 and 2. Current, voltage and timing requirements for each pin are specified in the Programming Parameter Table below.
All the AMD 20-pin PAL devices use identical programming conditions and sequences.

After all programming has been completed, the entire array should be reverified at $V_{\mathrm{CCL}}$ and again at $\mathrm{V}_{\mathrm{CCH}}$. Reverification can be accomplished by reading all eight outputs in parallel rather than one at a time. The array fuse verification cycle checks that
the correct array fuses have been blown and can be sensed by the outputs.
AMD PAL devices have been designed with many internal test features that are used to assure high programming yield and correct logical operation for a correctly programmed part.
An additional fuse is provided on each AMD PAL circuit to prevent unauthorized copying of AMD PAL fuse patterns when design security is desired. Blowing the security fuse blocks entry to the fuse pattern verify mode.
To blow the security fuse:

1. Power up part to $V_{C C P}$
2. Raise Pin 5 to $\mathrm{V}_{\mathrm{HH}}$.
3. Pulse Pin 11 from ground to $V_{\mathrm{OP}}$ for a $50 \mu \mathrm{sec}$ duration.
4. Periorm a normal end-of-programming verify cycle at $V_{\mathrm{CCL}}$ and $\mathrm{V}_{\mathrm{CCH}}$. All fuse locations should be sensed as blown if the security fuse has been successfully blown.

Note that parts with the security fuse blown may not be returned as programming rejects.
AMD PAL devices normally have high programming yields ( $>98 \%$ ). Programming yield losses are frequently due to poor socket contact, equipment out of calibration or improper use.

PROGRAMMING PARAMETERS $\left(T_{\mathrm{A}}=25^{\circ} \mathrm{C}\right)$

| Parameters | Description |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{HH}}$ | Control Pin Extra High Level | Pin 1@10-40mA | 10 | 11 | 12 | Volts |
|  |  | Pin 11 @ 10-40mA | 10 | 11 | 12 |  |
| $\mathrm{V}_{\mathrm{OP}}$ | Program Voltage Pins 12-19@ 15-200mA |  | 18 | 20 | 22 | Volts |
| $V_{\text {IHP }}$ | Input High Level During Programming and Verify |  | 2.4 | 5 | 5.5 | Volts |
| $V_{\text {ILP }}$ | Input Low Level During Programming and Verify |  | 0.0 | 0.3 | 0.5 | Volts |
| $\mathrm{V}_{\text {CCP }}$ | $\mathrm{V}_{\mathrm{CC}}$ During Programming @ $\mathrm{I}_{\mathrm{CC}}=50-200 \mathrm{~mA}$ |  | 5 | 5.2 | 5.5 | Volts |
| $V_{\text {CCL }}$ | $\mathrm{V}_{\mathrm{CC}}$ During First Pass Verification @ I $\mathrm{CC}=50-200 \mathrm{~mA}$ |  | 4.1 | 4.3 | 4.5 | Volts. |
| $\mathrm{V}_{\mathrm{CCH}}$ | $\mathrm{V}_{\mathrm{CC}}$ During Second Pass Verification @ I $\mathrm{CC}=50-200 \mathrm{~mA}$ |  | 5.4 | 5.7 | 6.0 | Volts |
| $V_{\text {Blown }}$ | Successful Blown Fuse Sense Level @ Output | 16L8, 16R8, 16R6, 16R4, 16LD8 |  | 0.3 | 0.5 | Volt |
|  |  | 16H8, 16HD8 | 2.4 | 3 |  | Volt |
| $\mathrm{dV}_{\mathrm{OP} / \mathrm{dt}}$ | Rate of Output Voltage Change |  | 20 |  | 250 | $\mathrm{V} / \mu \mathrm{sec}$ |
| $\mathrm{dV}_{11} / \mathrm{dt}$ | Rate of Fusing Enable Voltage Change (Pin 11 Rising Edge) |  | 100 |  | 1000 | $\mathrm{V} / \mu \mathrm{sec}$ |
| ${ }^{\text {tP }}$ | Fusing Time First Attempt |  | 40 | 50 | 100 | $\mu \mathrm{sec}$ |
|  | Subsequent Attempts |  | 4 | 5 | 10 | msec |
| $\mathrm{t}_{\mathrm{D}}$ | Delays Between Various Level Changes |  | 100 | 200 | 1000 | ns |
| tv | Period During which Output Is Sensed for $\mathrm{V}_{\text {Blown }}$ Level |  |  |  | 500 | ns |
| $V_{\text {ONP }}$ | Pull-Up Voltage on Outputs Not Being Programmed |  | $V_{\text {CCP }}-0.3$ | $V_{\text {CCP }}$ | $\mathrm{V}_{\text {CCP }}+0.3$ | Volts |
| R | Pull-Up Resistor on Outputs Not Being Programmed |  | 1.9 | 2 | 2.1 | ks |

AMD PAL PROGRAMMING EQUIPMENT INFORMATION


The machines noted above have been qualified by AMD to insure high programming yields. Check with the factory to determine the current status of vendors noted TBA or other available models.



## AmPAL*18P8 <br> 20-Pin IMOX ${ }^{\text {M }}$ Programmable Array Logic ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Pin compatible superset of all combinatorial 20 pin PALs .
- Eight logical product terms per output for increased logic power
- Increased input/output flexibility
- 18 possible array inputs
- Eight bidirectional I/Os with individually controllable output enable
- Ulitra high speed version tpD $=15 \mathrm{~ns}$ max
- Superior quality
- Full AC and DC parametric testing performed on every part
- Extensive on-chip test circuitry ensures post-programming functional yield (PPFY) of 99.9\%
- Platinum-Silicide fuses ensure high programming yield $>98 \%$, fast programming and unsurpassed reliability


## GENERAL DESCRIPTION

The AmPAL 18P8 is an ultra-high performance functionally enhanced 20-pin programmable array logic element. It utilizes the familiar sum-of-products (AND-OR) structure allowing users to program custom logic functions to precisely fit their application.
The AmPAL18P8 offers significantly enhanced functional capabilities when compared to other combinatorial 20 pin PAL devices. These include two additional bidirectional I/O pins as well as additional product terms (bringing each output to eight logical product terms and one 3 -state control
product term) for extra logic power. The device also features individual user programmable output polarity, giving the designer the capability to handle both active high and active low outputs on the same device.

A wide variety of speed/power selections is available, allowing precise matching to system requirements. The ultra-high speed version offers 15 ns max input to output propagation delay, opening up many new applications for the use of programmable logic.

*PAL is a registered trademark of and is used under license from Monolithic Memories, Inc. IMOX is a trademark of Advanced Micro Devices, Inc. This document contains information on a product under development at Advanced Micro Devices, Inc. The information is intended to help you to evaluate this product. AMD reserves the right to change or discontinue work on this proposed product without notice.

Order \# 05799A

## FUNCTIONAL DESCRIPTION

The AmPAL18P8 is a functionally enhanced Programmable Array Logic device. The block diagram on page one shows the basic architecture of the AmPAL18P8. There are up to 18 inputs and eight outputs available. The inputs are connected to a programmable AND array which contains 72 logical product terms. Initially the AND gates are connected, via fuses, to both the true and complement of every input. By selective programming of fuses the AND gates may be "connected" to only the true input (by blowing the complement fuse) to only the complement input (by blowing the true fuse), or to neither type of input (by blowing both fuses) establishing a logical "don't care." When both the true and complement fuses are left intact a logical false results on the output of the AND gate. An AND gate with all fuses blown will assume the logical true state.
The AmPAL18P8 has a possible maximum of 18 input pins, two more than previous 20 -pin PALs. The extra inputs extend the functional capabilities of the device which reduces design limitations making it easier to design with and more flexible.
The AmPAL18P8 can be programmed with more complex logic equations due to the eight product terms and one control term for each output. The control terms also allow for each of the eight bi-directional I/Os to be 3-stated, greatly expanding the realm of design possibilities.
The eight bi-directional I/O pins enhance the usefulness of the AmPAL 18P8 by allowing for greater complexity of logic equations and hence more logic power.
The AmPAL18P8 also has programmable output polarity, giving the designer the choice of either active high or active low on each
of the eight outputs. This simplifies the task of programming the 18P8 and allows more freedom in optimizing the logic functions. The high speed version of the AmPAL18P8 boasts 15ns max input to output propagation delay, which makes it the fastest TTL-compatible PAL on the market today, and creates new possibilities for the use of programmable logic devices in a wide variety of applications.
The AmPAL18P8 is manufactured using Advanced Micro Devices' MOX $^{\text {M }}$ oxide isolation process. This advanced process permits an increase in density and a decrease in internal capacitance resulting in the fastest possible programmable logic devices. The AmPAL18P8 is fabricated with AMD's fastprogramming, highly reliable Platinum-Silicide Fuse technology. Utilizing an easily implemented programming algorithm, these products can be rapidly programmed to any customized pattern.
Platinum-Silicide was selected as the fuse-link material to achieve a well-controlled melt rate resulting in large nonconductive gaps that ensure very stable, long-term reliability. Extensive operating testing has proven that this low-field, large gap technology offers the best reliability for fusible link programmable logic.
The AmPAL18P8 has been designed with extensive internal test circuitry that allows the programming and operating circuitry in the part to be thoroughly tested at the factory before programming. This assures excellent programming yield and functional performance to data sheet parameters after programming. The Post-Programming Functional Yield (PPFY) for this device is consistently better than $99.9 \%$.


MAXIMUM RATINGS (Above which the useful life may be impaired)

| Storage Temperature | -65 to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Supply Voltage to Ground Potential (pin 20 to pin 10) Continuous | -0.5 to +7 V |
| DC Voltage Applied to Outputs (except during programming) | -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \mathrm{max}$ |
| DC Voltage Applied to Outputs During Programming | 22 V |
| Output Current into Outputs During Programming (max duration of 1 sec ) | 200 mA |
| DC Input Voltage | -0.5 to +5.5 V |
| DC Input Current | -30 to +5 mA |

## OPERATING RANGE

| Parameters | Description | Commercial |  | Military |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| $V_{C C}$ | Supply Voltage | 4.75 | 5.25 | 4.50 | 5.50 | V |
| $\mathrm{T}_{\text {A }}$ | Operating Free Air Temperature | 0 | 75 | -55 |  | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\mathrm{C}}$ | Operating Case Temperature |  |  |  | 125 | ${ }^{\circ} \mathrm{C}$ |

## ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted)

| Paramete | Description | Test Conditions |  |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M i n \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{I}^{\mathrm{OH}}=-3.2 \mathrm{~mA}$ |  | COM'L | 2.4 | 3.5 |  | Volts |
|  |  |  | ${ }^{1} \mathrm{OH}$ | $-2 \mathrm{~mA}$ | MIL |  |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voitage | $\begin{aligned} & V_{C C}=\mathrm{Min} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ | $\mathrm{I}_{\mathrm{OL}}=24 \mathrm{~mA}$ |  | COM'L |  |  | 0.50 | Volts |
|  |  |  | $\mathrm{I}_{\mathrm{OL}}=$ | 12 mA | MIL |  |  |  |  |
| $\begin{aligned} & V_{1 \mathrm{H}} \\ & \text { (Note 2) } \end{aligned}$ | Input HIGH Level | Guaranteed Input Logical HIGH Voltage for All Inputs |  |  |  | 2.0 |  |  | Volts |
| $\begin{aligned} & V_{\mathrm{IL}} \\ & \text { (Note 2) } \end{aligned}$ | Input LOW-Level | Guaranteed Input Logical LOW Voltage for All Inputs |  |  |  |  |  | 0.8 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.40 \mathrm{~V}$ |  |  |  |  | -20 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  |  | 25 | $\mu \mathrm{A}$ |
| I | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  |  | 1.0 | mA |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ (Note 3) |  |  |  | -30 | -60 | -90 | mA |
| ${ }^{1} \mathrm{CC}$ | Power Supply Current | All Inputs $=$ GND, $\mathrm{V}_{\mathrm{CC}}=$ Max |  | 18P8A, 18P8B |  |  |  | 155 | mA |
|  |  |  |  | 18P8L, 18P8AL |  |  |  | 80 |  |
|  |  |  |  | 18P8Q |  |  |  | 40 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=M i n, l_{\text {N }}=-18 \mathrm{~mA}$ |  |  |  |  | -0.9 | -1.2 | Voits |
| ${ }^{\text {IOZH }}$ | Output Leakage Current | $\begin{aligned} & V_{C C}=M a x, V_{\mathrm{IL}}=0.8 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{H}}=2.0 \mathrm{~V} \end{aligned}$ |  | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{l}_{\mathrm{O} L}$ |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -250 |  |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{1 \mathrm{~N}}=2.0 \mathrm{~V} @ t=1 \mathrm{MHz}$ (Note 4) |  |  |  |  | 6 |  |  |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{~V} @ f=1 \mathrm{MHz}$ (Note 4) |  |  |  |  | 9 |  |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{C}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. These are absolute values with respect to device ground and all overshoots due to system or tester noise are included.
3. Not more than one output should be tested at a time. Duration of the short circuit should not be more than one second. $\mathrm{V}_{\mathrm{OUT}}=0.5 \mathrm{~V}$ has been chosen to avoid test problems caused by tester ground degradation.
4. These parameters are not $100 \%$ tested, but are periodically sampled.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameter | Description | Commercial |  |  |  |  |  | Military |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | B |  | A/AL |  | L/Q |  | - ${ }^{\text {crex }}$ |  | A/AL |  | L/Q |  |  |
|  |  | Typ | Max | Typ | Max | Typ | Max | Typ | Max | Typ | Max | Typ | Max |  |
| $t_{P D}$ | Input to Output Delay | 8 | 15 | 12 | 25. | $17{ }^{17}$ | 35. | 8 | 20.1 | 12 | 30 | 17 | 40 | ns |
| $t_{\text {EA }}$ | Input to Output Enable | 8 | 15 | 12 | 25 | ${ }^{17}$ | W35 | 8 | 20 | 12 | 30 | 17 | 40 | ns |
| $t_{\text {ER }}$ | Input to Output Disable | 8 | 45 | -12 | 25 | 17 \% | 135* | 8 | 20 | 12 | 30 | 17 | 40 | ns. |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}_{3}$
2. $t_{P D}$ is tested with switch $S_{1}$ closed and $C_{L}=50 \mathrm{pF}$
3. For three-state output, output enable times are tested with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ to the 1.5 V level; $\mathrm{S}_{1}$ is open for high impedance to HIGH tests and closed for high impedance to LOW tests. Output disable times are tested with $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$. HIGH to high impedance tests are made to an output voltage of $\mathrm{V}_{\mathrm{OH}}-0.5 \mathrm{~V}$ with $\mathrm{S}_{1}$ open; LOW to high impedance tests are made to the $\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$ level with $\mathrm{S}_{1}$ closed.


SWITCHING WAVEFORMS


05799A-6

KEY TO TIMING DIAGRAM

| WAVEFORM | inputs | OUTPUTS | WAVEFORM | InPUTS | OUTPUTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MUST BE STEADY | WILL BE STEADY | $\pm 10 x$ | DON'T CARE; ANY CHANGE PERMITTED | changing; STATE UNKNOWN |
| . |  |  |  | DOES NOT APPLY | CENTER LINE IS HIGH IMPEDANCE OFF" STATE |



## PROGRAMMING

Each AMD PAL fuse is programmed with a simple sequence of voltages applied to two control pins ( 1 and 11) and a programming voltage pulse applied to the output being programmed. Addressing of the 2600 element fuse array is accomplished with TTL and $\mathrm{V}_{\mathrm{HH}}$ levels on eight input pins (five select the input line number and three select the product term number). $V_{C C}$ is maintained at a normal level throughout the programming and verify cycle - no extra high $\mathrm{V}_{\mathrm{CC}}$ levels are required.
The necessary sequence of levels for programming any fuse is shown in the Programming Timing Diagram. The address of each fuse in terms of Input Line Number and Product Term Line Number is defined by the Fuse Address Tables 1 and 2. Current, voltage and timing requirements for each pin are specified in the Programming Parameter Table on the following page.
After all programming has been completed, the entire array should be reverified at $\mathrm{V}_{\mathrm{CCL}}$ and again at $\mathrm{V}_{\mathrm{CCH}}$. Reverification can be accomplished by reading all eight outputs in parallel rather than one at a time. The array fuse verification cycle checks that the correct array fuses have been blown and can be sensed by the outputs.

AMD PALs have been designed with many internal test features that are used to assure high programming yield and correct logical operation for a correctly programmed part.
An additional fuse is provided on each AMD PAL circuit to prevent unauthorized copying of AMD PAL fuse patterns when design security is desired. Blowing the security fuse blocks entry to the fuse pattern verify mode.
To blow the security fuse:

1) Power to $V_{C C P}$
2) Raise pin 11 to $\mathrm{V}_{\mathrm{OH}}$
3) Pulse pin 5 to $\mathrm{V}_{\mathrm{HH}}$ for 50 microseconds 10 times
4) Reverify the entire array. A secured device will verify as if all fuses in the array are blown
Note that parts with the security fuse blown may not be returned as programming rejects.
AMD PALs normally have high programming yields ( $>98 \%$ ). Programming yield losses are frequently due to poor socket contact, equipment out of calibration or improperly used.

| Design Aid Software for AmPAL18P8 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Name | Vendor | Versions | Notes |  |
| ABEL | $\begin{gathered} \text { Data I/O } \\ \text { (206) } 881-6444 \end{gathered}$ | IBM PC VAX/VMS VAX/UNIX | Under Development |  |
| CUPL | Assisted Technology (408) 942-8787 | IBM PC VAX/VMS VAX/UNIX CPM 80/86 | Under Development |  |
| PLPL | $\begin{gathered} \text { AMD } \\ \text { (408) } 732-2400 \end{gathered}$ | IBM PC VAX/VMS VAX/UNIX | Under Development |  |
| AMD Qualified Programmers |  |  |  |  |
| Name | Programmer Model(s) | AMD PAL Personality Module |  | Socket Adapter |
| Data I/O <br> 10525 Willow Road N.E. <br> Redmond, WA 98052 | Model 19 or 29 | Under Development |  | Under Development |
| Stag Microsystems 528-5 Weddell Drive Sunnyvale, CA 94086 | Model PPX or ZL.30 | Under Development |  | N/A |
| Kontron Electronics 630 Price Avenue Redwood City, CA 94036 | Model MMP-80S or EPP80 | Under Development |  | N/A |
| Structured Design 1700 Wyatt Drive Suite 3 <br> Santa Clara, CA 95084 | SD-1000 | Under Development |  | N/A |
| Valley Data Sciences 2426 Charleston Road Mountain View, CA 94043 | 160 Series | Under Development |  | N/A |
| Varix Corporation 122 Spanish Village Suite 608 Dallas, TX 75248 | OMNI Programmer | Under Development |  | N/A |
| Wavetek Digelec 586 Weddell Drive Suite 1 <br> Sunnyvale, CA 94089 | Model 803 | Under Development |  | Under Development |

PROGRAMMING PARAMETERS $T_{A}=25^{\circ} \mathrm{C}$

| Parameters |  | ption | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{HH}}$ | Control Pin Extra High Level | Pin 1 and $11 @ 10-40 \mathrm{~mA}$ | 10 | 11 | 12 | Volts |
|  | Address Extra High Level | Pin 4, 5, and 9 @ $\mathrm{V}_{\mathrm{HH}}$ |  |  |  |  |
| $\mathrm{V}_{\mathrm{OP}}$ | Program Voltage Pins 12-19@ 15-200mA |  | 18 | 20 | 22 | Volts |
| $\mathrm{V}_{\mathrm{IHP}}$ | Input High Level During Programming and Verify |  | 2.4 | 5 | 5.5 | Votts |
| $\mathrm{V}_{\text {ILP }}$ | Input Low Level During Programming and Verity |  | 0.0 | 0.3 | 0.5 | Volts |
| $V_{\text {CCP }}$ | $V_{C C}$ During Programming @ $I_{C C}=50-200 \mathrm{~mA}$ |  | 5 | 5.2 | 5.5 | Volts |
| $V_{\text {CCL }}$ | $V_{C C}$ During First Pass Verification @ $\mathrm{I}_{\text {cC }}=50-200 \mathrm{~mA}$ |  | 4.4 | 4.5 | 4.6 | Volts |
| $\mathrm{V}_{\mathrm{CCH}}$ | $\mathrm{V}_{\text {CC }}$ During Second Pass Veritication @ ICC $=50-200 \mathrm{~mA}$ |  | 5.4 | 5.5 | 5.6 | Volts |
| $\mathrm{V}_{\text {Blown }}$ | Successful Blown Fuse Source Level @ Output |  |  | 0.3 | 0.5 | Volts |
| $\mathrm{d} \mathrm{V}_{\text {OP/ }} / \mathrm{dt}$ | Rate of Output Voltage Change |  | 20 |  | 250 | $\mathrm{V} / \mu \mathrm{sec}$ |
| $\mathrm{dV}_{11} / \mathrm{dt}$ | Rate of Fusing Enable Voltage Change (pin 11 rising edge) |  | 100 |  | 1000 | $\mathrm{V} / \mu \mathrm{sec}$ |
| tp | Fusing Time First Attempt |  | 40 | 50 | 100 | $\mu \mathrm{sec}$ |
|  | Subsequent Attempts |  | 4 | 5 | 10 | msec |
| $t_{0}$ | Delays Between Various Level Changes |  | 100 | 200 | 1000 | ns |
| tv | Period During which Output Is Sensed for $V_{\text {Blown }}$ Level |  |  |  | 500 | ns |
| $\mathrm{V}_{\text {ONP }}$ | Pull-Up Voltage On Outputs Not Being Programmed |  | $\mathrm{V}_{\text {CCP }}-0.3$ | $\mathrm{V}_{\mathrm{CCP}}$ | $\mathrm{V}_{\text {CCP }}+0.3$ | Volts |
| R | Pull-Up Resistor On Outputs Not Being Programmed |  | 1.9 | 2 | 2.1 | k $\Omega$ |

PROGRAMMING WAVEFORMS


05799A-8
*The pulse to $V_{I H P}$ on pin 1 is unnecessary for fuse verification on combinatorial parts. It is used as a clock puise on registered parts and is kept to maintain algorithm compatibility.

TABLE 1. INPUT ADDRESSING

| Input <br> Line Number | Input Line Number Address Pin States |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 9 | 8 | 7 | 6 | 5 |
| 0 | L | L | L | L | L |
| 1 | L | L | L | L | H |
| 2 | L | L | L | H | L |
| 3 | L | L | L | H | H |
| 4 | L | L | H | L | L |
| 5 | L | L | H | L | H |
| 6 | L | L | H | H | L |
| 7 | L | L | H | H | H |
| 8 | L | H | L | L | L |
| 9 | L | H | L | L | H |
| 10 | L | H | L | H | L |
| 11 | L | H | L | H | H |
| 12 | $L$ | H | H | L | L |
| 13 | $L$ | H | H | L | H |
| 14 | L | H | H | H | L |
| . 15 | L | H | H | H | H |
| 16 | H | L | $L$ | L | L |
| 17 | H | L | L | L | H |
| 18 | H | $L$ | L | H | L |
| 19 | H | L | L | H | H |
| 20 | H | L | H | L | L |
| 21 | H | L | H | L | H |
| 22 | H | L | H | H | L |
| 23 | H | L | H | H | H |
| 24 | H | H | L | L | L |
| 25 | H | H | L | L | H |
| 26 | H | H | L | H | L |
| 27 | H | H | L | H | H |
| 28 | H | H | H | L | L |
| 29 | H | H | H | $L$ | H |
| 30 | H | H | H | H | 1 |
| 31 | H | H | H | H | H |
| 32 | HH | L | L | L | L |
| 33 | HH | L | L | L | H |
| 34 | HH | L | L | H | L |
| 35 | HH | L | L | H | H |
| 36* | HH | L | H | L | $L$ |

$\mathrm{L}=\mathrm{V}_{\mathrm{ILP}}$
$H=V_{I H P}$
$H H=V_{H H}$
*Output polarity.

SIMPLIFIED PROGRAMMING DIAGRAM


TABLE 2. PRODUCT TERM ADDRESSING

| Product Term Line Number |  |  |  |  |  |  |  | Product Term Select Address Pin |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | 4 | 3 | 2 |
| 0 | 9 | 18 | 27 | 36 | 45 | 54 | 63 | L | L | L |
| 1 | 10 | 19 | 28 | 37 | 46 | 55 | 64 | L | L | H |
| 2 | 11 | 20 | 29 | 38 | 47 | 56 | 65 | L. | H | L |
| 3 | 12 | 21 | 30 | 39 | 48 | 57. | 66 | L | H | H |
| 4 | 13 | 22 | 31 | 40 | 49 | 58 | 67 | H | L | L |
| 5 | 14 | 23 | 32 | 41 | 50 | 59 | 68 | H | L | H |
| 6 | 15 | 24 | 33 | 42 | 51 | 61 | 69 | H | H | $L$ |
| 7 | 16 | 26 | 34 | 43 | 52 | 61 | 70 | H | H | H |
| 8 | 17 | 26 | 35 | 44 | 53 | 62 | 71 | HH | L | L |
| P | P | P | P | P | P | P | P | HH | L | H |
| Pin | Pin | Pin | Pin | Pin | Pin | Pin | Pin | $\begin{aligned} & L=V_{1 L P} \\ & H=V_{I H P} \\ & H H=V_{H H} \end{aligned}$ |  |  |
| 19 | 18 | 17 | 16 | 15 | 14 | 13 | $12$ |  |  |  |
| Programming Access and Verify Pin |  |  |  |  |  |  |  |  |  |  |



ORDERING INFORMATION


Chip-Paks are rated at maximum case temperature only.
*Standard speed/standard power not available. Only standard speed/half power and standard speed/quarter power available.


# AmPAL*22V10 <br> 24-Pin IMOX ${ }^{\text {iM }}$ Programmable Array Logic 

## DISTINCTIVE CHARACTERISTICS

- Second generation PAL architecture
- Increased logic power - up to 22 inputs and 10 outputs
- Increased product terms - average 12 per output
- Variable product term distribution improves ease of use
- Each output USER PROGRAMMABLE for registered or combinatorial operation
- Individually USER PROGRAMMABLE output polarity
- Extra terms provide logical synchronous PRESET and asynchronous RESET capability
- Comes in standard and high speed versions - 15 ns typical propagation delay
- TTL level PRELOAD for improved testability
- Packaged in SLIMDIP ( 300 mil ) 24 pin package
- Platinum Silicide fuses ensure high programming yield, fast programming and unsurpassed reliability
- Full $A C$ and $D C$ testing done at the factory utilizing special - designed-in test features



## GENERAL DESCRIPTION

The AmPAL22V10 is a second generation Programmable Array Logic device. It utilizes the familiar sum-of-products (AND-OR) logic structure, allowing users to program custom logic functions. The AmPAL22V10 is an extension of the PAL concept. First generation devices were largely limited to TTL replacement applications. The AmPAL22V10 permits the development of custom LSI functions of 500 to 800 equivalent gate complexity.
The AmPAL22V10 contains up to 22 inputs and 10 outputs. It incorporates the unique capability of defining and programming the architecture of each output on an individual basis. Each output is user programmable for either registered or combinatorial operation. This allows the designer to optimize the device design, by having only as many registers as needed. In addition each output has user programmable output polarity, further simplifying design and contributing to precise applications requirements.
Increased logic power has been built into the AmPAL22V10 by increasing the number of product terms from 8 per output to an average of 12 per output. Further innovation can be seen in the introduction of variable product term distribution. This technique allocates from 8 to 16 logical product terms to each output (please refer to block diagram for distribution details.) This variable allocation of terms allows far more complex functions to be implemented than in previous devices.
System operation has been enhanced by the addition of a synchronous PRESET and an asynchronous RESET product term. These terms are common to all outputs.
The AmPAL22V10 also incorporates power-up reset and the unique capability to PRELOAD the output registers to any desired state during testing. PRELOAD is essential to permit full logical verification during test.


IMOX is a trademark of Advanced Micro Devices, Inc. *PAL is a registered trademark of and is used under license from Monolithic Memories, Inc. This document contains information on a product under development at Advanced Micro Devices, Inc. The information is intended to help you to evaluate this product. AMD reserves the right to change or discontinue work on this proposed product without notice.

Order \# 04162B

## FUNCTIONAL DESCRIPTION

The AmPAL22V10 is a second generation Programmable Array Logic device. It contains a programmable fuse array organized in the familiar sum-of-products (AND-OR) structure.

The block diagram below shows the basic architecture of the AmPAL22V10. There are up to 22 inputs and 10 outputs available. The inputs are connected to a programmable AND array which contains 120 logical product terms. Initially the AND gates are connected, via fuses, to both the true and complement of every input. By selective programming of fuses the AND gates may be "connected" to only the true input (by blowing the complement fuse), to only the complement input (by blowing the true fuse), or to neither type of input (by blowing both fuses) establishing a logical "don't care". When both the true and complement fuses are left intact a logical false results on the output of the AND gate. An AND gate with all fuses blown will assume the logical true state. The outputs of the AND gates are connected to fixed OR gates. There are an average of 12 product terms per OR gate (output) and as the block diagram shows, variable product term distribution has been implemented. This technique allocates different quantities of logical product terms to different outputs, allowing more complex logical functions to be performed than were previously possible. Up to 16 logical terms can be evaluated in one output in a single clock cycle (no feedback necessary).

A dramatic, innovation in logic design is the implementation on the AmPAL22V10 of variable output architecture. This allows the user to program on an output by output basis the function of the outputs. As shown in the output logic Macrocell diagram below, each output cell contains two additional fuses ( $\mathrm{R}_{\mathrm{n}}$ and $\mathrm{P}_{\mathrm{n}}$ ). $R_{n}$ controls whether the output will be registered or combinatorial. $P_{n}$ controls the output polarity (active HIGH or active LOW). Depending on the states of these 2 fuses, an individual output will operate in one of four modes (see logic diagrams on next page). Registered active LOW; Registered active HIGH; Combinatorial active LOW; Combinatorial active HIGH. (Note that the feedback path also changes with output mode.) This innovation gives the designer more flexibility and enables him to optimize the device for precise application requirements. It also allows for better device utilization - you only program as many registers as are needed.
To improve in-system functionality the AmPAL22V10 has additional PRESET and RESET product terms. These terms are connected to all registered outputs. When the synchronous PRESET product term is asserted (HIGH) the output registers will be loaded with a HIGH on the next LOW-to-HIGH clock transition. When the asynchronous RESET product term is asserted (HIGH) the output registers will be immediately loaded with a LOW (independent of the clock). These functions are particularly useful for applications such as system power-on and reset.


OUTPUT LOGIC MACROCELL DIAGRAM


| $\mathbf{S}_{\mathbf{1}}$ | $\mathbf{S}_{\mathbf{0}}$ | Output Configuration |
| :---: | :---: | :--- |
| 0 | 0 | Registered/Active Low |
| 0 | 1 | Registered/Active High |
| $\mathbf{1}$ | 0 | Combinatorial/Active Low |
| 1 | 1 | Combinatorial/Active High |

$0=$ Unblown Fuse
1 = Blown Fuse
$041628-4$

In order to simplify testing problems, the AmPAL22V10 is designed with unique PRELOAD circuitry that provides an easy method of testing registered devices for logical functionality. PRELOAD allows any arbitrary state value to be loaded into the output registers.
A typical functional test sequence would be to verify all possible state transitions for the device being tested. To verify these transitions requires the ability to set the state registers into an arbitrary "present state" value and to set the device inputs to any arbitrary "present input" value. Once this is done, the state machine is then clocked into a new state, or "next state". The next state is then checked to validate the transition from the present state. In this way any state transition can be checked.
Without PRELOAD, it is difficult and in some cases impossible to load an arbitrary present state value. This can lead to logic verification sequences that are either incomplete or excessively long. Long test sequences result when the feedback from the state register "interferes" with the inputs, forcing the state machine to go through many state transitions before it can reach an arbitrary state value. Therefore the test sequence will be mostly state initialization and not actual testing. The test sequence becomes excessively long when a state must be reentered many times to test a wide variety of input combinations.
In addition, complete logic verification may become impossible when states that need to be tested can not be entered with normal state transitions. For example, the state which the machine powers up into cannot be tested because it cannot be entered from
the main sequence. Similarly, "forbidden" or don't care states that are not normally entered need to be tested to ensure that they return to the main sequence.
PRELOAD eliminates these problems by providing the capability to go directly to any desired arbitrary state. Thus test sequences may be greatly shortened, and all possible states can be tested, greatly reducing test time and development costs, and guaranteeing proper in-system operation.
The AmPAL22V10 is manufactured using Advanced Micro Devices' MOX $^{\text {TM }}$ oxide isolation process. This advanced process permits an increase in density and a decrease in internal capacitance resulting in the fastest possible programmable logic devices.
The AmPAL22V10 is fabricated with AMD's fast programming, highly reliable Platinum-Silicide Fuse technology. Utilizing an easily implemented programming algorithm, these products can be rapidly programmed to any customized pattern. Extra test words are preprogrammed during manufacturing to ensure extremely high field programming yields ( $>98 \%$ ), and provide extra test paths to achieve excellent parametric correlation.

Platinum-Silicide was selected as the fuse link material to achieve a well controlled melt rate resulting in large nonconductive gaps that ensure very stable, long term reliability. Extensive operating testing has proven that this low-field, largegap technology offers the best reliability for fusible link programmable logic.

## REGISTERED/ACTIVE LOW



REGISTERED/ACTIVE HIGH


COMBINATORIAL/ACTIVE LOW


04162B-6
COMBINATORIAL/ACTIVE HIGH


041628-8

## KEY TO LOGIC DIAGRAM



Programmable AND Array
PAL Logic Diagram Representation


Programmable AND Array
Logic Equivalent


MAXIMUM RATINGS (Above which the useful life may be impaired)

| Storage Temperature | -65 to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Supply Voltage to Ground Potential (Pin 24 to Pin 12) Continuous | -0.5 to +7 V |
| DC Voltage Applied to Outputs (Except During Programming) | -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \mathrm{Max}$ |
| DC Voltage Applied to Outputs During Programming | 21 V |
| Output Current Into Outputs During Programming (Max Duration of 1 sec) | 200 mA |
| DC Input Voltage | -0.5 to +5.5 V |
| DC Input Current | -30 to +5 mA |
| Ambient Temperature with Power Applied | $+125^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Parameters | Description | Commercial |  | Military |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.75 | 5.25 | 4.50 | 5.50 | V |
| $\mathrm{T}_{\text {A }}$ | Operating Free Air Temperature | 0 | 75 | -55 |  | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\mathrm{C}}$ | Operating Case Temperature |  |  |  | 125 | ${ }^{\circ} \mathrm{C}$ |

ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Uniess Otherwise Noted)

| Parameter | Description | Test Conditions |  |  | Typ <br> Min <br> (Note 1) |  | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}^{\text {O }}$ | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M!N, \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{IOH}=-3.2 \mathrm{~mA}$ | COM'L | 2.4 | 3.5 |  | Volts |
|  |  |  | $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ | MIL |  |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{IOL}^{\text {a }}=16 \mathrm{~mA}$ | COM'L |  |  | 0.50 | Volts |
|  |  |  | $\mathrm{lOL}=12 \mathrm{~mA}$ | MIL |  |  |  |  |
| $V_{i H}$ <br> (Note 2) | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ <br> (Note 2) | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | . | 0.8 | Volts |
| ILL | Input LOW Current | $V_{C C}=M A X, V_{I N}=0.40 \mathrm{~V}$ |  |  |  | -20 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 25 | $\mu \mathrm{A}$ |
| $1 /$ | Input HIGH Current | $V_{C C}=M A X ; V_{\text {iN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1.0 | mA |
| $I_{\text {SC }}$ | Output Short Circuit Current | $V_{C C}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ (Note 3) |  |  | -30 | -60 | -90 | mA |
| ${ }^{\text {I CC }}$ | Power Supply Current | All inputs $=\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  |  |  | 140 | 180 | mA |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  | -0.9 | -1.2 | Volts |
| lozh | Output Leakage Current (Note 4) | $\begin{aligned} & V_{C C}=M A X, V_{I L}=0.8 \mathrm{~V} \\ & V_{I H}=2.0 \mathrm{~V} \end{aligned}$ | $V_{O}=2.7 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| lozl |  |  | $V_{0}=0.4 \mathrm{~V}$ |  |  |  | $-100$ |  |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5) |  |  |  | 6 |  | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5) |  |  |  | 9 |  |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.
2. These are absolute values with respect to device ground and all overshoots due to system or tester noise are included.
3. Not more than one output should be tested at a time. Duration of the short circuit should not be more than one second. VOUT $=0.5 \mathrm{~V}$
has been chosen to avoid test problems caused by tester ground degradation.
4. I/O pin leakage is the worst case of IOZX or IIX (where $X=H$ or L).
5. These parameters are not $100 \%$ tested, but are periodically sampled.

SWITCHING CHARACTERISTICS OVER OPERATING RANGE (Unless otherwise noted)

| Parameters | Description | Test Conditions | Typ (Note 1) | COM'L |  |  |  | , MIL |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | " $A$ " |  | "Std" |  | - "A" " |  | "Std" |  |  |
|  |  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {PD }}$ | Input or Feedback to Non-Registered Output | $\begin{gathered} \text { COM'L } \\ R_{1}=300 \\ R_{2}=390 \end{gathered}$ | 18 |  | 25. |  | 35 | \% | 30 |  | 40 | ns |
| $t_{\text {EA }}$ | Input to Output Enable |  | 18 | , | 25 | - | 35 |  | 30 |  | 40 | ns |
| ter | Input to Output Disable |  | 18 | - | 25 | , \% | 35 |  | 30 |  | 40 | ns |
| tco | Clock to Output |  | ¢ 10 | 大 | 15 |  | 25 |  | 20 |  | 25 | ns |
| $\mathrm{t}_{5}$ | Input or Feedback Setup Time |  | 18 | 25 | \% | 35 |  | 30 |  | 40 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Hold Time |  | -10 | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| tp | Clock Period ( $\mathrm{tS}_{\text {S }}+\mathrm{t}_{\mathrm{CO}}$ ) |  | - | 40 |  | 60 |  | 50 |  | 65 |  | ns |
| ${ }^{\text {tw }}$ | Clock Width |  | $3^{4}$ | 20 | . | 25 |  | 25 |  | 30 |  | ns |
| $f_{\text {MAX }}$ | Maximum Frequency |  |  |  | 25 |  | 16.5 |  | 20 |  | 15 | MHz |
| ${ }^{\text {AW }}$ | Asynchronous Reset Width |  |  |  | 25 |  | 35 |  | 30 |  | 40 |  |
| ${ }^{\text {t }}$ AR | Asynchronous Reset Recovery Time |  |  |  | 25 |  | 35 |  | 30 |  | 40 |  |
| ${ }^{t} A P$ | Asynchronous Reset to Registered Output Reset |  |  |  | 25 |  | 35 |  | 30 |  | 40 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. $t_{P D}$ is tested with switch $S_{1}$ closed and $C_{L}=50 \mathrm{pF}$
3. For three-state outputs, output enable times are tested with $C_{L}=50 \mathrm{pF}$ to the 1.5 V level; $\mathrm{S}_{\boldsymbol{1}}$ is open for high impedance to HIGH tests and closed for high impedance to LOW tests. Output disable times are tested with $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$. HIGH to high impedance tests are made to an output voltage of $\mathrm{V}_{\mathrm{OH}}-0.5 \mathrm{~V}$ with $\mathrm{S}_{1}$ open; LOW to high impedance tests are made to the $\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$ level with $\mathrm{S}_{1}$ closed.

## SWITCHING WAVEFORMS




## PRELOAD OF REGISTERED OUTPUTS

The AmPAL22V10 registered outputs are provided with circuitry to allow loading each register synchronously with either a high or low. This feature will simplify testing since any state can be jammed into the registers to control test sequencing.

The pin levels and timing necessary to perform the PRELOAD function are detailed below. Parameters are listed in the Programming Parameters Table (page 9).


## POWER-UP RESET

The registered devices in the AMD PAL family have been designed with the capability to reset during system power-up. Following power-up, all registers will be reset to low. The output state will depend on the polarity of the output buffer. This feature provides extra flexibility to the designer and is especially valuable in simplifying state machine initialization. A timing diagram and parameter table are shown below. Due to the asynchronous operation of the power-up reset and the wide range of ways $\mathrm{V}_{\mathrm{CC}}$ can rise to its steady state, two conditions are required to insure a valid power-up reset. These conditions are:

1. The $V_{C C}$ rise must be monotonic.
2. Following reset, the clock input must not be driven from low to high until all applicable input and feedback setup times are met.

This feature provides extra flexibility to the designer and is especially valuable in simplifying state machine initialization. A timing diagram and parameter table are shown below.


| Parameters | Description | Min |  |  | Typ |  | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {pr }}$ | Power-Up <br> Reset Time |  | 600 | 1000 | ns |  |  |  |
| $\mathrm{t}_{\mathrm{s}}$ | Input or Feedback <br> Setup Time | See Switching Characteristics |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{w}}$ | Clock Width |  |  |  |  |  |  |  |

## PROGRAMMING AND VERIFICATION

The AmPAL22V10 is programmed and verified using AMD's standard programmable logic programming algorithm. The fuse to be programmed is selected by input line number (array row), product term (array column), and by output (one at a time). The fuse is then programmed and verified by applying a simple -sequence of voltages to two control pins (1 and 13).
Input line numbers ( $0-43$ ) are addressed using a full decode scheme via TTL levels on pins $6-11$ where 6 is the LSB and 11 is the MSB. Even numbered input lines represent the true version of a signal and odd numbered lines represent the complement. Input line addressing is shown in Table 1. Note that input lines 44 - 62 are reserved for further expansion and input line 63 is utilized for selecting the fuses used for programming output polarity and whether the output is registered or combinatorial.
Product terms are addressed using a one-of-24 addressing scheme on pins $2-5$ where pin 2 is the LSB and 5 is the MSB. Product term addressing is shown in Table 2. Logical product terms ( $0-15$ ) are selected via TTL levels on the four addressing pins. Note that outputs with fewer than 16 product terms will decode blank space for decoding values greater than the number of product terms on that output. Architectural product terms are selected by placing a zener voltage level $\left(\mathrm{V}_{\mathrm{HH}}\right)$ on the MSB (pin 5) and using pins 2-4 for an additional eight decoding states (only 5 are used). The specific decoding of architectural features is best shown in Table 2.
Fuse selection by output must be done one output at a time (following control pin 1 going to $\mathrm{V}_{\mathrm{HH}}$ ) as shown in the programming timing diagram (Figure 1).

Once fuses have been selected, the simple programming and verification sequence may be completed as shown in Figure 1. $A C$ and DC requirements for programming are shown in the programming parameter table.

## SECURITY FUSE PROGRAMMING

A single fuse is provided on each AmPAL22V10 part to prevent unauthorized copying of PAL fuse patterns. Once blown, the circuitry enabling fuse verification and registered output preload is permanently disabled.
Programming of the security fuse is the same as an array fuse. Verification of a blown security fuse is accomplished by verifying the whole fuse array as if every fuse is blown.

## PROGRAMMING YIELD

AMD PALs have been designed to insure extremely high programming yields ( $>98 \%$ ). To help insure that a part was correctly programmed, once programming is completed, the entire fuse array should be reverified at both low and high V Cc . Reverification can be accomplished by reading all ten outputs in parallel rather than one at a time. This verification cycle checks that the array fuses have been blown and can be sensed by the outputs under varying conditions.
AMD PALs contain many internal test features, including circuitry and extra fuses which allow AMD to test the ability of each part to perform programming before shipping, to assure high programming yields and correct logical operation for a correctly programmed part. Programming yield losses are most likely due to poor programming socket contact, programming equipment out of calibration, or improper usage of said equipment.

## PROGRAMMING PARAMETERS $\left(T_{\mathrm{A}}=25^{\circ} \mathrm{C}\right)$

| Parameters | Description |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{HH}}$ | Control Pin Extra High Level | Pin 1 @ 10-40mA | 10 | 11 | 12 | Volts |
|  |  | Pin 13 @ 10-40mA | 10 | 11 | 12 |  |
| $\mathrm{V}_{\mathrm{OP}}$ | Program Voltage Pins 14-23 @ 15-200mA |  | 18 | 20 | 22 | Volts |
| $V_{\text {IHP }}$ | Input High Level During Programming and Verify |  | 2.4 | 5 | 5.5 | Volts |
| $V_{\text {ILP }}$ | Input Low Level During Programming and Verity |  | 0.0 | 0.3 | 0.5 | Volts |
| $V_{\text {CCP }}$ | $\mathrm{V}_{\mathrm{CC}}$ During Programming @ ICC $=50-200 \mathrm{~mA}$ |  | 5 | 5.2 | 5.5 | Volts |
| $\mathrm{V}_{\mathrm{CCL}}$ | $V_{\text {cc }}$ During First Pass Verification @ Icc $=50-200 \mathrm{~mA}$ |  | 4.1 | 4.3 | 4.5 | Volts |
| $\mathrm{V}_{\mathrm{CCH}}$ | Vcc During Second Pass Verification @ Icc $=50-200 \mathrm{~mA}$ |  | 5.4 | 5.7 | 6.0 | Volts |
| $\mathrm{V}_{\text {Blown }}$ | Successful Blown Fuse Sense Level @ Output |  |  | 0.3 | 0.5 | Volts |
| $\mathrm{dV}_{\mathrm{OP} / \mathrm{dt}}$ | Rate of Output Voltage Change |  | 20 |  | 250 | $\mathrm{V} / \mu \mathrm{sec}$ |
| $d V_{13} / \mathrm{dt}$ | Rate of Fusing Enable Voltage Change (Pin 13 Rising Edge) |  | 100 |  | 1000 | $\mathrm{V} / \mu \mathrm{sec}$ |
| tp | Fusing Time First Attempt |  | 40 | 50 | 100 | $\mu \mathrm{sec}$ |
|  | Subsequent Attempts |  | 4 | 5 | 10 . | msec |
| t ${ }_{\text {d }}$ | Delays Between Various Level Changes |  | 100 | 200 | 1000 | ns |
| tv | Period During which Output is Sensed for $V_{\text {Blown }}$ Level |  |  |  | 500 | ns |
| $\mathrm{V}_{\text {ONP }}$ | Pull-Up Voltage On Outputs Not Being Programmed |  | $\mathrm{V}_{\mathrm{CCP}}-0.3$ | $\mathrm{V}_{\mathrm{CCP}}$ | $V_{C C P}+0.3$ | Volts |
| R | Pull-Up Resistor On Outputs Not Being Programmed |  | 1.9 | 2 | 2.1 | $\mathrm{k} \Omega$ |

## AmPAL22V10 PROGRAMMING EQUIPMENT INFORMATION

| Source and <br> Location | Data I/O <br> 10525 Willows Rd., N.E. <br> Redmond, WA 98052 | Stag Microsystems <br> $528-5$ Weddel Drive <br> Sunnyvale, CA 94086 | Structured <br> Design, Inc. <br> 1700 Wyatt Dr. \#3 <br> Santa Clara, CA 95054 |
| :--- | :--- | :--- | :--- |
| Programmer <br> Model(s) | Model-100, 29 or 19 | Model ZL-30 | SD 1000 |
| AMD PAL <br> Personality <br> Module | Logicpak <br> $950-1942-001$ | On-Board <br> In Development | On-Board <br> In Development |
| Socket <br> Adapter | $715-1947-003$ <br> In Development | On-Board <br> In Development | On-Board <br> In Development |

The machines noted above have been qualified by AMD to insure high programming yields. Check with the factory to determine the current status of vendors noted TBA, in development, or other available models.

PROGRAMMING WAVEFORMS

$04162 \mathrm{~B}-18$

TABLE 1. INPUT ADDRESSING

| Input Line Number | Input Line Number Address Pin States |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 11 | 10 | 9 | 8 | 7 | 6 |
| 0 | L | L | L | $L$ | L | L |
| 1 | L | L | L | L | L | H |
| 2 | L | L | L | L | H | L |
| 3 | L | L | L | $L$ | H | H |
| 4 | L | L | L | H | L | L |
| 5 | L | L | L | H | L | H |
| 6 | L | L | L | H | H | L |
| 7 | L | L | L | H | H | H |
| 8 | L | L | H | L | L | L |
| 9 | L | L | H | L | L | H |
| 10 | L | L | H | L | H | L |
| 11 | L | L | H | L | H | H |
| 12 | L | L | H | H | L | L |
| 13 | L | L | H | H | L | H |
| 14 | L | L | H | H | H | L |
| 15 | L | L | H | H | H | H |
| 16 | L | H | L | L | L | L |
| 17 | L | H | L | L | L | H |
| 18 | $L$ | H | L | L | H | L |
| 19 | L | H | L. | L | H | H |
| 20 | L | H | L | H | L | 1 |
| 21 | L | H | 1 | H | L | H |
| 22 | L. | H | L | H | H | L |
| 23 | L | H | L | H | H | H |
| 24 | L | H | H | L | L | L |
| 25 | L | H | H | L | 1. | H |
| 26 | L | H | H | $L$ | H | L |
| 27 | L | H | H | L | H | H |
| 28 | L | H | H | H | L | L |
| 29 | L | H | H | H | L | H |
| 30. | L | H | H | H | H | L |
| 31 | L | H | H | H | H | H |


| Input Line Number | Input Line Number Address Pin States |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 11 | 10 | 9 | 8 | 7 | 6 |
| 32 | H | L | L | L | L | L |
| 33 | H | L | L | L | L | H |
| 34 | H | L | L | L | H | L |
| 35 | H | L | L | L | H | H |
| 36 | H | L | L | H | L | L |
| 37 | H | L | L | H | L | H |
| 38 | H | L | L | H | H | 1 |
| 39 | H | L. | L | H | H | H |
| 40 | H | L | H | L | L | L |
| 41 | H | L | H | L | L | H |
| 42 | H | L | H | L | H | L |
| 43 | H | $L$ | H | L | H | H |
|  |  |  |  |  |  |  |
| 63* | H | H | H | H | H | H |

*Architecture row
table 2. COLUMN NUMBER ADDRESSING



## AmPAL*20EV8

## ECL Programmable Array Logic

 ADVANCED INFORMATION
## DISTINCTIVE CHARACTERISTICS

- High performance
- 6 ns TPD, $125 \mathrm{MHz}+$ operation
- Flexible architecture
- Twentv induts includina eiaht I/Os (bidirectional)
- Eight USER programmable output macrocells. Each output user programmable for Registered (Iatched) or Combinatorial operation and active HIGH or active LOW polarity
- Variable product term distribution
- Extra product terms provide asynchronous RESET, synchronous PRESET, and Output Enables
- $10 \mathrm{KH} / 100 \mathrm{~K}$ options
- 50 mA drive with wired-or capability on all outputs.
- 24-pin Slim Dip (300 mil) package


## GENERAL DESCRIPTION

The AmPAL20EV8 is an advanced ECL I/O Programmable Array Logic (PAL) device. It utilizes the familiar Sum-ofProducts (SOP), single array logic structure allowing users to program custom logic functions. Combining the innovative architectural features of the AmPAL22V10 and the advanced bipolar IMOX ${ }^{\text {TM }}$ process technology, the AmPAL20EV8 represents the most advanced ECL PAL device.

The AmPAL20EV8 contains up to 20 inputs and 8 outputs. Incorporating the output logic macrocell concept of the AmPAL22V10, it allows the user to define and program the architecture of each output on an individual basis. Each output is user programmable for either Registered or Combinatorial operation. A latched/combinatorial version will also be offered. Via the output macrocell, the AmPAL20EV8 offers the most flexible architecture allowing the system
designers to tailor the device to their particular application. In addition, each output has user programmable output polarity.
Increased logic power has been built into the AmPAL20EV8 by providing a variable number of logical Product Terms (PTs) per output. Four outputs have 8 logical PTs each and the other four have 12 logical PTs each. This variable allocation of logical PTs allow complex functions to be implemented in a single ECL PAL device. Each output also has separate output enable product terms.
System operation has been enhanced by the addition of a synchronous PRESET and an asynchronous RESET product term. These PTs are common to all outputs. The AmPAL20EV8 also incorporates power-up reset capability on all registered outputs.


IMOX is a trademark of Advanced Micro Devices, Inc. *PAL is a registered trademark of and is used under license from Monolithic Memories, Inc. This document contains information on a product under development at Advanced Micro Devices, Inc. The information is intended to help you to evaluate this product. AMD reserves the right to change or discontinue work on this proposed product without notice.

Order \# 06176A

# Am29PL141 <br> Fuse Programmable Controller (FPC) 

ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Implements complex fuse programmable state machines
- 64 words of 32-bit-wide microprogram memory
- 16 outputs, 7 conditional inputs
- 20 MHz clock rate, 28 pin DIP
- 29 high-level microinstructions
- Conditional branching
- Conditional looping
- Conditional subroutine call
- Multiway branch
- Serial Shadow Register (SSR ${ }^{\text {tM }}$ ) diagnostics on chip (programmable option)


## GENERAL DESCRIPTION

The Am29PL 141 is a single-chip Fuse Programmable Controller (FPC) which allows implementation of complex state machines and controllers by programming the appropriate sequence of microinstructions. A repertoire of jumps, loops, and subroutine calls, which can be conditionally executed based on the test inputs, provides the designer with powerful control flow primitives.
The Am29PL141 FPC also allows distribution of intelligent control throughout the system. It off-loads the central controller by distributing FPCs as the control for various selfcontained functional units, such as register file/ALU, I/O, interrupt, diagnostic, and bus control units.

A microprogram address sequencer is the heart of the FPC. It provides the microprogram address to an internal 64word by 32 -bit PROM. The fuse programming algorithm is almost identical to that used for AMD's Programmable Array Logic family.
As an option, the Am29PL141 may be programmed to have on chip SSR diagnostics capability. Microinstructions can be serially shifted in, executed, and the results shifted out to facilitate system diagnostics.


## FUNCTIONAL DESCRIPTION

Figure 3, the block diagram of the Am29PL141 FPC, shows logic blocks and interconnecting buses. These allow parallel performance of different operations in a single microinstruction. The FPC consists of four main logic blocks: the microprogram memory, microaddress control logic, condition code selection logic, and microinstruction decode. A fifth optional block is the Serial Shadow Fegister (SSR).
The microprogram memory contains the user-defined instruction flow and output sequence. The microaddress control logic addresses the microprogram memory. This control logic supports high-level microinstruction functions including conditional branches, subroutine calls and returns, loops, and multiway branches. The condition code selection logic selects the condition code input to be tested when a conditional microinstruction is executed. The polarity of the selected condition code input is controlled by the POL bit in the microword. The microinstruction decode generates the control signals necessary to perform the microinstruction specified by the microinstruction part
( $\mathrm{P}[31: 16]$ ) of the microword. The SSR enables in-system testing that allows isolation of problems down to the IC level.

## MICROPROGRAM MEMORY

The FPC microprogram memory is a 64 -word by 32 -bit PROM with a 32 -bit pipeline register at its output. The upper 16 bits ( $\mathrm{P}[31: 16]$ ) of the pipeline register stay internal to the FPC and form the microinstruction to control address 'sequencing. The format for microinstructions is: a one-bit synchronous Output Enable OE, a five-bit OPCODE, a one-bit test polarity select POL, a three-bit TEST condition select field, and a six-bit immediate DATA field. The DATA field is used to provide branch addresses, test input masks, and counter values.
The lower 16 bits ( $\mathrm{P}[15: 0]$ ) of the pipeline register are brought out as user-defined, general purpose control outputs. The upper eight control outputs ( $\mathrm{P}[15: 8]$ ) are three-stated when $O E$ is programmed as a LOW. The lower eight control bits ( $\mathrm{P}[7: 0]$ ) are always enabled. The microword and general microinstruction format are shown in Figure 4.

Figure 3. Am29PL141 Block Diagram

**Note: These pins available only in normal mode.

Figure 4.

*Note: This format used only for the compare microinstruction.

## MICROADDRESS CONTROL LOGIC

The microaddress control logic consists of five smaller logic blocks. These are:

PC MUX - The microprogram counter multiplexer
PCNTR - Microprogram counter (PC) and incrementer (PC + 1)
SUBREG - Subroutine register (SREG) with subroutine mux (S MUX)
CNTR - Count register (CREG) with counter mux (C MUX), decrementer (COUNTER-1) and zero detect
GOTO - Specialized branch control logic
The PC MUX is a six-bit, four-to-one multiplexer. It selects either the PC, PC +1 , SREG, or GOTO output as the next microaddress input to the microprogram memory and to the PC. The PC thus always contains the address of the microinstruction in the pipeline register. During a Reset, the PC MUX output is forced to all ones, selecting location 63 of the microprogram memory.
The P CNTR block consists of a six-bit register (PC) driving a six-bit combinatorial incrementer (PC+1). Either the present or the incremented values of PC can address the microprogram PROM. The incremented value of PC can be saved as a subroutine return address. The present PC value can address the microprogram PROM when waiting for a condition to become valid. $\mathrm{PC}+1$. addresses the microprogram PROM for sequential microprogram flow, for unconditional microinstructions, and as a default for conditional microinstructions.
The SUBREG block consists of a six-bit, three-to-one multiplexer (S MUX) driving a six-bit register (SREG). The three possible SREG inputs are PC +1 , CREG, and SREG. SREG normally operates as a one-deep stack to save subroutine return addresses. PC+1 is the input source when performing subroutine calls and PC MUX is the output destination when performing return from subroutine.
The CNTR block consists of a six-bit, four-to-one multiplexer (C MUX); driving a six-bit register (CREG); a six-bit, combinatorial decrementer (COUNTER-1); and a zero detection circuit. The CNTR logic block is typically used for timing functions and iterative loop counting.
The SUBFIEG and CNTR can be considered as one logic block because of their unique interaction. To explain this interaction, notice that both have an additional input source and output destination root used in typical operation - each other. This allows the CRE.G to be an additional stack location when not used for countinf, $\}$, and the SREG to be a nested count location when not used as; a stack location. Thus, the SREG and CREG can operate in t'hree different modes:

1. As a separate one-deep stack and counter
2. As a two-deep stack.
3. As a two-deep nested counter.

The GOTO logic block serves three functions:

1) It provides a six-bit count value from the DATA Field in the pipeline register ( $\mathrm{P}[21: 16]$ ) or from the TEST inputs ( $\mathrm{T}[5: 0]$ ) masked by the DATA Field ( $\mathrm{P}[21: 16]$ ). (This is represented by T*M.)
2) It provides a branch address from the DATA. Field in the pipeline register ( $\mathrm{P}[21: 16]$ ) or from the TEST inputs ( $\mathrm{T}[5: 0]$ ) masked by the DATA Field ( $\mathrm{P}[21: 16]$ ). (This is represented by T*M.)
3) It compares the TEST inputs ( $T[5: 0]$ ) masked by the DATA Field ( $\mathrm{P}[21: 16]$ ), called $\mathrm{T}^{*} \mathrm{M}$, to the CONSTANT Field from the pipeline register $(\mathrm{P}[27: 22])$. If a match occurs, the EQ Flip-flop is set. EQ remains unchanged if there is no match. Constant fie!d bits that correspond to masked test field bits must be zero.
The EQ flag can be tested by the condition code selection logic. Multiple tests of any group of Tinputs in a manner analogous to sum-of-products can be performed since a no match comparison does not reset the EQ flag. Any conditional branch on EQ will reset the EQ flag. Conditional returns on EQ will not change the EQ flag. $\overline{\text { RESET input }}$ Low will reset the EQ flag.

NOTE: A zero in the DATA Field blocks the corresponding bit in the TEST Field; a one activates the corresponding bit.

## CONDITION CODE SELECTION LOGIC

The condition code selection logic consists of an eight-to-one multiplexer. The eight test condition inputs are the device inputs (CC and T[5:0]) and the EQ flag. The TEST field $\mathrm{P}[24: 22]$ selects one of the eight conditions to test.
The polarity bit POL in the microinstructions allows the user to test for either a true or false condition. Refer to Table 2 for details.

## MICROINSTRUCTION DECODE

The microinstruction decoder is a PLA that generates the control for 29 different microinstructions. The decoder's inputs include the OPCODE Field ( $\mathrm{P}[30: 26]$ ), the zero detection output from the CNTR, and the selected test condition code from the conditional code selection logic.

## Am29PL141 SSR DIAGNOSTICS OPTION

As a programmable option, the Am29PL141 FPC may be configured to contain Serial Shadow Register (SSR) diagnostics capability. SSR diagnostics is a simple, straightforward method of in-system testing that allows isolation of problems down to the IC level.

TABLE 1.

| - Inputs |  |  |  | Outputs |  |  | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SDI | MODE | DCLK. | .CLK | SDO | Shadow Register | Pipeline Register |  |
| D | L | $\uparrow$ | H, L, $\downarrow$ | $\mathrm{S}_{0}$ | $\begin{aligned} & \mathrm{S}_{\mathrm{i}}-1 \leftarrow \mathrm{~S}_{\mathrm{i}} \\ & \mathrm{~S}_{31} \leftarrow \mathrm{D} \end{aligned}$ | Hold | Serial Right Shift Register |
| CC | L | H, L, ل | $\dagger$ | $\mathrm{S}_{0}$ | Hold | $\mathrm{P}_{\mathrm{i}} \leftarrow \mathrm{PROM}_{\mathrm{i}}$ | Normal Load Pipeline Register from PROM |
| L | H | $\uparrow$ | H, L, $\downarrow$ | 1 | $S_{i} \leftarrow P_{i}$ | Hold | Load Shadow Register from Pipeline Register* |
| X | H | H, L, $\downarrow$ | $\dagger$ | SDI | Hold | $\mathrm{P}_{\mathrm{i}} \mathrm{S}^{\text {S }} \mathrm{S}$ | Load Pipeline Register from Shadow Register |
| H | H | $\dagger$ | H, L, $\downarrow$ | H | Hold | Hold | Hold Shadow Register |

## FUNCTION TABLE DEFINITIONS

## InPUTS

$\mathrm{H}=\mathrm{HIGH}$
L = LOW
$X=$ Don't Care
$\uparrow=$ LOW-to-HIGH transition
$\downarrow=$ HIGH-to-LOW transition
${ }^{*} \mathrm{~S}_{7}, \mathrm{~S}_{6}$ are undefined. $\mathrm{S}_{15}-\mathrm{S}_{8}$ load from the source driving pins $P[15]-P[8]$. If $P[31]$ in the microword is a one, $S_{15}-S_{8}$ are loaded from the pipeline register. If $\mathrm{P} \mid 31]$ in the microword is a zero, $\mathrm{S}_{15}-\mathrm{S}_{8}$ are loaded from an external source.

TABLE 2.

| Input <br> Condition <br> Being Tested | POL | Condition |
| :---: | :---: | :---: |
| 0 | 0 | Fail |
| 0 | 1 | Pass |
| 1 | 0 | Pass |
| 1 | 1 | Fail |

The SSR diagnostics configuration activates a 32-bit-wide, D-type register, called a "shadow" register, on the pipeline register inputs. The shadow register can be serially loaded from the SDI pin, parallel loaded from the pipeline register, or held. The pipeline regsiter can be loaded from the microprogram memory in normal operation or from the shadow register during diagnostics. A redefinition of four device pins is required to control the different diagnostics functions. CC also functions as the Serial Data input (SDI), $\overline{Z E R O}$ becomes the Serial Data Output (SDO), $P[7]$ becomes the diagnostic clock (DCLK), and $P[6]$ becomes the diagnostic mode control (MODE). The various diagnostic and normal modes are shown in Table 1.

Serially loading a test microinstruction into the shadow register and parallel loading the shadow register contents into the pipeline register forces execution of the test microinstruction. The result of the test microinstruction can then be clocked into the pipeline register, as in normal operation mode, parallel loaded into the shadow register, and serially shifted out for system diagnostics.

The general microinstruction format is shown below:

## Am29PL141 General Microinstruction Format

> WHERE:
> OE $\quad=$ Synchronous Output Enable for $\mathrm{P}[15: 8]$.
> OPCODE $=$ A five-bit opcode field for selecting one of the twenty-eight single data field microinstructions.

POL $\quad=$ A one-bit test condition polarity select.
$0=$ Test for true (HIGH) condition. $1=$ Test for false (LOW) condition.

TEST $=\mathrm{A}$ three-bit test condition select.


DATA $=$ A six-bit conditional branch microaddress, test input mask, or counter value field designated as PL in microinstruction mnemonics.
The special two data field comparison microinstruction format is shown below:

## Am29PL141 Comparison Microinstruction Format



04179C-6

## WHERE:

OE $\quad=$ Synchronous Output Enable for $\mathrm{P}[15: 8]$.
OPCODE $=$ Compare microinstruction (binary 100).
CONSTANT $=\mathrm{A}$ six-bit constant for equal to comparison with $\mathrm{T}^{*} \mathrm{M}$.
DATA $\quad=$ A six-bit mask field for masking the incoming $T[5: 0]$ inputs.

## MICROINSTRUCTION SET TABLE

| Code | Mnemonics | Definition | CREG <br> Content | Pass |  |  | Fail |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | PC <br> MUX | SREG | CREG | $P C$ MUX | SREG | CREG |
| 00 | RETLDPL | Return: Load Pipeline | $x$ | SREG | Hold | Data | $P C+1$ | Hold | Hold |
| 01 | , RETNLDPL | Return Nested: Load Pipeline | X | SREG | CREG | Data | $P C+1$ | Hold | Hold |
| 02 | RET | Return | X | SREG | Hold | Hold | $P C+1$ | Hold | Hold |
| 03 | RETN | Return Nested | X | SREG | CREG | Hold | $P C+1$ | Hold | Hold |
| 04 | LDPL | Load Pipeline | $x$ | $P C+1$ | Hold | Data | $P C+1$ | Hold | Hoid |
| 05 | LDPLN | Load Pipeline Nested | X | $P C+1$ | CREG | Data | $P C+1$ | Hold | Hold |
| 06 | LDTM | Load T*M | X | $P C+1$ | Hold | T*M | $P C+1$ | Hold | Hold |
| 07 | LDTMN | Load T*M Nested | X | $P C+1$ | CREG | T*M | $P C+1$ | Hold | Hold |
| 08 | LPPL | Loop Pipeline | $\neq 0$ | Data | Hold | DCRMT |  |  |  |
|  |  |  | $=0$ | $P C+1$ | Hold | Hold |  |  |  |
| 09 | DEC | Decrement | X | $P C+1$ | Hold | DCRMT | $P C+1$ | Hold | Hold |
| OA | LPPLN | Loop Pipeline Nested | $\neq 0$ | Data | Hold | DCRMT |  | * |  |
|  |  |  | $=0$ | $P C+1$ | Hold | SREG |  |  |  |
| OB | GOTOPLZ | Go to Pipeline Zero | $\neq 0$ | $P C+1$ | Hold | Hold |  |  |  |
|  |  |  | $=0$ | Data | Hold | Hold |  |  |  |
| OC | CTLDPL | Count/Load Pipeline | $\neq 0$ | PC | Hold | DCRMT |  |  |  |
|  |  |  | $=0$ | $P C+1$ | Hold | Data |  |  |  |
| OD | CONT | Continue | x | $\mathrm{PC}+1$ | Hold | Hold | $P C+1$ | Hold | Hold |
| OE | CTLDTM | Count/Load T*M | $\neq 0$ | PC | Hold | DCRMT |  |  |  |
|  |  |  | $=0$ | $P C+1$ | Hold | T*M |  |  |  |
| OF | GOTOTM | Go to T*M | X | T*M | Hold | Hold | $P C+1$ | Hold | Hold |
| $\begin{aligned} & 10-13 \\ & (100 x X \\ & \text { Binary } \end{aligned}$ | CMP | Compare* | $x$ | $P C+1$ | Hold | Hold | $P C+1$ | Hold | Hold |
| 14 * | PSHLDPL | Push: Load Pipeline | x | $P C+1$ | $\mathrm{PC}+1$ | Data | $P C+1$ | Hold | Hold |
| 15 | PSH | Push | $x$ | $P C+1$ | $P C+1$ | Hold | $P C+1$ | Hold | Hold |
| 16 | PSHLDTM | Push: Load T*M | $x$ | $\mathrm{PC}+1$ | $P C+1$ | T*M | $P C+1$ | Hold | Hold |
| 17 | PSHN | Push Nested | X | $P C+1$ | $P C+1$ | SREG | $\mathrm{PC}+1$ | Hold | Hold |
| 18 | FORK | Fork | $X$ | Data | Hold | Hold | SREG | Hold | Hold |
| 19 | GOTOPL | Go to Pipeline | $\times$ | Data | Hold | Hold | $P C+1$ | Hold | Hold |
| 1A | HOLDPL | Hold Pipeline | X | Data | Hold | Hold | PC | Hold | DCRMT |
| 1B | CNTHLDPL | Count: Hold Pipeline | $\neq 0$ | Data | Hold | Hold | PC | Hold | DCRMT |
|  |  |  | $=0$ | $P C+1$ | Hold | Hold | $P C+1$ | Hold | Hold |
| 1 C | CALPL | Call Pipeline | $X$ | Data | $P C+1$ | Hold | $P C+1$ | Hold | Hold |
| 1 D | CALPLN | Call Pipeline Nested | $x$ | Data | $P C+1$ | SREG | $P C+1$ | Hold | Hold |
| 1E | CALTM | Call T*M | $X$ | T*M | $P C+1$ | Hold | $P C+1$ | Hold | Hold |
| 1F | CALTMN | Call T*M Nested | X | T*M | $P C+1$ | SREG | $P C+1$ | Hold. | Hold |

*EQ = ((T[5:0]. AND. DATA). XNOR. CONSTANT).OR. EQ
CONSTANT field bits that correspond to masked test field bits must be zero.
Notes: 1. (/)Signifies two different operations may occur, depending on the condition.
2. (:) Signifies two parallel operations on the same condition.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature . . . . . . . . . . . . . . . . . . . . . . -65 to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias . . . . . . . . . -55 to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
(Pin 28 to Pin 14) Continuous . . . . . . . . . . . . . . . . -0.5 to +7 V
DC Voltage Applied to Outputs (Except
During Programming)
-0.5 V to $\mathrm{V}_{\mathrm{CC}} \max$
DC Voltage Applied to Outputs During
Programming
21V
Output Current Into Outputs During
Programming (Max Duration of 1 sec ) . . . . . . . . . . . . . . . 200mA
DC Input Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.5 to +5.5 V
DC Input Current . . . . . . . . . . . . . . . . . . . . . . . . . . . -30 to +5 mA
Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect reliability

OPERATING RANGE
Commercial (C) Devices

Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted)

| Parameters |  | Test Conditions |  |  | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\mathrm{OH}}$ | Output HIGH Voltage | $V_{C C}=\mathrm{MIN}, \mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{IH}}$ or $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{I}_{\mathrm{OH}}=-$ | COM'L | 2.4 | - | Volts |
|  |  |  | $\mathrm{l}_{\mathrm{OH}}=-$ | MIL |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{IH}}$ or $\mathrm{V}_{\mathrm{IL}}$ | ${ }^{\mathrm{OL}}=$ | COM'L |  | 0.50 | Volts |
|  |  |  | ${ }^{1} \mathrm{OL}=$ | MIL |  |  |  |
| $V_{1 H}$ <br> (Note 1) | Input HIGH Level | Guaranteed Input Logical HIGH Voltage for All Inputs |  |  | 2.0 |  | Volts |
| $\begin{aligned} & V_{11} \\ & \text { (Note 1) } \end{aligned}$ | Input LOW Level | Guaranteed Input Logical LOW Voltage for All Inputs |  |  |  | 0.8 | Volts |
| ILL | Input LOW Current | $V_{C C}=$ MAX, $V_{I N}=0.40 \mathrm{~V}$ |  |  |  |  | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{IH}}$ | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.7 \mathrm{~V}$ |  |  |  | 25 | $\mu \mathrm{A}$ |
| 4 | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| $I_{\text {SC }}$ | Output Short Circuit Current | $V_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ ( Note 2) |  |  |  |  | mA |
| ${ }^{\text {c }}$ C | Power Supply Current | All inputs = GND, $V_{\text {CC }}=\mathrm{MAX}$ |  |  |  | 450 | mA |
| $V_{1}$ | Input Clamp Voltage | $V_{C C}=$ MIN, $\mathrm{I}_{\text {IN }}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| $\mathrm{I}_{\mathrm{OZH}}$ | Output Leakage Current (Note 3) | $\begin{aligned} & V_{C C}=M A X, V_{I L}=0.8 \mathrm{~V} \\ & V_{I H}=2.0 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  |  | $\mu \mathrm{A}$ |
| $\mathrm{l}_{\mathrm{OZL}}$ |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  |  |

Notes: 1. These are absolute values with respect to device ground and all overshoots due to system or tester noise are included.
2. Not more than one output should be tested at a time. Duration of the short circuit should not be more than one second. $\mathrm{V}_{\mathrm{OUT}}=0.5 \mathrm{~V}$ has been chosen to avoid test problems caused by tester ground degradation.
3. $\mathrm{I} / \mathrm{O}$ pin leakage is the worst case of $\mathrm{I}_{\mathrm{OZX}}$ or $\mathrm{I}_{\mathrm{X}}$ (where $\mathrm{X}=\mathrm{H}$ or L ).
4. Those parameters are not $100 \%$ tested, but are periodically sampled.

# Am27S12A • Am27S13A Am27S12•Am27S13 

## 2048-Bit Generic Series Bipolar PROM ( $512 \times 4$ bits with ultra fast access time)

"A" VERSION ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- High Speed - 30ns max commercial range access time
- Excellent performance over full MIL and commercial ranges
- Highly reliable, ultra-fast programming PlatinumSilicide fuses
- High programming yield
- Low current PNP inputs
- High current open collector and three-state outputs
- Fast chip select
- Access time tested with $\mathrm{N}^{2}$ patterns
- Pin for pin replacements for industry standard products
- Common Generic PROM series electrical characteristics and simple programming procedures


## GENERIC SERIES CHARACTERISTICS

The Am27S12A/12 and Am27S13A/13 are members of an Advanced PROM series incorporating common electrical characteristics and programming procedures. All parts in this series are produced with a fusible link at each memory location storing a logic LOW and can be selectively programined to a logic HIGH by applying appropriate voltages to the circuit.

All parts are fabricated with AMD's fast programming highly reliable Platinum-Silicide Fuse technology. Utilizing easily implemented programming (and common programming personality card sets) these products can be rapidly programmed to any customized pattern. Extra test words are pre-programmed during manufacturing to insure extremely high field programming yields, and produce excellent parametric correlation.

Platinum-Silicide was selected as the fuse link material to achieve a well controlled melt rate resulting in large nonconductive gaps that ensure very stable long term reliability. Extensive operating testing has proven that this low-field, large-gap technology offers the best reliability for fusible link PROMs.

Common design features include active loading of all critical AC paths regulated by a built-in temperature and voltage compensated bias network to provide excellent parametric performance over MIL supply and temperature ranges. Selective feedback techniques have been employed to minimize delays through all critical paths producing the fastest speeds possible from Schottky processed PROMs.

## FUNCTIONAL DESCRIPTION

The Am27S12A/12 and Am27S13A/13 are high speed electrically programmable Schottky read only memories. Organized in the industry standard $512 \times 4$ configuration, they are available in both open collector Am27S12A/12 and three-state Am27S13A/13 output versions. After programming, stored information is read on outputs $\mathrm{O}_{0}-\mathrm{O}_{3}$ by applying unique binary addresses to $A_{0}-A_{8}$ and holding the chip select input, $\overline{\mathrm{CS}}$, at a logic LOW. If the chip select input goes to a logic HIGH, $\mathrm{O}_{0}-\mathrm{O}_{3}$ go to the off or high impedance state.


This document contains information on a product under development at Advanced Micro Devices, Inc. The information is intended to help you to evaluate this product. AMD reserves the right to change or discontinue work on this proposed product without notice.

MAXIMUM RATINGS (Above which the useful life may be impaired)

| Storage Temperature | -65 to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Temperature (Ambient) Under Bias | -55 to $+125^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential (Pin 16 to Pin 8) Continuous | -0.5 to +7.0 V |
| DC Voltage Applied to Outputs (Except During Programming) | -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \mathrm{max}$ |
| DC Voltage Applied to Outputs During Programming | 21 V |
| Output Current into Outputs During Programming (Max Duration of 1 sec) | 250 mA |
| DC Input Voltage | -0.5 to +5.5 V |
| DC Input Current | -30 to +5 mA |

## OPERATING RANGE

| Range | $V_{C C}$ | Temperature |
| :---: | :---: | :---: |
| COML | 4.75 to 5.25 V | $T_{A}=0$ to $+75^{\circ} \mathrm{C}$ |
| $M I L$ | 4.5 to 5.5 V | $\mathrm{~T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ |



ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted)

| Parameters | Description | Test Conditions |  |  |  Typ <br> Min (Note 1) |  | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH (Note 2) | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I \\ & V_{I N}=V_{I H} \text { or } \end{aligned}$ | $=-2.0 n$ |  | 2.4 |  | . | Volts |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{I H} \text { or } \end{aligned}$ | $=16 \mathrm{~mA}$ |  |  |  | 0.45 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed voltage for all | ut logical puts (No |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed voltage for all | ut logical puts (No |  |  |  | 0.8 | Volts , |
| ILL | Input LOW Current | $V_{C C}=$ MAX | $\mathrm{N}=0.45 \mathrm{~V}$ |  |  | -0.010 | -0.250 | mA |
| $\mathrm{I}_{\mathrm{H}}$ | Input HIGH Current | $V_{C C}=$ MAX, | $\mathrm{N}=2.7 \mathrm{~V}$ |  |  |  | 25 | $\mu \mathrm{A}$ |
| IsC (Note 2) | Output Short Circuit Current | $V_{C C}=$ MAX, | OUT $=0.0$ |  | -20 | -40 | -90 | mA |
| ${ }^{\text {I C C }}$ | Power Supply Current | All inputs = $V_{C C}=M A X$ |  |  |  | 100 | 130 | mA |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, I | $=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| ${ }^{\text {I CEX }}$ | Output Leakage Current | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MAX} \\ & V_{\overline{\mathrm{CS}}}=2.4 \mathrm{~V} \end{aligned}$ |  | $V_{O}=4.5 \mathrm{~V}$ |  |  | 40 | $\mu \mathrm{A}$ |
|  |  |  | (Note 2) | $V_{O}=2.4 \mathrm{~V}$ |  |  | 40 |  |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ | - |  | -40 |  |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5) |  |  |  | 4 |  | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5 ) |  |  |  | 8 |  |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. This applies to three-state devices only.
3. These are absolute voltages with respect to device ground pin and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment.
4. Not more than one output should be shorted at a time. Duration of the short circuit should not be more than one second.
5. These parameters are not $100 \%$ tested, but are periodically sampled.

# Am27S18A •Am27S19A Am27S18•Am27S19 <br> 256-Bit Generic Series Bipolar PROM ( $32 \times 8$ bits with ultra fast access time) <br> "A" VERSION ADVANCED INFORMATION 

## DISTINCTIVE CHARACTERISTICS

- High Speed - 25ns max commercial range access time
- Excellent performance over full MIL and commercial ranges
- Highly reliable, ultra-fast programming PlatinumSilicide fuses
- High programming yield
- Low current PNP inputs
- High current open collector and three-state outputs
- Fast chip select
- Access time tested with $\mathrm{N}^{2}$ patterns
- Pin for pin replacements for industry standard products
- Common Generic PROM series electrical characteristics and simple programming procedures


## FUNCTIONAL DESCRIPTION

The Am27S18A/18 and Am27S19A/19 are high speed electrically programmable Schottky read only memories. Organized in the industry standard $32 \times 8$ configuration, they are available in both open collector Am27S18A/18 and three-state Am27S19A/19 output versions. After programming, stored information is read on outputs $\mathrm{O}_{0}-\mathrm{O}_{7}$ by applying unique binary addresses to $\mathrm{A}_{0}-\mathrm{A}_{4}$ and holding the chip select input, $\overline{\mathrm{CS}}$, at a logic LOW. If the chip select input goes to a logic $\mathrm{HIGH}, \mathrm{O}_{0}-\mathrm{O}_{7}$ go to the off or high impedance state.

## GENERIC SERIES CHARACTERISTICS

This Am27S18A/18 and Am27S19A/19 are members of an Advanced PROM series incorporating common electrical characteristics and programming procedures. All parts in this series are produced with a fusible link at each memory location storing a logic LOW and can be selectively programmed to a logic HIGH by applying appropriate voltages to the circuit.

All parts are fabricated with AMD's fast programming highly reliable Platinum-Silicide Fuse technology. Utilizing easily implemented programming (and common programming personality card sets) these products can be rapidly programmed to any customized pattern. Extra test words are pre-programmed during manufacturing to insure extremely high field programming yields, and produce excellent parametric correlation.
Platinum-Silicide was selected as the fuse link material to achieve a well controlled melt rate resulting in large non-conductive gaps that ensure very stable long-term reliability. Extensive operating testing has proven that this low-field, large-gap technology offers the best reliability for fusible link PROMs.
Common design features include active loading of all critical AC paths regulated by a built-in temperature and voltage compensated bias network to provide excellent parametric performance over MIL supply and temperature ranges. Selective feedback techniques have been employed to minimize delays through all critical paths producing the fastest speeds possible from Schottky processed PROMs.

BLOCK DIAGRAM


## CONNECTION DIAGRAMS

Top Views

DIP
Chip-Pak ${ }^{\text {m }}$ L-20-1


03209A-2

5 ○ 0


03209A-3

Note: Pin 1 is marked for orientation,

This document contains information on a product under development at Advanced Micro Devices, Inc. The information is intended to help you to evaluate this product. AMD reserves the right to change or discontinue work on this proposed product without notice.

MAXIMUM RATINGS (Above which the useful life may be impaired)

| Storage Temperature | -65 to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Temperature (Ambient) Under Bias | -55 to $+125^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential (Pin 16 to Pin 8) Continuous | -0.5 to +7.0 V |
| DC Voltage Applied to Outputs (Except During Programming) | -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \mathrm{max}$ |
| DC Voltage Applied to Outputs During Programming | 21 V |
| Output Current into Outputs During Programming (Max Duration of 1 sec$)$ | 250 mA |
| DC Input Voltage | -0.5 to +5.5 V |
| DC Input Current | -30 to +5 mA |

## OPERATING RANGE

| Range | $\mathrm{V}_{\mathrm{CC}}$ | Temperature |
| :---: | :---: | :---: |
| COML | 4.75 to 5.25 V | $\mathrm{~T}_{\mathrm{A}}=0$ to $+75^{\circ} \mathrm{C}$ |
| MIL | 4.5 to 5.5 V | $\mathrm{~T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ |



ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted)

| Parameters | Description | Test Conditions |  |  | Min | Typ (Note (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\text {( }}$ (Note 2) | Output HIGH Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MiN}, \mathrm{IOH}_{\mathrm{OH}}=-2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ |  |  | 2.4 |  |  | Volts |
| $V_{\text {OL }}$ | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N, I O L=16 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  |  |  |  | 0.45 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs (Note 3) |  |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs (Note 3) |  |  |  |  | 0.8 | Volts |
| $1 / \mathrm{L}$ | Input LOW Current | $\mathrm{V}_{C C}=$ MAX, $\mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  |  |  | -0.010 | -0.250 | mA |
| ${ }_{1} \mathrm{H}$ | Input HiGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 25 | $\mu \mathrm{A}$ |
| IsC (Note 2) | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ (Note 4) |  |  | -20 | -40 | -90 | mA |
| $\mathrm{I}_{\mathrm{cc}}$ | Power Supply Current | All inputs = GND, $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  |  |  | 90 | 115 | mA |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{l}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | Volts |
| Icex | Output Leakage Current | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MAX} \\ & V_{\mathrm{CS}}=2.4 \mathrm{~V} \end{aligned}$ |  | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 40 | $\mu \mathrm{A}$ |
|  |  |  | (Note 2) | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 40 |  |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -40 |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | $\mathrm{V}_{1 \mathrm{~N}}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5) |  |  |  | 4 |  | pF |
| Cout | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \dot{\mathrm{~V}}$ @ $\mathrm{f}=1 \mathrm{MHz}$ (Note 5) |  |  |  | 8 |  |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. This applies to three-state devices only.
3. These are absolute voltages with respect to device ground pin and include all overshoots due to system and/or tester noise.

Do not attempt to test these values without suitable equipment.
4. Not more than one output should be shorted at a time. Duration of the short circuit should not be more than one second.
5. These parameters are not $100 \%$ tested, but are periodically sampled.

# Am27S20A •Am27S21A Am27S20 • Am27S21 

## 1024-Bit Generic Series Bipolar PROM ( $256 \times 4$ bits with ultra fast access time)

"A" VERSION ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- High Speed - 30ns max commercial range access time
- Excellent performance over full MIL and commercial ranges
- Highly reliable, ultra-fast programming PlatinumSilicide fuses
- High programming yield
- Low current PNP inputs
- High current open collector and three-state outputs
- Fast chip select
- Access time tested with $\mathrm{N}^{2}$ patterns
- Pin for pin replacements for industry standard products
- Common Generic PROM series electrical characteristics and simple programming procedures


## GENERIC SERIES CHARACTERISTICS

The Am27S20A/20 and Am27S21A/21 are members of an Advanced PROM series incorporating common electrical characteristics and programming procedures. All parts in this series are produced with a fusible link at each memory location storing a logic LOW and can be selectively programmed to a logic HIGH by applying appropriate voltages to the circuit.

All parts are fabricated with AMD's fast programming highly reliable Platinum-Silicide Fuse technology. Utilizing easily implemented programming (and common programming personality card sets) these products can be rapidly programmed to any customized pattern. Extra test words are pre-programmed during manufacturing to insure extremely high field programming yields, and produce excellent parametric correlation.
Platinum-Silicide was selected as the fuse link material to achieve a well controlled melt rate resulting in large nonconductive gaps that ensure very stable long term reliability. Extensive operating testing has proven that this low-field, large-gap technology offers the best reliability for fusible link PROMs.
Common design features include active loading of all critical AC paths regulated by a built-in temperature and voltage compensated bias network to provide excellent parametric performance over MIL supply and temperature ranges. Selective feedback techniques have been employed to minimize delays through all critical paths producing the fastest speeds possible from Schottky processed PROMs.

## FUNCTIONAL DESCRIPTION

The Am27S20A/20 and Am27S21A/21 are high speed electrically programmable Schottky read only memories. Organized in the industry standard $256 \times 4$ configuration, they are available in both open collector Am27S20A/20 and three-state Am27S21A/21 output versions. After programming, stored information is read on outputs $\mathrm{O}_{0}-\mathrm{O}_{3}$ by applying unique binary addresses to $A_{0}-A_{7}$ and holding chip select inputs, $\overline{\mathrm{CS}}_{1}$ and $\overline{\mathrm{CS}}_{2}$, at a logic LOW. If either chip select input goes to a logic $\mathrm{HIGH}, \mathrm{O}_{0}-\mathrm{O}_{3}$ go to the OFF or high impedance state.


This document contains information on a product under development at Advanced Micro Devices, Inc. The information is intended to help you to evaluate this product. AMD reserves the right to change or discontinue work on this proposed product without notice.

MAXIMUM RATINGS (Above which the useful life may be impaired)

| Storage Temperature | -65 to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: | ---: |
| Temperature (Ambient) Under Bias | -55 to $+125^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential (Pin 16 to Pin 8) Continuous | -0.5 to +7.0 V |
| DC Voltage Applied to Outputs (Except During Programming) | -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \mathrm{max}$ |
| DC Voltage Applied to Outputs During Programming $\quad$. | 21 V |
| Output Current into Outputs During Programming (Max Duration of 1 sec) | 250 mA |
| DC Input Voltage. | -0.5 to +5.5 V |
| DC Input Current | -30 to +5 mA |

## OPERATING RANGE

| Range | $V_{\text {CC }}$ | Temperature |
| :---: | :---: | :---: |
| COML | 4.75 to 5.25 V | $\mathrm{~T}_{\mathrm{A}}=0$ to $+75^{\circ} \mathrm{C}$ |
| MIL | 4.5 to 5.5 V | $\mathrm{~T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ |

ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted)

| Parameters | Description | Test Conditions |  |  | Min | $\begin{aligned} & \text { Typ } \\ & \text { (Note 1) } \end{aligned}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\text {( }}$ (Note 2) | Output HIGH Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{H}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ |  |  | 2.4 |  |  | Volts |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O L}=16 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & \hline \end{aligned}$ |  |  |  |  | 0.45 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs (Note 3) |  |  | 2.0 |  |  | Volts |
| VIL | Input LOW Level | Guaranteed input logical LOW voltage for all inputs (Note 3) |  |  |  |  | 0.8 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  |  |  | -0.010 | -0.250 | mA |
| IIH | Input HIGH Current | $\mathrm{V}_{C C}=$ MAX, $\mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 25 | $\mu \mathrm{A}$ |
| ISC (Note 2) | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ ( Note 4) |  |  | -20 | -40 | -90 | mA |
| ${ }^{\text {c }} \mathrm{C}$ | Power Supply Current | $\begin{aligned} & \text { All inputs = GND } \\ & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \end{aligned}$ |  |  |  | 100 | 130 | mA |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=$ MIN, $1 \mathrm{l} \mathrm{IN}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | Volts |
| Icex | Output Leakage Current | $\begin{aligned} & V_{C C}=\mathrm{MAX} \\ & V_{\mathrm{CS}_{1}}=2.4 \mathrm{~V} \end{aligned}$ |  | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 40 | $\mu \mathrm{A}$ |
|  |  |  | (Note 2) | $\mathrm{V}_{0}=2.4 \mathrm{~V}$ |  |  | 40 |  |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -40 |  |
| $\mathrm{Cin}_{\text {in }}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5) |  |  |  | 4 |  | pF |
| Cout | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5 ) |  |  |  | 8 |  |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{C}} \mathrm{C}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. This applies to three-state devices only.
3. These are absolute voltages with respect to device ground pin and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment.
4. Not more than one output should be shorted at a time. Duration of the short circuit should not be more than one second.
5. These parameters are not $100 \%$ tested, but are periodically sampled.

## Section 3

## How to Design with PALs

Introduction to Fuse Maps and Design Examples<br>Exclusive-OR<br>The Multiplexer<br>Decoding/Chip Select<br>Shift Registers<br>The Counter

## How to Design with PALs

Since any Boolean function can be expressed in the sum-ofproducts form, any logic function can be implemented in a PAL as long as the number of inputs, outputs and product terms required to perform the function do not exceed what is available in the device. There are many ways of deriving this sum-of-products form, one common way is by the use of Karnaugh maps (K-Maps). When implementing functions in PALs with active HIGH outputs (AND-OR), the usual method of grouping the " 1 "s will produce the desired equations (see Figure 1a). However, when using PALs with active LOW outputs (AND-OR-INVERT), the sum-of-products equations are obtained by grouping the " 0 "s (Figure 1b). Grouping the " 0 " $s$ instead of the " 1 "s has the effect of inverting the equations. This is a convenient technique for generating inverted logic for use with active LOW PALs.
When using PALs, the term "product term" is often used. This is simply another way of describing an AND function. Referring again to Figure 1a, since there are 3 logical AND terms in
the function equation, we would say that it would require 3 product terms to perform that function. The phrase "product term" is often abbreviated as "PT".

A demonstration of an early methodology used to relate logic equations to the internal structure of PALs is shown in the design example. This is a technique which relies on the hand generation of fuse maps. As you might imagine, it is slow and extremely cumbersome, but is included for the interested reader. Instead, to aid in the development of PAL designs, a software tool called PALASM has been developed. This tool greatly speeds the development of PAL designs. AMD offers a version of this called AMPALASM20, which supports all AMD 20-pin PALs, and offers improved ease of use and error detection. AMPALASM20 has been used in most of the examples in this section. Its use is described more fully in Section 4 of this handbook.

$f=\mathrm{C} \cdot \overline{\mathrm{D}}+\mathrm{A} \cdot \overline{\mathrm{D}}+\mathrm{B} \cdot \mathrm{C}$
03862A-37
(a)


$$
f^{\prime}=\bar{A} \cdot \overline{\mathrm{C}}+\overline{\mathrm{C}} \cdot \mathrm{D}+\overline{\mathrm{B}} \cdot \mathrm{D}
$$

(b)

Figure 1. Using K-Maps for Obtaining the Sum-of-Products Form of PAL Logle

## INTRODUCTION TO FUSE MAPS AND DESIGN EXAMPLES

Prior to the availability of PALASM as a tool to aid in the development of PAL designs, all designs were generated by hand using a technique which depended upon fuse maps. With this technique the designer was required to actually identify the individual fuses which needed to be blown to implement the desired function. While this technique is no longer used, it is still useful, as an understanding of it provides a firm foundation in physical reality of how a PAL implements a function.
As a demonstration of this methodology, we will use the arbitrary circuit shown in Figure 2 as an example for selecting and coding a PAL. This example shows the technique of using a PAL once the logic diagram has been developed. Again, this technique is no longer used, as it is much easier to simply generate the equations directly as input to PALASM.


Figure 2. Design Example, Logic Diagram

The first step is to generate the Boolean equations for this function. These are derived directly from the logic diagram. (lt should be noted that good design practice is to use meaningful pin names rather than $\mathrm{I}_{1}$ or $\mathrm{O}_{6}$. This will help in providing good design documentation.)
The following symbols will be used for all logic equations:

$$
*=\operatorname{AND} \quad+=0 \mathrm{R} \quad /=\text { NOT (invert) }
$$

Boolean equations for Figure 2 are:

$$
\begin{aligned}
& 01=/ I 1 \\
& 02=/ I 1 * I 2 \\
& 03=I 1+I 3 \\
& 04=/(/ I 3 * I 4) \\
& 05=/\left(/ I 3^{*} I 5 * I 6+I 7+I 8 * I 9\right) \\
& 06=/\left(I 8^{*} I 9+/ I 3^{*} / I 7 * I 9 * I 10\right)
\end{aligned}
$$

The next step is to select the particular PAL we want to use for this function. Since no registers are required, we should select from the combinatorial devices (AmPAL16L8, AmPAL16H8, AmPAL16LD8 or AmPAL16HD8). Since 3 outputs have AND-OR functions and 3 outputs, have AND.ORINVERT functions, we could still select from either active HIGH or active LOW (H or L) parts, but since the more complex functions are AND-OR-INVERT, the active LOW (L) series is most likely. Finally, we see that no output enable is required, thus we could use either the AmPAL16L8 or the AmPAL16LD8. For the purposes of this example we will select the AmPAL16L8.

Now, since we have selected an AmPAL16L8 (which has inverting outputs) we need to apply DeMorgan's theorem to convert these equations from the active HIGH to the active LOW output. DeMorgan's theorem can be used to convert any logic equation in any form into the AND-OR structure used in PALs. Applying DeMorgan's theorem gives the active LOW form of the equation:

$$
\begin{aligned}
& / 01=I 1 \\
& / 02=I 1+/ I 2 \\
& / 03=/ I 1 * / I 3 \\
& / 04=/ I 3^{* I} 4 \\
& / 05=/ I 3^{*} \mathrm{I} 5 * I 6+I 7+I 8^{* I} I 9 \\
& / 06=I 8^{*} I 9+/ I 3^{*} / I 7 * I 9^{*} I 10
\end{aligned}
$$

We can now determine which fuses need to be programmed for the PAL to perform this function. Figure 3 shows the conventions which are used when coding fuse maps.
Figure 4 shows the logic diagram of the AmPAL16L8. We will assign outputs $\mathrm{O}_{1}-\mathrm{O}_{6}$ to pins $14-19$, and inputs $\mathrm{I}_{1}-\mathrm{l}_{10}$ to pins 2-9, 11 and 13.
$\mathrm{O}_{1}$ is assigned to pin 19. To make this output the inverse of $\mathrm{l}_{1}$, leave input line 0 connected (not blown) to product term 1 and blow all the remaining fuses on that product term. This is indicated by the $X$ at the intersection of input line 0 and product term 1 in Figure 4.
Since the other inputs to the OR gate are unused, they are forced to zero by leaving all the fases intact on product terms

2-7. As shown in Figure 3, unused product terms (those with all fuses intact) are indicated by Xs in the small AND gates at the NOR gate inputs.

The final consideration for $\mathrm{O}_{1}$ is the output enable. By referring back to either the logic diagram for the circuit (Figure 2) or the Boolean equation, we see that there is no output enable function for $\mathrm{O}_{1}$. In other words, $\mathrm{O}_{1}$ should be enabled all the time. Referring to Figure 4, we see that product term 0 controls the output enable function for $\mathrm{O}_{1}$. To have the output always enabled, we blow all the fuses in product term (PT) O. A product term with all fuses blown is always HIGH, so this will leave the three-state gate always on, and the output will always be enabled.


Symbols

| (L) | Low |
| :--- | :--- |
| (H) | High |
| (N) | Negative |
| (P) | Positive |
| (0) | Zero |
| (1) | One |
| - | Fuse intact |
| + | Fuse blown |

Figure 3. Coding Conventions


Figure 4. Logic Diagram for Function of Figure 1 Using the AmPAL16L8

The next output, $\mathrm{O}_{2}$, is the AND function of $\mathrm{I}_{1}$ and $\mathrm{I}_{2}$. Again, since we are using an " L " device, we must apply DeMorgan's theorem and use the inverted form. Since we want to have $\mathrm{O}_{2}=I_{1}+\bar{I}_{2}$, we first leave input line $0\left(I_{1}\right)$ connected to PT 9 and blow the rest of the fuses on that product term. Then since we have an $\mathrm{OR}(+)$ function, we go to the next product term, and leave input line $5\left(\bar{T}_{2}\right)$ connected to PT 10.
Since PT 11-15 will be unused, we indicate this as we did in $\mathrm{O}_{1}$, by putting a X in the AND gate at the input to the NOR gate. Also, since we want $\mathrm{O}_{2}$ to be always enabled, we leave PT 8 blank, indicating that all of the fuses in that product term should be programmed.
Output $\mathrm{O}_{3}$ is the AND of $\bar{\Gamma}_{1}$ and $\bar{I}_{3}$. To implement this, we leave input line 1 connected to PT 17. Since we want an AND function, we also leave input line $9\left(\overline{I_{3}}\right)$ connected to PT 17. These connections are indicated by Xs . We then blow the rest of the fuses in PT 17. Since the rest of the product terms are unused, we place an $X$ in the AND gates for PT 18-23. Again, we leave PT 16 blank, which will leave $\mathrm{O}_{3}$ always enabled.
Output $\mathrm{O}_{4}$ is very similar to $\mathrm{O}_{3}$. In order to generate this AND function, we leave input line $9\left(\bar{I}_{3}\right)$ and input line $12\left(I_{4}\right)$ connected to PT 25, and program the remainder of the fuses in PT
25. We again indicate that the rest of the product terms are unused, and the output is always enabled.
Output $\mathrm{O}_{5}$ is generated by ANDing $\bar{T}_{3}, \mathrm{I}_{5}$, and $\mathrm{I}_{6}$ on PT 33, connecting $\mathrm{I}_{7}$ to PT 34, ANDing $\mathrm{I}_{8}$ and $\mathrm{I}_{9}$ on PT 35, and leaving PT 36-39 unused.
Output $\mathrm{O}_{6}$ is generated by ANDing $\mathrm{I}_{8}$ and $\mathrm{I}_{9}$ on PT 41 and ANDing $\Gamma_{3}, \Gamma_{7}, I_{9}$ and $I_{10}$ on PT 42: Product terms 43-47 are left unused.
Since pins 12 and 13 are not being used as outputs, $X$ s are put in the AND gates for all of those product terms.
The completed fuse map is shown in Figure 4.
As you can see, any function can be put into the sum-of-products form and then used to generate a fuse map. However, it can be very time consuming to generate these maps by hand. Therefore, AMD has developed a software tool called AMPALASM20 which will automatically generate the fuse map from the Boolean equations. This software tool is described in Section 4, but for comparison purposes, Figures 5 and 6 show abbreviated input and output data for AMPALASM20.


Figure 5. Abbreviated AMPALASM20 Input

DESIGN EXAMPLE
1111111111222222222233
01234567890123456789012345678901

2 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 3 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 4 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 5 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 6 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX
7 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX
$8-$

 11 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 12 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 13 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 14 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 15 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX

16 ---- ---- ---- ---- ---- ---- ---- ----

18 xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx 19 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 20 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 21 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 22 XXXXX XXXX XXXX XXXX XXXX XXXXX XXXX XXXXX 23 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX

26 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 27 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 28 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 29 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 30 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 31 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX



36 XXXX XXXX XXXXX XXXX XXXX XXXX XXXX XXXX
37 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 38 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 39 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX


43 XXXX XXXX XXXX XXXX XXXX XXXXX XXXX XXXX
44 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX
45 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX
46 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 47 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX

48 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 49 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 50 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 51 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 52 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 53 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 54 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 55 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX

56 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 57 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 58 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 59 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 60 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 61 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 62 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 63 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX

LEGEND: $\mathrm{X}:$ FUSE NOT BLOWN ( $\mathrm{L}, \mathrm{N}, \mathrm{O}$ ) - : FUSE BLOWN ( $\mathrm{H}, \mathrm{P}, 1$ )
NUMBER OF FUSES BLOWN $=493$
03862A-43
Figure 6. AMPALASM20 Output Fuse Map

## Complex Functions

Most complex functions can be built up from smaller functional building blocks that are easy to understand and design. This section will show some techniques for designing several common functional blocks that can be tailored for specific applications and used to build up the desired PAL designs. Each block includes a PAL DESIGN SPECIFICATION, a compiled AMPALASM20 output, and a fuse map of the desired function.

## Control Functions

An important feature of PALs with registers is the availability of registered outputs as inputs to the programmable array. This feedback is often used to configure PALs into state sequencers. Feedback also gives an easy way to create a device with a "clock enable". The purpose of disabling the clock is to prevent the contents of the output registers from changing (retain the same state). This result is easily obtained by feeding back the contents of the registers and having these values be clocked back in. In this way, the clock is not actually disabled, but the desired effect is achieved.
Another feature of PALs is programmable I/O pins. One product term controls a three-state driver whose output is fedback as an array input as well as connected to a pin. Thus, if the three-state driver is disabled (high impedance state), the pin can be used as an input. This makes these pins perfect for use as bidirectional lines for such purposes as shifting data serially.
Several common "special" functions, such as clearing and setting, can be incorporated into PALs with ease. The clear
function is performed by disabling all of the AND-gates, causing the output of the register to go LOW. On the other hand, the set function is performed by forcing one product term HIGH, causing the output of the register to go HIGH. Loading the registers with data is another common function and, for each bit, can be accomplished by selecting one AND. gate to pass the input data to the registers while disabling the remaining AND-gates. In general, a control or logic function is performed by selecting the necessary AND-gates and deselecting all others unused by the function.

## EXCLUSIVE-OR

An Exclusive-OR (XOR) is often used as a selective inverter or digital comparator. The XOR ( 2 -input) performs the following function: if either of the inputs is HIGH, but not both, then the output is HIGH. The function table and logic equation of the 2 -input XOR appearing in Figure 7 shows this graphically. The logic equation can be derived through the use of a Karnaugh map if desired. The logic diagram and logic symbol for the 2-input XOR appear in Figure 8.

XORs of more than two inputs are often used for Modulo-2 arithmetic and odd parity generation. Intuitively, the multiple input XOR is HIGH when an odd number of inputs are HIGH. Figure 9 shows the Karnaugh map for a 4 -input XOR. Notice that due to the diagonal pattern of one's in the map, there is no way to combine terms. Also note that exactly half of the squares in the map are ones. Since an n-input function results in $2^{n}$ squares in a Karnaugh map, an n-input XOR will require $2^{(n-1)}$ product terms. For example, the 4 -input XOR of Figure 7 requires eight product terms (see Figure 10).

| INPUTS |  | OUTPUT | $\mathbf{Y}=\mathbf{A} \cdot \overline{\mathbf{B}}+\overline{\mathbf{A}} \cdot \mathbf{B}$ |
| :---: | :---: | :---: | :---: |
| A | B | Y |  |
| 0 | 0 | 0 |  |
| 0 | 1 | 1 |  |
| 1 | 0 | 1 |  |
| 1 | 1 | 0 | 03862A-44 |

Figure 7. XOR Function Table and Logic Equation

(a) XOR Logic and (b) Symbolic Representation

Figure 8. XOR Logic Diagram and Logic Symbol


Figure 9. Karnaugh Map and Logic Symbol for a 4-Input XOR

$Y=\bar{A} \cdot \bar{B} \cdot \bar{C} \cdot D+\bar{A} \cdot \bar{B} \cdot C \cdot \bar{D}+\bar{A} \cdot B \cdot \bar{C} \cdot \bar{D}+A \cdot \bar{B} \cdot \bar{C} \cdot \bar{D}+$ $\bar{A} \cdot B \cdot C \cdot D+A \cdot \bar{B} \cdot C \cdot D+A \cdot B \cdot \bar{C} \cdot D+A \cdot B \cdot C \cdot \bar{D}$ 03862A-47

Figure 10. 4-Input XOR Logic

## THE MULTIPLEXER

The multiplexer (also called a data selector) is used to selectively route data from several inputs to one output. A simple 4-to-1 multiplexer has four data input lines and two control lines that select which one of the four data inputs is to be passed to the output. The function table for this device is shown in Figure 11. The logic equation can be derived directly from the function table (see Figure 12).
Each AND-gate has a data input and a two-input combination of select inputs. Given one of four possible combinations of

| INPUTS |  |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ |  | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ |  | $\mathrm{D}_{0}$ | Y |
|  | 0 | X | X | $\times$ | 0 | 0 |
| 0 | 0 | X | X | X | 1 | 1 |
| 0 | 1 | X | X | 0 | X | 0 |
| 0 | 1 | X | X | 1 | X | 1 |
| 1 | 0 | X | 0 | X | X | 0 |
| 1 | 0 | $x$ | 1 | X | x | 1 |
| 1 | 1 | 0 | X | X | X | 0 |
| 1 | 1 | 1 | X | X | X | 1 |

Figure 11. Function Table for 1-of-4 Multiplexer


Figure 12. Multiplexer Logic
select bits, only the AND-gate corresponding to this combination is enabled, allowing the desired input data to pass to the output. This can be easily expanded to accommodate more data simply by adding more select lines and data inputs. For every $n$ select lines there can be $2^{\text {n }}$ data inputs, each of which requires one product term.
The Design Specification and Logic Diagram for this Exclu-sive-OR and multiplexer based on an AmPAL16H8 are shown in Tables 1(a) and 1(b).

PAL16H8
PAL DESIGN SPECIFICATION
PATO20
JENNY YEE 10/22/82
XOR AND MUX FUNCTION
adVanced micro devices
XA XB XC DO D1 D2 D3 S1 SO GND
NC NC NC NC NC NC NC MUXY XORY VCC
;
;XOR AND MUX OUTPUT SIGNALS
;

$$
\begin{aligned}
& \mathrm{XORY}=/ \mathrm{XA}^{*} / \mathrm{XB}^{*} \mathrm{XC}+ \\
& \underset{\mathrm{XA}^{*} / \mathrm{XB}^{*} / \mathrm{XC}}{\mathrm{XA}}+ \\
& \mathrm{XA}^{\mathrm{X}} / \mathrm{XB}^{*} \mathrm{XB}^{*} / \mathrm{XC} \mathrm{CC}+ \\
& \text { X }
\end{aligned}
$$

$$
\begin{aligned}
& \text { S1* S0*D3 }
\end{aligned}
$$

FUNCTION TABLE


Note: See Section 4 for description of the PAL DESIGN SPECIFICATION format.

Table 1(a). Design Specification for XOR and MUX Function (Continued)

PAL16H8
PATO20
XOR AND MUX FUNCTION
ADVANCED MICRO DEVICES
*D9725
*FO*
L0000 11111111111111111111111111111111 *
L0032 10100111111111111111111111111111 *
L0064 01101011111111111111111111111111 *
L0096 10011011111111111111111111111111 *
L0128 01010111111111111111111111111111 *
L0256 11111111111111111111111111111111 *
L0288 11111111011111111111111110111011 *
LO320 111111111111101111111111110110111 *
L0352 111111111111111110111111101111011 * L0384 11111111111111111111011101110111 * C26D2*
V0001 000xXXXXXX0XXXXXXXXXLI * V0002 001XXXXXXX0XXXXXXXXH1 * V0003 010XXXXXXOXXXXXXXXH1 * V0004 011XXXXXXOXXXXXXXXL1 * V0005 100XXXXXXX0XXXXXXXXX 1 * V0006 101XXXXXXOXXXXXXXXL1 $\%$ V0007 111XXXXXXOXXXXXXXXH1 * V0008 XXX0XXX000XXXXXXXLX1 * V0009 XXX1XXX000XXXXXXXHX1 \% V0010 XXXX0XX010XXXXXXXLX1 * V0011 XXXX1XX010XXXXXXXHX1 * V0012 XXXXX0X100XXXXXXXLX1 * V0013 XXXXX1X100XXXXXXXHX1 * V0014 XXXXXX0110XXXXXXXLX1 * V0015 XXXXXX1110XXXXXXXHX1 * 0221

PAL DESIGN SPECIFICATION JENNY YEE 10/22/82

Table 1(b). Logic Diagram for XOR and Multiplexer Using AmPAL16H8


## DECODING/CHIP SELECT

Decoding is one of the most common logic functions to be performed in a design. Essentially all random logic control signals are generated by decoding. Two examples are output enabling and chip selection. The decoding function can be described as being true when the desired set of inputs is true. This, of course; is simply the AND function. In its most general form, an n-input decoder can have $2^{n}$ decoded outputs implemented by $2^{n}$ AND-gates. Each AND-gate has a different combination of inputs allowing only one output to be true at any given time. If Karnaugh maps were used to describe an n-input decoder, there would be $2^{n}$ maps with only a single one in each one. Figure 13 shows the truth table, logic equations and logic diagram for a 3 -to-8 decoder imple-

| INPUTS |  |  |  | OUTPUTS |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{2}$ | $\mathrm{~S}_{1}$ | $\mathrm{~S}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |  |
| 0 | $\cdot 0$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |  |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |  |  |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |  |  |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |  |  |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |  |  |
| 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |  |  |
| 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

03862A-53
(a) Truth Table 3.to-8 Decoder

| $\mathrm{D}_{0}=\overline{\mathrm{S}_{2}} \cdot \overline{\mathrm{~S}_{1}} \cdot \overline{\mathrm{~S}_{0}}$ |  |
| :---: | :---: |
| $\mathrm{D}_{1}=\overline{\mathrm{S}_{2}} \cdot \overline{\mathrm{~S}_{1}} \cdot \mathrm{~S}_{0}$ |  |
| $\mathrm{D}_{2}=\overline{\mathbf{S}_{2}} \cdot \mathrm{~S}_{1} \cdot \overline{S_{0}}$ |  |
| $\mathrm{D}_{3}=\overline{S_{2}} \cdot \mathrm{~S}_{1} \cdot \mathrm{~S}_{0}$ |  |
| $\mathrm{D}_{4}=\mathrm{S}_{2} \cdot \overline{\mathrm{~S}_{1}} \cdot \overline{S_{0}}$ |  |
| $\mathrm{D}_{5}=\mathrm{S}_{2} \cdot \overline{S_{1}} \cdot \mathrm{~S}_{0}$ |  |
| $\mathrm{D}_{6}=\mathrm{S}_{2} \cdot \mathrm{~S}_{1} \cdot \overline{S_{0}}$ |  |
| $\mathrm{D}_{7}=\mathrm{S}_{2} \cdot \mathrm{~S}_{1} \cdot \mathrm{~S}_{0}$ | 03862A-54 |

(b) Equations 3-to-8 Decoder

Figure 13
mented with an AmPAL16H8. The design specification and logic diagram for this decoder are shown in Tables 2(a) and 2(b).

In most applications, three inputs (such as in a 3-to-8 decoder), are insufficient to perform the entire decode. For example, decoding the address and control for an I/O device requires anywhere from 8 to 16 address control and timing inputs. Besides the address lines, the control and timing signals which are commonly used as inputs for decoding are: READ/WRITE (R/W), MEMORY/IO (M/IO); BYTE/WORD (B/W) and ADDRESS STROBE (AS). Figure 14 shows typical input and output ports with required decoders.

(c) Logic Diagram 3-to-8 Decoder


Figure 14. Typical Input and Output Ports

PAL16H8
PAL DESIGN SPECIFICATION
PAT022
JENNY YEE 10/22/82

3 TO 8 DECODER
ADVANCED MICRO DEVICES

| S2 | S1 | S0 | NC | NC | NC | NC | NC | NC | GND |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| NC | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | VCC |

;
;DECODER OUTPUT SIGNALS
;
D0 $\quad=/ \mathrm{S} 2 * / \mathrm{Sl}^{*} / \mathrm{SO}$
$\mathrm{D} 1=/ \mathrm{S} 2^{*} / \mathrm{S} 1^{*} \mathrm{~S} 0$
$\mathrm{D} 2=/ \mathrm{S} 2 * \mathrm{~S} 1^{*} / \mathrm{S} 0$
D3 $\quad=/ \mathrm{S} 2 * \mathrm{~S} 1 * \mathrm{~S} 0$
$\mathrm{D} 4=\mathrm{S} 2 * / \mathrm{S} 1 * / \mathrm{S} 0$
D5 $=\mathrm{S} 2^{*} / \mathrm{S} 1^{*}$ S0
$\mathrm{D} 6=\mathrm{S} 2^{*} \mathrm{~S} 1^{*} / \mathrm{S} 0$
$\mathrm{D7}=\mathrm{S} 2 * \mathrm{~S} 1 * \mathrm{~S} 0$
FUNCTION TABLE
$\begin{array}{lllllllllll}\text { S2 } & \text { S1 } & \text { S0 } & \text { D7 } & \text { D6 } & \text { D5 } & \text { D4 } & \text { D3 } & \text { D2 } & \text { D1 } & \text { D0 }\end{array}$

| L | L | L | L | L | L | L | L | L | L | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| L | L | H | L | L | L | L | L | L | H | L |
| L | H | L | L | L | L | L | L | H | L | L |
| L | H | H | L | L | L | L | H | L | L | L |
| H | L | L | L | L | L | H | L | L | L | L |
| H | L | H | L | L | H | L | L | L | L | L |
| H | H | L | H | H | H | L | L | L | L | L |
| H |  |  |  |  |  |  |  |  |  |  |
|  | H | L | L | L | L | L | L | L |  |  |

DESCRIPTION
THIS DEVICE IMPLEMENTS A 3 TO 8 DECODER. THE SAMPLE SHOWS THE DESIGN OF THE DECODER USING PAL. 03862A-57

PAL16H8
PAT022 3 TO 8 DECODER ADVANCED MICRO DEVICES *D9725
*FO*
LOOOO 11111111111111111111111111111111 * LOO32 01010111111111111111111111111111 *
 LO288 01011011111111111111111111111111 * L0512 11111111111111111111111111111111 * L0544 10010111111111111111111111111111 * L0768 11111111111111111111111111111111 \% L0800 1001.1011111111111111111111111111 * L1024 11111111111111111111111111111111 * L1056 01100111111111111111111111111111 * L1280 11111111111111111111111111111111 * L1312 01101011111111111111111111111111 * L1536 11111111111111111111111111111111 * L1568 10100111111111111111111111111111 * L1792 11111111111111111111111111111111 * L1824 10101011111111111111111111111111 * C3EC4*
V0001 000XXXXXXOXHLLLLLLL1 * V0002 001XXXXXXOXLHLLLLLL1 * V0003 010XXXXXX0XLLHLLLLL1 * V0004 $011 \times X X X X X 0 X L L L H L L L L 1$ * V0005 100XXXXXXOXLLLLHLLL1 * V0006 101XXXXXXOXLLLLLHLLI * V0007 110XXXXXXOXLLLLLLHL1 * V0008 111XXXXXXOXLLLLLLLH1 * FC30

PAL DESIGN SPECIFICATION JENNY YEE 10/22/82


## SHIFT REGISTERS

Shift registers are useful for multiplication, division and serial communications.

An easy way to construct a shift register is to think of it as being composed of a set of multiplexers with registered outputs. A typical shift register can load data, shift data to the right, shift data to the left, and "hold" (leave unchanged) the data. There would be two select lines that control the multiplexers and choose the desired function. If data is to be loaded into the shift register, this path is enabled and the data is passed through and clocked into the registers (see Figure 15a). Figures 15b and 15c illustrate how the shift functions are performed. When shifting right, bit i will clock in bit $i+1$. This is accomplished by feeding back the output of register $i+1$ to the multiplexer of bit $i$ and selecting this path. Similarly, shifting left is done by clocking bit $\mathrm{i}-1$ into bit i ,
using similar feedback techniques. "Holding" data is easily done by feeding back register $i$ to itself and selecting the path, as shown in Figure 15d. Thus keeping data unchanged is accomplished by feedback, not by gating the clock (which is a poor design practice).

This information is now used to design a 4-bit shift register using an AmPAL16H8. The function has four data inputs, four outputs, and two select lines, a left serial input, a right serial input, an output enable, and a clock input. The serial inputs are bidirectional and are used to input new data while shifting. The function table for the shift register is shown in Figure 16 and the logic diagram in Figure 17. The Design Specification and Logic Diagram for these shifters are shown in Tables 3(a) and 3(b).


Figure 15a. Loading the Shifter


Figure 15b. Shifting Right


Figure 15c. Shifting Left


Figure 15d. "Holding" Data

| INPUTS |  |  |  | OUTPUTS |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{S}_{1} \mathbf{S}_{0}$ |  | SERIAL |  | Q ${ }_{3}$ |  | $Q_{1}$ | $Q_{0}$ | SERIAL |  |
|  |  | LEFT | RIGHT |  |  |  |  | RIGHT | LEFT |
| 0 | 0 | X | X | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | Do | Z | Z |
| 0 | 1 | X | 0 | 0 | Q3o | Q20 | Q10 | Q00 | Z |
| 0 | 1 | X | 1 | 1 | Q30 | Q20 | Q10 | $\mathrm{QO}_{0}$ | Z |
| 1 | 0 | 0 | X | Q20 | Q10 | Q00 | 0 | Z | Q3o |
| 1 | 0 | 1 | $X$ | Q20 | Q10 | Q0 | 1 | Z | Q30 |
| 1 | 1 | X | X | Q30 | Q20 | Qio | $\mathrm{QO}_{0}$ | Z | Z |

Figure 16. Shift Reglster Function Table


Figure 17. 4-Bit Bidirectional Shift Register

## Table 3(a). Design Specification for Shift Register

```
PAL16R6
PATO23
SHIFT REGISTER
ADVANCED MICRO DEVICES
CK Sl S0 D3 D2 D1 D0 NC NC.GND
OE SRISLO NC Q3 Q2 Q1 Q0 NC SLISRO VCC
;
;SHIFT REGISTER OUTPUT SIGNALS
;
/Q3 := /S1*/SO*/D3
        ll
        S1* SO*/Q3
    /Q2 :=/S1*/SO*/D2
        /S1* S0*/Q3
        S1*/SO*/Q1
        S1* SO*/Q2
    /Q1 :=/S1*/SO*/D1
        /S1* SO*/Q2
        S1*/SO*/Q0
        S1* SO*/Q1
/QO :=/S1*/SO*/DO
        /S1* S0*/Q1
        S1*/SLISRO*/S0
        S1* SO*/QO
IF(/S1*SO) /SLISRO = /QO
IF(S1*/S0) /SRISLO = /Q3
    03862A-66
```

| FUNCTION TABLE |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CK | S1 | S0 D3 | D2 | D1 | 1 D | D |  | SRISL0 | SLISRO | Q3 | Q2 | Q1 | Q0 |
| ; |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ; LOAD AND SHIFT RIGHT |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | L | L L | L | L | L | - | L | Z | Z | L | L | L | L |
| C | H | H X | X | X | X | X | L | Z | Z | L | L | L | L |
| C | L | H X | X | X | X | X | L | H | L | H | L | L | L |
| C | L | H X | X | X | X | X | L | L | L | L | H | L | L |
| C | L | H X | X | X | X | X | L | L | L | L | L | H | L |
| C | L | H X | X | X | X | X | L | L | H | L | L | L | H |
| C | L | H X | X | X | X | X | L | L | L | L | L | L | L |
| ; LOAD AND SHIFT LEFT |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | L | L H | H | H | H | H | L | Z | Z | H | H | H | H |
| C | H | H X | X | X | X | X | L | Z | Z | H | H | H | H |
| C | H | L X | X | X | X | X | L | H | L | H | H | H | L |
| C | H | L X | X | X | X | X | L | H | H | H | H | L | H |
| C | H | L X | X | X | X | X | L | H | H | H | L | H | H |
| C | H | L X | X | X | X | X | L | L | H | L | H | H | H |
| C | H | L X | X | X | X | X | L | H | H | H | H | H | H |
| ; |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ; HOLD |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | H | H X | X | X | X | X | L | Z | Z | H | H | H | H |
| DESCRIPTION |  |  |  |  |  |  |  |  |  |  |  |  |  |
| THIS DEVICE IMPLEMENTS A SHIFT REGISTER. THE LAYOUT PROVIDED IS |  |  |  |  |  |  |  |  |  |  |  |  |  |
| A DEMONSTRATION OF HOW THE SHIFT REGISTER MAY BE DESIGNED USING |  |  |  |  |  |  |  |  |  |  |  |  |  |
| A PAL. 03862A.67 |  |  |  |  |  |  |  |  |  |  |  |  |  |

PAL16R6 PAT023
SHIFT REGISTER
ADVANCED MICRO DEVICES
. D 9724
*FO*
L0000 10110111111111111111111111111111 * L0032 11111111111011111111111111111111 * L0512 1011101111111111111110111111 1111** L0544 10110111111111101111111111111111 * L0576 01101011111111111111111111111111 * L0608 01110111111011111111111111111111 * L0768 10111011111111111011111111111111 * L0800 101101111111111111101111.11111111 * L0832 01111011111011111111111111111111 * L0864 01110111111111101111111111111111 * L1024 10111011111110111111111111111111 * L1056 10110111111111111111111011111111 . * L1088 01111011111111101111111111111111 * L1120 01110111111111111110111111111111 * L1280 10111011101111111111111111111111 *
 L1344 01111011111111111110111111111111 * L1376 01110111111111111111111011111111 * L1792 0111101111111111111111111111.1111 * L1824 111111111111111111111111011111111 * C49E9*
V0001 C000000XX00ZXLLLLXZ1 * V0002 C11XXXXXXOOZXLLLLXZ1 * V0003 C01XXXXXX001XHLLLXL1 * v0004 C01XXXXXX000XLHLLXL1 * V0005 C01XXXXXX000XLLHLXL1 * V0006 C01XXXXXX000XLLLHXH1 v0007 C01XXXXXX000XLLLLXL1 * v0008 C001111XXOOZXHHHHXZ1 * V0009 C11XXXXXXOOZXHHHHXZ1 * V0010 C10XXXXXXOOHXHHHLX01 ; V0011 C10XXXXXXOOHXHHLHX11 * V0012 C10XXXXXXOOHXHLHHX11* v0013 C10XXXXXXOOLXLHHHX11 *
 v0015 C11XXXXXX00ZXHHHHXZ1 * 5060

PAL DESIGN SPECIFICATION
JENNY YEE 10/22/82

Table 3(b). Logic Diagram for Shift Register Using AmPAL16R6


## THE COUNTER

Counters are used for such purposes as state sequencing, delay timing, and event counting. The key to designing a counter is knowing when a bit should be toggled. For an upcounter, a bit is toggled whenever every bit of lesser significance is HIGH (see the counting sequence of Figure 18).

Conversely, for a down-counter, a bit is toggled whenever every bit of lesser significance is LOW. In both cases, the LSB is always toggled. By ANDing all bits of lesser significance along with the complement of the current data in the register, the problem of when this bit is to be toggled has been solved. However, this is not sufficient. In order to complete the design, it must be ensured that the bit remains unchanged under all other conditions. This can be accomplished by ORing the complements of the lesser significant bits together and then ANDing the result with the current data in the register (see Figure 19). The equation in Figure 19 can be changed into the sum-of-products form (Figure 20) for direct implementation in a PAL. Thus if a bit is to be toggled, the complement of the current data will be clocked in; if not, the data remains unchanged by clocking in the current data.

A 4-bit up-counter example illustrates this approach. Typical counter functions are loading data, counting, and "holding" data (COUNTING). The function table is shown in Figure 21 and the logic diagram in Figure 22.

Expanding the number of bits in the counter is done by expanding the function table to incorporate the additional bits. Karnaugh maps, although not essential, can be used to find the required equations in sum-of-products form for PAL implementation. In general, besides any fixed overhead for control functions (CLEAR, LOAD, and HOLD in this example) bit $n$ will require $n$ additional product terms. Therefore, if this example 4 -bit counter is to be expanded to five bits, the fifth bit will require five product terms plus three additional product terms for clearing, loading, and counting (see Figure 23). Notice that the original 4 -bit block is unaffected by the addition of the fifth bit. This basic counter is easily expandable to perform more complex functions. The Design Specification and Logic Diagram for this counter, using an AmPAL16R8 device, are shown in Tables 4(a) and 4(b).

| CURRENT | NEXT |  |
| :--- | :--- | :--- |
| STATE | STATE |  |
| 0000 | 0001 |  |
| 0001 | 0010 |  |
| 0010 | 0011 |  |
| 0011 | 0100 |  |
| 0100 | 0101 |  |
| 0101 | 0110 |  |
| 0110 | 0111 |  |
| 0111 | 1000 |  |
| 1000 | 1001 |  |
| 1001 | 1010 |  |
| 1010 | 1011 |  |
| 1011 | 1100 |  |
| 11100 | 1101 |  |
| 11101 | 1110 |  |
| 11110 | 1111 |  |
| 1111 | 0000 | $03862 A-70$ |

Figure 18. Counting Sequence

$\overline{\text { TOGGLE }}=Q_{i} \cdot\left(\overline{Q_{0}}+\overline{Q_{1}}+\overline{Q_{2}}+\cdots+\overline{Q_{i-1}}\right)$
03862A. 71

Figure 19. Logic for not Toggling Bit 1

$\overline{\text { TOGGLE }}=\overline{Q_{0}} \cdot Q_{i}+\overline{Q_{1}} \cdot Q_{i}+\overline{Q_{2}} \cdot Q_{i}+\cdots+\overline{Q_{i-1}} \cdot Q_{i}$
03862A. 72

|  | INPUTS |  | OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{S}_{1}$ | $\mathrm{S}_{0}$ | Q30 | Q20 | Q10 | $\mathrm{QO}_{0}$ | $\mathrm{Q}_{3}$ | $\mathrm{Q}_{2}$ | $\mathrm{Q}_{1}$ | $\mathbf{Q}_{0}$ |
| CLEAR | 0 | 0 | X | X | X | X | 0 | 0 | 0 | 0 |
| LOAD | 0 | 1 | X | X | X | $X$ | $\mathrm{D}_{3}$ | - $\mathrm{D}_{2}$ | D1 | $\mathrm{D}_{0}$ |
|  | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
|  | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |
|  | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 |
|  | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 |
|  | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |
|  | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 |
|  | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 |
|  | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |
| - | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |
|  | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 |
|  | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 |
|  | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 |
|  | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 |
|  | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| HOLD | 1 | 1 | X | X | X | X | Q30 | Q20 | Q10 | 000 |

03862A-73

Figure 21. Function Table for 4-Bit Up Counter



```
PALl6R8
PAT021
4-BIT COUNTER
ADVANCED MICRO DEVICES
CK Sl S0 D4 D3 D2 D1 D0 NC GND
OE NC NC.NC Q0 Q1 Q2 Q3 NC VCC
;
;COUNTER OUTPUT SIGNALS
;
/QO := /S1*/SO
        /S1* SO*/D0
        S1*/SO* QO +
        S1* SO*/Q0
/Q1 := /S1*/S0
        /S1* SO*/D1
        S1*/SO*/Q1*/Q0
        S1%/SO*Q1* Q0 +
        S1* SO*/Q1
/Q2 := /S1*/S0
        /S1* SO*/D2
        S1*/SO*/Q2*/Q0
        S1*/SO*/Q2*/Q1
        S1*/SO* Q2* Q1* Q0 +
        S1* SO*/Q2
/Q3 := /S1*/S0
        /S1* S0*/D3
        S1*/SO*/Q3*/Q0
        S1*/SO*/Q3*/Q1
        S1*/SO*/Q3*/Q2
        S1*/SO* Q3* Q2* Q1* Q0 +
        S1* SO*/Q3
```

        PAL DESIGN SPECIFICATION
        JENNY YEE 10/22/82
    FUNCTION TABLE


PAL16R8
PAT021
4-BIT COUNTER
ADVANCED MICRO DEVICES
*D9724
*FO*
L0256 10111011111111111111,111111111111 *
L0288 10110111111110111111111111111111 *
L0320 01111010111111111110111111111111 *
L0352 01111010111111101111111111111111 *
L0384 01111010111011111111111111111111 *
L0416 01111001110111011101111111111111 *
L0448 01110110111111111111111111111111 *
L0512 10111011111111111111111111111111 *
L0544 10110111111111111011111111111111 *
L0576 01111011111011111110111111111111 *

L0640 01111011110111011101111111111111 *
L0672 01110111111011111111111111111111 .*
L0768 10111011111111111111111111111111 *
L0800 10110111111111111111101111111111 *
L0832 01111011111111101110111111111111 *
L0864 01111011111111011101111111111111 *
L0896 01110111111111101111111111111111 *
L1024 10111011111111111111111111111111 *
L1056 10110111111111111111111110111111 \%
L1088 01111011111111111101111111111111 *
L1120 01110111111111111110111111111111 *
C4FAE*
V0001 C00XXXXXX00XXXLLLLX1 *
V0002 C01X1111X00XXXHHHHX *
V0003 C01X0000X00XXXLLLLX1 *
V0004 C10XXXXXXOOXXXHLLLX1 *
V0005 C10XXXXXX00XXXLHLLX1 *
V0006 C10XXXXXXX00XXXHHLLX1 *
V0007 C10XXXXXX00XXXLLHLX1 *
V0008 C10XXXXXX00XXXHLHLX1 *
V0009 C10XXXXXX00XXXLHHLX1 *
V0010 C10XXXXXX00XXXHHHLX1 *
V0011 C10XXXXXX00XXXLLLHX1 *
V0012 C10XXXXXX00XXXHLLHX1 *
V0013 C10XXXXXX00XXXLHLHX1 *
V0014 C10XXXXXX00XXXHHLHX1 *
V0015 C10XXXXXX00XXXLLHHX1 *
V0016 C10XXXXXXOOXXXHLHHX1 *
V0017 C10XXXXXXOOXXXLHHHX1 *
V0018 C10XXXXXX00XXXHHHHX1 *
V0019 C10XXXXXX00XXXLLLLX1 * V0020 C11XXXXXX00XXXLLLLX1 * 887C

PAL DESIGN SPECIFICATION
JENNY YEE 10/22/82

Table 4(b). Logic Diagram for 4-Bit Counter Using AmPAL16R8
Columns: Inputs (0-31)

$\rightarrow=$ Fuse intact $-\mathbb{X}-=$ All fuses intact $\quad+=$ Fuse blown

## Section 4

## Software Support for AMD PALs

Design Aid Software for Programmable Logic
PAL DESIGN SPECIFICATION

## Design Aid Software for Programmable Logic

## INTRODUCTION

The main function of programmable logic design aid software is to translate a custom logic design specification into a format which can be accepted by a programmer.
Programmable logic software is also an excellent tool for design simulation and documentation. Simulation aids in debugging an initial design and helps to assure that a device will operate as intended the first time instead of requiring multiple design iterations. Documentation capability is essential for someone other than the original designer to understand a custom programmable logic specification.

## THIRD PARTY SOFTWARE

Many different programmable logic design aid software programs and software programs resident on programmable logic programmers are available or under development. Table 1 lists some current suppliers of these design tools. Contact
the indicated companies for the status of their particular product.

## PALASM

One particular software program, specifically for PALs, is PALASM (short for PAL ASSEMBLER).

PALASM is a computer aided design tool which has the capability of accepting an input file of Boolean equations and assembling the file into an output (fuse map) in a format compatible with PAL programmers. PALASM also allows the designer to input, in a tabular format, test vectors to perform simulation and debug of the Boolean equation input. The PAL design input file, cailed PAL DESIGN SPECIFICATION, when used in conjunction with PALASM documentation outputs, can provide as much documentation as is required to understand custom PAL design.

Table 1. Third Party Design Aid Software Tools
CUPL
(Software)
IBM PC
PALASM
(Programmer Resident)
PALASM
(Programmer Resident)
PALASM
(Programmer Resident)
PALASM
(Programmer Resident)

Assisted Technology, Inc.
Suite 150
2381 Zanker Road
San Jose, CA 95131
(408) 942-8787

Data I/O Corporation
10525 Willows Road N.E./C-46
Redmond, WA 98052
(206) 881-6444

Digilec, Inc.
7335 East Acoma Drive
STE. 103
Scottsdale, AZ 85260
(602) 991-7268

Stag Microsystems, Inc.
528-5 Weddell Drive
Sunnyvale, CA 94086
(408) 745-1991

Structured Design
1700 Wyatt Drive
Suite 3
Santa Clara, CA 95054
(408) 988:0725

## AMPALASM20

Advanced Micro Devices offers a powerful, enhanced version of PALASM, called AMPALASM20 to support the AMD 20 -pin PAL family. It is based on the original version of PALASM but adds extensive error checking features and the industry standard JEDEC output format PLDTF (Programmable Logic Data Transfer Format).

The new error checking functions insure that creation of a correct PALDESIGN SPECIFICATION is an easily understood and straightforward process. Most important, AMPALASM20 does not allow the designer to create incorrect fuse patterns or try to program a device with inadequate logical capacity for the desired function. The JEDEC PLDTF output is designed to transfer data in a format which can program PALs from all manufacturers. This eliminates the need for the user to modify code to accommodate different supplier's devices.

AMPALASM20 is currently available on 8 inch floppy disk media in IBM 3740 format for the CP/M operating system. It is offered in both Fortran source code and object code versions. Advanced Micro Devices only supports object code written for 8080 based systems. Source code is provided for customers who wish to port AMPALASM20 to their particular system, but no support is furnished and no responsibility can be accepted for any use of source code information.

To use this version of AMPALASM20 the designer should have access to:
-A microcomputer with a CP/M operating system
-An 8 inch floppy disk drive (IBM 3740 format)
-A CRT terminal with keyboard
-System software which includes an editor
-A means of downloading the fuse programming data to a programmer

To perform automatic downloading of AMPALASM20 output to a PAL programmer, a link between the computer and the programmer is required. Most programmers accept input via an RS232 interface. This usually requires only an RS232 port, and RS232 cable from the computer and a software driver for the port, which are resident on most computers. Please refer to the programmer manufacturer's reference materials for details. The CP/M version of AMPALASM20 provides the necessary software driver.

Versions of AMPALASM20 for the IBM CMS operating system and VAX VMS operating system are under development. Check with your local Advanced Micro Devices sales office for price and availability.
A complete specification of the CP/M version AMPALASM20 and the PAL DESIGN SPECIFICATION input file appears later in Section 4.

## PAL DESIGN SPECIFICATION

The input to AMPALASM20 is called the PAL DESIGN SPECIFICATION. Since AMPALASM20 is a batch-oriented program, the PAL DESIGN SPECIFICATION is intended to be an input file created using the editing facility of the machine on which AMPALASM20 is executing. The PAL DESIGN SPECIFICATION is divided into five main sections: the heading, pin list, logic equations, function table, and description.

## HEADING

The heading comprises the first four lines of the PAL DESIGN SPECIFICATION. Line one requires the left justified PAL part number starting in column one. Valid PAL part numbers supported by the present version of AMPALASM20 are the following:

AMPAL16L8
AMPAL16R8
AMPAL16R6
AMPAL16R4
AMPAL16H8
AMPAL16LD8
AMPAL16HD8

An invalid part number will generate a fatal (nonrecoverable) error. The rest of the heading is optional, the following recommendations are standard.

The recommended heading "PAL DESIGN SPECIFICATION" should be included after the part number (separated by at least one space).

Lines two through four are reserved for design documentation. The recommended format for these lines is:
Line 2: User internal part number, date
Line 3: Device application name
Line 4: Company name, address
An example heading is given below:

AMPAL16R4
PAL DESIGN SPECIFICATION
PATTERN NUMBER K2/044-C
WARREN MILLER 4/1/82
DUAL BUS 4-BIT COUNTER WITH BIT SWAPPABLE OUTPUTS
ADVANCED MICRO DEVICES 901 THOMPSON PLACE SUNNYVALE CA 94086

## PIN LIST

The pin list must begin on line five. It is a sequence of symbolic names given to device pins 1 through 20 in order. Each pin name must be separated by one or more spaces. The following rules should be followed when specifying the pin list:
(1) The pin list must contain exactly 20 names or a fatal error will be reported.
(2) Pin names should not exceed 8 characters. If they do, only the last 8 characters will be used.
(3) Any printable characters may be used in a pin name except " = : * + ( );". A slash may be used as the first character in a pin name to indicate an active LOW input signal.
(4) Duplicated pin niames are allowed (for example, NC for No Connection), but only if they are not used in any equations.
(5) GND and VCC may be usd on pins 10 and 20 respectively, but should not be used in any equations.

An example pin list is given below:

| CLK | CARRYIN | ADATA0 | ADATA1 | ADATA2 | ADATA3 | S0 S1 | RESET | GND |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| /OE | BDATAO | BDATA1 | Q0 | Q1 | Q2 | Q3 | BDATA2 | BDATA3 |

## LOGIC EQUATIONS

Logic equations may begin on the first line after the pin list. These equations are the heart of the PAL DESIGN SPECIFICATION. They specify the logical operations of a device in a sum-of-products (AND-OR) Boolean format.
The terms used when writing logic equations are: •
OPERATOR SYMBOLS (in hierarchy of evaluation):

* AND (product)
+ OR (sum)
EXPRESSION is a sequence of PIN NAMES (or their complements) separated by operators, where the PIN NAME is the symbolic input or output name taken from the pin list. PRODUCT is a sequence of PIN NAMES (or their complements) separated by the AND operator, "*", where the PIN NAME is the symbolic input or output name taken from the pin list.


## ADDITIONAL SYMBOLS:

; The remainder of the present line is a comment
1 Complement, prefix to a pin name
$=$ Combinatorial equality
$:=$ Sequential equality
Three forms of logic equations are possible:

## PIN NAME = EXPRESSION

Combinatorial equality. The output specified by the PIN NAME is logically equal to the expression. If the device has an inverting output, the complement of the PIN NAME must be specified.

## IF (PRODUCT) PIN NAME = EXPRESSION

Conditional combinatorial equality. When the product is logically true, the output specified by PIN NAME is equivalent to the expression. When the product is logically false, the output is placed in the high impedance (high-Z) state. If the device has an inverting output, the complement of the PIN NAME must be specified.

## PIN NAME:= EXPRESSION

Sequential equality. On the low to high transition of the clock, the registered output specified by the PIN NAME is loaded with the logical value defined by the equation. If the device has an inverting output, the complement of the PIN NAME must be specified.

It is important to notice that AMPALASM20 equations are written with respect to the AND inputs of the internal ANDOR structure. The only way to enable (output $=\mathrm{HIGH}$ ) an AND-gate is with all HIGHs on the inputs. Therefore to enable an AND-gate when active LOW inputs (pin names with preceding slashes) are specified, the complement of the inputs (active HIGH or true version, without the slash) are necessary. Also, notice that to enable an AND-gate with active HIGH inputs the active HIGH version of the inputs is necessary (no slash). Thus the polarity of the input signals is written the same independent of the polarities of the pin names. It is, then merely a question of AMPALASM20 automatically selecting the inverting (active LOW) on non-inverting (active HIGH) path of the input buffer to the AND-gate.
It is also important to notice that the AMPALASM20 equations are written with respect to the output of the ORstructure in the combinatorial (16L8, 16H8, 16LD8, 16HD8) devices and at the $Q$ outputs of the registers for the registered (16R8, 16R6, 16R4) devices. On the active LOW parts (16L8, 16LD8, 16R8, 16R6, 16R4) the output signals on the output pins are inverted versions of the internal, AMPALASM20 specified, OR-structure outputs. A warning is generated by AMPALASM20 if this inversion between pin list pin names and AMPALASM20 output pin names is not observed.

An example with a pin list and output equations is given below. Note the inversion between pin names and left hand sides of the equations, the use of sequential equality on registered outputs, and combinatorial equality on the non-registered outputs. Furthermore, note that an input such as RESET could be made active LOW by just adding a preceding slash " $f$ " to the pin name (this tells PALASM 20 to select the inverting path of the input buffer).


## FUNCTION TABLE

The function table portion of the PAL DESIGN SPECIFICA TION is similar to the familiar truth table found in most TTL data books. It defines, in a tabular format, how the device is to function. Additionally, the function table is used by the SIMULATE function to check a PAL DESIGN for correctness. SIMULATE will take the vector specified in the function table and "plug it into" the equation portion of the PAL DESIGN SPECIFICATION.

Any discrepancy between the computed values and the function table values will be flagged by the output of SIMULATE. Besides catching the most common errors (signal inversions and typing errors), it also provides a check on the more subtle logic errors. The more detailed the function table, the higher the confidence level that the device will function as desired.
For combinatorial PALs, by using the input values specified in a function table line, the outputs may be computed against the output values listed in the same line of the table. For registered PALs, the present state (before clock) of the registers may also be necessary to compute and check the next state (after clock) outputs. The function table defines the present state outputs to be the registered outputs of the previous vector (i.e., line) and next state outputs to be in the current vector (line) with the present inputs. Note that the first vector in a function table has no present state and therefore cannot be dependent upon one. Also note that the combinatorial outputs of registered PALs are defined as a function of the present inputs and next state outputs.
The function table format is given below:

| FUNCTION TABLE: | (pin list) |
| :---: | :---: |
| d d |  |
|  |  |
| $\mathrm{d} d .$ |  |

The beginning of the function table is defined by the text "FUNCTION TABLE:". This identifier must begin in column 1. Following the function table, on the next line, is a pin list which defines the order of function table entries. This pin list must use the same signal names as the pin list at the beginning of the equation section of AMPALASM20. However, either the true or complement of the signal may be specified. Additionally, the order of entries need not be the same between the two pin lists.

Following the pin list is a dashed line of any length, which specifies the beginning of the body of the function table. Each entry in the function table indicates the forced state (in the case of inputs) or the checked state (in the case of outputs). A full line in the function table represents a test vector. A state (e.g., L, H, C, X, Z) must be specified for each pin name, with separating spaces optional. Optional comments may follow the vector. An entire line may be commented if the first
character of the line is a semi-colon ";". The definitions for inputs and outputs in the function table are:

For inputs:
L indicates drive input to a logical LOW
H indicates drive input to a logical HIGH
C indicates drive input to a logical LOW, then to a logical HIGH (clock)
$X$ indicates an irrelevant input (treated as drive to a logical LOW)

## For outputs:

L indicates test output for a logical LOW
H indicates test output for a logical HIGH
Z indicates test output for a logical HIGH impedance
$X$ indicates don't test
A function table for the sample device in the equations section is shown on the following page. The sample device equations implement a 4 -bit loadable up counter. The counter is loadable from both the ADATA and BDATA ports. The counter outputs are available on both the three-state Qoutput and the BDATA port. When enabled onto the BDATA port either the normal output ( $\mathrm{Q}_{3}, \mathrm{Q}_{2}, \mathrm{Q}_{1}, \mathrm{Q}_{0}$ ) or a swapped output ( $\mathrm{Q}_{0}, \mathrm{Q}_{1}$, $Q_{2}, Q_{3}$ ) is available.

Note that the function table pin list does not maintain the same order as the device pinout. This allows the table to be laid out in a logical manner and be easily read and understood. Also note that the pin list is defined with the same polarity as the device pinout. This makes the table more like a "black box" definition of how the device will work. In general, the complement version of the device pinout is more desirable in the list only when internal state variables or multilevel logic is defined in the device. This is because these functions are intermediate and have nothing to do with the "black box" definition, and also because the true version of internal points of a PAL is usually the complement of the pinout (it's easier to read).

The first test vector of the function table checks the output disable function. This is done by driving the OE signal HIGH $(\mathrm{H})$ and checking the Q outputs for the disabled state (Z). The second vector tests the reset function. The RESET signal is driven LOW ( L ), OE is LOW (L) and the clock input is clocked (C). The resulting Q outputs should be LOW (L).

The next two function table entries load the A and B ports respectively. This is done by selecting the load operations (LL and LH select codes) and checking that the correct value is clocked into the register.

The next 16 function table entries check the increment and $B$ outputs functions. The first 7 vectors check the normal $B$ output, the last 9 check the swapped B output. It is important to realize that the next state value of registered outputs can depend on both the inputs and the previous state (from the previous line) of the register. For example, the first entry in the increment section uses the previous value of the register (LLLL) as an input. This is incremented to the new value (LLLH). The next vector then uses that register state (LLLH) for the starting value of the test.


## PAL DESCRIPTION

The description section of the PAL DESIGN SPECIFICATION is an important documentation tool. In this section the designer can describe the operation of the device and its intended application. If this section is done correctly the PAL DESIGN SPECIFICATION becomes a data sheet for the newly created device, completely documenting the design. The format for the description section is simply the keyword DESCRIPTION: followed by the text describing the design. An example description ' is given below:

DESCRIPTION: THIS PAL IMPLEMENTS A 4-BIT COUNTER FOR A MULTIPLE BUS CPU. THE COUNTER CAN BE LOADED FROM EITHER THE ADATA INPUT BUS OR THE BDATA INPUT-OUTPUT BUS. THE CONTENTS OF THE COUNTER CAN BE OUTPUT TO THE THREE STATE Q BUS OR THE BDATA INPUT-OUTPUT BUS. ADDITIONALLY WHEN THE BDATA BUS IS USED TO OUTPUT THE COUNTER CONTENTS EITHER A BIT-NORMAL OR A BIT-REVERSED VERSION CAN BE SELECTED.

MODE DEFINITIONS ARE GIVEN BELOW.

|  | S1 | SO | CARRY-IN |  |
| :--- | :--- | ---: | ---: | :---: |
| LOAD A | 0 | 0 | X |  |
| LOAD B |  | 0 | 1 | X |
| HOLD, OUTPUT B NORMAL | 1 | 0 | 0 |  |
| COUNT, OUTPUT B NORMAL | 1 | 0 | 1 |  |
| HOLD, OUTPUT B SWAPPED | 1 | 1 | 0 |  |
| COUNT, OUTPUT B SWAPPED | 1 | 1 | 1 |  |

## EXAMPLE

The following pages contain the complete PAL DESIGN SPECIFICATION for the example used in the previous sections.

AMPAL16R4
PATTERN NUMBER K2/044-C
PAL DESIGN SPECIFICATION
WARREN MILLER 4/1/82
ADVANCED MICRO DEVICES 901 THOMPSON PLACE SUNNYVALE CA 94086
CLK CARRYIN ADATAO ADATA1 ADATA2 ADATA3 SO S1 RESET GND
/OE BDATAO BDATA1 Q0 Q1 Q2 Q3 BDATA2 BDATA3 VCC

| /Q0 := | RESET |
| :---: | :---: |
|  | /S1*/S0*/ADATAO |
|  | /S1* S0*/bData0 |
|  | S1* Q0* CARRYIN |
|  | S1*/Q0*/CARRYIN |

$$
\begin{array}{ll}
+ & \\
+ & \text { LOAD A } \\
+ & \text {;LOAD B } \\
+ & ; \text { COUNT }
\end{array}
$$

/Q1 := RESET /S1*/S0*/ADATA1
$+\quad$ + LOAD A /S1* SO*/BDATA1 + ;LOAD B
S1* Q1* Q0* CARRYIN
S1*/Q1*/Q0 S1*/Q1*/CARRYIN
/Q2 : $=$ RESET
/S1*/SO*/ADATA2 + ;LOAD A /S1* SO*/BDATA2 + ;LOAD B S1* Q2* Q1* Q0* CARRYIN + ;COUNT
S1*/Q2*/Q1
$+$
S1*/Q2*/Q0 +
S1*/Q2*/CARRYIN
/Q3 := RESET
/S1*/SO*/ADATA3 + ;LOAD A
/S1* S0*/BDATA3 + ;LOAD B
S1* Q3* Q2* Q1* Q0* CARRYIN + ;COUNT
S1*/Q3*/02
S1*/Q3*/Q1 +
S1*/Q3*/Q0 +
S1*/Q3*/CARRYIN
IF ( S1 ) /BDATAO $=/ \mathrm{SO}^{*} / \mathrm{QO} \quad+$;ENABLE NORMAL SO*/Q3 ;ENABLE SWAPPED
$\operatorname{IF}(\mathrm{S} 1) / \mathrm{BDATA1}=/ \mathrm{SO} / \mathrm{Q} 1 \quad+$;ENABLE NORMAL SO*/Q2 ;ENABLE SWAPPED
$\operatorname{IF}(\mathrm{S} 1) / \mathrm{BDATA} 2=/ \mathrm{SO} / \mathrm{Q} 2 \quad+$;ENABLE NORMAL SO*/Q1 ;ENABLE SWAPPED

IF ( S1 ) /BDATA3 $=/ \mathrm{SO} / \mathrm{Q} 3+$; ENABLE NORMAL SO*/Q0 ;ENABLE SWAPPED

FUNCTION TABLE:
CLK ADATA3 ADATA2 ADATA1 ADATAO BDATA3 BDATA2 BDATA1 BDATAO
/RESET S1 S0 CARRYIN /OE Q3 Q2 Q1 Q0


DESCRIPTION: THIS PAL IMPLEMENTS A 4-BIT COUNTER FOR A MULTIPLE BUS CPU. THE COUNTER CAN BE LOADED FROM EITHER THE ADATA INPUT BUS OR THE BDATA INPUT-OUTPUT BUS. THE CONTENTS OF THE COUNTER CAN BE OUTPUT TO THE THREE STATE Q BUS OR THE BDATA INPUT-OUTPUT BUS. ADDITIONALLY WHEN THE BDATA BUS IS USED TO OUTPUT THE COUNTER CONTENTS EITHER A BIT-NORMAL OR A BIT-REVERSED VERSION CAN BE SELECTED.

MODE DEFINITIONS ARE GIVEN BELOW.

|  |  | S1 | S0 | CARRY-IN |
| :--- | ---: | ---: | ---: | :---: |
| LOAD A |  | 0 | 0 | X |
| LOAD B |  | 0 | 1 | X |
| HOLD, OUTPUT B NORMAL | 1 | 0 | 0 |  |
| COUNT, OUTPUT B NORMAL | 1 | 0 | 1 |  |
| HOLD, OUTPUT B SWAPPED | 1 | 1 | 0 |  |
| COUNT, OUTPUT B SWAPPED | 1 | 1 | 1 |  |

## AMPALASM20 COMMANDS (CP/M Version)

AMPALASM20 contains several different commands which simplify the design process. These commands not only translate the PAL DESIGN SPECIFICATION into a format useable by a programmable logic device programmer, but also help in checking designs for correctness and assist in design documentation. The list of AMPALASM20 commands appears below. A detailed description of each command follows the list.

JEDEC: Creates a fuse map in the JEDEC standard PLDTF from the PAL DESIGN SPECIFICA. TION and stores it on disk.
SIMULATE: Simulates the Boolean equation input by comparing it with a user created table of test vectors in the PAL DESIGN SPECIFICATION, called the FUNCTION TABLE. Following simulation, a JEDEC standard PLDTF output with fuse map and test vectors is created.
ECHO: Prints a copy of the PAL DESIGN SPECIFICATION.
PLOT: Prints a graphic representation of the programmed PAL fuse map.
NEXT: Loads a new file from the disk to be assembled. This allows multiple files to be assembled in a single session.
CHANGE: Changes the output destination to either the CRT, disk or programmer.
QUIT: Quit AMPALASM20 and return to native operating system. ${ }^{\text {• }}$

## JEDEC STANDARD PROGRAMMABLE LOGIC DATA TRANSFER FORMAT "J"

The Joint Electron Devices Engineering Council (JEDEC) programmable logic data transfer format (PLDTF) is a universal transfer format for fuse and test information between hosts and intelligent device programmers. This format is an industry standard used by many commercial programmer manufacturers. It gives each fuse a unique decimal address (specified in a logic diagram schematic) and indicates the state of each fuse for the programmed part. The format consists of four main sections: the design specification identifier, fuse link information, structured functional test information, and the sumcheck. The output of this command is a fuse map ready to be downloaded to a PAL programmer.

Details of the various sections of the PLDTF are available in Appendix A for the interested user.

An example of the JEDEC transfer format is shown on the next page. All fields except the structured test vectors are shown. The structured vectors are only created from AMPALASM20 following the SIMULATE command (explained later).

ENTER PAL20 OPTION: J
AMPAL16R4
PATTERN NUMBER K2/044-C
DUAL BUS 4-BIT COUNTER
ADVANCED MICRO DEVICES 901 THOMPSON PLACE SUNNNYVALE CA 94086 *D9724
*FO*
L0000 11111111111111111111111101111111 *
L0032 11111111111011111111101111111111 *
L0064 11111111111111111111011011111111 *
 L0288 11111111111111101111101111111111 \% L0320 11111111111111111110011111111111 * L0512 11111111111111111111111111110111 * L0544 11111111111111111011101110111111 * L0576 11101111111111111111011110111111 * L0608 01111111110111011101110101111111 * L0640 $11111111111011101111111101111111 *$ L0672 11111111111011111110111101111111 * L0704 11111111111011111111111001111111 * L0736 10111111111011111111111101111111 * L0768 11111111111111111111111111110111 * L0800 111111111111101111111011.10111111 *
L0832 11111110111111111111011110111111 *
L0864 01111111111111011101110101111111 *
L0896 11111111111111101110111101111111 *
L0928 11111111111111101111111001111111 *
L0960 101111111111111011111111101111111 *
L1024 11111111111111111111111111110111 *
L1056 11111111101111111111101110111111 *
L1088 11111111111111111111011110101111 *
L1120 01111111111111111101110101111111 *
L1152 11111111111111111110111001111111 *
L1184 10111111111111111110111101111111 *
L1280 11111111111111111111111111110111 *
L1312 11111011111111111111101110111111 *
L1344 11111111111111111111011110111110 *
L1376 01111111111111111111110101111111 *
L1408 10111111111111111111111001111111 *
L1536 11111111111111111111111101111111 *
L1568 11111111111111111110101111111111 *

L1792 11111111111111111111111101111111 *
L1824 11111111111111111111101011111111 *
L1856 11111111111011111111011111111111 *
C8C36*
89A3

## SIMULATE "S"

The SIMULATE command uses the function table entries and the logic equations to emulate the operation of the specified device. Any difference between the expected value (computed value) and the actual value (function table value) is flagged as a fatal error. The output format follows the JEDEC Programmable Logic Data Transfer Format as described previously under the JEDEC output format command. This output may be used by intelligent device programmers to program and test programmable logic devices, verifying logical functionality. An example output of the SIMULATE command is given below:

ENTER PAL20 OPTION: S
AMPAL16R4 PAL DESIGN SPECIFICATION
PATTERN NUMBER K2/044-C WARREN MILLER 4/1/82 DUAL BUS 4-BIT COUNTER WITH BIT SWAPPABLE OUTPUTS ADVANCED MICRO DEVICES 901 THOMPSON PLACE SUNNNYVALE CA 94086 *D9724
$* \mathrm{FO}^{*}$
L0000 11111111111111111111111101111111 *
L0032 1111111111101111111110111111,1111 *
L0064 11111111111111111111011011111111 *
L0256 11111111111111111111111101111111 *
L0288.1111 1111111111101111101111111111 *
L0320 11111111111111111110011111111111 *
L0512 11111111111111111111111111110111 *
L0544 11111111111111111011101110111111 *
L0576,1110 1111111111111111011110111111 *
L0608 01111111110111011101110101111111 *
L0640 11111111111011101111111101111111 \%
L0672 11111111111011111110111101111111 *
L0704 11111111111011111111111001111111 *
L0736 10111111111011111111111101111111 *
L0768 1111111111111111111111111111.0111 *
L0800 111111111111110111111101110111111 *
L0832 11111110111111111111011110111111 \%
L0864 01111111111111011101110101111111 *
L0896 111111111111111101110111101111111 *
L0928 11111111111111101111111001111111 *
L0960 10111111111111101111111101111111 *
L1024 11111111111111111111111111110111 * L1056 1111111110111111111110111011 1111 * L1088 11111111111111111111011110101111 * L1120 01111111111111111101110101111111 * L1152 11111111111111111110111001111111 \% L1184 1011111111111111111011110111.1111 * L1280 $11111111111111111111111111110111 *$ L1312 $11111011111111111111101110111111 \%$ L1344 $11111111111111111111011110111110 \%$ L1376 01111111111111111111110101111111 * L1408 10111111111111111111111001111111 * $\begin{array}{lllllllllll}\text { L1536 } & 1111 & 1111 & 1111 & 1111 & 1111 & 1111 & 0111 & 1111 & *\end{array}$ L1568 11111111111111111110101111111111 \% L1600 111111111111111101111011111111111 * L1792 11111111111111111111.111101111111 * L1824 $111111111111111111111101011111111 \%$ L1856 1111 1111111011111111011111111111 * C8C36*
V0001 XXXXXXXXXX01XXZZZZXXX1 *
V0002 C011110010011LLLL111 *
V0003 C011110000000HHHHOO1 *
V0004 C011111000000LLLL001 *
V0005 C1XXXX01000HLHLLLLL1 * V0006 C1XXXX01000LHLHLLLLL1 * V0007 C1XXXX01000HHHHLLLL1 * V0008 C1XXXX01000LLLLHLHL1 * V0009 C1XXXX01000HLHLHLHL1 * V0010 C1XXXX01000LHLHHLHL1 * V0011 C1XXXX01000HHHHHLHL1 * V0012 C1XXXX1 1000HLLLLHLL1 * V0013 C1XXXX11000HLHLLHLH1 * V0014 C1XXXX11000HLLHLHHL1 * V0015 C1XXXX11000HLHHLHHHI * V0016 C1XXXX11000HHLLHHLLI * V0017 C1XXXX11000HHHLHHLH1 * V0018 C1XXXX1 1000HHLHHHHL1 * V0019 C1XXXX11000HHHHHHHH1 * V0020 C1XXXX01000LLLLLLLL1 * V0021 C0XXXX01000LLLLLLLL1 * 1B05

## ЕСНО "E"

The ECHO command displays the PAL DESIGN SPECIFICATION input file on the console. This mode allows the file to be reviewed for correctness or spooled to a listing device as a hard copy. An example of the ECHO command is given below:

ENTER PAL20 OPTION: E
AMPAL16R4
PATTERN NUMBER K2/044-C
PAL DESIGN SPECIFICATION
WARREN MILLER 4/1/82
DUAL BUS 4-BIT COUNTER WITH BIT SWAPPABLE OUTPUTS
ADVANCED MICRO DEVICES 901 THOMPSON PLACE SUNNYVALE CA 94086
CLK CARRYIN ADATAO ADATA1 ADATA2 ADATA3 SO S1 RESET GND
/OE BDATAO BDATA1 Q0 Q1 Q2 Q3 BDATA2 BDATA3 VCC
/QO:= RESET
/S1*/SO*/ADATAO + ;LOAD A
/S1* SO*/BDATAO + ;LOAD B
S1* QO* CARRYIN + ;COUNT S1*/QO*/CARRYIN

/S1* SO*/BDATA1 + ;LOAD B
S1* Q1* Q0* CARRYIN + ;COUNT S1*/Q1*/Q0 S1*/Q1*/CARRYIN
/Q2 := RESET
/S1*/SO*/ADATA2 + ;LOAD A
/S1* SO*/BDATA2 + ;LOAD B S1* Q2* Q1* Q0* CARRYIN + ;COUNT S1*/Q2*/Q1
$+$ S1*/Q2*/Q0 + S1*/Q2*/CARRYIN

/S1* SO*/BDATA3 + ;LOAD B S1* Q3* Q2* Q1* Q0* CARRYIN + ; COUNT S1*/Q3*/Q2 + S1*/Q3*/Q1 + S1*/Q3*/Q0 + S1*/Q3*/CARRYIN


FUNCTION TABLE:
CLK ADATA3 ADATA2 ADATA1 ADATAO BDATA3 BDATA2 BDATA1 BDATA0 /RESET S1 SO CARRYIN /OE Q3 Q2 Q1 Q0


DESCRIPTION: THIS PAL IMPLEMENTS A 4-BIT COUNTER FOR A MULTIPLE BUS CPU. THE COUNTER CAN BE LOADED FROM EITHER THE ADATA INPUT BUS OR THE BDATA INPUT-OUTPUT BUS. THE CONTENTS OF THE COUNTER CAN BE OUTPUT TO THE THREE STATE Q BUS OR THE BDATA INPUT-OUTPUT BUS. ADDITIONALLY WHEN THE BDATA BUS IS USED TO OUTPUT THE COUNTER CONTENTS EITHER A BIT-NORMAL OR A BIT-REVERSED VERSION CAN BE SELECTED.

MODE DEFINITIONS ARE GIVEN BELOW.

|  | Sl | SO | CARRY-IN |
| :--- | ---: | :---: | :---: |
| LOAD A | 0 | 0 | X |
| LOAD B | 0 | 1 | X |
| HOLD, OUTPUT B NORMAL | 1 | 0 | 0 |
| COUNT, OUTPUT B NORMAL | 1 | 0 | 1 |
| HOLD, OUTPUT B SWAPPED | 1 | 1 | 0 |
| COUNT, OUTPUT B SWAPPED | 1 | 1 | 1 |

## PLOT "P"

The PLOT command displays a graphical representation of the location of blown and intact fuses defined in the PAL DESIGN SPECIFICATION. It is oriented similarly to the fuse map in the PAL logic diagram; inputs from top to bottom, product terms from left to right. Additionally, the equation is displayed to the right of each product term. A cross " $X$ " indicates an intact link and a dash " - " indicates a blown link for the appropriate input line. An example plot is given below:

ENTER PAL20 OPTION: P
dual bus 4-bit counter with bit swappable outputs
1111111111222222222233
01234567890123456789012345678901

 xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx


 -X-- -----------8 Xxxx Xxxx xxxx xxxx xxxx xxxx xxxx xxxx XXXX XXXX XXXX XXXX XXXX XXXX XXXX .XXXX

 --_ -- -- --

 5 Xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx 6 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 47 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX

 xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 3 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 55 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX
 57 … --...9 Xxxx Xxxx Xxxx xxxx xxxx xxxx xxxx xxxx 60 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 61 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX 62 Xxxx XxXx XXXX XXXX XXXX XXXX XXXX XXXX 63 XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX

LEGEND: X : FUSE NOT BLOWN (L,N,O) - : FUSE BLOWN (H, P, 1)
NUMBER OF FUSES BLOWN $=1120$

## NEXT "N"

The NEXT command loads a new file from the disk to be assembled. This allows multiple files to be assembled in a single session.

Enter PALASM20 Option: N
Enter PAL DESIGN SPEC Input Filename: DMC.PAL
Output Destination:

$$
\begin{aligned}
& \mathrm{D}=\mathrm{DISK} \\
& \mathrm{C}=\mathrm{CRT} \\
& \mathrm{P}=\text { PROGRAMMER (PUN) }
\end{aligned}
$$

Enter Destination: C
ASSEMBLY SUCCESSFUL!

## CHANGE "C"

The CHANGE command reassigns the output destination to either the CRT, disk or programmer.

Enter PALASM20 Option: C
Output Destination:

$$
\begin{aligned}
& \mathrm{D}=\mathrm{DISK} \\
& \mathrm{C}=\mathrm{CRT} \\
& \mathrm{P}=\text { PROGRAMMER (PUN) }
\end{aligned}
$$

Enter Destination: C

## QUIT "Q"

The QUIT command transfers control back to the native operating system.

Enter PALASM20 Option: Q

## ERROR MESSAGES

## Introduction

AMPALASM20 may produce error messages when improper PAL description files are processed. Three types of error messages are possible: warnings, errors, or fatal errors. Examples of typical error messages are given below. Details of others are provided on AMPALASM20 HELP file.

## Warning Messages

Warnings are used to notify the user that an oversight may have been made when the PAL description file was created. A warning will not prohibit creation of an output file, but the user should check the warnings before programming a device to insure that the output matches the intended device definition.
\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\% \% . \% * $\because * *$ WARNING $* * * *$ VCC/GND IS NOT RECOMMENDED TO BE USED \% \% IN THE EQUATIONS! \% \% \%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\% DESCRIPTION:

You do not have to use VCC or GND in the equation. Try to delete it.

## \%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%

\%
$\%$ THE FUNCTION TABLE IS OMITTED $\%$
\% PREVENTING SIMULATION! \%
\% \%
\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%

## Error Messages

Errors are used to notify the user that an illegal operation has been requested during execution of AMPALASM20. For exam. ple if an illegal file is requested as input to or output from AMPALASM20, an error message will be displayed.
\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%
\%
\%
\% *****ERROR***** INPUT READ ERROR IN LINE @ \%
\% \%
\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%
DESCRIPTION:
Physical read error.
\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%


The program cannot find the input file specified; you have to reenter an existing input file name.

## Fatal Error Messages

Fatal errors are used to notify the user that a nonrecoverable error exists in a PAL description file. These errors prohibit output file creation and must be corrected by the user prior to re-running AMPALASM20.

## \%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\% \% <br> \% ***FATAL ERROR*** THE PAL PART YOU SPECIFY CAN NOT BE \% <br> \% RECOGNIZED BY AMPALASM 20! \% <br> \% \% <br> \%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\% DESCRIPTION:

This occurs because AMPALASM20 cannot recognize the PAL part you specify in the first line, note that the first line must begin with PAL, AMPAL, AmPAL, otherwise will activate this fatal error. Check your input file!
\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%

\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%

## DESCRIPTION:

A pin name is missed between the specified pin name and following operator.

## Symbol Definition

(13) is a place holder for the part number or pin name associated with the indicated error. In the displayed error message the actual number or name will be shown.

- is a place holder for the line of text associated with the indicated error. In the displayed error message the actual text will be shown.


## APPENDIX A

## JEDEC Standard Programmable Logic Data Transfer Format＂J＂

The Joint Electron Devices Engineering Council（JEDEC）pro－ grammable logic data transfer format（PLDTF）is a universal transfer format for fuse and test information between hosts and intelligent device programmers．This format is an in－ dustry standard used by many commercial programmer man－ ufacturers．It gives each fuse a unique decimal address （specified in a logic diagram schematic）and indicates the state of each fuse for the programmed part．The format consists of four main sections：the design specification iden－ tifier，fuse link information，structured functional test infor－ mation，and the sumcheck．The output of this command is a fuse map ready to be downloaded to a PAL programmer．

## Design Specification Identifier

The DESIGN SPECIFICATION identifier is a heading used by the designer to document the device to be programmed．The user is free to specify any documenting text desired．The AMD recommended format is identical to the first four lines of the PAL DESIGN SPECIFICATION．The heading is begun with an ASCII＂STX＂（02 HEX）and is terminated with an ASCII asterisk＂＊＂（2A HEX）．Notice that this requires the PAL DESIGN SPECIFICATION heading to be asterisk free．

An optional device code can be specified，indicating to the device programmer the type of part to be programmed．This code is a variable length decimal number，preceded by an ASCII＂D＂（44 HEX）and terminated by an ASCII＂＊＂（2A HEX）．

## Fuse Link Information

This section of the format defines the state of each fuse，and consists of three fields：fuse default state，link information， and checksum．The first field is optional and is used to in－ dicate the fuse default state．If a fuse state isn＇t otherwise specified，the default state will be used．The default state is specified by an ASCII＂F＂（46 HEX）followed by an ASCII＂ 0 ＂ （ 32 HEX ）for a low resistance link or an ASCII＂ 1 ＂（ 33 HEX ）for a high resistance link．The field is terminated with an ASCII ＂＊＂（2A HEX）．
The second field，link information，identifies the state of each fuse individually．The field begins with an ASCII＂L＂（4C HEX） followed by an ASCII decimal fuse address of variable length， terminated by an ASCII＂＊＂（2A HEX）．This indicates the fuse address of the first fuse state．The individual fuses are specified by an ASCII＂ 0 ＂（ 32 HEX）or an ASCII＂ 1 ＂（ 33 HEX ）in－ dicating low resistance and high resistance respectively．The fuse address is incremented for each additional fuse state． Thus fuse states can be specified sequentially．Any number of fuse addresses may be specified by inserting additional ＂$L$＂fields．If a link is specified 2 or more times，the last state replaces the preceding entries．
The third field is an optional checksum for the link informa－ tion．This checksum is computed by performing a 16 －bit addi－ tion of the 8 －bit words constructed from the specified state of each fuse link in the device．The 8 －bit words are constructed sequentially from the single bit fuse state definitions．The method of constructing these words is shown below．

MSB
LSB




Link No． $\begin{array}{lllllllll}15 & 14 & 13 & 12 & 11 & 10 & 9 & 8\end{array}$


Link No． $\begin{array}{lllllllll}23 & 22 & 21 & 20 & 19 & 18 & 17 & 16\end{array}$

|  | ． | ＊ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | ＊ |  |  |  |  |  |
|  |  | ＊ |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
| Word | 137 | ＊ | ＊ | ＊ | ＊ |  | ＊ |
|  |  |  | 芜泬 | 苓莫 | ＊ |  |  |
| Link No． |  | $\begin{array}{llll} 1100 & 1099 & 1098 & 1097 \\ \text { last } & & \\ \text { link } \end{array}$ |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |

The word encompassing the last link is constructed by setting zeros for all bit locations more significant than the last link. The 16 -bit sum is expressed as 4 ASCII Hex characters. On ASCII " C " precedes the four Hex characters. The last character is followed by an ASCII "*".

## Structured Functional Test Information

The structured functional test information is an optional field which can define test vectors to be used by intelligent programmable logic device programmers to test the logical functionality of a programmed device. These vectors specify the driven state for inputs and the checked value for outputs.

The field is specified with an ASCII " V " followed by a variable length decimal test vector address. The address is terminated by an ASCII "W". Following the test vector address is a series of 20 characters specifying the driven or tested state for each pin.
The format for each character in the test vector output is given below:

H Test output for a logical HIGH
L Test output for a logical LOW

1 Drive input to a logical HIGH
0 Drive input to a logical LOW
$X$ Irrelevant. If an output do not test. If an input drive to a logical LOW as a default.
C Drive input from logical LOW to logical HIGH. (clock pulse).
Z Test output for high impedance.
The test vector is terminated with an ASCII asterisk "*". Multiple test vectors are specified by incrementing the decimal vector address by 1 for each additional test vector.

## Sumcheck

The sumcheck field provides redundancy to help in detecting errors in data transmission. This field is constructed by performing a binary addition of each character between the STX and ETX in the transmitted file. The resulting least significant 16 bits are the sumcheck. This number is represented as four Hex characters preceded by an ASCII asterisk "*" in the final printout.
Examples of the JEDEC transfer format are shown previously in descriptions of the JEDEC and SIMULATE commands.

## Section 5

## Applications

Four-Bit Slice Registered Barrel Shifter<br>Dynamic Memory Control State Sequencer<br>GCR (4B-5B) Encoder/Decoder<br>Interfacing the 8086 ( 8088 ) to the Z-BUS<br>An AMD PAL MULTIBUS Arbiter<br>Am8500 to MC68000 PAL Interface<br>The Berkeley-1 Plus-A High Performance CPU Utilizing PALs

## Four-Bit Slice Registered Barrel Shifter

## by Warren Miller Advanced Micro Devices

In most data processing systems, some form of data shifting or rotation is necessary. This elementary function is used in such diverse applications as floating point arithmetic and string manipulation. In the typical computer, the shifter is located on the output of the ALU. This architecture allows single cycle add and shift, and mask and shift operations (see Figure 1 for a typical computer ALU architecture).

## DESIGN REQUIREMENTS

A barrel shifter takes data input and cyclically rotates it by an arbitrary number of bit positions. This cyclic rotation means
that data rotated off the most significant end of the shifter is brought back on the least significant end. The name barrel shifter is used because of the circular nature of the shift operation.

The storage register on the output of the shifter is used in this architecture to pipeline the data operation, increasing throughput. The three-state Buffer on the register output is necessary to interface the ALU to the output data bus.


Figure 1. Typical ALU Architecture

## DESIGN APPROACH

An 8-bit registered barrel shifter would take at least 8 data inputs, 8 registered data outputs, and 3 control lines to implement (see Figure 2). The AmPAL16R8 has 8 registered data outputs but only 8 inputs, not enough to implement the 8 -bit registered barrel shifter in a single device. In cases like this, where the function to be implemented can't fit into a single PAL because of pin limitations, the problem is best approached by dividing it into smaller functions. These smaller functions should be chosen in such a way that each function requires a reduced number of pins, hence, easing the pin limitation problem. One possible approach would be to "slice" the 8 -bit function into two 4 -bit functions. Figure 3 shows the approach used to divide the part into two sections, each containing a smaller number of pins.

Notice that every data and control input participates in each output function. Thus the 4-bit partition must include all data
and control inputs, giving a total of 11 array inputs and 4 outputs per device. If both devices are programmed identically, the 8 -bit function can be implemented as shown in Figure 4. The data inputs are "offset" by 4 places to differentiate between the upper and lower nibbles.

A 4-bit slice of the 8-bit barrel shifter can be implemented in a AmPAL16R4. This part allows up to 12 inputs (one more than necessary) and 4 registered outputs. The extra input is used for a set function, loading the output register with all ones. The logic diagram and PALASM listing for the registered barrel shifter slice are shown following.

The PAL solution requires only two 20-pin packages. An MSI version of the 8 -bit barrel shifter would require 4 Am25S10 four-bit shifters and an Am25S374 octal three state register. The savings in cost, board space and power are considerable, and the PAL solution is also faster.


FUNCTION DEFINITION

| CONTROL INPUTS |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{2}$ | $\mathrm{~S}_{1}$ | $\mathrm{~S}_{0}$ | INPUT TO OUTPUT MAPPING |  |  |  |  |  |  |  |
| 0 | 0 | 0 | $\mathrm{Y}_{7}$ | $\mathrm{Y}_{6}$ | $\mathrm{Y}_{5}$ | $\mathrm{Y}_{4}$ | $\mathrm{Y}_{3}$ | $\mathrm{Y}_{2}$ | $\mathrm{Y}_{1}$ | $\mathrm{Y}_{0}$ |
| 0 | 0 | 1 | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| 0 | 1 | 0 | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | $\mathrm{D}_{7}$ |
| 0 | 1 | 1 | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ |
| 1 | 0 | 0 | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ |
| 1 | 0 | 1 | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ |
| 1 | 1 | 0 | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ |
| 1 | 1 | 1 | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ |
| 1 | $\mathrm{D}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ |  |  |

03862A. 82

Figure 2. 8-Bit Registered Barrel Shifter


Figure 3. 4-Bit Slice Approach


Figure 4. 8-Bit Barrel Shifter Implementation with Two 4-Bit Slices

PAL16R4
PAT001
4-BIT SLICE FOR AN 8-BIT BARREL SHIFTER ADVANCED MICRO DEVICES
CK D7 D6 D5 D4 D3 D2 D1 D0 GND
/E /SET S0 Q0 Q1 Q2 Q3 S1 S2 VCC
$/ \mathrm{Q3}:=/ \mathrm{SET} * / \mathrm{S} 2 * / \mathrm{S} 1^{*} / \mathrm{SO}^{*} / \mathrm{D} 3+$ /SET*/S2*/S1* S0*/D2 + /SET*/S2* S1*/SO*/D1 + /SET*/S2* S1* SO*/D0 + /SET* S2*/S1*/S0*/D7 + /SET* S2*/S1* S0*/D6 + /SET* S2* S1*/SO*/D5 + /SET* S2* S1* SO*/D4
$/ \mathrm{Q} 2:=/ \mathrm{SET}^{*} / \mathrm{S}^{*}$ */S1*/SO*/D2 + /SET*/S2*/S1* SO*/D1 + /SET*/S2* S1*/SO*/D0 + /SET*/S2* S1* SO*/D7 + /SET* S2*/S1*/SO*/D6 + /SET* S2*/S1* SO*/D5 + /SET* S2* S1*/SO*/D4 + /SET* S2* S1* S0*/D3
$/ \mathrm{Q} 1 .:=/ \mathrm{SET}^{*} / \mathrm{S} 2 * / \mathrm{S} 1^{*} / \mathrm{SO} * / \mathrm{D} 1+$ /SET*/S2*/S1* SO*/D0 + /SET*/S2* S1*/SO*/D7 + /SET*/S2* S1* SO*/D6 + /SET* S2*/S1*/SO*/D5 + /SET* S2*/S1* S0*/D4 + /SET* S2* S1*/SO*/D3 + /SET* S2* S1* SO*/D2
$/ \mathrm{QO}:=/ \mathrm{SET} * / \mathrm{S} 2^{*} / \mathrm{S}^{*} / \mathrm{SO}^{*} / \mathrm{DO}+$ /SET*/S2*/S1* S0*/D7 + /SET*/S2* S1*/S0*/D6 + /SET*/S2* S1* S0*/D5 + /SET* S2*/S1*/SO*/D4 + /SET* S2*/S1* SO*/D3 + /SET* S2* S1*/SO*/D2 + /SET* S2* S1* SO*/D1

PAL DESIGN SPECIFICATION KEVIN M. OW-WING 6/22/82

FUNCTION TABLE
CK /E /SET S2 S1 S0 D7 D6 D5 D4 D3 D2 D1 D0 Q3 Q2 Q1 Q0

HIGH Z TEST
$\begin{array}{lllllllllllllllll}H & X & X & X & X & X & X & X & X & X & X & X & X & Z & Z & Z & Z\end{array}$
SET OUTPUTS TEST
$\begin{array}{llllllllllllllllll}L & L & X & X & X & X & X & X & X & X & X & X & X & H & H & H & H\end{array}$
PSEUDO RANDOM BARREL SHIFTER TEST SEQUENCE

| L | H | L | L | L | L | L | L | L | L | L | L | H | L | L | L | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| L | H | L | L | H | L | L | L | L | L | L | H | L | L | H | L | L |
| L | H | L | H | L | H | L | L | L | L | L | L | L | L | L | H | L |
| L | H | L | H | H | L | L | H | L | L | L | L | L | L | L | L | H |
| L | H | H | L | L | L | H | L | L | L | L | L | L | L | H | L | L |
| L | H | H | L | H | L | L | L | H | L | L | L | L | L | L | H | L |
| L | H | H | H | L | L | L | H | L | L | L | L | L | H | L | L | L |
| L | H | H | H | H | L | L | L | L | L | L | H | L | L | L | L | H |
| L | H | L | L | H | L | L | L | L | L | H | L | L | H | L | L | L |
| H | H | L | L | L | L | H | L | L | L | L | H | L | L |  |  |  |

DESCRIPTION: THIS PART IS A 4-BIT SLICE OF AN 8-BIT REGISTERED
BARREL SHIFTER. IT TAKES 8 DATA INPUTS AND CYCLICALLY ROTATES THE DATA FROM 0 TO 7 PLACES UNDER CONTROL OF THE SELECT ( S ) INPUTS. A SET INPUT CAN BE USED TO INITIALIZE THE OUTPUTS TO THE ALL ONES STATE.

PAL16R4
PAT001
4-BIT SLICE FOR AN 8-BIT BARREL SHIFTER ADVANCED MICRO DEVICES
*D9724
*FO*
L0512 11101110111111111011111111101101 *
L0544 11101110111111111111101111011101 *
L0576 11101101111111111111111110101101 *
L0608 11101101111111111111111111011001 *
L0640 10011110111111111111111111101101 *
L0672 11011010111111111111111111011101 *
L0704. 11011101101111111111111111101101 * L0736 11011101111110111111111111011101 * L0768 $111011101111 \cdot 11111111101111101101$ * L0800 11101110111111111111111110011101 * L0832 11101101111111111111111111101001 * L0864 10101101111111111111111111011101 * L0896 11011010111111111111111111101101 * L0928 1101111010111111111111111101.1101 * L0960 11011101111110111111111111101101 * L0992 11011101111111111011111111011101 * L1024 11101110111111111111111110101101 * L1056 11101110111111111111111111011001 * L1088 10101101111111111111111111101101 * L1120 11101001111111111111111111011101 L1152 11011110101111111111111111101101 * L1184 1101111011111011111111111101 1101* L1216 11011101111111111011111111101101 * L1248 11011101111111111111101111011101 * L1280 11101110111111111111111111101001 * L1312 10101110111111111111111111011101 * L1344 11101001111111111111111111101101 * L1376 11101101101111111111111111011101 * L1408 11011110111110111111111111101101 * L1440 11011110111111111011111111011101 * L1472 11011101111111111111101111101101 * L1504 11011101111111111111111110011101 * C67E0*
V0001 Xxxxxxxxx01xxzZZzZxx1 * V0002 CXXXXXXXX000XHHHHXX1 * V0003 C000000010010HLLLO01 * V0004 C000000100011LLHLOO1 * V0005 C100000000010LHLL101 * v0006 C001000000011HLLL101 * V0007 C010000000010LLHLO11 * V0008 C000100000011LHLL011 * V0009 C001000000010LLLH111 * V0010 C000000100011HLLL111 * V0011 C000001000011LLLH001 * V0012 C000010000011LLHLL11 * 994E

PAL DESIGN SPECIFICATION KEVIN M. OW-WING 6/22/82

## LOGIC DIAGRAM FOR:

4-BIT SLICE REGISTERED BARREL SHIFTER USING AmPAL16R4
Columns: Inputs (0-31)


# Dynamic Memory Control State Sequencer 

## by Brad Kitson Advanced Micro Devices

An example of a control path application for an AMD PAL is in a memory system. Most large memory systems use MOS dynamic RAMs. Their high density allows packing a large memory size into a small board area. Dynamic RAM prices also make them very cost effective.

Dynamic RAMs require external logic for address multiplex ing, timing generation and refresh control. This application note shows the use of an AmPAL16R8A and an Am2964B to provide the necessary external logic for a typical dynamic memory system. The PAL is used as a state sequencer for timing generation and the Am2964B provides specialized control circuitry and reduces timing skew between control signals. This implementation replaces about 20 SSI/MS packages.

## DESIGN REQUIREMENTS

A system block diagram is shown in Figure 1. The control bus provides most of the inputs to the PAL state sequencer. These include: Memory Request ( $\overline{\mathrm{MREQ}})$, READ/ $\overline{\mathrm{WRITE}}(\mathrm{RW})$, RESET (RST), Refresh Clock (RFCK), and Read-Modify-Write (RMW). Two upper address lines of the address bus serve as board selects ( $\mathrm{BS}_{1}, \mathrm{BS}_{0}$ ), and one local signal, SLOW/FAST Memory (FAST), allows use of either slow or fast memory. A READ/WRITE sequence is initialized by MREQ ANDed with the proper board select conditions and a refresh sequence is initialized by RFCK. If both sequences are requested at the same time, a refresh sequence is performed. RW when HIGH selects a READ operation and when LOW selects a WRITE operation. RMW when HIGH selects a Read-Modify-Write cycle.


Figure 1. Dynamic Memory Controller
03862A. 86

The outputs of the PAL provide the timing and control inputs to the Am2964B. These are: Row Address Strobe ( $\overline{\text { RAS }}$ ), Address Multiplexer Select (MS), Column Address Strobe (CAS), and Refresh ( $\overline{\mathrm{RFSH}}$ ). In addition, the PAL provides the Write Enable (WE) to the Memory Array. Figure 2 shows the timing for fast READ/WRITE cycles. The memory cycle is initiated by $\overline{M R E Q}$ going LOW. The PAL responds by bringing $\overline{\text { RAS }}$ LOW at $\mathrm{t}_{0}$, followed by MS going LOW at $\mathrm{t}_{1}$, and finally bringing CAS LOW at $\mathrm{t}_{2}$. If RW is LOW, $\bar{W}$ is also brought LOW at
$t_{2}$. WE is held LOW until $t_{4}$. $\overline{\text { RAS }}, \mathrm{MS}$ and $\overline{\text { CAS }}$ are brought HIGH at $t_{5}$. The rising edge of any of these 3 signals may be used to latch output data during a Read operation. The state sequencer is then disabled for 3 states to allow for memory precharge.

By holding the FAST input LOW, an extended memory cycle is available to accommodate slower RAMs. The timing appears in Figure 3.


Figure 2. Fast READ/WRITE Cycle


Figure 3. Extended Memory Cycle

RAS-Only refresh cycle timing is shown in Figure 4. The refresh cycle is initiated when RFCK goes HIGH. The RFSH output goes L.OW at $t_{0}$, followed by RAS at $t_{1}$. The Am2964B supplies the necessary refresh address. $\overline{\text { RAS }}$ is brought back HIGH at $\mathrm{t}_{5}$ and precharge is then timed out. An extended refresh cycle for slower memory is available also. Burst refresh can be accomplished by leaving RFCK HIGH for as many refresh cycles as desired.

Read-Modify-Write cycle timing is activated by setting RMW HIGH. This is especially valuable in systems with Error Detection/Correction (EDC) capability. Data can be read, modified by the EDC circuitry (Am2960), and if necessary, written back to memory in a single memory cycle. Read-Modify-Write cycle timing is shown in Figure 5. Note that WE goes LOW at the end of the cycle.


Figure 4. $\overline{\operatorname{RAS}}$-Only Refresh Cycle


Figure 5. Read-Modity-Write Cycle

## DESIGN APPROACH

The first step in the state sequencer design process is to define the timing waveforms for all of the functions desired. Figures 2, 3, 4 and 5 are the result. Next, characteristics of the resulting waveforms are examined. Initially, the sequencer is waiting on the MREQ or RFCK input. If MREQ goes LOW, the $\overline{R A S}$ to MS to CAS sequence is initiated. If RFCK goes HIGH, the $\overline{\text { RFSH }}$ to $\overline{\text { RAS }}$ sequence is initiated. Both sequences are equivalent to a simple "shift" function. Once the shift sequence is completed and the signals are asserted, they must stay asserted for a specific time depending on the selected function. To time the length that signals must stay asserted
requires a "counting" function. The precharge sequence at the end of all cycles also requires "counting". This partitions most of the design into two smaller functional blocks; a shifter and a counter. The remaining function select and control logic is partitioned into a "multiplexer-like" functional block. Figure 6. shows the PAL partitioned into functional blocks. By dividing the design into blocks, its implementation becomes simple.

The following pages show the easy to read PAL DESIGN SPECIFICATION and a logic diagram for the AmPAL16R8A dynamic memory state sequencer.


Figure 6. Partitioned Design/PAL Equivalent

PAL DESIGN SPECIFICATION BRAD S. KITSON 2/10/82

PAT002
DYNAMIC MEMORY CONTROL STATE SEQUENCER ADVANCED MICRO DEVICES
CK RFCK /RST RW /MREQ RMW FAST BS1 BSO GND
/E /Q0 /Q1 /Q2 /RFSH /WE /CAS• MS /RAS VCC
Q0 : = /RST* /MS*/Q0 /RST* RFSH*RAS*/Q0 /RST*/FAST*/Q0*Q2 /RST*/FAST*/Q0*Q1 /RST*/FAST* Q1*Q2 $^{*}$ /RST* FAST*/RMW*QO*/Q1 /RST* FAST*/RMW*Q0*/Q2

Q1 := /RST* RAS*/Q0* Q1 + /RST* RAS* Q0*/Q1 + /RST*/RAS* QO* Q1 +

- /RST*/RAS*/QO* Q2

Q2 $:=/$ RST $^{*}$ RAS*Q2 + /RST* QO*Q2 + /RST*RAS*QO*Q1

RFSH : $=/$ RST*RFCK*/Q2*/Q1*/Q0*/RAS + | /RST*RFSH*RAS | + |
| :--- | :--- |
| /RST*RFSH*/FAST* 01 | + | /RST*RFSH* Q2

WE $:=/ \mathrm{RST}^{*} / \mathrm{RW}^{*} / \mathrm{MS}^{*} / \mathrm{RFSH}^{*} / \mathrm{RMW}^{*} / \mathrm{QO} * / \mathrm{Q}$ /RST*/RW*/MS*/RFSH*/RMW*/Q1*/Q2 + /RST*/RW*/MS*/RFSH* RMW*/QO* Q1*Q2 + /RST*/RW*/MS*/RFSH* RMW* Q0*/Q1*Q2

CAS :=/RST*/RFSH*/MS*/Q0 + /RST*/RFSH*/MS*/Q1 + /RST*/RFSH*/MS*/Q2
$/ \mathrm{MS}:=/ \mathrm{RST}^{*} / \mathrm{RFSH}^{*} \mathrm{RAS}^{*} / \mathrm{QO}+$ /RST*/RFSH*RAS*/Q1 + /RST*/RFSH*RAS*/Q2

RAS $:=/ \mathrm{RST}^{*} / \mathrm{RFCK}^{*} / \mathrm{QO} * / \mathrm{Q1}^{*} / \mathrm{Q2*} \mathrm{MREQ}^{*} / \mathrm{BSI}^{*} / \mathrm{BSO}+$ /RST*/RFSH*/QO*/Q1*/Q2*MREQ*/BS1*/BSO + /RST* RFSH*/Q0*/Q1*/Q2 + /RST*RAS*/Q0 /RST*RAS*/Q1 /RST*RAS*/Q2

FUNCTION TABLE
CK /E /RST /MREQ BS1 BSO RFCK RW RMW FAST RAS /MS CAS WE RFSH Q2 Q1 Q0
; INITIALIZ
 ;
;RAS ONLY REFRESH CYCLE

| C | L | H | H | X | X | H | X | X | X | L | L | L | L | H | L | L | L |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| C | L | H | X | X | X | H | X | X | X | H | L | L | L | H | L | L | L |
| C | L | H | X | X | X | X | X | X | H | H | L | L | L | H | L | L | H |
| C | L | H | X | H | X | X | X | X | X | X | X | H | H | L | L | L | H |
| C | L | H | X | X | H | H |  |  |  |  |  |  |  |  |  |  |  |
| C | L | H | X | X | X | X | X | X | X | H | H | L | L | L | H | L | L |
| C | L | H | H | H | H | H | H |  |  |  |  |  |  |  |  |  |  |
| C | L | H | X | X | X | X | X | L | L | L | H | H | L | L |  |  |  |
| X | X | H | L | L | L | L | H | L | H | L |  |  |  |  |  |  |  |
| X | X | H | L | L | L | L | L | L | L | L |  |  |  |  |  |  |  | ;

;READ-MODIFY-WRITE OPERATION

| C | L H | L | L | L | L | X | X | X | H | L | L | L | L | L | L | L |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C | L H | X | X | X | X | X | X | X | H | H | L | L | L | L | L | L |
| C | L H | X | X | X | X | L | H | L | H | H | H | L | L | L | L | H |
| C | L H | X | X | X | X | L | H | L | H | H | H | L | L | L | H | L |
| C | L H | X | X | X | X | L | H | L | H | H | H | L | L | L | H | H |
| C | L H | X | X | X | X | L | H. | L | H | H | H | L | L | H | L | L |
| C | L H | X | X | X | X | L | H | L | H | H | H | L | L | H | L | H |
| C | L H | X | X | X | X | L | H | L | H | H | H | H | L | H | H | L |
| C | L H | X | X | X | X | L | H | L | H | H | H | H | L | H | H | H |
| C | L H | X | X | X | X | L | H | L | L | L | L | L | L | H | L | H |
| C | L H | X | X | X | X | L | H | L | L | L | L | L | L | H | L | L |
| C | L H | X | X | X | X | L | H | L | L | L | L | L | L | L | H | H |

DESCRIPTION
DYNAMIC MEMORY CONTROL STATE SEQUENCER FOR USE WITH THE AM2964B MEMORY CONTROLLER. THE SEQUENCER PROVIDES /RAS,MS,/CAS, \& REFRESH TIMING GENERATION TO THE AM2964B AND /WE TO THE DRAMS. IT SUPPORTS BOTH FAST (150NS) AND SLOW (300NS) READ/WRITE CYCLES, /RAS ONLY REFRESH, BURST REFRESH, AND READ-MODIFY-WRITE FOR MEMORY BOARDS OF UP TO 256K.

PAL16R8
PAT002
DYNAMIC MEMORY CONTROL STATE SEQUENCER ADVANCED MICRO DEVICES
*D9724
*FO*
L0000 10110111111110111111110110011001 *
L0032 1111 0111111110111101110110011001 *
L0064 11110111111111111110110111011101 *
L0096 11100111111111111111111111111101 *
L0128 11100111111111111111111111011111 *
L0160 11100111111111111111110111111111 *
L0256 11100111111111111101111111111101 *
L0288 11100111111111111101111111011111 *
L0320 11100111111111111101110111111111 *
L0512 11110110111111111101111111111101 *
L0544 11110110111111111101111111011111 *
L0576 11110110111111111101110111111111 *
L0768 11110110101111111001110111111101 *
L0800 11110110101111111001110111011111 *
L0832 11110110101111110101111011101101 *
L0864 11110110101111110101111011011110 *
L1024 01010111111111111111110111011101 *
L1056 11100111111111111110111111111111 *
L1088 11110111111111111110101111101111 *
L1120 11110111111111111110111011111111 *
L1280 11100111111111111111111011111111 *
$\begin{array}{lllllllllll}L 1312 & 1111 & 0111 & 1111 & 1111 & 1111 & 1110 & 1111 & 1110 & *\end{array}$
L1344 11100111111111111111111111101110 *
L1536 11100111111111111111111111101101 *
L1568 11100111111111111111111111011110 *
L1600 11010111111111111111111111101110 *
L1632 $11010111 \cdot 111111111111111011111101$ *
L1792 11110110111111111111111111111101 *
L1824 11100111111111111110111111111101 *
L1856 11110111111111111111101011111101 *
L1888 11110111111111111111101111101101 *
L1920 $11110111111111111111101011101111 *$ L1952 11110111111111111011011111011110 *
L1984 11110111111111111011010111111110 *
C713B*
VO001 CXOXXXXXXOOHHHHHHHH1 *
V0002 C01X0XX0000HHHHHHHL1 *
V0003 CX1XXXXXXOOHHHHHHLL1
V0004 CX10X01XX00LHHHLLLLL1
V0005 CX10X01XX00LLHHLLLLL
V0006 CX10X01XX00LHLHHLLL1
V0007 CX10X01XX00LLLLHHLLL1
V0008 CX10X01XX00HHLHHHHH1
V0009 CX10X01XX00HLHHHHHH1
V0010 CX10X01XXOOHHHHHHHH1
V0011 C11X1XXXXOOHHHLHHHH1
V0012 C1IXXXXXXOOHHHLHHHL1
V0013 CX1XXX1XXO0LHHLHHHL1
V0014 CX1XXX1XXOOLLHLHHHL1

PAL DESIGN SPECIFICATION BRAD S. KITSON 2/10/82

```
V0015 CX1XXX1XXOOLHLLHHHL1 *
V0016 CX1XXX1XXOOLLLLHHHL1
V0017 CX1XXX1XX00HHLLHHHH1
V0018 CXIXXX1XXOOHLLHLHHHH1 *
V0019 CXIXXXIXXOOHHHHHHHH1
V0020 C01X0XX000OHHHHHHHLI
V0021 CX1XXXXXXOOOHHHHHHLL1 *
V0022 CX10X10XX00LHHHHLLL1
V0023 CX10X10XX00HLHHHLLLL1
V0024 CX10X10XX00LLHHHLLLL1 *
V0025 CX10X10XX00HHLHHLLLL1 *
V0026 CX10X10XX00LHLHHLLLL1 *
V0027 CX10X10XX00HLLHLLLLL1 *
V0028 CX10X10XX00LLLHLLLLL1
V0029 CX10X10XX00LHLHHHHHH1 *
V0030 CX10X10XX0OHHLHHHHH1 *
V0031 CX10X10XX00LLHHHHHH1 *
395F
```

```
LOGIC DIAGRAM FOR:
DYNAMIC MEMORY CONTROL STATE SEQUENCER USING AmPAL16R8A
```

Columns: Inputs (0-31)


## GCR (4B-5B) Encoder/Decoder

## by Warren Miller Advanced Micro Devices

One of the more common logic functions performed on serial data is the data encode/decode function. Usually it is desirable to map (encode) the logical bit stream to a physical bit stream, adjusting for the peculiarities of the particular transmission or storage media.

Noise, bandwidth, and reliability considerations may mean that a different data format would be desirable when data is sent along to or stored on a given media. For example, groupcoded recording (GCR) formats take a given number of data bits and encode them with a larger number of bits. A 4B-5B

GCR code would take 4 data bits and encode them into 16 states with 5 new bits. A particular 4B-5B code is shown in Table 1.
This mapping allows at most two zeros to occur in succession. Also note that data combinations with more than one zero at the beginning and end of the word are excluded. This is necessary to insure that when data words are serialized, no more than two zeros occur in succession at any point in the bit stream. Finally, the data combination 11111 is reserved as a synchronization mark. In tape systems, this results in increased bit density and eases clock synchronization.

Table 1. 4B-5B Code

| 4B-5B Code |  |
| :---: | :---: |
| 4-Bit Data | 5-Bit Data |
| 0000 | 1100 |
| 001 | 110 |
| 0010 | 100 |
| 0011 | 100 |
| 0100 | 1110 |
| 010 | 101 |
| 0110 | 101 |
| 0111 | 101 |
| 1000 | 1101 |
| 001 | 0100 |
| 010 | 010 |
| 1011 | 010 |
| 1100 | 1111 |
| 1101 | 0110 |
| 1110 | 011 |
| 111 | 011 |

## DESIGN REQUIREMENTS

The system diagram in Figure 1 shows how the GCR Encoder/Decoder (GCR E/D) interfaces to a tape drive and tape controller. Parallel input data is given to the GCR E/D, converted to the 5 -bit format, serialized, and written to the tape. On a read, the serial data from the tape is parallelized, converted back to the 4 -bit format and output to the tape controller. Additionally, during a read, two status signals are developed. The first signal, $\overline{\mathrm{NV},}$ indicates the presence of an invalid input, ie., too many zeros in succession. The second status signal, $\overline{\mathrm{H}}$, indicates the detection of the synchronization mark (11111).

The operation modes for the GCR E/D are shown in the DataFlow Diagrams of Figure 2. The control signal definition and operation functions are indicated for each operation mode. In particular, the data flow between each bit of the output register is indicated schematically.
The first, mode of operation of the GCR E/D is the HOLD mode. When ENABLE is HIGH, all data operations on the output register are disabled, independent of the two mode controls, $M_{1}$ and $M_{0}$. The output data is simply fed-back to the register inputs. Thus the register content is retained after the clock transition.
When the ENABLE input is LOW, the operations indicated by the $M_{1}$ and $M_{0}$ mode bits are executed on the clock transition. When $M_{1}$ and $M_{0}$ are both LOW, the SERIAL SHIFT IN mode is selected: In this mode the output register is configured as a serial shift register. The serial input is consecutively shifted into the register until all 5 bits from the tape have been stored, MSB at $Y_{3}$ and LSB at SERIAL OUT.

The CONVERT SERIAL INPUT AND LOAD operation is selected when ENABLE is LOW, $M_{1}$ is HIGH and $M_{0}$ is LOW. After the 5 bits of data have been serialized by the SERIAL SHIFT IN instruction, the 5B code must be converted to a 4B code. This is accomplished by taking the outputs of the 5 register bits and converting them to 4 bits with combinatorial logic. On the clock transition, the result is loaded into the $Y$ register. On the same clock transition that loads the converted data into the $Y$ register, the serial input is loaded into the serial output register. Because the serial data is being read continuously, one data bit per clock transition, the conversion must be done without missing a serial data bit.

The CONVERT PARALLEL INPUT AND LOAD operation is selected when ENABLE is LOW, $M_{1}$ is HIGH and $M_{0}$ is HIGH. This mode takes the 4 input data bits and converts them to the 5 bit representation. The result is loaded into the output register on the clock transition. The LSB of the 5B representation is loaded into the $Y_{3}$ bit of the output register and the MSB is loaded into the serial output bit. This configuration, in conjunction with the next instruction, allows the serial data to be written to the tape drive one bit per clock transition.

The final operation, SERIAL SHIFT OUT, is selected when ENABLE is LOW, $M_{1}$ is LOW and $M_{0}$ is HIGH. After the CONVERT PARALLEL INPUT AND LOAD operation is executed, the SERIAL SHIFT OUT operation outputs the converted data to the tape drive. A series of one convert operation followed by 4 shift operations will transfer a sequence of 5 -bits to the tape drive, one bit per clock cycle.


Figure 1. Typical Tape Storage System
ENABLE

## DESIGN APPROACH

The PAL implementation of the GCR Encoder/Decoder takes advantage of the multiplexer-like structure of the AND-OR array. Each valid combination of ENABLE, $M_{1}$ and $M_{0}$ selects a different set of AND terms. In some cases, only one term is selected (in data steering operations for example). In other cases, multiple AND terms are selected to implement a combinatorial logic function (the $5 B$ to $4 B$ conversion for example). This concept, using the control inputs to enable one or more AND terms, allows the direct implementation of the PAL design from the mode Data-Flow Diagrams (with a little Karnaugh map help). The K-Maps for the 5B to 4B conversion logic and the 4B to 5B conversion logic for the $Y_{3}$ output are shown in Figures 3 and 4. Given these maps and the flow diagrams in Figure 2, the Boolean equations can be constructed for the $\mathrm{Y}_{3}$ output. The resulting equation, in PALASM format, is shown in Figure 5.

It is important to note that the equation in Figure 5 is written for the inverse of the $Y_{3}$ output $\left(\overline{Y_{3}}\right)$. This is necessary if true data is desired on the output pin because of the inverting nature of the output buffer on the PAL. The inverted form of the equation is easily implemented by selecting the negative version of the data ( $\mathrm{Y}_{3}$ in the hold operation for example) or by grouping zeros in a combinatorial logic function (see Figures 3 and 4). Notice that the multiplexer strategy works equally well for active LOW or active HIGH logic functions.

Once the transformation of the Data-Flow Diagrams and K-Maps to Boolean equations is understood, the interested reader should be able to construct K-Maps for the other Y outputs and, in conjunction with the Data-Flow Diagrams of Figure 2, write the PALASM equations for the resulting logic functions. This exercise will help the reader to fully appreciate the advantages of the Data-Flow Diagram/Multiplexer method of PAL design. Consult the full PALASM listing (Figure 9) for the compleie solutions.
Once the data portion of the Encoder/Decoder is completed, only the two status outputs, $\bar{H}$ and $\overline{\mathrm{INV}}$, need to be implemented. $\bar{H}$ indicates the synchronization mark (11111) has been detected and is simply an AND of $Y_{3}$ through $S_{\text {OUT }}$. INV indicates an invalid serial input was received.

The $\overline{\mathrm{INV}}$ signal is registered and held until the clear $\overline{\mathrm{INV}}$ flag input (CIF) is brought LOW, deactivating the flag. Only during a $5 \mathrm{~B}-4 \mathrm{~B}$ conversion operation $\left(\mathrm{M}_{1}=\mathrm{HIGH}, \mathrm{M}_{0}=\mathrm{LOW}\right)$ is the $\overline{I N V}$ flag activated. Figures 6 and 7 show the $\overline{\mathrm{NV}}$ flag mode definitions and the intermediate INVALID logic equation respectively.
In this case, an active LOW output is desired so the active HIGH form of the $\overline{\mathrm{NV}}$ signals is developed internally. Ones are grouped in the intermediate combinatorial logic function (INVALID) and the true version of the data is selected. The complete PALASM equation for INV is given in Figure 8.


Figure 3. 5B to 4B Conversion K-Map for $\mathrm{Y}_{3}$ Output


$$
\overline{B_{0}}=D_{3} * \overline{D_{0}}+D_{1} * \overline{D_{0}} \quad \text { 03862A-97 }
$$

Figure 4. 4B to 5B Conversion K-Map for $\mathrm{Y}_{3}$ Output

$$
\begin{array}{rlrl}
\overline{Y_{3}}:= & E N * \overline{Y_{3}} & + \text {;HOLD } \\
\overline{E N} * \overline{M_{1}} * \overline{M_{0}} * \overline{Y_{2}} & + & ; \text { SERIAL SHIFT IN } \\
& \overline{E N} * \overline{M_{1}} * M_{0} * \overline{S O U T} & + & \text {;SERIAL SHIFT OUT } \\
& \overline{E N} * M_{1} * \overline{M_{0}} * Y_{3} * S O U T & & + \text {;CONVERT SERIAL } \\
& \overline{E N} * M_{1} * \overline{M_{0}} * \overline{Y_{3}} * \overline{Y_{2}} & & + \text {;INPUT AND LOAD } \\
& \overline{E N} * M_{1} * M_{0} * D_{3} * \overline{D_{0}} & & + \text {;CONVERT PARALLEL }
\end{array}
$$

Figure 5. PALASM Equation for $\overline{Y_{3}} \quad$ 03862A-98


Figure 6. INV Flag Mode Definitions
03862A-99


Figure 7. PALASM Equation for INVALID


```
CIF*M M * }\overline{\mp@subsup{M}{0}{}}*\overline{\mp@subsup{Y}{3}{}}*\overline{\mp@subsup{Y}{2}{}
CIF* M1 *\overline{\mp@subsup{M}{0}{}}*\overline{\mp@subsup{Y}{0}{}}*\overline{\mathrm{ SOUT}}
CIF}*\mp@subsup{M}{1}{}*\overline{\mp@subsup{M}{0}{}}*\overline{\mp@subsup{Y}{2}{}}*\overline{\mp@subsup{Y}{1}{}}*\overline{\mp@subsup{Y}{0}{}
\overline { C I F } * M _ { 1 } ^ { * } * \overline { M _ { 0 } } * Y _ { 3 } * Y _ { 2 } ^ { * } * Y _ { 1 } * Y _ { 0 } ^ { * } * \text { SOUT}
```

Figure 8. PALASM Equation for INV

PAL16R6
PAT003
4B-5B ENCODER/DECODER
ADVANCED MICRO DEVICES
CK M1 MO D3 D2 D1 DO /EN /CIF GND
/E SIN /INV YO Y1 Y2 Y3 SOUT /H VCC
/SOUT := EN*/SOUT /EN*/M1*/MO*/SIN /EN*/M1* MO*/YO /EN* M1*/MO*/SIN /EN* M1* MO* D3* D1 /EN* M1* MO* D3* DO
$/ \mathrm{YO}:=\mathrm{EN}^{*} / \mathrm{YO}$ /EN*/M1*/M0*/SOUT /EN*/M1* MO*/Y1 /EN* M1*/MO*/SOUT /EN* M1*/MO* Y3* Y2*/YO /EN* M1* MO*/D3* D1 /EN* M1* MO*/D3* D2* DO
/Y1 := EN*/Y1
$/ E N^{*} / \mathrm{M1}^{*} / \mathrm{MO} * / \mathrm{YO}$
/EN*/M1* MO*/Y2 /EN* M1*/MO*/YO /EN* M1*/MO* Y3* Y2 /EN* M1* MO*/D2
/Y2 : = EN*/Y2
/EN*/M1*/MO*/Y1
/EN*/M1* M0*/Y3
/EN* M1*/MO*/Y1
/EN* M1* MO*/D3*/D1*/DO
/EN* M1* MO*/D3* D2*/D1 /EN* M1* MO* D3*/D1* DO
/Y3 := EN*/Y3
/EN*/M1*/MO*/Y2
/EN*/M1* M0*/SOUT
/EN* M1*/MO* Y3* SOUT
/EN* M1*/MO* Y3*/Y2
/EN* M1* MO* D3*/DO
/EN* M1* MO* D1*/DO
INV := /CIF* INV
/CIF* M1*/MO*/Y3*/Y2 + ; SET INV FLAG IF INVALID TRUE
$/$ CIF $^{*} \mathrm{M1}^{*} / \mathrm{MO} / \mathrm{Y} 2^{*} / \mathrm{Y} 1^{*} / \mathrm{YO}+$;
/CIF* M1*/MO*/YO*/SOUT +
/CIF* M1*/MO* Y3* Y2* Y1* YO* SOUT
$\mathrm{H}=\mathrm{Y} 3 * \mathrm{Y} 2 * \mathrm{Y} 1 *$ YO* SOUT

PAL DESIGN SPECIFICATION
Warren K. MILLer 2/15/82

FUNCTION TABLE
CK /E /EN M1 MO D3 D2 D1 DO SIN /CIF Y3 Y2 Y1 YO SOUT /INV /H



DESCRIPTION
THIS PART IMPLEMENTS A 4B 5B ENCODER/DECODER FOR TAPE DRIVES. ON A WRITE IT ENCODES THE 4B INPUT DATA TO THE 5B FORMAT AND SERIALIZES THE DATA. ON A READ THE 5B DATA IS SHIFTED IN, RECONVERTED TO THE 4B FORMAT, AND OUTPUT TO THE DATA BUS.

PAL16R6
PAT003
4B-5B ENCODER/DECODER ADVANCED MICRO DEVICES *D9724
*FO*
L0000 11111111111111111111111111111111 * L0032 11111101110111011101110111111111 *
L0256 11111110111111111111111110111111 *
LO288 10111011111111111111111101111110 *
L0320 10110111111111111111111001111111 *
L0352 01111011111111111111111101111110 *
L0384 01110111011111110111111101111111 *
L0416 01110111011111111111011101111111 *
L0512 11111111111011111111111110111111 *
L0544 10111011111111101111111101111111 *
L0576 10110110111111111111111101111111 *
L0608 01111001110111111111111101111111 *
L0640 01111011110111101111111101111111 *
L0672 01110111011111111111101101111111 *
L0704 01110111111111110111101101111111 *
L0768 11111111111111101111111110111111 *
L0800 1011.1011111111111110111101111111 *
L0832 10110111111011111111111101111111 *
L0864 01111011111111111110111101111111 *
L0896 01110111101111111011101101111111 *
L0928 01110111101101111011111101111111 *
L0960 01110111011111111011011101111111 *
L1024 11111111111111111110111110111111 *
L1056 10111011111111111111111001111111 *
L1088 10110111111111101111111101111111 *
L1120 01111011111111111111111001111111 *
L1152 01111011110111011111111101111111 *
L1184 01110111111110111111111101111111 *
L1280 11111111111111111111111010111111 *
L1312 1011101011111111111111110111.1111 *
L1344 10110111111111111110111101111111 *
L1376 01111010111111111111111101111111 *
L1408 01111011110111011111111001111111 *
L1440 01110111101111110111111101111111 *
L1472 01110111101101111111011101111111 *

L1568 01111011111011101111111111110111 *
L1600 $01111011-111111101110111011110111$ *
L1632 01111010111111111111111011110111 *
L1664 01111001110111011101110111110111 *
C8E23*
V0001 XXXXXXXXX01XZZZZZZZX1
V0002 CXXXXXXXX000XHXXXXXX1
V0003 C1111111100XHHHHHLH1
V0004 C00XXXX11001HLНHHHH1
V0005 C00XXXX11001HHL НННН1
V0006 C00XXXX11001HHHLHHH1
V0007 C00XXXX11001HHHHLHH1
V0008 C00XXXX11001HHHHHHL1

V0009 C1100001100XHHLLHHH1 * v0010 C10xxxx11000HHHLLLH1 V0011 C1100011100XHHLHHHH1 V0012 C10xxxx11000HHLLLLH1 V0013 C1100101100xHLLHLHH1 V0014 C10XXXX11000HHLLHLH1 V0015 Cl100111100XHLLHHHH1 V0016 C10XXXX11000HLLLLLH1 V0017 C1101001100XHHHLHHH1 * V0018 C10xxxx11000HHHHLLH1 * V0019 C1101011100XHLHLHHH1 V0020 C10XXXX11000HHLHLLH1 V0021 C1101101100XHLHHLHH1 V0022 C10XXXX11000HHLHHLH1 V0023 C1101111100XHLHHHHH1 V0024 C10XXXX11000HLLHLLH1 V0025 C1110001100XHHLHLHH1 V0026 C10XXXXI 1000 HHHLHLH V0027 C1110011100XHHLLHLH1 * v0028 C10xxxx11000HLHLLLH1 V0029 C1110101100xHHLHLLH1 V0030 C10XXXX11000HLHLHLH1 V0031 C1110111100xHHLHHLH1 V0032 C10XXXX11000HLLLHLH1 V0033 C1111001100XHHHHLHH1 V0034 C10XXXX11000HHHHLLH1 V0035 C1111011100×HHHLHLH1 V0036 Cl0XXXX11000HLHHLLH1
V0037 C1111101100xHHHHLLH1 V0038 C10XXXX11000HLHHHLH1 V0039 Cl111111100xHHHHHLH1 V0040 C10XXXX11000HLLHHLH1 V0041 C1111111100хHHHHHLH1 V0042 C01XXXX1100ХННННLНH1 V0043 C01XXXX1100XHHHLHHH1 V0044 CO1XXXX1100XHHLHHHH1 V0045 C01XXXX1100XHLHHHHH1 V0046 C01XXXX1100XHHHHHLH1 V0047 C01XXXX1100XHHHHLHH1 * CA76


## Interfacing the 8086 (8088) to the Z-BUS

## by Nick Zwick Advanced Micro Devices

This application note describes how replacing two 8086 support chips with a Z8000 support chip and an AmPAL16R8A allows the 8086 CPU to interface directly to the $Z$-BUS. Since the timing of the signals used is the same for the 8088 CPU, this circuit will work equally well in those applications.
Interfacing the 8086 CPU to the Z-BUS allows 8086 users to take advantage of the very powerful Z 8000 peripheral and memory support circuits that are available. The Z8000 peripheral circuits in particular offer the user higher throughput rates, simpler control software and less system overhead requirements than any previous generation peripheral family for any CPU.

## DESIGN REQUIREMENTS

The 8086 CPU can operate in two different modes. In minimum mode, it generates all the bus control and timing signals for the $8086(8085,8088)$ buses directly on-chip. In maximum mode, the CPU put's out status information early in each bus cycle and relies on an external bus controller chip, the 8288 , to generate timing and control signals. This implementation uses the CPU in maximum mode and replaces the 8288 with a programmable array logic element
(AmPAL16R8A) that generates the Z-BUS timing and control signals from the status signals provided by the CPU. It also makes use of the AmZ8127 clock generator to allow precise timing resolution by providing an oscillator signal at 3 times the CPU clock frequency. The AmZ8127 provides all the clock generation functions of an 8284A as well as several additional functions. Either clock chip will work in this system.
The bus controller provides the following functions:
-Generates $\overline{A S}, \overline{D S}, \overline{\text { INTACK }}$ and R/W with proper timing relative to address and data.
-Provides simultaneous assertion of $\overline{A S}$ and $\overline{D S}$ during reset.
-Automatic insertion of 1 wait state for all l/O cycles.
-Synthesizes a single Z-BUS interrupt acknowledge cycle from the 8086 IACK cycles.
Figure 1 shows the circuit interconnection diagram. The system uses a high speed AmPAL16R8A to generate $\overline{A S}, \overline{\mathrm{DS}}$, R/W and INTACK of the Z-BUS, RDY for wait state generation, and three internal state variables. The registers are clocked with the 15 MHz OSC signal from the 8127 . The five input signals to the PAL are 5MHz CPU Clock Signal(CLK), System Reset (RESET), and the three CPU Status States $\left(\overline{\mathbf{S}_{0}}, \overline{\mathbf{S}_{1}}, \overline{\mathrm{~S}_{2}}\right)$.


Figure 1. Circuit Interconnection Diagram

The CPU indicates the start of a bus cycle by bringing at least one of the status lines low from the idle high state (see Figure 2). This starts an internal timing sequence within the PAL which corresponds closely to the various $T$ states of a bus cycle. $\overline{\mathrm{AS}}$ is asserted during the time CLK is LOW during $\mathrm{T}_{1} . \overline{\mathrm{DS}}$ is asserted at the start of $\mathrm{T}_{3}$. If it is an I/O cycle, then RDY would be disabled for one CLK period straddling $T_{2}$ and $T_{3}$ causing the 8127 to request 1 wait state after $T_{3}$. In either case, $\overline{D S}$ remains asserted until after the first $1 / 3$ of $T_{4}$, which is identified by the status lines returning to the idle state during the previous cycle. $R / W$ is generated by sampling $\overline{S_{0}}$ and $\overline{\mathrm{S}_{1}}$ during $\overline{\mathrm{AS}}$.

It is in the realm of interrupts where the Z8000 peripherals shine over other periperhals. Each peripheral can identify many different exception conditions during its operation. The occurrence of one or more of these conditions causes activation of a single interrupt request line. The peripheral wants the CPU to respond with a single interrupt acknowledge cycle, during which the peripheral resolves priority and provides the CPU with enough status and vector information to allow it to respond to the exception without any further interrogation of the peripheral. This allows interrupt driven systems to achieve very high data throughput rates.


Figure 2. Memory and I/O Timing Diagram

The 8086 CPU responds to an interrupt request with a sequence of two interrupt acknowledge cycles, and only in the second is any data read off the bus. As stated before, the Z-BUS peripherals require only one acknowledge cycle. The timing of this has to be such that there is enough delay between $\overline{A S}$ going HIGH and $\overline{\mathrm{SS}}$ going LOW to allow any prioritizing daisy chains to settle, and $\overline{\text { DS }}$ has to be wide enough to allow the peripheral time to place vector or status information on the bus. Figure 3 shows how these two requirements are accomplished by turning the two acknowledge cycles into one. The first cycle allows only $\overline{A S}$ and the second asserts only $\overline{D S}$ and does so for the complete cycle. This appears to the peripheral as one very long bus cycle which is identified as an interrupt acknowledge cycle by the assertion of INTACK.

## DESIGN APPROACH

To implement this design in a AmPAL16R8A requires recognizing the Z-BUS timing characteristics in Figures 2 and 3. The major characteristic to consider is counting the phases of a bus cycle. Internal state variables $P_{0}$ and $P_{1}$ are the result (see Figure 4a). An additional internal state variable $\left(1_{2}\right)$ is necessary to count the second bus cycle of an interrupt acknowledge sequence. As shown in Figure $4 b, I_{2}$ in conjunction with INTACK allows $\overline{A S}$ to be asserted only in the first interrupt acknowledge cycle and $\overline{\mathrm{DS}}$ only in the second. The RESET input is used to initialize the internal variables and assert $\overline{\mathrm{AS}}$ and $\overline{\mathrm{DS}}$. Note also that $\overline{\mathrm{S}}_{0}$ and $\overline{\mathrm{S}_{1}}$ are included in the $\overline{D S}$ equation to prevent $\overline{D S}$ from being asserted during a halt cycle.


03862A-105

Figure 3. Interrupt Acknowledge Timing Diagram

The fact that AMD PALs are user programmable allows a great deal of flexibility for the designer. Minor timing changes are easily implemented by simply adding or changing a term in the logic equations and reprogramming the device. In this system, we have timing resolution to 67 ns . This same configuration can be used with a 24 MHz crystal for 8 MHz CPU chips. The logic equations would change because the OSC period would be 42ns. The only hardware change would be the crystal.

An additional PAL could also perform chip select decoding based on both address and status signals.

## CONCLUSION

We have seen how a properly programmed PAL can be used to replace a specialized bus controller chip and allow an 8086 CPU to interface directly to Z-BUS peripheral(s) and/or memory systems. This brings all the advantages of the superior $\mathbf{Z 8 0 0 0}$ peripheral family in terms of both throughput and ease of use to 8086 users with no increase in chip count while still allowing a wide range of design flexibility. The logic diagram and PALASM equations for the AmPAL16R8A 8086 to Z-BUS interface chip are also shown.

| $\mathrm{P}_{1}$ | $\mathrm{P}_{0}$ | PHASE | CPU T STATES |
| :---: | :---: | :--- | :--- |
| 0 | 0 | IDLE | $\mathrm{T}_{4}, \mathrm{~T}_{1}$ |
| 0 | 1 | $\overline{\text { AS }}$ TIME | $\mathrm{T}_{1}$ |
| 1 | 0 | $\overline{\text { AS }}$ TO $\overline{\mathrm{DS}}$ DELAY | $\mathrm{T}_{2}$ |
| 1 | 1 | $\overline{\mathrm{DS}}$ TIME | $\mathrm{T}_{3}, \mathrm{~T}_{\mathrm{W}}$ |

03862A-106
Figure 4a

| $1_{2}$ | $\overline{\text { INTACK }}$ | $\overline{\text { AS }}$ | $\overline{\mathrm{DS}}$ |
| :---: | :---: | :---: | :---: |
| NO | NO | YES | YES |
| NO | YES | YES | NO |
| YES | YES | NO | YES |

03862A-107
Figure 4b

```
PAL16R8
PAT004
8086 T0 Z-BUS INTERFACE CHIP
ADVANCED MICRO DEVICES
CK RESET CLK /SO /S1 /S2 NC NC NC GND
/E /PO /P1 /RW /DS /AS /INTACK RDY /I2 VCC
;INTERNAL STATE VARIABLES
PO := /RESET* SO*/PO*/P1*/CLK +
        /RESET* S1*/PO*/P1*/CLK +
        /RESET* S2*/PO*/P1*/CLK +
        /RESET*P0*/CLK +
        /RESET*P1*CLK* SO +
        /RESET*P1*CLK* S1 +
        /RESET*P1*CLK* S2
P1 := /RESET*PO*/P1*CLK
        /RESET*P1*/CLK
        /RESET*P1*CLK* SO +
        /RESET*P1*CLK* S1 +
        /RESET*P1*CLK* S2
I2 :=/RESET*INTACK*/I2*CLK*PO*P1 +
    /RESET*I2*/P1
    /RESET*I2*/PO
    /RESET*I2*PO*P1*/CLK
;Z-BUS OUTPUT SIGNALS
AS \(:=\underset{/ \mathrm{RESET}}{\mathrm{RE}} / \mathrm{P} 1^{*}\) CLK \(* / \mathrm{I} 2 \quad+\) AS*/PO*/I2*/DS
DS := RESET /INTACK*/P0*P1*CLK*SO /INTACK*/P0*P1*CLK*S1 I2* S0* S1* S2 DS*PO*P1
RW :=AS*SO*/S1 + RW*/AS
INTACK : = /RESET* SO* S1* S2 /RESET*INTACK*/I2*P1 + /RESET*I2
/RDY \(:=/\) RESET*SO*/S1* S2*/PO*P1 + ;DISABLE READY ON I/O OP /RESET*/S0*S1* S2*/P0*P1
```

| C | H | X | X | X | X | L | L | L | L | L | X | H | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

; MEMORY WRITE OPERATION

| C | L | L | H | H | H | L | L | L | H | H | H | H | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| C | L | H | H | H | L | L | L | L | L | H | H | H | H |
| C | L | L | H | H | L | H | L | L | L | H | L | H | H |
| C | L | L | H | H | L | H | L | L | H | H | L | H | H |
| C | L | H | H | H | L | L | H | L | H | H | L | H | H |
| C | L | L | H | H | L | L | H | L | H | H | L | H | H |
| C | L | H | H | H | L | L | L | H | L | H | H | L | H |
| C | L | L | H | H | L | H | L | H | L | H | L | H | H |
| C | L | L | H | H | H | H | H | L | H | L | L | H | H |
| C | L | H | H | H | L | L | L | H | L | L | H | H |  |
| C | H | H | H | H | L | L | L | H | H | L | H | H |  |
| L | H | H | L | H | H |  |  |  |  |  |  |  |  |

$$
\begin{aligned}
& \text {;I/O READ OPERATION } \\
& \text { C L } \quad \mathrm{H} \quad \mathrm{~L} \quad \mathrm{~L}
\end{aligned}
$$

| C | L | H | L | L | H |
| :--- | :--- | :--- | :--- | :--- | :--- |
| C | L | L | L | L | H |
| C | L | L | L | L | H |
| C | L | H | L | L | H |
| C | L | L | L | L | H |
| C | L | L | L | L | H |
| C | L | H | L | L | H |
| C | L | L | L | L | H |
| C | L | L | L | L | H |
| C | L | H | L | L | H |
| C | L | L | L | L | H |
| C | L | L | H | H | H |
| C | L | H | H | H | H |
| L | H | H |  |  |  |


| L | L | L | L | H | L | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| H | L | L | L | H | H | H |
| H | L | L | H | H | H | H |
| L | H | L | H | H | H | H |
| L | H | L | H | H | H | H |
| L | H | L | H | H | H | H |
| H | H | L | H | L | H | H |
| H | H | L | H | L | H | H |
| H | H | L | H | L | H | H |
| H | H | L | H | L | H | H |
| H | H | L | H | L | H | H |
| H | H | L | H | L | H | H |
| L | L | L | H | L | H | H |
| L | L | L | H | H | H | H |

;TWO CYCLE INTERRUPT SEQUENCE

| C | L | H | L | L | L | L | L | L | L | H | H | L | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| C | L | L | L | L | L | H | L | L | L | H | H | L | H |
| C | L | L | L | L | L | H | L | L | H | H | H | L | H |
| C | L | H | L | L | L | L | H | L | H | H | H | L | H |
| C | L | L | L | L | L | L | H | L | H | H | H | L | H |
| C | L | L | L | L | L | L | H | L | H | H | H | L | H |
| C | L | H | L | L | L | H | H | L | H | H | H | L | H |
| C | L | L | L | L | L | H | H | L | H | H | H | L | H |
| C | L | L | H | H | H | H | H | L | H | H | H | L | H |
| C | L | H | H | H | H | L | L | H | H | H | H | L | H |
| C | L | L | H | H | H | L | L | H | H | H | H | L | H |
| C | L | L | H | H | H | L | L | H | H | H | H | L | H |
| C | L | H | L | L | L | L | L | H | H | L | H | L | H |
| C | L | L | L | L | L | H | L | H | H | L | H | L | H |
| L | H | L | L | L | H | L | H | H | L | H | L | H | H |


| C | L | L | L | L | L | L | H | H | H | L | H | L | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| C | L | L | L | L | L | L | H | H | H | L | H | L | H |
| C | L | H | L | L | L | H | H | H | H | L | H | L | H |
| C | L | L | L | L | L | H | H | H | H | L | H | L | H |
| C | L | L | H | H | H | H | H | H | H | L | H | L | H |
| C | L | H | H | H | H | L | L | L | H | L | H | L | H |
|  | L | L | H | H | H | L | L | L | H | H | H | H | H |

DESCRIPTION
THIS DEVICE IS USED FOR INTERFACING THE 8086 CPU DIRECTLY TO THE Z-BUS ALLOWING INTEGRATION OF THE VERY POWERFUL Z8000 PERIPHERAL AND MEMORY SUPPORT CIRCUITS INTO 8086 SYSTEMS. THE DEVICE IS DESIGNED TO WORK IN CONJUNCTION WITH THE Z8127 CLOCK GENERATOR FOR PRECISE TIMING RESOLUTION.

PAL16R8
PAT004
8086 TO Z-BUS INTERFACE CHIP ADVANCED MICRO DEVICES
*D9724
*FO*
L0000 10010111111011111111111111101110
L0032 10101111111111111111111111011111
L0064 1010111111111111111111111111 1101*
L0096 10101011111111111111111111101110
L0256 10111111101101111011111111101101
L0288 1011111101111011101111111110 1101*
L0512 10111111101110111011111111111111 *
L0544 10011111111011111111111111101111
$\begin{array}{llll}20576 & 1010 & 1111 & 1111 \\ 1111 & 1111 & 1111 & 1111 \\ 1111\end{array}$
L0768 01111111111111111111111111111111 *
L0800 11010111111111111111111111011101 *
L0832 11011111111111101101111111111101
L1024 01111111111111111111111111111111 *
L1056 11110111100111111111111111101101 *
L1088 11110111110110111111111111101101 *
L1120 11101111101110111011111111111111 *
L1152 11111111111111111110111111101110 *
L1280 11111111101101101111111111111111 *
$\begin{array}{llll}L 1312 & 1111 & 1111 & 1111 \\ 1101 & 1111 & 1110 & 1111 \\ 1111\end{array}$
L1536 10110111111111111111111111011110 *
L1568 10111011111111111111111111101111 *
L1600 10110111101111111111111111101111 *
L1632 101101111111.10111111111111101111 *
L1664 10110111111111111011111111101111 *
L1792 10111011101111111111111111011101 *
L1824 10111011111110111111111111011101 *
L1856 10111011111111111011111111011101 *
L1888 10111011111111111111111111111110 *
L1920 10110111101111111111111111101111 *
L1952 10110111111110111111111111101111 *
L1984 10110111111111111011111111101111 *
C711D*
V0001 C1XXXXXXXOXHHXLLHHH1 *
V0002 С00111XXхОХНННННННН *
V0003 C01011XXXOXHHHHLHHH1 *
V0004 C00011XXXOXLHLHLHHH1 *
V0005 C00011XXXOXLHLHHHHH1
V0006 C01011XXXOXHLLHHHHH1 *
V0007 C00011XXXOXHLLHHHHH1
V0008 C00011XXXOXHLLHHHHH1
V0009 C01011XXXOXLLLLHHHH1
V0010 C00011XXXOXLLLLHHHH1
V0011 C00111XXXOXLLLLHHHH1
V0012 C01111XXXOXHHLLHHHH1
V0013 C00111XXXOXHHLHHHHH1
V0014 C00111XXXOXHHLHHHHH1
V0015 C01100XXXOXHHLHLHHH1
V0016 C00100XXXOXLHHHLHHH1
V0017 C00100XXXOXLHHHHHHH1 *

PAL DESIGN SPECIFICATION NICK ZWICK 6/21/82

V0018 C01100XXXOXHLHHHHHH1 * V0019 C00100XXXOXHLHHHHLH1 V0020 C00100XXX0XHLHHHLLH1 V0021 C01100XXXOXLLHLHHLH1 V0022 COO100XXXOXLLHLHHHH1 V0023 C00100XXXOXLLHLHHHH1 V0024 C01100XXXOXLLHLHHHH1 V0025 C00100XXXOXLLHLHHHH1 V0026 C00111XXXOXLLHLHHHH1 V0027 C01111XXX0XHHHLHHHH1 V0028 C00111XXXOXHHHHHHHH1 V0029 CO1000XXXOXHHHHLLHH1 V0030 C00000XXXOXLHHHLLHH1 V0031 COOOOOXXXOXLHHHHLHH1 V0032 C01000XXXOXHLHHHLHH1 V0033 C00000XXXOXHLHHHLHH1 V0034 C00000XXXOXHLHHHLHH1 V0035 C01000XXXOXLLHHHLHH1 V0036 C00000XXXOXLLHHHLHH1 V0037 C00111XXXOXLLHHHLHH1 V0038 C01111XXXOXHHHHHLHL1 V0039 C00111XxхохнHHHHLHL1 V0040 C00111XXXOXHHHHHLHL1 V0041 C01000XXXOXHHHLHLHL1 V0042 C00000XXXOXLHHLHLHL1 V0043 C00000XXXOXLHHLHLHLL V0044 C01000XXXOXHLHLHLHL1 * V0045 COOOOOXXX0XHLHLHLHL1 * V0046 C00000xXX0XHLHLHLHL1 * V0047 C01000XXX0XLLHLHLHL1 * V0048 C00000XXXOXLLHLHLHLL * V0049 C00111XXXOXLLHLHLHLL * V0050 C01111XXXOXHHHLHLHH1 * V0051 C00111хххохнннннннн1 * A334

```
LOGIC DIAGRAM FOR:
8086 TO ZBUS INTERFACE USING AmPAL16R8
```

Columns: Inputs (0-31)


# An AMD PAL MULTIBUS Arbiter <br> <br> by Mark S. Young <br> <br> by Mark S. Young Advanced Micro Devices 

 Advanced Micro Devices}

The popularity of bus oriented systems can be traced to their low cost, flexibility, and expandability. Expansion is easy because a well defined standard enforces compatibility and simplifies interfacing. The MULTIBUS is a good example of a popular and easily used bus standard. However, all of these bus systems require some way of interacting with the other devices on the bus. This interaction is generally controlled by an arbitration unit. This application note will describe how a PAL can be used to construct a custom MULTIBUS arbiter which is higher performance and more economical than the LSI alternatives.

## DESIGN REQUIREMENTS

Since the MULTIBUS can have more than one master trying to use the bus at the same time, an arbitration scheme is required to ensure correct operation of the system. Prioritization is accomplished by assigning different access priorities to the different bus masters. The two implementations available to assign priority are serial and parallel. The serial method involves a daisy chain of bus grant ins (BPRN) and bus grant outs ( $\overline{\mathrm{BPRO}}$ ) with higher priority devices occupying the positions closer to the beginning of the chain (Figure 1a). The parallel method prioritizes the bus requests ( $\overline{\mathrm{BREQ}}$ ) of all the masters and generates a bus grant in ( $\overline{B P R N}$ ) to the master of highest priority (Figure 1b). The priority decoder of Figure 1 b is easily implemented in a single AmPAL16L8 (Figure 1c).
The timing requirements for the MULTIBUS are very easy to implement and are designed to handle the usual timing problems that appear in many systems. Control signals are all active LOW so that unconnected signals don't interfere with the
normal operation of the bus. All bus arbitration is synchronous and all data transfers are asynchronous (see Figures 2 a and 2 b ). The only requirement is that an address be valid 50 ns before any control signals (read or write) become active. This prevents subtle timing problems caused by slow buffer/driver turn-on times.

The arbitration and grant timing (illustrated in Figure 2c) is also straightforward. Transfer requests are sent to the arbiters which then decide who gets the bus. If a master device is currently using the bus and is ordered off, it is allowed to complete its current bus transfer cycle (i.e., the current word or byte only). If the master, which was overruled, still needs the bus, it must wait until its priority is high enough to regain the bus.

A typical sequence is initiated when an external request is received (SREQ) from a master device. This signal is synchronized to insure a valid bus request, minimizing the possibility of a metastable state occurring. After synchronization, the bus priority out (BPRO) line is disabled to signal lower priority masters in the chain that a higher priority master wants the bus (serial method). In the parallel method, bus request and common bus request ( $\overline{\mathrm{BREQ}}$ and $\overline{\mathrm{CBREQ}}$ ) are asserted to let the other MULTIBUS arbiters know a master wants the bus. Now, if the bus is not busy (BUSY is inactive), then the arbiter grants the requesting master access to the bus and asserts BUSY. The address buffers are enabled at this time, one cycle ahead of the read and write signals. When the master receives a bus acknowledge (XACK) from the slave device, a single transfer cycle has occurred. The bus master then releases the bus and if it needs to do more transfers, another arbitration/grant cycle must take place.


Figure 1a. Serial Priority Resolution


Figure 1b. Parallel Priority Technique
03862A-110


Figure 1c. PAL Implementation of Parallel Priority Resolution for MULTIBUS


Figure 2a. Read AC Timing 03862A-112


Figure 2b. Write AC Timing


Figure 2c. Bus Control Exchange Operation

## DESIGN APPROACH

The first step in actually designing the arbiter was to convert the arbitration/grant and control signal sequence into a simple state transition diagram (see Figure 3). The state diagram was then partitioned into its three basic components:

> -request/synchronization
> -grant/access logic
> -control signals

The bus request logic decides when to issue a bus request using SREQ along with a qualifying read or write request (RD or WR). This signal is then fed through a double synchronizer (states 1 and 2). This creates an internally stable bus request signal for the arbiter state machine (see Figure 4a). Next, this
request is fed into a bus grant flip-flop through some intervening logic. The intervening logic uses current bus status lines to determine whether to acquire the bus, give it up after the current transfer cycle is complete, or hold the bus (see grant/access logic in Figure 4b). The final major function is the bus control logic. After successful acquisition of the bus, the appropriate control signals (MRDC, $\overline{M W T C}, \overline{I O R C}, \overline{I O W C}$ ) and address buffer enables must be asserted. In this case, the address buffer enable/grant ( $\overline{\mathrm{AEN}}$ ) line is run through a flip-flop to become a delayed read/write control signal enable (OEN). This gives the drivers enough turn-on and set-up time (100ns minimum) for the address to stabilize on the MULTIBUS. The bus transfer control signal logic is illustrated in Figure 4c.


Figure 3. PAL MULTIBUS Arbiter State Transition Diagram


Figure 4a. Request Synchronizer


Figure 4b. Grant/Access Logic


Figure 4c. Bus Transfer Control

The RESET line is run to all the registers to provide a synchronous reset for arbiter initialization. The full MULTIBUS standard requires a control signal drive capability of 32 mA for all of its control lines. The PAL 24 mA drive specification can drive up to 7 cards on the bus, which is more than adequate for almost all applications.

A couple of interesting features are avallable which show the flexibility and functionality of PALs in a custom logic design such as this. The available MULTIBUS arbiters, like most LSI devices, have been optimized for one processor family. Any microprocessor (from the $Z 80$ to the $8086, \mathrm{Z8000}$ or 68000) can be interfaced to the MULTIBUS by tailoring the request logic of the PAL arblter. This can result in a significant parts count reduction. The MULTIBUS uses open collector drivers for several signal lines (BUSY and CBREQ). While PALs don't have open collector drivers, that condition can easily be
simulated by enabling the output drivers only when the output is active. In addition, most MULTIBUS arbiters force each master to re-arbitrate for access to the bus at the end of each data transfer. However, in the PAL arbiter design, if a master is executing multiple data transfers and if no master of higher priority is requesting the bus then the current master can retain the bus and execute more transfers. This reduces bus arbitration overhead and increases bus bandwidth. Finally, at the completion of all transfers, the current bus master normally releases the bus. In this design, if no one wants the bus, the last master to use it holds onto the bus on the assumption that it is going to be the next user. If it is, arbitration time is saved. If not, no time is lost.
Figure 5 shows a block diagram of the arbiter and bus control logic (which fits into $1 / 2$ of a AmPAL16L8). A complete logic diagram and PALASM equations of the AmPAL16R4 are shown on the following pages.


Figure 5. PAL MULTIBUS Arbiter with Bus Control Logic

PAL16R4
PAT005
MULTIBUS ARBITER
ADVANCED MICRO DEVICES
BCLK /RD /WR /SREQ /RESET /BPRN NC NC NC GND
/E /CBREQ /BUSY /SYNC /BPRO /AEN /OEN /BREQ NC VCC
SYNC :=/RESET*SREQ*RD /RESET*SREQ*WR

BPRO :=/RESET*SYNC
AEN := /RESET* AEN*BPRO*WR + /RESET* AEN*BPRO*RD + /RESET*BPRO*BPRN*/BUSY + /RESET* AEN*BPRN*/CBREQ

OEN $:=/$ RESET*SREQ*AEN

- $\mathrm{IF}(\mathrm{BPRO}$ */AEN $) \mathrm{CBREQ}=\mathrm{BPRO} / \mathrm{AEN}$

IF (AEN) BUSY = AEN
$\mathrm{BREQ}=\underset{\mathrm{AEN}}{\mathrm{BPRO}}$

FUNCTION TABLE
BCLK /E /RESET /RD /WR /SREQ /BPRN SYNC BPRO AEN OEN CBREQ BUSY BREQ

| ; INITIALIZE |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C |  | L | X | X | X | X | L | L | L | L | L | L | L |
| ;WRITE OPERATION |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | L | H | H | H | L | L | L | L | L | L | L | L | L |
| C | L | H | H | L | L | L | H | L | L | L | L | L | L |
| C | L | H | H | L | L | L | H | H | L | L | H | L | H |
| C | L | H | H | L | L | L | H | H | H | L | L | X | H |
| C | L | H | H | L | L | L | H | H | H | H | L | H | H |
| C | L | H | H | L | L | L | H | H | H | H | L | H | H |
| C | L | H | H | L | L | L | H | H | H | H | L | H | H |
| C | L | H | H | H | L | L | L | H | H | H | L | H | H |
| C | L | H | H | H | H | L | L | L | H | L | L | H | H |
| ;REMOVE THE ARBITER FROM THE BUS |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | L | H | H | H | H | H | L | L | L | L | L | L | L |
| ; READ OPERATION (WITH BUS CONTENTION) |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | L | H | H | H | L | L | L | L | L | L. | L | H | L |
| C | L | H | L | H | L | L | H | L | L | L | L | H | L |
| C | L | H | L | H | L | L | H | H | L | L | H | H | H |
| C | L | H | L | H | L | L | H | H | L | L | H | H | H |
| C | L | H | L | H | L | L | H | H | L | L | H | H | H |
| C | L | H | L | H | L | L | H | H | H | L | L | X | H |
| C | L | H | L | H | L | L | H | H | H | H | L | H | H |
| C | L | H | L | H | L | L | H | H | H | H | L | H | H |
| C | L | H | L | H | L | I | H | H | H | H | L | H | H |
| C | L | H | L | H | L | L | H | H | H | H | L | H | H |
| C | L | H | H | H | L | L | L | H | H | H | L | H | H |
| C | L | H | H | H | H | L | L | L | H | L | L | H | H |

## DESCRIPTION

THIS DEVICE IS A MULTIBUS ARBITER. IT SUPPORTS BOTH SERIAL AND PARALLEL buS arbitration schemes. Internal synchronization logic minimizes the POSSIBILITY OF METASTABLE CONDITIONS. THE GRANT/ACCESS LOGIC HAS BEEN DESIGNED TO MINIMIZE BUS ARBITRATION OVERHEAD. THE TRANSFER CONTROL LOGIC HAS BEEN DESIGNED TO ALLOW INTERFACING A WIDE VARIETY OF PROCESSORS TO THE MULTIBUS.

PAL16R4
PAT005
MULTIBUS ARBITER
ADVANCED MICRO DEVICES
*D9724
*FO*
L0256 11111111111111111111111111111111 *
L0288 11111111111111111110111111111111 *
L0320 11111111111111101111111111111111 *
L0512 11111111101101101111111111111111 *
L0768 11111011111101101110111111111111 *
L0800 10111111111101101110111111111111 *
L0832 11111111111101111010111111011111 *
L0864 11111111111101101011111111111101 *
L1024 11111111111101111111111011111111 *
L1280 10111111101101111111111111111111 *
L1312 11111011101101111111111111111111 *
L1536 11111111111111101111111111111111 *
L1568 11111111111111101111111111111111 *
L1792 11111111111111011110111111111111 *
L1824 11111111111111011110111111111111 *
C3602*
V0001 CXXX0XXXX0011HHHHHX1 *
V0002 C11010XXX0011HHHHHX1 *
V0003 C10010XXX0011LHHHHX1
V0004 C10010XXX00L1LLHHLX1 *
V0005 C10010XXX001XLLLHLX1
v0006 C10010XXX001LLLLLLXI
V0007 C10010xxx001LLLLLLXX1 * V0008 C10010xXx001LLLLLLXI *
V0009 C11010XXX001LHLLLLX1
v0010 C11110XXX001LHHLHLX1
V0011 C11111XXX0011HHHHX1
V0012 C11010XXX0010HHHHHX1
V0013 C01010XXX0010LHHHHX1
V0014 C01010XXX00LOLLHHLX1
V0015 C01010XXX00LOLLHHLX1
V0016 C01010XXX00LOLLHHLX1
V0017 C01010xxX001XLLLHLXI
V0018 C01010XXX001LLLLLLX1 *
V0019 C01010xxx001LLLLLLLX1
V0020 C01010XXX001LLLLLLLX1 *
V0021 C01010XXX001LLLLLLX1 *
V0022 C11010XXX001LHLLLLX1 *
V0023 C11110XXX001LHHLHLXI * 5484

PAL DESIGN SPECIFICATION MARK S. YOUNG 6/22/82


# Am8500 to MC68000 PAL Interface <br> $\cdots$ <br> by Mark S. Young Advanced Micro Devices 

Modern 16-bit microprocessors, such as the $8086, \mathrm{Z8000}$, and 68000 , are being used to form the nucleus of powerful personal/business computers and engineering workstations. However, support peripheral chips are virtually non-existent for the most recently introduced 16 -bit CPUs such as the Motorola 68000 . Since the modern microprocessor system depends as much on the peripheral controllers as it does on the CPU, it is important for a system designer to have a large variety of peripheral chips available. The 8500 family of peripheral chips from AMD, provides users of non-multiplexed bus microprocessors, such as the 68000, a variety of powerful peripheral chips that can be interfaced easily with a single programmable array logic (AMD PAL) device.

## THE Am8500 FAMILY

The Ar'8500 family is a group of programmable peripheral chips which offload a variety of system functions from the main CPU. They support a variety of operating modes which are specified by writing to their control registers. The current members of the family include the Am8536 Counter/Timer and Parallel I/O Unit (CIO), the Am8038 FIFO Input/Output Interface Unit (FIO), and the Am8530 Serial Communications Controller (SCC). While the object of this article is not to discuss the capabilities of the Am8500 family, a brief overview is necessary to fully understand its interface requirements.
The Am8536 is a counter/timer chip which has available three 16 -bit counters. These timer/counters have features such as duty cycle control (pulsed, one-shot, or square waved), retriggering options, and external access control lines. The CIO also provides up to 20 lines of programmable I/O ports. The Am8038 FIO is an asynchronous 128 byte buffer specially designed to be used by two CPUs or a CPU and a peripheral device as a communication or data buffer. It supports a variety of handshake interfaces on both I/O ports. Finally, the Am8530 SCC is a dual channel, multi-protocol data communications peripheral. The SCC functions as a serial to parallel, parallel to serial converter/controller. It supports a wide variety of serial communications protocols and includes extensive on-board hardware such as baud rate generators, digital phase-locked-loops, and crystal oscillators to reduce the need for external logic.

The Control and frequently used Data registers are accessed in a different manner. These registers are accessed using a single cycle or write. This scheme allows the CPU to interact efficiently with the 8500 peripherals during normal use. The slower, clumsier initialization procedure is used much less frequently and protects the user from altering the operation mode accidentally.
All the members of the Am8500 family are controlled and configured by software. The host CPU initializes the Am8500 operating modes by writing to the internal modeloptions registers. The internal mode registers are not directly addressable by the CPU like the Control and some data registers. Instead, a two cycle process is needed to write to them. First, the address of the mode/options register being modified is written to the Control register; next, the data is written to the mode/options register via the Control register. The Am8500 peripheral has an internal state machine to keep track of whether address or data is being written to the Control register. Reading the value of the mode/options register is accomplished by first, writing an address to the Control register, and second, reading the modeloptions data from the Control register.

## DESIGN REQUIREMENTS

There are several problems associated with interfacing a general purpose peripheral device to a CPU. One major problem involves the various control signals each chip uses. Unless the two families are designed to be pin for pin compatible (e.g., the AMD/Intel 8086/8087/8089) there generally is going to be minor variations between them; the same problem exists when interfacing the 8500 peripherals to the 68000. Part of the pin incompatibility involves genuine signal differences while other pins only require name changes.

The data pins ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) on the 8500 parts are connected directly to the lower 8 data lines on the 68000 bus. The register select pins ( $\left.A_{0}, A_{1}, A / \bar{B}, D / \bar{C}\right)^{*}$ can be directly connected to $A_{1}$ and $A_{2}$ of the 68000 address bus. The $\overline{R D}$ and $\overline{W R}$ lines have to be generated from the 68000's R/W and AS/UDS/LDS signals. The 8500 clock (PCLK) is generated by dividing down the 68000 clock.
*Note: The register select/control pins have different names on each of the 8500 peripherals.

The Interrupt Request line ( $\overline{(\mathbb{N T})}$ can be wire-ORed together and connected to one of the $\overline{\mathrm{P}}_{0}-\mathrm{IPL} \mathrm{P}_{2}$ inputs on the 68000, giving all the peripherals a common interrupt priority level. An alternate method might be to give each of the peripherals a separate priority level (which would require priority encoding). The interrupt acknowledge line must be generated from the CPU status lines $\left(\mathrm{FC}_{0}-\mathrm{FC}_{2}\right)$ by the PAL. Whenever an interrupt acknowledge cycle is started, $\mathrm{FC}_{0}-\mathrm{FC}_{2}$ equal all, ones. The Interrupt daisy chain control pins (IEI and IEO on each 8500 device) are tied together in a standard priority daisy chain arrangement (see Figure 1). When implementing the daisy chain, arbitration delay down the chain must be accounted for in the PAL signal generation logic. The chip enable pins for each of the 8500 devices must come from the system memory mapping logic. The system designer must also provide an 8500 PAL enable line to select the PAL controller whenever any one of the 8500 devices has been
selected. The DTACK signal back to the CPU will be generated by the PAL logic using an internally implemented state counter to generate the correct timing. The output is implemented as a simulated open collector output so that other non-Am8500 peripherals in the system can use the DTACK line.

Another problem with interfacing general purpose peripherals to the 68000 is timing. Most peripherals run at speeds considerably slower than the $8,10,12$, and 16 MHz CPUs being produced today. This means using either a slower clock or dividing down the CPU clock. In the case of the 8500 family this generally means dividing the CPU clock in half and using a CPU operating at less than or equal to 12 MHz . Aside from just speed problems, system integrators frequently have to


Figure 1

Table 1. Interrupt Daisy Chain/Propagation Delay

| Chain Position (ns) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Peripheral |  | First | Middle | Last |  |
| 8536 | CIO | 350 | 150 | 100 |  |
| 8038 | FIO | 350 | 150 | 100 |  |
| 8530 | SCC | 250 | 120 | 120 |  |

Note: First position timing is INTACK to IEO.
Middle position timing is IEI to IEO.
Last position timing is IEl to data strobe set-up.
tackle subtle timing differences between signals or from devised signal equivalents, e.g., deriving the Am8500 $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and DTACK from the 68000's $\overline{L D S}$ and R/W; or guaranteeing data set-up and hold times.

The 68000 has two ways of interfacing to peripherals such as the 8500 family. The first uses the special VPA (Valid Peripheral Address) input pin on the 68000. The VPA pin can be activated by the Am8500 device select logic at the start of a cycle to tell the 68000 that a peripheral is being accessed. This interface was designed to allow the slow, synchronous bus 6800 peripherals to talk to the 68000 's asynchronous bus until the new 68000 peripherals could be produced. Also, the VPA interface has a slow access rate (a minimum peripheral access time of over 1000ns not including recovery time) which would slow down the CPU considerably. And, since all the 68000 peripherals are being designed to use the asynchronous method, this interface will not be discussed.
When writing data, the 68000 puts address and data onto their respective buses and uses the DTACK line as a "got data successfully" handshake from the selected device. When the DTACK line is recognized, the 68000 removes ad dress and data one CPU clock later. This method allows the user to take advantage of the asynchronous bus of the 68000 . The major difference between the 8500 family and the 68000 DTACK timing is the way data is strobed in and out of the 8500 chips. The 8500 devices sample the data on the falling edge of WR. The 68000 asserts an address (when reading) onto the bus and then uses the DTACK signal from the selected peripheral (memory included) to indicate valid data and then
samples on the next falling edge of the CPU clock. The other method of interfacing the Am8500 family to the 68000 uses the Data Transfer Acknowledge (DTACK) cycle.

## DESIGN APPROACH

Two different methods of interfacing 8500 devices to the 68000 bus will be presented. One method allows the user to obtain fast access to all the 8500 devices. However, some minimum software requirements are imposed. The other interface slows down the access rate by the CPU but guarantees all 8500 minimum timing specifications and imposes no software overhead.

There are several timing requirements imposed by the 8500 family. The first involves read/write access to the parts. The $8500(4 \mathrm{MHz})$ peripherals have a read/write/interrupt acknowiedge timing as shown in Figure 2. The minimum read/write access time is 400 ns . This means the PAL interface must guarantee a valid access cycle of greater than 400ns (by forcing the 68000 to execute several wait states).

The basic read or write cycle generated by the PAL interface looks like Figure 3. The $68000 \mathrm{R} / \overline{\mathrm{W}}$ and $\overline{\mathrm{LDS}}$ lines have been converted into $8500 \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ control signals and with a state timing generator, produce the 68000 data valid signal DTACK. While the 8500 peripherals latch the data internally on the falling edge of WR, all 9500 (Intel-type) peripherals use the rising edge of $\overline{W R}$ to strobe in data. So, the timing used is designed to guarantee proper set-úp and hold time for both Am8500 and Am9500 devices.


03862A-123
Figure 2. Am8500 Interface Timing (4MHz)

The DTACK control logic is the only control line which employs any sort of special timing in both of the PAL interfaces. In order to guarantee proper set-up and hold time for write operations to the 9500 parts, it was necessary to start the $\overline{D T A C K}$ cycle in the middle of a PCLK cycle. Hence, it was necessary to use the CPU clock to condition the assertion of $\overline{\text { DTACK. Using the } C_{0} \text { (PCLK) and the } \mathrm{C}_{1}-\mathrm{C}_{3} \text { inputs only, would }}$ have allowed a potential set-up time violation during a write operation under worst case conditions for an 8 MHz 68000 .

The interrupt acknowledge cycle is very similar to the read/write cycle; only two differences exist. First, the interrupt acknowledge cycle involves only a read operation (see
interrupt acknowledge timing In Figure 3). Secondly, the read cycle needs to be stretched out to allow time for the interrupt daisy chain to resolve priority. If a parallel priority resolution scheme is used, then only the priority decode time delay and peripheral response time is added on to the interrupt cycle. The interrupt time delay varies, based on the number of 8500 devices in the daisy chain. The time delay is based on the 8500's position in the chain: first, somewhere in the middle, and the last device in the daisy chain (see Table 1). Both of the current PAL interfaces assume there are three 8500 peripherals in the interrupt daisy chain.


Figure 3a 03862A-124


03862A-125
*Delay time assumes three Am8500 devices in the daisy chain.
Note: $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ may not be asserted LOW simultaneously.
Figure 3b. PAL Generated Interface SIgnals

The PAL interfaces offered are designed to give the system designer maximum flexibility in integrating Am8500 peripherals with 68000 based systems. The first version is designed to allow maximum access to the 8500 devices (see Figure 4a). It does this by delegating the read/write recovery time into software. All 8500 peripherals have a minimum post access recovery time, l.e., they can't be accessed for a minimum period of time after being read or written (see Table 2). Generally, this restriction manifests itself only if the CPU has to make repeated accesses to the same peripheral part rapidly. While the instruction fetch time of the CPU allows for some recovery time, it doesn't guarantee enough time (since the average recovery time is approximately 1000 ns and a 68000 instruction fetch requires a minimum of 500 ns (0) 8 MHz ). Hence, the first design requires the user to implement minimum software recovery time.

The software recovery routines in this case generally take the form of executing 1-2 instructions (depending on execution and fetch time) in between accessing the same 8500 device. For most systems, these instruction executions can be used to process the data just received. Another method of insuring the minimum peripheral recovery time is to juggle the accessing of the 8500 devices in the system so the recovery time requirement is not violated.
The second design (see slow PAL timing in Figure 4b) relieves the user of all software considerations when using the Am8500 parts. The recovery time is built into the PAL design. This is done by delaying access on the read/write and then taking advantage of the 68000 next instruction fetch to guarantee that the minimum recovery time is given. Also, a minor change was required in the interrupt acknowledge timing, i.e., stretching out the INTACK timing slightly to avoid a potential glitch on the $\overline{\mathrm{RD}}$ line after an interrupt acknowledge cycle.

The advantage of software-independent hardware is offset by longer read/write cycles to the peripherals, even for single accesses. Also, the user is denied access to another 8500 peripheral until the minimum recovery time has been met for the previous one. However, having software-independent hardware is sometimes an important feature in a system; and slowing down the peripheral access rate slightly is a small price to pay for it. Note, the interrupt acknowledge cycles for both designs are virtually the same. This occurred because the normal interrupt processing by the 68000 guarantees that another access to the 8500 parts cannot occur in time to violate their access recovery times. Hence no software delay is needed for the fast access interface.

The interrupt acknowledge delay (for the daisy chained priority resolution scheme) in this example has been chosen by using an assumption of three 8500 peripherals in the chain. Larger or smaller numbers of parts in the daisy chain would increase or decrease this result with minor changes to the PAL logic equations. The design is flexible enough to support the addition of at least 3 more peripherals in the daisy chain.

The PAL equations and logic diagram for both designs are given at the end of the article. The equations were derived directly from their respective timing diagrams (Figures 4 a and 4b). Some obvious logic simplification was done on the initial equations to reduce the number of terms. The integration of the Am8500 peripherals and the PAL timing generator are shown in a sample configuration in Figure 5.

Finally, the design presented was optimized for an 8 MHz 68000 system and 4 MHz 8500 parts. The timing/state counter ( $\mathrm{C}_{0}-\mathrm{C}_{4}$ ) only counts as far as it is needed. Higher performance CPUs, up to 12 MHz , can be used with this interface, but 6 MHz 8500 parts will have to be used.

Table 2. Peripheral Access Recovery Time

| Peripheral <br> $(4 \mathrm{MHz})$ | Recovery Time |
| :---: | :---: |
| 8530 | SCC |
| 8536 | CIO |
| 8038 | FIO | Greater than 6 PCLK cycles + 200ns | Greater than 3 PCLK cycles or 1000ns |
| :---: |



Figure 4a. "Fast" PAL Am8500 to MC68000



Figure 5. PAL Am8500 to MC68000 Hookup

FAST AM8500 TO MOTOROLA 68000 PAL ADVANCED MICRO DEVICES
CLK DCLK /CS /RESET /LDS RW FCO FCl FC2 GND
/OE /RD /WR /C3 /C2 /C1 /CO /INTACK /DTACK VCC
;
; STATE MACHINE COUNTER CO - C3
CO := /CO
$\mathrm{Cl}:=\mathrm{C} 0^{*} / \mathrm{C} 1 * \mathrm{CS}^{*}$ LDS*/RESET
$+/ \mathrm{CO}^{*} \mathrm{C} 1 * \mathrm{CS}^{*} \mathrm{LDS} * /$ RESET
$\mathrm{C} 2:=\mathrm{CO}{ }^{*} \mathrm{C} 1^{*} / \mathrm{C} 2 * \mathrm{CS} * / R E S E T$
$+/ \mathrm{C} 1 * \mathrm{C} 2 * \mathrm{CS} * / \mathrm{RESET}$
$+/ \mathrm{CO}^{*} \mathrm{C} 1^{*} \mathrm{C} 2 * \mathrm{CS}{ }^{*} /$ RESET
$\mathrm{C} 3:=\mathrm{CO} * \mathrm{C} 1 * \mathrm{C} 2 * / \mathrm{C} 3 * \mathrm{CS} * / \mathrm{RESET}$
$+/ \mathrm{Cl}{ }^{*} / \mathrm{C} 2 * \mathrm{C}^{*} \mathrm{CS}^{*} / \mathrm{RESET}$
$+/ \mathrm{CO}^{*} \mathrm{C} 1^{*} / \mathrm{C} 2 * \mathrm{C} 3^{*} \mathrm{CS} * /$ RESET
$\mathrm{RD}=\mathrm{C} 1^{*} / \mathrm{C} 2^{*} / \mathrm{C} 3 * \mathrm{RW}^{*} /$ INTACK ${ }^{*} \mathrm{CS}^{*} /$ RESET ; NORMAL READ
$+/ \mathrm{C} 1 * \mathrm{C} 2 * / \mathrm{C} 3 * \mathrm{RW} * /$ INTACK $^{*}$ CS*/RESET ; NORMAL READ
$+\mathrm{C} 0^{*} \mathrm{C} 1 * \mathrm{C} 2 * / \mathrm{C} 3 *$ INTACK*CS*/RESET ; INTERRUPT ACKNOWLEDGE

+ RD*INTACK*CS*/RESET ; INTERRUPT ACKNOWLEDGE
$\mathrm{WR}=\mathrm{Cl}{ }^{*} / \mathrm{C} 2 * / \mathrm{C}^{*} / \mathrm{RW}^{*} \mathrm{CS} * /$ INTACK*/RESET ; WRITE OPERATION $+/ \mathrm{C} 1^{*} \mathrm{C} 2 * / \mathrm{C} 3^{*} / \mathrm{RW}^{*} \mathrm{CS} * /$ INTACK*/RESET ; WRITE OPERATION
: DATA ACKNOWLEDGE
IF (CS) DTACK $=/ \mathrm{DCLK}^{*} / \mathrm{CO} * / \mathrm{C} 1^{*} \mathrm{C} 2 * / \mathrm{C} 3^{*} / \mathrm{INTACK}^{*} /$ RESET
+ DTACK*RD*/RESET
+ DTACK*WR*/RESET
$+/ \mathrm{DCLK}^{*} \mathrm{CO}^{*} / \mathrm{C} 1^{*} / \mathrm{C} 2 * \mathrm{C} 3^{*}$ INTACK*/RESET
; INTERRUPT ACKNOWLEDGE
INTACK $=\mathrm{FCO}{ }^{*} \mathrm{FC} 1^{*} \mathrm{FC}^{*}{ }^{*} \mathrm{C} 1 * / \mathrm{C} 3^{*}$ LDS $^{*} /$ RESET
$+\mathrm{C} 2 * \mathrm{FCO}{ }^{*} \mathrm{FC} 1^{*} \mathrm{FC} 2 * / \mathrm{RESET}$
$+/ \mathrm{Cl}^{*} \mathrm{C}^{*}{ }^{*} \mathrm{FCO}^{*} \mathrm{FC1}{ }^{*} \mathrm{FC} 2^{*} / \mathrm{RESET}$
$+/ \mathrm{CO}^{*} \mathrm{C} 1^{*} \mathrm{C}^{*}{ }^{*} \mathrm{FCO}^{*} \mathrm{FCl}^{*} \mathrm{FC}^{*} /$ RESET

```
FUNCTION TABLE:
```

```
; NOTE: FOR THE SIMULATION, ALL THE SIGNALS USED ARE AT THE
```

; NOTE: FOR THE SIMULATION, ALL THE SIGNALS USED ARE AT THE
PIN LEVEL (I.E. WHAT THE CHIP SEES AND PUTS OUT). THE
PIN LEVEL (I.E. WHAT THE CHIP SEES AND PUTS OUT). THE
ONE EXCEPTION ARE THE CO - C3 PINS. THESE ARE DEFINED
ONE EXCEPTION ARE THE CO - C3 PINS. THESE ARE DEFINED
AT THE REGISTER OUTPUT LEVEL (NON-INVERTED) BECAUSE
AT THE REGISTER OUTPUT LEVEL (NON-INVERTED) BECAUSE
THEY WERE DIRECTLY DERIVED FROM THE TIMING DIAGRAMS
THEY WERE DIRECTLY DERIVED FROM THE TIMING DIAGRAMS
AND THIS MAKES IT EASIER TO RELATE TO THE TIMING
AND THIS MAKES IT EASIER TO RELATE TO THE TIMING
DIAGRAM.

```
                                    DIAGRAM.
```

CLK DCLK /CS /RESET /LDS RW FCO FC1 FC2
/OE /RD /WR CO Cl C2 C3 /INTACK /DTACK
;
;
RESET SEQUENCE

| C | H | H | L | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| L | L | H | L | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |
| C | H | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H | Z |
| L | L | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H | Z |
| L | H | H | H | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |
|  | H | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |  |  |

;
;WRITE OPERATION (RW=L)

| C | H | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H |
| C | H | H | H | X | X | X | X | X | L | H | H | H | L | L | L | H |
| L | L | H | H | X | X | X | X | X | L | H | H | H | L | L | L | H |
| C | H | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H |
| L | L | L | H | L | L | X | X | X | L | H | H | L | L | L | L | H |
| C | H | L | H | L | L | X | X | X | L | H | H | H | $L$ | L | L | H |
| L | L | L | H | L | L | X | X | X | L | H | H | H | L | L | L | H |
| C | H | L | H | L | L | X | X | X | L | H | L | L | H | L | L | H |
| L | L | L | H | L | L | X | X | X | L | H | L | L | H | L | L | H |
| C | H | L | H | L | L | X | X | X | L | H | L | H | H | L | L | H |
| L | L | L | H | L | L | X | X | X | L | H | L | H | H | L | L | H |
| C | H | L | H | L | L | X | X | X | L | H | L | L | L | H | L | H |
| L | L | L | H | L | L | X | X | X | L | H | L | L | L | H | L | H |
| C | H | L | H | L | L | X | X | X | L | H | L | H | L | H | L | H |
| L | L | L | H | L | L | X | X | X | L | H | L | H | L | H | L | H |
| C | H | L | H | L | H | X | X | X | L | H | H | L | H | H | L | H |
| L | L | H | H | X | X | X | X | X | L | H | H | L | H | H | L | H |
| C | H | H | H | X | X | X | X | X | L | H | H | H. | L | L | L | H |
| L | L | H | H | X | X | X | X | X | L | H | H | H | L | L | L | H |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ;INTACK CYCLE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | H | H | H | X | X | X | X | X | L | H | H | L | L | L | $L$ | H |
| L | L | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H |
| C | H | H | H | X | X | X | X | X | L | H | H | H | L | L | L | H |



DESCRIPTION:
THE FASTZTOM PAL PROVIDES INTERFACING BETWEEN THE SINGLE CHIP 8500 TO THE 68000. THE PAL USED IS A MEANS TO PROVIDE FOR THE FASTEST POSSIBLE INTERFACE. THE REQUIREMENTS FOR THIS MAXIMUM ACCESS UTILIZES IMPLEMENTED SOFTWARE FOR REPEATED ACCESSES. THE USER, HENCE, IS ABLE TO GET MAXIMUM ACCESS WITH MINIMAL WAIT STATE INSERTION. THE INTERFACE PROVIDES TOTAL SIGNAL COMPATIBILITY.

PAL16R4
PAT050
FAST AM8500 TO MOTOROLA 68000 PAL adVanced micro devices
*D9724
*FO*
LOOOO 1111101111111111111111111111.1111 *
L0032 10111101010111011110110111111111 *
L0064 11101111011111111111111111111110 *
L0096 11101111011111111111111111101111 *
L0128 10111110011011011101111011111111 *
L0256 11111111111111111111111111111111 *
L0288 11111111011110101111010101110111 *
L0320 11111111011111111110011101110111 *
L0352 11111111011111011111011001110111 *
L0384 11111111010111101111011001110111 *
L0512 11111111110111111111111111111111 *
L0768 11111011011010011111111111111111 *
L0800 11111011010110101111111111111111 *
L1024 11111011011011101101111111111111 *
L1056 11111011011111011110111111111111 *
L1088 11111011010111101110111111111111 *
L1280 11111011011011101110110111111111 *
L1312 11111011011111011101111011111111 *
L1344 11111011010111101101111011111111 *
L1536 11111111111111111111111111111111 *
L1568 11111001011111101001110111111111 *
L1600 11111001011111011010110111111111 *
L1792 11111111111111111111111111111111 *
L1824 11111001011111100101110111111111 *
L1856 11111001011111010110110111111111 *
L1888 11111010011011101110110111111111 *
L1920 11111010011111111111111111111110 *
C58C0*
V0001 Cl10XXXXX00HHннHLHZ1 *
V0002 0010XXXXX00HHHHHLHZ1 *
V0003 C111XXXXXOOHHHHHHHZ1 *
V0004 0011XXXXX00HHHHHHHZ1 *
V0005 C111XXXXXOOHHHHHLHZ1 *
V0006 0011XXXXXOOHHHHHLHZ1 *
V0007 C111XXXxX00HHHHHHHZ1 *
V0008 0011XXXXX00HHHHHHHZ1 *
V0009 C111XXXXXOOHHHHHLHZ1 *
V0010 0011XXXXXOOHHHHHLHZ1 *
V0011 C111XXXXXOOHHHHHHHZ1 *
V0012 000100XXX00HHHHHHHH1 *
V0013 C10100XXXOOHHHHHLHH1 *
V0014 000100XXXOOHHHHHLHH1 *
V0015 C10100XXX00HLHHLHHH1 *
V0016 000100XXX00HLHHLHHH1 *
V0017 C10100XXX00HLHHLLHH1 *
V0018 000100XXX00HLHHLLHH1
V0019 C10100XXX00HLHLHHHH1
V0020 000100XXX00HLHLHHHL1 *
V0021 C10100XXX00HLHLHLHL1 *

PAL DESIGN SPECIFICATION MARK YOUNG $1 / 21 / 83$

```
V0022 000100XXX00HLLHLHLHL1 *
V0023 C10101XXXOOHHHLLLHHH1 *
V0024 0011XXXXXOOHHHLLLHHZ1 *
V0025 C111XXXXXOOHHHHHLHZ1 *
V0026 0011XXXXXOOHHHHHLHZ1 *
V0027 C111XXXXXX00HHHHHHHZ1 *
V0028 0011XXXXXX00HHHHHHHZ1 *
V0029 CI11XXXXXX00HHHHHLHZ1 *
V0030 0011XXXXXX00HHHHHLHZ1 *
V0031 C1010111100HHHHLHLH1
V0032 00010111100HHHHLHLLH1
V0033 C1010111100HHHHLLLH1
V0034 00010111100HHHHLLLH1
V0035 Cl010111100HHHLHHLH1
V0036 00010111100HHHLHHLH1
V0037 C1010111100HHHLHLLH1
V0038 00010111100HHHLHLLH1
V0039 C1010111100HHHLLHLH1
V0040 00010111100HHHLLHLH1
V0041 C1010111100LHHLLLLH1
V0042 00010111100LHHLLLLH1
V0043 C1010111100LHLHHHLH1
V0044 00010111100LHLHHHLH1 *
V0045 C1010111100LHLHHLLH1 *
V0046 00010111100LHLHHLLLL1 *
V0047 C1010111100LHLHLHLL1 *
V0048 00010111100LHLHLHLL1 *
V0049 C1010111100HHLHLLHH1 *
V0050 00111XXXX00HHLHLLLHZ1 *
V0051 C1111XXXXOOHHHHHHHZ1 *
V0052 001111XXXX00HHHHHHHZ1 *
7BCF
```



SLOW AM8500/9500 TO MOTOROLA 68000 PAL MARK YOUNG

CLK DCLK /CS /RESET /LDS RW FCO FC1 FC2 GND
/OE /RD /WR /C3 /C2 /C1 /CO /INTACK /DTACK VCC
;
; STATE MACHINE COUNTER CO - C3
CO : $=/ \mathrm{CO}$
; 8500 CLK
$\mathrm{Cl}:=\mathrm{CO} * / \mathrm{C} 1 * / \mathrm{C} 2 *$ LDS $* \mathrm{CS} * /$ RESET
$+/ \mathrm{CO}{ }^{*} \mathrm{C} 1 * / \mathrm{C} 2 * \mathrm{LDS} * \mathrm{CS} * / \mathrm{RESET}$
$+\mathrm{C} 0 * / \mathrm{C} 1 * \mathrm{C} 2 * \mathrm{LDS} * \mathrm{CS} * /$ RESET
$+/ \mathrm{CO} * \mathrm{C} 1 * \mathrm{C} 2 * \mathrm{C} 2 * / \mathrm{C} 3 * \mathrm{LDS}^{*} \mathrm{CS} * / R E S E T$
$\mathrm{C} 2:=\mathrm{CO} * \mathrm{Cl}^{*} / \mathrm{C} 2 * \mathrm{CS} * / \mathrm{RESET}$
$+/ \mathrm{C} 1 * \mathrm{C} 2 * \mathrm{CS} * / \mathrm{RESET}$
$+/ \mathrm{C} 0 * \mathrm{C} 1 * \mathrm{C} 2 * / \mathrm{C} 3 * \mathrm{CS} * / \mathrm{RESET}$
$\mathrm{C} 3:=\mathrm{CO} * \mathrm{C} 1 * \mathrm{C} 2 * / \mathrm{C} 3 * \mathrm{CS} * / \mathrm{RESET}$
$+/ \mathrm{C} 2 * \mathrm{C} 3 * \mathrm{CS} * / \mathrm{RESET}$
$+/ \mathrm{C} 1 * \mathrm{C} 2 * \mathrm{C} 3^{*} \mathrm{CS} * / R E S E T$
$\mathrm{RD}=\mathrm{C} 1 * / \mathrm{C} 2 * \mathrm{C} 3 * \mathrm{RW} * \mathrm{CS} * /$ INTACK $* / R E S E T$
$+/ \mathrm{C} 1 * \mathrm{C} 2 * \mathrm{C} 3 * \mathrm{RW} * \mathrm{CS} * /$ INTACK $* / R E S E T$
; NORMAL READ
$+\mathrm{C} 0 * \mathrm{C} 1 * \mathrm{C} 2 * / \mathrm{C} 3 *$ INTACK $* /$ RESET
; NORMAL READ
$+/ \mathrm{C} 1 * / \mathrm{C} 2 * \mathrm{C} 3^{*}$ INTACK*/RESET
$+/ \mathrm{CO} * \mathrm{C} 1 * / \mathrm{C} 2 * \mathrm{C} 3 *$ INTACK $/$ /RESET
INTERRUPT ACKNOWLEDGE
; INTERRUPT ACKNOWLEDGE
; INTERRUPT ACKNOWLEDGE
$\mathrm{WR}=\mathrm{C} 1 * / \mathrm{C} 2 * \mathrm{C} 3 * / \mathrm{RW} * \mathrm{CS} * / \mathrm{INTACK} * / \mathrm{RESET}$
; WRITE OPERATTON
$+/ \mathrm{Cl} * \mathrm{C}^{*} * \mathrm{C} 3 * / \mathrm{RW} * \mathrm{CS} * /$ INTACK*/RESET
; WRITE OPERATION
; DATA ACKNOWLEDGE
IF (CS) DTACK $=/ \mathrm{DCLK}^{*} / \mathrm{CO} * / \mathrm{Cl}{ }^{*} \mathrm{C} 2 * \mathrm{C} 3 * / \mathrm{INTACK}^{*} / \mathrm{DTACK}^{*} / \mathrm{RESET}$

+ DTACK*RD*/RESET
+ DTACK*WR*/RESET
$+/ D C L K * C 0 * / C 1 * / C 2 * C 3 *$ INTACK $* / R E S E T$
; INTERRUPT ACKNOWLEDGE
INTACK $=\mathrm{FC} 0 * \mathrm{FC} 1 * \mathrm{FC} 2 * \mathrm{C} 1 * / \mathrm{C} 3 * \mathrm{LDS}^{*} \mathrm{CS}^{*} / \mathrm{RESET}$
$+\mathrm{C} 2 * / \mathrm{C} 3 * \mathrm{FCO} * \mathrm{FC} 1^{*} \mathrm{FC} 2 * \mathrm{CS} * / \mathrm{RESET}$
$+/ \mathrm{C}^{*}{ }^{*} 3^{*} \mathrm{FCO}^{*} \mathrm{FC} 1 * \mathrm{FC} 2 * \mathrm{CS} * /$ RESET

FUNCTION TABLE:

```
    NOTE: FOR THE SIMULATION, ALL THE SIGNALS USED ARE AT THE
    PIN LEVEL (I.E. WHAT THE CHIP SEES AND PUTS OUT). THE
    ONE EXCEPTION ARE THE CO - C3 PINS. THESE ARE DEFINED
    AT THE REGISTER OUTPUT LEVEL (NON-INVERTED) BECAUSE
    THEY WERE DIRECTLY DERIVED FROM THE TIMING DIAGRAMS
    AND THIS MAKES IT EASIER TO RELATE TO THE TIMING
    DIAGRAM.
```

    CLK DCLK /CS /RESET /LDS RW FCO FC1 FC2
    /OE /RD /WR CO C1 C2 C3/INTACK /DTACK
    .... ..........................
;RESET SEQUENCE

| C | H | H | L | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| L | L | H | L | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |
| C | H | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H | Z |
| L | L | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H | Z |
| C | H | H | H | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |
| L | H | H | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |  | ;

$\because$;WRITE OPERATION (RW=L)

| C | H | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H | Z |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L. | L | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H | Z |
| C | H | H | H | X | X | X | X | X | L | H | H | H | L | L | L | H | Z |
| L | L | H | H | X | X | X | $X$ | X | L | H | H | H | L | L | L | H | 2 |
| C | H | H | H | X | X | X | X | X | L | H | H | L | L | L | L | H | Z |
| L | L | L | H | L | L | X | X | X | L | H | H | L | L | L | L | H | H |
| C | H | L | H | L | L | X | X | X | L | H | H | H | L | L | L | H | H |
| L | L | L | H | L | L | X | X | X | L | H | H | H | L | L | L | H | H |
| C | H | L | H | L | L | X | X | X | L | H | H | L | H | L | L | H | H |
| L | L | L | H | L | L | X | X | X | L | H | H | L | H | L | L | H | H |
| C | H | L | H | L | L | X | X | X | L | H | H | H | H | L | L | H | H |
| L | L | L | H | L | L | X | X | X | L | H | H | H | H | L | L | H | H |
| C | H | L | H | L | L | X | X | X | L | H | H | L | L | H | L | H | H |
| L | L | L | H | L | L | X | X | X | L | H | H | L | L | H | L | H | H |
| C | H | L | H | L | L | X | X | X | L | H | H | H | L | H | L | H | H |
| L | L | L | H | L | L | X | X | X | L | H | H | H | L | H | L | H | H |
| C | H | L | H | L | H | X | X | X | L | H | H | L | H | H | L | H | H |
| L | L | L | H | L | L | X | X | X | L | H | H | L | H | H | L | H | H |
| C | H | L | H | L | L | X | X | X | L | H | H | H | H | H | L | H | H |
| L | L | L | H | L | L | X | X | X | L | H | H | H | H | H | L | H | H |
| C | H | L | H | L | L | X | X | X | L | H | H | L | L | L | H | H | H |

 ;
;INTACK CYCLE

| C | H | H | H |
| :---: | :---: | :---: | :---: |
| L | L | H | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | L | H |
| C | H | L | H |
| L | L | H | H |
| C | H | H | H |
| L | L | H | H |













Z
Z
H
H
H
H
H
H
H
H
H
H
H
H
H
H
H
H
H
H
H
L
L

DESCRIPTION:
THE SLOWZTOM PAL IS A SELF-CONTAINED 8500 TO 68000 INTERFACE. THERE IS NO USER SOFTWARE REQUIRED FOR THIS INTERFACE, BUT THERE IS A TRADE-OFF OF SLOWER ACCESS TIME. AGAIN, THE INTERFACE PROVIDES TOTAL SIGNAL COMPATIBILITY.

PAL16R4
PAT051
SLOW AM8500/9500 TO MOTOROLA 68000 PAL ADVANCED MICRO DEVICES *D9724
*FO*
L0000 11111011111111111111111111111111 *
L0032 10011101010111011110111011111111 *
L0064 11101111011111111111111111111110 *
L0096 11101111011111111111111111101111 *
L0128 10111110011011011101111011111111 *
L0256 11111111111111111111111111111111 *
L0288 11111011011110101111010101110111 *
LO320 11111011011111111110010101110111 *
L0352 11111011011111111101011001110111 *
L0512 11111111110111111111111111111111 *
L0768 11111011011010011101111111111111 *
L0800 11111011010110101101111111111111 *
L0832 11111011011010011110111111111111
L0864 11111011010110101110110111111111
L1024 11111011011011101101111111111111 *
L1056 11111011011111011110111111111111 *
L1088 11111011010111101110110111111111
L1280 11111011011011101110110111111111 *
L1312 11111011011111111101111011111111 *
L1344 11111011011111011110111011111111 *
L1536 11111111111111111111111111111111 *
L1568 11111001011111101001111011111111 *
L1600 11111001011111011010111011111111 *
L1792 11111111111111111111111111111111 *
L1824 11111001011111100101111011111111 *
L1856 11111001011111010110111011111111 *
L1888 11111110011011101110110111111111 *
L1920 11111110011111011101111011111111 *
L1952 11111110010111101101111011111111 *
C5D43*
V0001 C110XXXXX00HHHHHLHZ1 *
v0002 0010XXXXX00HHHHHLHZ1 *
V0003 C111Xxxxx00ннннHHHZ1
v0004 0011XXXXX00НHHHHHHZ1 *
V0005 C111Xxxxx00HHHHHLHZI
V0006 0011XXXXXOOHHHHHLHZ1
V0007 C111XXXXX00нннннHHZ1
V0008 0011XXXXXOOHHHHHHHZ1
V0009 C111XXXXX00НHHHHLHZ1
V0010 0011XXXXX00HHHHHLHZ1
V0011 C111XxxxxоонннННННZ1
V0012 000100хххооннннНнНн1
V0013 C10100xXX00НнНННLHH1
V0014 000100XXX0OHHHHHLHH1
V0015 C10100XXX00HHHHLHHH1
V0016 000100хххООННННLHHH1
V0017 Cl0100xxx00HHHHLLHH1
V0018 000100XXXOOHHHHLLHH1 *
V0019 C10100XXXOOHHHLHHHH1 *

PAL DESIGN SPECIFICATION MARK YOUNG 1/21/83

V0020 000100XXXOOHHHLHHHH1 *
V0021 C10100XXX00HHHLHLHH1
V0022 000100XXX00HHHLHLHH1 V0023 C10101XXXOOHHHLLHHH1 * ' V0024 000100XXX00HHHLLHHH1
V0025 C10100XXXOOHHHLLLHH1 V0026 000100XXX00HHHLLLHH1 V0027 ClO100XXXOOHHLHHHHH1 V0028 000100XXX00HHLHHHHH1 V0029 C10100XXXOOHHLHHLHH1 V0030 000100XXX00HHLHHLHH1 V0031 C10100XXX00HLLHLHHH1 V0032 000100XXX00HLLHLHHH1 V0033 C10100XXX00HLLHLLHH1 V0034 000100XXXOOHLLHLLHH1 V0035 C10100XXXOOHLLLHHHH1 V0036 000100XXX00HLLLHHHL1 V0037 C10100XXX00HLLLHLHL1 V0038 000100XXXOOHLLLHLHL1 V0039 C10100XXX00HHLLLHHH1 V0040 000100XXX0OHHLLLHHH1 V0041 C11111XXXOOHHHHHLHZ1 V0042 0011XXXXXOOHHHHHLHZ1 V0043 C111XXXXXOOHHHHHHZZ1 V0044 0011XXXXXOOHHHHHHHZ1 V0045 C111XXXXXOOHHHHHLHZ1 V0046 0011 XXXXXOOHHHHHLHZ1 V0047 C1010111100HHHHLHLH1 * V0048 $00010111100 \mathrm{HHHHLHLH1}$ V0049 C1010111100HHHHLLLH1 V0050 00010111100 HHHHLLLH 1 V0051 C1010111100HHHLHHLH1 V0052 00010111100HHHLHHLH1 V0053 C1010111100HHHLHLLH1 V0054 00010111100HHHLHLLH1 V0055 C1010111100HHHLLHLH1 V0056 00010111100 HHHLLHLH1 V0057 C1010111100LHHLLLLH1 V0058 00010111100LHHLLLLH1 V0059 C1010111100LHLHHLLH1 V0060 $00010111100 \mathrm{LHLHHHLH1}$ V0061 C1010111100LHLHHLLH1 V0062 00010111100LHLHHLLLI V0063 C1010111100LHLHLHLL1 V0064 00010111100LHLHLHLL1 V0065 C1010111100HHLHLLLH1 V0066 00111XXXX00HHLHLLHZ1 V0067 C111XXXXXOOHHHHHHHZ1 V0068 0011XXXXX00HHHHHHHZ1 * F7FD

## Columns: Inputs (0-31)



# The Berkeley-1 Plus A High Performance CPU Utilizing PALs 

by Jeff Kitson and Kevin Ow-Wing Advanced Micro Devices

## INTRODUCTION

This paper illustrates the design of a high performance 16-bit CPU, called the Berkeley-1 Plus, utilizing PALs. It is intended to show where PALs fit into an overall system design, what kind of complex functions PALs can implement, and how a designer can realize the full advantages of PALs. To oversimplify, PALs fit everywhere in a design. Of the 56 chips used in this design, 34 are PALs. In the data path, they are used for data steering and data manipulation. Using PALs for data steering functions simplified the implementation of a multiple bus architecture. The data manipulation functions include a 16 -bit arithmetic barrel shifter, constant generation logic and sign extension logic. PALs are also used extensively to optimize the control path. For example, control functions include instruction predecoding, double pipelining control, microprogram branch control, register file control and special instruction control.

## THE BERKELEY-1 PLUS

The Berkeley-1 Plus was originally conceived of at the University of California, Berkeley as a design project for computer architecture students. The Berkeley-1 Plus is essentially a PDP-11 16-bit general purpose computer with a streamlined instruction set. The Berkeley-1 Plus was chosen as a test vehicle for PAL system design for three reasons. First, the authors had already designed the computer (in the class at Berkeley) using a limited parts list consisting mainly of fixedfunction TTLSSI/MSI devices. This provided a benchmark for the new design. Second, the original computer design by the authors was done separately and the new design was a joint effort. This proved to be a true test of the flexibility of PALs because of the effect of one designer's changes on the other. Finally, the architecture was not conceived with any particular device limitations in mind. This allowed the authors to optimize the PALs to implement the architecture, instead of optimizing the PALs to fit a constrained architecture limited by available devices.

## ARCHITECTURE

The architecture of the Berkeley-1 Plus, like any other computer, is defined by the instruction set and the functional blocks required to implement the instruction set. The Berkeley-1 Plus architecture is organized as a two address, register based processor to implement its simple, yet powerful instruction set. The processor interfaces to a 16 -bit address bus and a 16-bit data bus. This allows the processor to address up to 64 K of memory and to operate on 16 -bit data and instruction words. Instruction words are orthogonal in nature allowing selection of the instruction opcode to be independent of the selection of both operand addressing
modes (for instructions with operands). The instruction set and addressing modes are shown in Appendix A. To implement the instruction set, the architecture is defined to contain an arithmetic and logic unit (ALU), an eight location register file (RF), a 16 -bit program counter (PC), a 16 -bit instruction register (IR), and a 4-bit processor status word (PSW). In addition, the processor also supports interrupts and illegal instruction traps.

## INSTRUCTION SET

Berkeley-1 instructions have a general format that divides the instruction word into a separate 4 -bit instruction opcode field (OPCODE), 6 -bit source operand field (SOURCEOP) and 6 -bit destination operand field (DESTOP). The general format is as follows:

| OPCODE |  | SOURCEOP |  |  | DESTOP |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 |  | 11 | 6 | 5 |  | 0 |
|  |  |  | 1 |  |  |  |

The OPCODE field encodes which of the sixteen instructions is to be executed. This is true for all Berkeley-1 instructions, even those that do not follow the general format. The SOURCEOP field encodes which of the seven addressing modes is to be used to find the source operand. The DESTOP field is the same as the SOURCEOP field except that it also defines where the resit of an instruction is placed. For example, if the instruction is an addition, the SOURCEOP is register 1 and the DESTOP is register 2, the values inside of registers 1 and 2 would be added together and placed in register 2.

The instructions adhering to the general format include move (MOV), addition (ADD), subtraction (SUB), compare (CMP), logical and (AND), logical or (OR), exclusive-or (XOR), shift level (SHL), shift right (SHR), load multiple registers with memory (LDM), and store multiple registers to memory (STM). The unconditional jump (JMP) and unconditional jump to subroutine (CALL) instructions have the same general format except the SOURCEOP field is unused because the jump address is derived from the DESTOP field only. The unconditional return from subroutine (RET) and interrupt enable/disable (INTENB) instructions differ from the general format because they do not need any operands. The only instruction which differs from the general format significantly is the conditional branch (CBR) instruction.

The format of the CBR instruction is as follows:

| OPCODE |  | BRCOND |  | BROFFSET |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 15 |  | 11 |  | 7 | 0 |
|  |  |  |  |  |  |

The 4-bit BRCOND field is used to select which of sixteen branch conditions are to be tested. The branch conditions are derived from the PSW. The BROFFSET field is an 8 -bit signed offset that is added to the program counter, when the tested condition is true, to provide a new address. This allows position independent code, but limits the range of the CBR instruction to +127 or -128 locations relative to the program counter.
Each instruction is defined in more detail in Appendix A.

## ADDRESSING MODES

As previously mentioned there are seven different addressing modes that can be used to address operands. These addressing modes are: short immediate, register, register indirect, register indexed, absolute, stack pointer auto-increment, and stack pointer auto-decrement. The short immediate addressing mode is selected when the uppermost bit of the operand field (SOURCEOP or DESTOP) is zero, leaving the lower five bits of the field as the operand. The format for short immediate is as follows:

| SOURCEOP VALUE |  |  |  | DESTOP VALUE |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 5 | 4 | 0 | 5 | 4 | 0 |
| [0] |  |  | $[0]$ | [ |  |

To encode the addressing modes that specify registers into the SOURCEOP and DESTOP fields, these two fields are each further divided into two smaller 3-bit fields as follows:

| SOURCEMODE SOURCEREG DESTMODE DESTREG |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 53 | 2 - 0 | 53 | 2 |  |

The SOURCEMODE and DESTMODE fields encode the addressing mode and the SOURCEREG and DESTREG fields select one of the eight registers. These modes are: register, register indirect, and register indexed. The remaining addressing modes, absolute, stack pointer auto-increment, and stack pointer auto-decrement, that do not use registers are selected by the register field when the mode field is equal to seven. Seven was chosen because the stack pointer is register seven in the register file. The format for these modes is shown below:

| SOURCEMODE SOURCEREG | DESTMODE | DESTREG |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 5 | 32 | 0 | 5 | 3 | 2 | 0

The addressing modes are shown in more detail in Appendix A.

## IMPLEMENTATION

The implementation of the Berkeley- 1 is obviously controlled by the architecture, but the architecture definition does not
control the method of implementation. For example, the 16 -bit arithmetic operations specified in the instruction set could be done serially four bits at a time in four repeatable cycles. This could result in a minimum parts count, but also in a very slow ALU. Conversely, an instruction can be executed at the same time as the next instruction is being decoded and the next one after that is being fetched. This results in a very fast machine, but parts count and the complexity of doing many things in parallel can be costly. The objective of this implementation of the Berkeley-1 Plus was to build a very high performance CPU that could fit on a single board with a very fast synchronous memory. This required a minimum parts count while implementing a complex machine operating in parallel. Thus PALs were brought to the rescue. Their ability to implement complex, custom functions at high speeds made them the ideal choice.
A block diagram of the CPU appears in Figure 1. It is characterized by multiple buses and functional blocks that have multiple input sources and multiple output destinations. The multiple buses and multiple input/output functional blocks facilitate parallel operation. The five major buses are the memory data bus (DBUS), the memory address bus (ABUS), the source operand bus (RBUS), the destination operand bus (SBUS), and the result bus (YBUS). The DBUS and ABUS are used for interface to the external world and the RBUS, SBUS and YBUS are used for internal CPU operations. The ten functional blocks are the ALU and register file, PC, IR, memory data register $1\left(\mathrm{MDR}_{1}\right)$, memory data register $2\left(\mathrm{MDR}_{2}\right)$, memory address register (MAR), barrel shifter, value register, RBUS control and SBUS control. The only other major functional block is the control sequencer.
The control sequencer block diagram appears in Figure 2. The control sequencer consists of two instruction mapping PROMs, a horizontal pipelined microprogram memory and a PAL conditional microbranch controller.
Significant performance enhancement resulted from the parallel, double-pipelined design implementation. For example, in a single cycle the Berkeley- 1 can perform a barrel shift of up to 16 places while decoding the next instruction, incrementing the PC, fetching the next instruction plus one, and testing for interrupts and traps. All of this takes place in a worst case cycle time of 131 ns . Effectively, due to all of these operations happening at the same time instructions are performed in a single cycle (short immediate and register mode only). This results in the Berkeley-1 Plus performing approximately 7.5 million instructions per second ( 7.5 MIPs ). The timing and critical path analysis appears in Appendix B.
The actual design was divided up by the authors so that one was responsible for the data path and the other was responsible for the control path. The CPU portion shown in Figure 1 was designed by Jeff and the control sequencer of Figure 2 was designed by Kevin. This resulted in a more or less clean interface for interaction between the designers. Every time an optimization was contemplated in the CPU, an analysis had to take place to see if the control sequencer could support it or if the change was worth changing the sequencer, too. Likewise, every time the control sequencer needed to be changed the effects on the CPU had to be analyzed. With PALs, most of these changes were easily implemented by reprogramming a device by one designer or the other. For example, the original designs were not double-pipelined, but Jeff made changes in the data path and Kevin changed the control path to support it. Thus most of the design effort was in deciding the method of an optimized implementation (and working relationship) because of the flexibility of PALs to implement a design change easily.


Figure 1. CPU Block Diagram


Figure 2. Control Sequencer Block Dlagram

A simplified state diagram of the Berkeley-1 Plus appears in Figure 3. The state diagram should allow the reader to easily understand the complexity of a double-pipelined CPU and to get a feel for how this implementation of the Berkeley-1 Plus actually performs instructions.

The various functional blocks are described in detail in the following sections. A logic diagram and PAL DESIGN SPECIFICATION for each PAL used in this design appear in Appendix C.

## ALU AND REGISTER FILE

The logic diagram of the ALU and register file is shown in Figure 4. It is implemented with four 4-bit slice Am29203 bipolar microprocessors and one Am2902A high speed lookahead carry generator. A block diagram of the Am29203 appears in Figure 5. The Am29203s were chosen because their internal three bus architecture, two-port register file, ALU, ease of control from microcode, and high speed fit ideally into the design.

The three internal buses of the Am29203 interface directly to the three internal buses of the system (see Figure 1) via I/O pins on the device. The A port of the Am29203's register file is gated onto the RBUS by the signal OEA, the B port of the register file is gated onto the SBUS by $\overline{O E B}$, and the ALU output is gated onto the YBUS by $\overline{\mathrm{OEY}}$. Each of the control signals comes directly from microcode.

The two-port register file of the Am29203 allows reading both source and destination operands from the register file and writing an operation result into the destination in a single cycle. This capability is a necessity for performing the execution cycle of an instruction in a single CPU cycle. The source and destination registers are addressed on the A and B address inputs by the value register (explained later). Writing an operation result to the destination register is controlled by the microcode signal WR REG.

The ALU in the Am29203 is controlled directly from microcode on the instruction inputs (INST(8:0)) and by the INSTEN input. The ALU performs all arithmetic and logical operations specified in the Berkeley-1 Plus architecture except the single state barrel shift. The single state barrel shift is performed in PALs (explained later). In addition, the Am29203 has capabilities such as BCD arithmetic, multiply and divide not specified by the Berkeley-1, but which could be added to the system by simply rewriting some of the microcode.

## BARREL SHIFTER

The barrel shifter is an excellent example of the trade-off between minimal implementation and performance. One easy implementation is to use the single bit shifter already present inside the Am29203. Unfortunately, a shift of fifteen bits would take fifteen CPU cycles. This is an acceptable level of performance only in machines that require a minimum amount of shift capability. Another alternative is to implement a barrel shifter which can perform a shift of any arbitrary number of bits in a single cycle. This alternative, although high in performance, can be complex to implement. An MSI solution would require the use of sixteen Am25S10 shifters. Another question is where to put the shifter; following the ALU or in parallel with the ALU. If the barrel shifter is implemented following the ALU, every operation must pass
through the ALU and the shifter resulting in a long delay. This is clearly unacceptable in a system where speed is the critical factor. In parallel, the delay is small but extra hardware is necessary to calculate the zero condition code which can no longer be calculated in the ALU. This is not a trivial task because condition codes must be calculated in parallel with the shift to maintain speed and therefore it is conditional which data bits affect the condition codes! (In MSI, this would require an additional barrel shifter forzero calculation.) In addition, hardware (two Am25LS244s) is required to gate the proper source, ALU or barrel shifter, onto the YBUS.

The Berkeley- 1 uses eight AmPAL16H8As to implement the barrel shifter in parallel with the ALU for the highest performance while maintaining a reasonable parts count. In addition, the barrel shifter PALs perform condition code calculation on the data and can be gated onto the YBUS. The barrel shifter is shown in Figure 6. The implementation is in two levels; the first is the nibble shifter and the second is the bit shifter. The nibble shifter performs a shift of $0,4,8$, or 12 bits based on the upper two bits of the four-bit shift distance (RBUS(3:2)). The nibble shifter also performs the zero condition code calculation based upon all four shift distance bits (RBUS(3:0)), the data (SBUS(15:0)), and the microcode control inputs INST(0) and SHIFTERIALU. The second level is the bit shifter which performs a right or left bit shift of $0,1,2$, or 3 places controlled by the lower two bits of the shift distance (RBUS(1:0)) and the microcode input SHRISHL. In addition, the SHIFTERIALU input controls the gating of the bit shifter onto the YBUS.

## INSTRUCTION REGISTER

The instruction register (IR) is a good example of how PALs can be used to optimize a common function. An instruction register is generally used to receive instructions off of the data bus during memory fetch operations. The instruction is then decoded by the control sequencer and the instruction is executed. Any data in the instruction word, such as an immediate value or branch address, is operated on during the execution cycle. The Berkeley-1 instruction register performs the same function as well but in a special manner. Instruction information used during the decoding cycle is separated from information used during execution cycle. This allows the IR to predecode instructions on-the-fly from sixteen bits down to ten bits as they are received off of the data bus without losing data in the instruction word. The result is a significant increase in control sequencer speed.

The instruction register can be seen in Figure 7. The IR is implemented with two AmPAL16R8As and one Am29825 8-bit register. The microcode input CEIR when low enables instructions to be clocked into the IR. The full instruction register is 22 bits wide. This includes the 10 -bit field (MAP ADR(9:0)) of predecoded instruction information and a 12 -bit field (IR(11:0)) of data information.

Predecoding of the instruction from sixteen bits down to ten is accomplished by encoding the SOURCEOP and DESTOP fields down from six bits each to three bits each.






Notes: 1. $\mathrm{DA}_{0-3}$ is input only on Am2903, but is I/O port on Am29203.
2. On Am2903, zero logic is connected to $Y$, after the $\overline{\mathrm{OE}}_{\mathrm{Y}}$ buffer.
3. On Am2903, IEN controls WRITE. On Am29203 WRITE is not affected by IEN.

Figure 5. Block Diagram



Each three-bit field contains a value for one of the seven addressing modes or a value stating an illegal mode was chosen.

| MODE | VALUE |
| :--- | :---: |
| Absolute | 000 |
| SP Auto-Increment | 001 |
| SP Auto-decrement | 010 |
| Short Immediate | 011 |
| Register | 100 |
| Register Indirect | 101 |
| Register Indexed | 110 |
| Illegal | 111 |

The MAP ADR(9:0) outputs are sent directly to the address inputs of the 1 K mapping PROMs in the control sequencer.
The data field ( $\operatorname{IR}(11: 0)$ ) is simply the lower twelve bits of the instruction word (i.e., everything but the opcode). IR(11:0) are sent directly to the value register. Notice that all 22 bits of the IR are always on and no three-state control is necessary.

## VALUE REGISTER AND DECREMENT REGISTER

The value register is used to contain the instruction information, such as a conditional branch address, immediate data values, and/or register file addresses, necessary for the execution cycle. The value register is required to support the double-pipelined architecture implemented. For example, during a typical double-pipelined cycle where instruction $n$ is being fetched from memory and instruction $n-1$ is in the IR and being decoded, instruction $n-2$ is being executed. Without the value register the information necessary to execute instruction $n-2$ would be lost. This register is the prinicipal additional hardware required to implement double-pipelining. The value register, along with the decrement register, also controls all of the addressing required for the register file.

The value register is implemented using three identically programmed AmPAL16R6As and the decrement register is implemented using a single AmPAL16R4A. Both can be seen in Figure 7. The microcode input CEVR when low enables data to be clocked into the value register. The value register provides data information on the $\operatorname{VR}(11: 0)$ outputs, the $A$ address for the register file on the A ADR(2:0) outputs, and the B address on the $\operatorname{BADR}(2: 0)$ outputs. $\operatorname{VR}(11: 0)$ is simply $\operatorname{IR}(11: 0)$ delayed by one clock cycle.

Register $A$ and $B$ address selection is controlled by the RFAR SEL(3:0) inputs from microcode. The address selection combinations on the A address include the SOURCEREG(2:0) field (obtained from the IR or VR) and a HOLD mode. The address selection combinations on the B address include the DESTREG(2:0) field, SOURCEREG(2:0) field, decrement register, and a HOLD mode. Address selection is obtained from the IR on instructions that are to be executed in the following cycle and from the VR on instructions where multiple operand fetch and instruction execute cycles are necessary. The decrement register is used as an address source for the special LDM and STM instructions (see Appendix A) which require the loading and storing of multiple registers in sequence.
The decrement register is loaded with the address of the first register to be operated on and simply provides sequential addresses of the next registers to be operated on. The decrement register is loaded from the RBUS(2:0) when the register is selected via an immediate or register addressing mode or from the DBUS(2:0) when a memory addressing mode is selected. Loading and decrementing are controlled by the microcode inputs DR SEL(1:0). Additionally, the decrement
register is gated onto the RBUS(2:0) when the microcode in put OERBUS is low to provide the lower three bits so that they can be added as an offset to the memory address where data is to be stored or loaded.

## RBUS CONTROL PALs

The RBUS control PAL logic consists of two AmPAL16H8As and is shown in Figure 8. Their primary function is to perform sign extension for short immediate source operands and to put constant values onto the RBUS. SOURCEOP(4) selects the sign of the short immediate operand. The function is controlled by the microcode signal RBUS SEL. Additionally, they are used to gate zeroes onto the upper thirteen bits of the RBUS when the decrement register is on the lower three bits. This is controlled by the microcode signal OERBUS(15:3). The signal OERBUS(2:0) gates the lower three bits of the PALs onto the RBUS during all other functions.

## CBR AND SBUS CONTROL PALs

The CBR andSBUS control PALlogic is also shown in Figure 8. The primary function of these PALs is to perform all control necessary for execution of the conditional branch instruction (CBR), sign extension for short immediate destination operands (allowed for compare instruction (CMP) only), and constant generation. The CBR control logic is implemented in one AmPAL16R6A. The CBR logic derives a CBR flag dependent upon the true version of all eight branch conditions and which test is being selected. The branch conditions are generated from the four condition codes: zero (Z), minus (N), overflow (V), and carry (C). The condition being tested is selected by VR(10:8). The $Z$ and $N$ condition codes are loaded in the CBR PAL by the LOADZN microcode signal and the C and V condition codes are loaded by the LOADCV signal. The CBR flag is sent directly to the SBUS control PALs.

The SBUS control PALs are implemented using two AmPAL16H8As. The function performed by these PALs is controlled by microcode inputs SBUS SEL(1:0) and gating of data onto the SBUS is controlled by the OESBUS input. When a CBR instruction is selected, a sign extended branch offset relative to the $\operatorname{PC}$ is derived from $\operatorname{VR}(9: 0)$ and gated onto the SBUS dependent upon the CBR flag and the true/false test polarity select (VR(11)). When high, the test polarity select initiates a branch when the CBR flag is also high (true), and when low it initiates a branch when the CBR flag is also low (false). Should the branch condition not be met the value - 1 is added to the PC preventing a branch.

## PROGRAM COUNTER

The program counter is an excellent example of how PAL. are used in this design to implement data steering. The PC is shown in Figure 9. It is implemented using four identically programmed AmPAL16R4As and one AmPAL16H8A. The PC is basically implemented as an incrementing register that can be parallel loaded from the YBUS. The inherent problem with the PC is that it must source both the ABUS for memory fetch operations and the RBUS for relative branch calculations. Unfortunately, a typical MSI device cannot drive two separate buses because they are not designed with multiple three-state outputs. This can lead to the need to add separate three-state controls for each bus (four AM25LS244s) and unnecessary added delay in the memory path. The PC PALs are designed to provide multiple outputs thus saving ICs and delay time in the critical memory path.



Microcode inputs PC SEL(1:0) select the function to be performed by the PC. The $\overline{O E P C R}$ and $\overline{O E P C A}$ inputs control whether the PC is to drive the RBUS or the ABUS, respectively. The PC CARRY IN signal is used to force incremention of the PC. Additionally, the PC internally generates the vector addresses necessary for initialization, illegal instruction traps and interrupts.

## MEMORY ADDRESS REGISTER

Thememory address register(MAR) is primarily used for fetching of memory source and destination operands, and storing operation results in the memory destination. The MAR is implemented with four AmPAL16R4As and is shown in Figure 10. Memory address register functions are controlled by the MARSEL(1:0) inputs. The MAR is gated onto the ABUS when the microcode input $\overline{\text { OEMAR }}$ is low. Note that the MAR also has the capability to decrement, which is necessary to support the special LDM and STM instructions.

## MEMORY DATA REGISTER 1

Memory data register $1\left(\mathrm{MDR}_{1}\right)$ is another excellent example of PALs facilitating data steering functions in the Berkeley-1. $\mathrm{MDR}_{1}$ is used for $1 / \mathrm{O}$ operations between the CPU and memory requiring multiple input and output paths. It is im. plemented with four AmPAL16R4As and can also be seen in Figure 10. MDR ${ }_{1}$ is loaded from the DBUS when the LOAD SEL input is high and the $\overline{\mathrm{CEMDR}}{ }_{1}$ input is low (enabled), and is loaded from the YBUS when LOAD SEL is low and $\overline{\mathrm{CEMDR}}{ }_{1}$ is enabled. Additionally, MDR ${ }_{1}$ is gated onto the RBUS by $\overline{\mathrm{OE} \mathrm{MDR}_{1} \mathrm{R}}$ and onto the DBUS by OE MDR $\mathrm{D}_{1} \mathrm{D}$.

## MEMORY DATA REGISTER 2

Memory data register $2\left(\mathrm{MDR}_{2}\right)$ provides an additional data path from memory into the CPU. It is implemented wth two Am29823 high speed 8 -bit registers. It is loaded by the $\overline{C E}$ ${\overline{\mathrm{MDR}_{2}} \text { input and gated onto the SBUS by the } \overline{\mathrm{OEMDR}} 2 \text { input. }}^{\text {in }}$ $\mathrm{MDR}_{2}$ is primarily used to fetch memory destination operands.

## THE CONTROL SEQUENCER

The control of the CPU is performed by an exceptionally fast (105ns worst case cycle time), pipelined, microprogrammed sequencer that is comprised of only 17 chips. The operation of the sequencer is very straightforward. After initialization ( $\mathrm{PC}-0$ ), the first instruction is fetched. The instruction is decoded and the microprogram branches to a specific sequence of states to fetch the operands or begin execution (for instructions that don't require operands). The starting microprogram PROM address of this sequence of states is given by the Instruction Mapping PROMs. The pipeline register is then successively loaded with the microinstruction corresponding to each state in the sequence and the instruction is "executed." When the execution of the current instruction is complete, the next instruction is fetched (if not already done during the execution of the previous instruction), decoded, and executed. This cycle repeats for every instruction.
The sequencer and its operation will now be separated into three sections and examined in greater detail.

## INSTRUCTION DECODE

The Instruction Register (IR) is composed of three chips; two AmPAL16R8As and one Am29825. The PALs are used to decode the source and destination addressing modes of the instruction prior to actually being loaded into the IR. The main advantages of this "predecode" are:

1) the number of address bits needed for the Instruction Mapping PROMs is reduced, thus reducing PROM space required.
2) sequencer cycle time is improved.

The 6-bit source and destination fields are both reduced to 3 -bit fields, which is all that is necessary since there are only seven different addressing modes. These two 3 -bit fields, along with the four opcode bits, form the 10-bit address to the Instruction Mapping PROMs, IMAP 1 and $\operatorname{IMAP}{ }_{2}$. Both IMAP $_{1}$ and $I \mathrm{MAP}_{2}$ use these ten bits to determine the microprogram PROM address needed to begin operand fetches and instruction executions. $1 \mathrm{MAP}_{1}$ is used to generate the initial microprogram PROM addresses for all operand fetches and for the execution of instructions that don't require operands (e.g., CALL). $\mathrm{IMAP}_{2}$ generates the initial microprogram PROM addresses for the execution of instructions that require operand fetches. Addresses generated by IMAP ${ }_{2}$ are loaded into an Am29825, which is an 8 -bit register with a clock enable and three-statable outputs. This step is necessary because the IR is often overwritten with the next instruction (instruction prefetching) and the address from $I M A P_{2}$ is not used until the operands have been fetched and execution is to begin. This is not required of $I M A P_{1}$ because the addresses it generates are always used immediately.

## NEXT MICROPROGRAM ADDRESS SELECTION

There are four sources from which the next address for the microprogram PROM can come. These are IMAP,$I M A P_{2}$ and two microprogram PROMs. As previously mentioned, IMAP ${ }_{1}$ contains the addresses needed to begin operand fetch cycles or instruction execution cycles, and $\mathrm{IMAP}_{2}$ contains initial microprogram addresses for instruction execution cycles only. Both of the microprogram PROMs contain next state addresses for these cycles to complete.
One AmPAL16R6A is used to select which one of the four sources will provide the next microprogram PROM address. Inputs to this microbranch control PAL consist of three bits from microcode, the outputs of the decrement counter ( 3 bits), and two bits for interrupt control. There are four outputs, which control the three-state drivers of the four address sources.
The three bits from microcode are used to select the conditions which must be considered for microbranching (e.g., unconditional, DECREMENT COUNTER $=0$ ?, INTERRUPT? and INTERRUPTS ENABLED?). The PAL decodes these conditions and selects the proper source for the next state address. The PAL's function table is shown in Appendix C along with the other PAL DESIGN SPECIFICATIONS.

## MICROPROGRAM MEMORY

The microcode for the Berkeley-1 Plus resides in eight Am27S25 $512 \times 8$ registered PROMs and one Am27S29512 88 PROM. The latter PROM is used in conjunction with a AmPAL16R6A to generate the next microprogram address as explained above. The entire sequencer is shown in Figure 11.

## CONCLUSION

The PAL implementation of the Berkeley-1 Plus results in a truly high performance 16 -bit CPU. Functions such as the barrel shifter and double-pipelining control are not feasibly implemented in standard SSI/MSI devices. Specialized functions such as LDM and STM are application dependent and therefore not easily optimized in LSI implementations either. The flexibility of PALs makes these functions easy to optimize, resulting in the high performance design shown.


Figure 10. Memory Data Registers 1 and 2 and Memory Address Register


## APPENDIX A

Instruction Set and Addressing Modes

## INSTRUCTION SET



CONDITIONAL BRANCH INSTRUCTIONS:

| BA Branch (Unconditional) | $0^{080000}{ }_{8}$ plus 8-bit OFFSET | PC - PC + OFFSET | N : unaffected <br> $Z$ : unaffected <br> V: unaffected <br> C: unaffected |
| :---: | :---: | :---: | :---: |
| BEQ <br> Branch if equal (to zero) | $\mathrm{OBO400}_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & \text { PC-PC }+ \text { OFFSET } \\ & \text { if } Z=1 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V: unaffected <br> C : unaffected |
| BMI Branch if minus | 081000 plus 8 -bit OFFSET | $\begin{aligned} & P C-P C+O F F S E T \\ & \text { if } N=1 \end{aligned}$ | N : unaffected <br> $Z$ : unaffected <br> $V$ : unaffected <br> C: unaffected |

INSTRUCTION SET (Continued)

| Mnemonic/ instruction | OPCode | Operation | Condition Codes |
| :---: | :---: | :---: | :---: |
| BCS Branch if carry set | $\mathrm{OB1400}_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & \mathrm{PC}-\mathrm{PC}+\mathrm{OFFSET} \\ & \text { if } \mathrm{C}=1 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V : unaffected <br> C: unaffected |
| BVS <br> Branch if <br> $V$ bit set | $082000_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & \mathrm{PC} \curvearrowleft \mathrm{PC}+\mathrm{OFFSET} \\ & \text { if } \mathrm{V}=1 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V : unaffected <br> C: unaffected |
| BLT <br> Branch if less than | $\begin{aligned} & 082400_{8} \\ & \text { plus } 8 \text {-bit } \\ & \text { OFFSET } \end{aligned}$ | $\begin{aligned} & P C-P C+O F F S E T \\ & \text { if } N \nvdash V=1 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V: unaffected <br> C: unaffected |
| BLE <br> Branch if less than or equal to | $083000_{8}$ <br> plus 8 -bit <br> OFFSET | $\begin{aligned} & \text { PC-PC }+\mathrm{OFFSET} \\ & \text { if }(\mathrm{Z}) \mathrm{V}(\mathrm{~N} \forall V)=1 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V: unaffected <br> C: unaffected |
| BLOS <br> Branch if lower or same | $083400_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & \mathrm{PC} \leftarrow \mathrm{PC}+\mathrm{OFFSET} \\ & \text { if } \mathrm{NVZ}=1 \end{aligned}$ | $N$ : unaffected <br> Z: unaffected <br> V : unaffected <br> C: unaffected |
| NOP <br> No Operation | $084000_{8}$ plus 8 -bits of Don't Care | $P C-P C+1$ | N : unaffected <br> $Z$ : unaffected <br> V : unaffected <br> C: unaffected |
| BNE <br> Branch if not equal | $0^{084400}{ }_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & \mathrm{PC}-\mathrm{PC}+\mathrm{OFFSET} \\ & \text { if } \mathrm{Z}=0 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V: unaffected <br> $C$ : unaffected |
| BHIS <br> Branch if higher than or same | $085000_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & \mathrm{PC}-\mathrm{PC}+\mathrm{OFFSET} \\ & \text { If } \mathrm{N}=0 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V: unaffected <br> C: unaffected |
| BCC Branch if carry clear | $085400_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & \mathrm{PC}-\mathrm{PC}+\mathrm{OFFSET} \\ & \text { if } \mathrm{C}=0 \end{aligned}$ | $N$ : unaffected <br> Z: unaffected <br> V: unaffected <br> C: unaffected |
| BVC <br> Branch if $V$ <br> bit clear | $0^{086000}{ }_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & \mathrm{PC}-\mathrm{PC}+\mathrm{OFFSET} \\ & \text { if } \mathrm{V}=0 \end{aligned}$ | $N$ : unaffected <br> Z: unaffected <br> V: unaffected <br> C: unaffected |
| BGE <br> Branch if greater than or equal | $086400_{\text {B }}$ plus 8 -bit OFFSET | $\begin{aligned} & \mathrm{PC}-\mathrm{PC}+\mathrm{OFFSET} \\ & \text { if } \mathrm{N} \forall V=0 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V: unaffected <br> C: unaffected |
| BGT <br> Branch if greater than | $087000_{8}$ plus 8-bit OFFSET | $\begin{aligned} & \mathrm{PC}-\mathrm{PC}+\mathrm{OFFSET} \\ & \text { if }(\mathrm{Z}) \mathrm{V}(\mathrm{~N} \not \mathrm{~V})=0 \end{aligned}$ | $N$ : unaffected <br> $Z$ : unaffected <br> V: unaffected <br> C: unaffected |
| BHI <br> Branch if higher | $087400_{8}$ plus 8 -bit OFFSET | $\begin{aligned} & P C-P C+O F F S E T \\ & \text { if } N V Z=0 \end{aligned}$ | N : unaffected <br> Z: unaffected <br> V: unaffected <br> C: unaffected |
| MOV <br> Move | $11 S^{\text {S }}$ ( ${ }_{8}$ | (dst)-(src) | $N$ : unaffected <br> Z: unaffected <br> V: unaffected <br> C: unaffected |

## INSTRUCTION SET (Continued)

| Mnemonic/ Instruction | OPCode | 'Operation |
| :---: | :---: | :---: |
| CALL Jump to Subroutine | $12 \mathrm{XXDD}_{8}$ | $\begin{aligned} & \text { MEM[SP-1]-PC } \\ & \text { PC }-d s t \end{aligned}$ |
| RET <br> Return from <br> Subroutine | $13 \times X X X_{8}$ | $\begin{aligned} & P C-M E M[S P] \\ & S P \leftarrow S P+1 \end{aligned}$ |
| LDM <br> Load from <br> Memory | $14 S^{\text {S }}$ ( ${ }_{8}$ | $\begin{aligned} & \text { FOR } i:=0 \text { to } i=s r c \\ & \text { BEGIN } \\ & \text { REG(src }-i)- \text { MEM[dst }+s r c-i] \\ & \text { END } \end{aligned}$ |
| STM <br> Store into Memory | $15 S S D D_{8}$ | $\begin{aligned} & \text { FOR } i:=0 \text { to } i=s r c \\ & \text { BEGIN } \\ & \text { MEM[dst + src }-i]- \text { REG(src }-i) \\ & \text { END } \end{aligned}$ |
| INTENB <br> Enable or Disable Interrupts | $15 X^{2} X_{0}$ <br> to disable <br> 16 XXX1 $_{8}$ <br> to enable | INT ENB FLAG-IR ${ }_{0}$ |
| JUMP Jump | $17 \times X D_{8}$ | PC-dst |

## Condition Codes

N : unaffected
Z: unaffected
V : unaffected
C: unaffected
N : unaffected
Z: unaffected
V: unaffected
C: unaffected
N : unaffected
Z: unaffected
V: unaffected
C: unaffected
N : unaffected
Z: unaffected
V: unaffected
C: unaffected
N : unaffected
Z: unaffected
V: unaffected
C: unaffected
$N$ : unaffected
$Z$ : unaffected
V: unaffected
C: unaffected

## ADDRESSING MODES



## APPENDIX B

Critical Path Analysis

## CRITICAL PATH ANALYSIS SEQUENCER



03862A-144


## CRITICAL PATH ANALYSIS FOR BERKELEY-1 PLUS SEQUENCER

## Path 1:

| tco | IR AmPAL16R8A | 15ns |
| :--- | :--- | ---: |
| tAA | IMAP1 | 35 ns |
|  | Am27S281A |  |
| ts | $\mu$ Program PROM <br> Am27S25A | 30 ns |
|  |  |  |
|  |  | 80 ns |

## Path 4:

| tco | $\mu$ Branch PAL AmPAL16R6A | 15ns |
| :---: | :---: | :---: |
| tpzx | $\begin{aligned} & \text { IMAP }_{1} \\ & \text { Am27S281A } \end{aligned}$ | $25 n s$ |
| $t_{A A}$ | ${ }_{\mu}$ Program PROM Am27S29A | 35 ns |
| ts | ${ }_{\mu}$ Branch PAL AmPAL16R6A | 20 ns |

## Path 2:

| tco | IR AmPAL16R8A | 15ns |
| :--- | :--- | ---: |
| taA | IMAP2 | 35 ns |
|  | Am27S281A |  |
| ts | Execution <br> Decode REG <br>  | Am29825 |

Path 3:
Path 5:

| tco | $\mu$ Branch PAL <br> AmPAL16R6A | 15ns |
| :--- | :--- | :--- |
| tPZX | $\mu$ Program PROM <br> next $\mu$ ADDRESS | 25ns |
| taA | Am27S25A |  |
| ts | $\mu$ Program PROM <br> Am27S29A <br> $\mu$ Branch PAL <br> AmPAL16R6A | 35ns |

95ns

Path 6:

| tco | $\mu$ Branch PAL AmPAL16R6A | 15ns |
| :---: | :---: | :---: |
| $t_{\text {PZX }}$ | Execution Decode Register Am29825 | 15ns |
| $t_{A A}$ | ${ }_{\mu}$ Program PROM Am27S29A | 35ns |
| $t_{s}$ | ${ }_{\mu}$ Branch PAL AmPAL16R6A | 20ns |

Note: tco $=$ Clock to Output Delay
$t_{A A}=$ Access Time delay
ts = Set-Up time
tPZX = Output Enable delay

## CRITICAL PATH ANALYSIS FOR BERKELEY-1 PLUS CPU

## INSTRUCTION ADD

Path 1:

| tco $\quad$ VR AmPAL16R6A | 15 ns |  |
| :--- | ---: | ---: |
| ADR to $\overline{P_{1}}, \overline{G_{i}}$ of Am29203 | 52 ns |  |
| $\overline{P_{i}}, \bar{G}_{1}$ to $C_{n}+z$ of Am2902A | 9ns |  |
| $C_{n}$ to $C_{n}+4$ of Am29203 | 18 ns |  |
| ts $\quad$ CBR Control PAL | 20 ns |  |
|  | AmPAL16R6A |  |
|  |  | 114 ns |

5 ns
9 ns
18 ns
20 ns
114ns

## Path 4:

| tco | ${ }_{\mu}$ Program PROM Am27S25A | 25ns |
| :---: | :---: | :---: |
| Ito Y of Am29203 |  | 64ns ${ }^{\text {' }}$ |
| ts | Destination (PALs) | 20ns |

Path 5:

Path 2:

| tco | $\mu$ Program PROM Am27S25A | 25ns |
| :---: | :---: | :---: |
| Ito $\overline{P_{i}}, \overline{G_{i}}$ of Am29203 |  | 50ns |
| $\overline{P_{i}}, \bar{G}_{i}$ to $\mathrm{C}_{\mathrm{n}+2}$ of $\mathrm{Am}^{\text {a }}$ 2902A |  | 9 ns |
| $\mathrm{C}_{\mathrm{n}}$ to $\mathrm{C}_{\mathrm{n}+4}$ of $\mathrm{Am}^{\text {29203 }}$ |  | 18ns |
| ts | CBR Control PAL AmPAL16R6A | 20ns |

122ns

| tco | VR AmPAL16R6A | 15 ns |
| :--- | :--- | ---: |
| $t_{p d}$ | RBUS Control PALs | 25 ns |
| AmPAL16H8A |  |  |
| DA or DB to $\overline{P_{i}}, \overline{G_{l}}$ of Am29203 |  |  |
| $\overline{P_{i}}, \overline{G_{i}}$ to $C_{n+z}$ of Am2902A | 44 ns |  |
| $C_{n}$ to $C_{n}+4$ of Am29203 | 9 ns |  |
| ts $\quad$ CBR Control PAL | 18 ns |  |
|  | AmPAL16R6A | 20 ns |
|  |  |  |

## Path 6:

| tco | VR AmPAL16R6A | 15ns |
| :---: | :---: | :---: |
| $t_{p d}$ | RBUS Control PALs AmPAL16H8A | 25ns |
| DAo | O Y of Am29203 | 59ns |
| ts | Destination (PALs) | 20ns |



03862A-148
Register-to-Register ADD

## CRITICAL PATH ANALYSIS FOR BERKELEY-1 PLUS CPU (Continued)

## INSTRUCTION SHIFT:

## Path 1:

| tco | VR AmPAL16R6A | 15 ns |
| :--- | :---: | ---: |
| A or B ADR to DA or DB of Am29203 | 24 ns |  |
| $t_{\text {pd }}$ | Barrel Shifter | 50 ns |
| ts | Y to RAM of Am29203 | 16 ns |

## Path 2:

| $t_{c o}$ | VR AmPAL16R6A | 15 ns |
| :--- | :--- | ---: |
| $t_{\text {pd }}$ | RBUS PALs | 25 ns |
| $t_{p d}$ | Barrel Shifter | 50 ns |
| $t_{s}$ | $Y$ to RAM of Am29203 | 16 ns |

## Path 3:

| tco | VRAmPAL16R6A | 15 ns |
| :--- | :--- | ---: |
| $t_{\text {pd }}$ | RBUS PALs | 25 ns |
| $t_{\text {pd }}$ | Barrel Shifter | 50 ns |
| ts | MDR $_{1}$ | 20 ns |
|  | $A m P A L 16 R 4 A$ |  |
|  |  | 110 ns |



Immediate Source, Register Destination Shift

## CRITICAL PATH ANALYSIS FOR BERKELEY-1 PLUS CPU (Continued)

## MEMORY ACCESS:

Indexed:

| tco $\quad$ VR AmPAL16R6A | 15 ns |  |
| :--- | :---: | ---: |
| ADR to $Y$ of Am29203 | 68 ns |  |
| ts $\quad$ MAR | 20 ns |  |
|  | AmPAL16R4A |  |


| tco | $\mu$ Program PROM Am27S25A | 25ns |
| :---: | :---: | :---: |
| tpzX | $\begin{aligned} & \mathrm{MDR}_{2} \\ & \text { Ami29823 } \end{aligned}$ | 15ns |
| DB to Y of Am29203 |  | 59 ns |
| ts | MAR <br> AmPAL16R4A | 20ns |

Indirect:


## APPENDIX C

PAL Design Specifications

PAL16H8
PAT023
BIT SHIFTER
ADVANCED MICRO DEVICES
I0 I1 I2 I3 I4 I5 I6 I7 I8 GND
I9 YO Y1 OE SRNSL R0 R1 Y2 Y3 VCC
;BIT SHIFTER OUTPUT SIGNALS

| IF (OE) | Y3 | $=/ \mathrm{RI} 1 * / \mathrm{R} 0 * \mathrm{I} 6$ |
| :---: | :---: | :---: |
|  |  | /R1* R0* SRNSL*I7 |
|  |  | R1*/RO* SRNSL*I8 |
|  |  | R1* RO* SRNSL*I9 |
|  |  | /R1* R0*/SRNSL*I5 |
|  |  | R1*/R0*/SRNSL*I4 |
|  |  | R1* R0*/SRNSL*I3 |
| IF (OE) | Y2 | $=/ \mathrm{R} 1 * / \mathrm{R} 0 * \mathrm{I} 5$ |
|  |  | /R1* R0* SRNSL*I6 |
|  |  | R1*/R0* SRNSL*I7 |
|  |  | R1* RO* SRNSL*I8 |
|  |  | /R1* R0*/SRNSL*I4 |
|  |  | R1*/RO*/SRNSL*I3 |
|  |  | R1* RO*/SRNSL*I2 |
| IF (OE) | Y1 | $=/ \mathrm{Rl}$ \% $/ \mathrm{RO} 0 \mathrm{I} 4$ |
|  |  | /R1* R0* SRNSL*I5 |
|  |  | R1*/RO* SRNSL*I6 |
|  |  | R1* RO* SRNSL*I7 |
|  |  | /R1* R0*/SRNSL*I3 |
|  |  | R1*/RO*/SRNSL*I2 |
|  |  | R1* RO*/SRNSL*I1 |
| IF (OE) | YO | $=/ \mathrm{R} 1 * / \mathrm{RO} * \mathrm{I} 3$ |
|  |  | /R1* R0* SRNSL*I4 |
|  |  | R1*/R0* SRNSL*I5 |
|  |  | R1* RO* SRNSL*I6 |
|  |  | /R1* R0*/SRNSL*I2 |
|  |  | R1*/RO*/SRNSL*I1 |
|  |  | R1* R0*/SRNSL*I0 |

JEFF KITSON 10/4/82

FUNCTION TABLE
I0 I1 I2 I3 I4 I5 I6 I7 I8 I9 OE SRNSL R1 R0
Y0 Y1 Y2 Y3
;SHIFT ZERO

| H | H H L | L L | H | H | H | L | H | H | L | L | L | L |  | H |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | H H L | L L | H | H | H | L | H | L | L | L | L | L | L | H |
| ; SHIFT ONE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| H | H H L L | L L | H | H | H | L | H | H | L | H | L | L | H | H |
| H | H H L | L L | H | H | H | L | H | L | L | H | H | L | L | L |
| ;SHIFTIWO |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| H | H H L | L L | H | H | H | L | H | H | H | L | L | H | H | H |
| H | H H L L | L L | H | H | H | L | H | L | H | L | H | H | L | L |
| ;SHIFT THREE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| H | H H L L | L L | H | H | H | L | H | H | H | H | H | H | H | L |
| H | H $\quad \mathrm{H} \quad \mathrm{L}$ | L L | H | H | H | L | H | L | H | H | H | H | H | L |

DESCRIPTION
THE SECOND LEVEL OF THE BARREL SHIFTER IS THE BIT SHIFTER PERFORMS A RIGHT OR LEFT SHIFT OF $0,1,2$ OR 3 PLACES, WHICH IS CONTROLLED BY THE LOWER TWO BITS OF THE RBUS, I.E. RBUS $\langle 1: 0\rangle$. THE SHR/SHL SIGNAL CONTROLS THE DIRECTION OF THE SHIFT. THE SHIFTER/ALU SIGNAL CONTROLS THE GATING OF THE SHIFTER ONTO THE YBUS. THIS FOUR INPUT AND FOUR OUTPUT PAL SLICE IS CASCADED TO IMPLEMENT A 16-BIT SHIFTER.

PAL16H8
PAT023
BIT SHIFTER
ADVANCED MICRO DEVICES
*D9725
*FO*
L0000 11111111111111111111110111111111 *
L0032 11111111111011101111011111111111 *
L0064 11111111111011011101111101111111 *
L0096 11111111110111101101111111110111 *
L0128 11111111110111011101111111111101 *
L0160 11111111111011010110111111111111 *
LO192 11111111110101101110111111111111 *
L0224 11111111010111011110111111111111 *
L0256 11111111111111111111110111111111 *
L0288 11111111111011100111111111111111 *
L0320 11111111111011011101011111111111 *
L0352 11111111110111101101111101111111 *
L0384 11111111110111011101111111110111 *
L0416 11111111111001011110111111111111 *
L0448 11111111010111101110111111111111 *
L0480 11110111110111011110111111111111 *
L1536 11111111111111111111110111111111 *
L1568 11111111111001101111111111111111 *
L1600 11111111111011010101111111111111 *
L1632 11111111110111101101011111111111 *
L1664 11111111110111011101111101111111 *
L1696 11111111011011011110111111111111 *
L1728 11110111110111101110111111111111 *
L1760 01111111110111011110111111111111 *
L1792 11111111111111111111110111111111 *
L1824 11111111011011101111111111111111 *
L1856 11111111111001011101111111111111 *
L1888 11111111110111100101111111111111 *
L1920 11111111110111011101011111111111 *
L1952 11110111111011011110111111111111 *
L1984 01111111110111101110111111111111 *
L2016 11011111110111011110111111111111 *
C722F*
V0001 11100011100LL1100LH1 *
V0002 11100011100LL1000LH1 **
V0003 11100011100 LL 1110 HH 1 *
V0004 11100011100HL1010LL1 *
V0005 11100011100LH1101HH1 *
V0006 11100011100 HH 1001 LL 1 *
V0007 11100011100 HH 1111 HL 1 *
V0008 11100011100HH1011HL1 *
79AF

PAL DESIGN SPECIFICATION JEFF KITSON 10/4/82


PAL16H8
PAT024
NIBBLE SHIFTER A
ADVANCED MICRO DEVICES
S4 S3 S2 S1 S0 R3 R2 R1 R0 GND OE NC SRNSL IO I1 I2 I3 ZOE Z VCC
;NIBBLE SHIFTER A OUTPUTS
$\mathrm{IF}\left(\mathrm{OE}^{*} \mathrm{ZOE}\right) \mathrm{Z}=\mathrm{ZOE} / \mathrm{ZOE}$
ZOE $=/$ SRNSL* $^{*} /$ R $^{*} \mathrm{RO}^{*}$
I1

$$
+
$$

PAL DESIGN SPECIFICATION JENNY YEE

10/4/82

I3 $=$ SRNSL* S2*/R3* R2 SRNSL* S1* R3* R2 SRNSL* SO* R3* R2
/SRNSL* S4*/R3* R2 /SRNSL* S4* R3*/R2

I2
$=$ SRNSL* S1*/R3* R2
SRNSL* SO* R3*/R2
/SRNSL* S3*/R3* R2
/SRNSL* S4* R3*/R2
/SRNSL* S4* R3* R2
S2*/R3*/R2

I1. $=$ SRNSL* SO*/R3*R2 /SRNSL* S2*/R3* R2 /SRNSL* S3* R3*/R2 /SRNSL* S4* R3* R2
S1*/R3*/R2
IO $=/$ SRNSL* S1*/R3* R2 /SRNSL* S2* R3*/R2 /SRNSL* $\begin{array}{r}\text { S3* R3* R2 } \\ \text { SO }^{*} / \text { R3 }^{*} / \mathrm{R} 2\end{array}$


FUNCTION TABLE

| S4 S3 S2 S1 S0 | R3 R2 R1 R0 | SRNSL | OE |  |  | I1 | IO | 20E | Z |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ;SHIFT ZERO |  |  |  |  |  |  |  |  |  |
| $\begin{array}{lllllll}\text { L } & \mathrm{H} & \mathrm{H} & \mathrm{H} & \mathrm{L}\end{array}$ | L L L L L | H | H | H | H | H | L | H | L |
|  | L L L $\quad \mathrm{L}$ | L | H | H | H | H | L | H | L |
| ;SHIFT ONE |  |  |  |  |  |  |  |  |  |
| $\begin{array}{llllll}\mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{H}\end{array}$ | $\begin{array}{lllll}\text { L } & \mathrm{H} & \mathrm{L} & \mathrm{H}\end{array}$ | H | H | L | H | H | L | H | L |
| $\begin{array}{llllll}\text { L } & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{H}\end{array}$ | L $\quad \mathrm{H} \quad \mathrm{L} \quad \mathrm{H}$ | L | H | L | H | L | H | H | L |
| ;SHIFT TWO L |  |  |  |  |  |  |  |  |  |
| $\begin{array}{lllllll}\text { L } & \mathrm{H} & \mathrm{H} & \mathrm{L} & \mathrm{L}\end{array}$ | H L $\quad \mathrm{H}$ L | H | H | L | L | L | L | L | Z |
|  | H L H L | L | H | L | L | H | H | H | L |
| ; SHIFT THREE |  |  |  |  |  |  |  |  |  |
| $\begin{array}{llllll}\mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{H}\end{array}$ | $\begin{array}{lllll}\mathrm{H} & \mathrm{H} & \mathrm{H} & \mathrm{H}\end{array}$ | H | H | H | L | L | L | L | Z |
| L H L H H | H $\quad \mathrm{H} \quad \mathrm{H} \quad \mathrm{H}$ | L | H | L | L | L | H | H | L |

## DESCRIPTION

THE NIBBLE SHIFTER IS IMPLEMENTED USING FOUR AMPAL16H8AS. IT PERFORMS A SHIFT OF $0,4,8$ OR 12 BITS. THE NUMBER OF SHIFTS IS DEPENDENT UPON THE UPPER TWO BITS OF THE FOUR BIT SHIFT DISTANCE, RBUS<3:2>. ZERO CONDITION CODE CALCULATION IS PERFORMED USING ALL FOUR SHIFT DISTANCE BITS, RBUS $\langle 3: 0\rangle$. SHIFT DIRECTION IS DETERMINED BY SHR/SHL. DATA INPUTS ARE SBUS<15:0>. NIBBLE SHIFTER A USES INPUTS SBUS $\langle 15,11,7,3\rangle$.

PALI6H8
PATO24
NIBBLE SHIFTER A
ADVANCED MICRO DEVICES
*D9725
*FO*
L0000 11111111111111111111111111111101 * L0032 11111101111111111111111111111111 * L0256 11111111111111111111111111111111 * L0288 11111111110111111111111110100111 * L0320 11111111111111011111111111111111 * L0352 11111111111111111101111111111111 * L0384 11111111111111111111110111111111 * L0512 11111111111111111111111111111111 * L0544 11110111111111111011011111011111 * L0576 11111111011111110111011111011111 * L0608 11111111111101110111011111011111 * L0640 11011111111111111011011111101111 * L0672 11011111111111110111101111101111 * L0704 11011111111111110111011111101111 * L0736 01111111111111111011101111111111 * L0768 11111111111111111111111111111111 * L0800 11111111011111111011011111011111 * L0832 11111111111101110111101111011111 * L0864 01111111111111111011011111101111 * L0896 11011111111111110111101111101111 * L0928 11011111111111110111011111101111 * L0960 111101111111111110111011.11111111 * L1024 11111111111111111111111111111111 * L1056 11111111111101111011011111011111 * L1088 11110111111111111011011111101111 * L1120 01111111111111110111101111101111 * L1152 11011111111111110111011111101111 * L1184 11111111011111111011101111111111 * L1280 11111111111111111111111111111111 * L1312 11111111011111111011011111101111 * L1344 111101111111 1111 0111101111101111 * L1376 01111111111111110111011111101111 * L1408 11111111111101111011101111111111 * C7F31*
V0001 01110000001X1LHHHHH1 * V0002 01110000001 ХOLHHHHH1 * V0003 $01011010101 \times 1 \mathrm{LHHLHH1}$ V0004 01011010101 XOHLHLHH1 V0005 $01100101001 \times 1 L L L L L L 1$ V0006 $01100101001 \times$ XHHLLHH1 V0007 $01011111101 \times 1 L L L H L L 1$ V0008 $01011111101 \times 0 \mathrm{HLLLHH1}$ 8543

PAL DESIGN SPECIFICATION JENNY YEE

10/4/82


PAL16H8
PAT024
NIBBLE SHIFTER B ADVANCED MICRO DEVICES
S4 S3 S2 S1 S0 R3 R2 R1 R0 GND OE NC SRNSL IO I1 I2 I3 ZOE Z VCC
; NIBBLE SHIFTER B OUTPUTS
IF ( $\mathrm{OE}^{*} \mathrm{ZOE}$ ) $\mathrm{Z}=\mathrm{ZOE}^{*} / \mathrm{ZOE}$

ZOE | SRNSL*/R1* | I3 | + |
| ---: | :--- | :--- |
| SRNSL $^{*} / R^{*} 1^{*}$ IO | + |  |
|  | SRNSL*/RO* $^{*}$ IO | + |
|  | I2 | + |

I3 $=$ SRNSL* S2*/R3* R2 SRNSL* S1* R3*/R2 SRNSL* SO* R3* R2 /SRNSL* S4*/R3* R2 /SRNSL* S4* R3*/R2 /SRNSL* S4* R3* R2 S3*/R3*/R2

I2 $=$ SRNSL* S1*/R3* R2 SRNSL* SO* R3*/R2 /SRNSL* S3*/R3* R2 /SRNSL* S4* R3*/R2 /SRNSL* S4* R3* R2 S2*/R3*/R2
$11=$ SRNSL* $^{*}$ SO* $^{*} /$ R3* R2 $^{*}$ /SRNSL* S2*/R3* R2 /SRNSL* S3* R3*/R2 S1*/R3*/R2

$$
\begin{aligned}
& + \\
& + \\
& + \\
& +
\end{aligned}
$$ /SRNSL* S4* R3* R2 +

IO $\quad$ /SRNSL* S1*/R3* R2 + $\begin{array}{ll}\text { /SRNSL* } & \text { S2* R3*/R2 } \\ \text { /SRNSL* } & \text { S3 }^{*} \text { R3* R2 } \\ & S^{*} / \text { R3*/R2 }^{*}\end{array}$

|  | SRNSL* | S1* R3*/R2 |
| :---: | :---: | :---: |
|  | SRNSL* | S0* R3* R2 |
|  | /SRNSL* | S4*/R3* R2 |
|  | /SRNSL* | S4* R3*/R2 |
|  | /SRNSL* | S4* R3* R2 |
|  |  | S3*/R3*/R2 |
| I2 | $=$ SRNSL* | S1*/R3* R2 |
|  | SRNSL* | S0* R3*/R2 |
|  | /SRNSL* | S3*/R3* R2 |
|  | /SRNSL* | S4* R3*/R2 |
|  | /SRNSL* | S4* R3* R2 |
|  |  | S2*/R3*/R2 |

SO*/R3*/R2

PAL DESIGN SPECIFICATION JEFF KITSON 10/4/82

| FUNCTION TABLE |  |  |  |  |  |  |  |  | 1 |  | 20E 2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S4 S3 S2 S1. S0 | R3 R2 R1 R0 |  |  |  | SRNSL OE |  |  |  |  |  |  |  |
| ;SHIFT ZERO |  |  |  |  |  |  |  |  |  |  |  |  |
| $\begin{array}{llllll}\text { L } & \mathrm{H} & \mathrm{H} & \mathrm{H} & \mathrm{L}\end{array}$ | L | L | X | X | H | L | H | H | H | L | H | Z |
| $\begin{array}{lllllll}\mathrm{L} & \mathrm{H} & \mathrm{H} & \mathrm{H} & \mathrm{L}\end{array}$ | L | L | X | X | L | L | H | H | H | L | H | Z |
| ; SHIFT ONE |  |  |  |  |  |  |  |  |  |  |  |  |
| L $\quad \mathrm{H} \quad \mathrm{L}$ H $\quad \mathrm{H}$ | L | H | X | X | H | L | L | H | H | L | H | Z |
| L H L L H H | L | H | X | X | L | L | L | H | L | H | H | Z |
| ;SHIFT TWO |  |  |  |  |  |  |  |  |  |  |  |  |
| L $\quad \mathrm{H} \quad \mathrm{H} \quad \mathrm{L}$ L | H | L | X | X | H | L | L | L | L | L | L | Z |
| L H H H L L | H | L | X | X | L | L | L | L | H | H | H | Z |
| ; SHIFT THREE |  |  |  |  |  |  |  |  |  |  |  |  |
| L $\quad \mathrm{H}$ L | H | H | X | X | H | L | H | L | L | L | H | Z |
| $\begin{array}{lllllll}\text { L } & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{H}\end{array}$ | H | H | X | X | L | L | L | L | L | H | L | Z |

DESCRIPTION
NIBBLE SHIFTER B IS THE SECOND SLICE OF THE SERIES OF FOUR GASCADED NIBBLE SHIFTER PALS. THE FUNCTIONS ARE THE SAME, WITH NIBBLE SHIFTER B USING SBUS $\langle 14,10,6,2\rangle$ AS DATA INPUTS.

PAL16H8
PAT024
NIBBLE SHIFTER B
ADVANCED MICRO DEVICES
*D9725
*F0*
LOOOO 11111111111111111111111111111101 *
L0032 11111101111111111111111111111111 *
L0256 11111111111111111111111111111111 *
L0288 11111111110111111111111110011111 *
L0320 11111111111111111111110110011111 * L0352 11111111111111111111110111011011 * L0384 11111111111111011111111111111111 * L0416 11111111111111111101111111111111 * L0512 11111111111111111111111111111111 * L0544 11110111111111111011011111011111 *
L0576 11111111011111110111101111011111 * L0608 11111111111101110111011111011111 * L0640 11011111111111111011011111101111 * L0672 11011111111111110111101111101111 *
L0704 11011111111111110111011111101111 * L0736 01111111111111111011101111111111 * L0768 11111111111111111111111111111111 * L0800 11111111011111111011011111011111 * L0832 1111111111110111011110111101 1111 * L0864 01111111111111111011011111101111 * L0896 11011111111111110111101111101111 * L0928 11011111111111110111011111101111 * L0960 1111011111111111101110111111 1111* * L1024 11111111111111111111111111111111 * L1056 11111111111101111011011111011111 * L1088 11110111111111111011011111101111 * L1120 01111111111111110111101111101111 * L1152 11011111111111110111011111101111 * L1184 $1111111101111111101110111111-1111$ * L1280 11111111111111111111111111111111 * L1312 11111111011111111011011111101111 * L1344 11110111111111110111101111101111 * L1376 01111111111111110111011111101111 * L1408 11111111111101111011101111111111 * C82C7*
V0001 0111000XX00X1LHHHHZ1 * V0002 0111000XX00XOLHHHZZ1 * V0003 0101101XX00X1LHHLHZ1 * V0004 0101101XX00XOHLHLHZ1 * V0005 0110010xX00x1LLLLLZ1 * V0006 0110010XX00X0HHLLHZ1 * V0007 0101111XX00X1LLLHHZ1 * V0008 $0101111 \times x 00 \times 0 H L L L L Z 1$ $911 F$

PAL DESIGN SPECIFICATION JEFF KITSON 10/4/82

## LOGIC DIAGRAM FOR: <br> NIBBLE SHIFTER B USING AmPAL16H8A

Columns: Inputs (0-31)
Rows: Product Terms (0-63)


PAL16H8
PAT025
NIBBLE SHIFTER C
ADVANCED MICRO DEVICES
S4 S3 S2 S1 S0 R3 R2 R1 R0 GND OE NC SRNSL IO I1 I2 I3 ZOE Z VCC
;NIBBLE SHIFTER C OUTPUTS
IF (OE*ZOE) Z $=$ ZOE*/ZOE

ZOE = | /SRNSL*/R1* | I3 |
| ---: | ---: |
| /SRNSL*/R0* | I3 |
| SRNSL*/R1* | I0 |
|  | I2 |
|  | I1 |

$I 3=$ SRNSL* S2*/R3* R2 SRNSL* S1*R3*/R2 SRNSL* SO* R3* R2 /SRNSL* S4*/R3* R2 /SRNSL* S4* R3*/R2 /SRNSL* S4* R3* R2 S3*/R3*/R2
$\mathrm{I} 2=$ SRNSL* S1*/R3* R2 SRNSL* SO* R3*/R2 /SRNSL* S3*/R3* R2 /SRNSL* S4* R3*/R2 /SRNSL* S4* R3* R2 S2*/R3*/R2
$\mathrm{Il}=$ SRNSL* $\mathrm{SO}^{*} / \mathrm{R} 3 * \mathrm{R} 2$ /SRNSL* S2*/R3*/R2 /SRNSL* S3* R3*/R2 /SRNSL* S4* R3* R2 S1*/R3*/R2

I0 $=/$ SRNSL* ${ }^{*}$ 1 $^{*} /$ R3* R2 /SRNSL* S2* R3*/R2 /SRNSL* S3* R3* R2 SO*/R3*/R2

PAL DESIGN SPECIFICATION JENNY YEE 10/4/82

$$
++++
$$

$$
+
$$

$$
+
$$

$$
+
$$

$$
\begin{aligned}
& + \\
& +
\end{aligned}
$$

$$
\begin{aligned}
& + \\
& +
\end{aligned}
$$

$$
\begin{aligned}
& + \\
& + \\
& + \\
& + \\
& +
\end{aligned}
$$

$$
\begin{aligned}
& + \\
& + \\
& + \\
& +
\end{aligned}
$$

$$
+
$$

$$
+
$$

FUNCTION TABLE
S4 S3 S2 S1 So R3 R2 R1 R0 SRNSL OE I3 I2 I1 IO ZOE Z
; SHIFT ZERO
$\begin{array}{lllllllllllllllll}\text { L } & \text { H } & \text { H } & \text { H } & \text { L } & \text { L } & \text { L } & \text { L } & \text { L } & \text { H } & \text { H } & \text { H } & \text { H } & \text { H } & \text { L } & \text { H } & \text { L } \\ \text { L } & \text { H } & \text { H } & \text { H } & \text { L } & \text { L } & \text { L } & \text { L } & \text { L } & \text { L } & \text { H } & \text { H } & \text { H } & \text { H } & \text { L } & \text { H } & \text { L }\end{array}$ ; SHIFT ONE
$\begin{array}{lllllllllllllllll}\mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{H} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{L}\end{array}$

;SHIFT TWO
$\begin{array}{lllll}\mathrm{L} & \mathrm{H} & \mathrm{H} & \mathrm{L} & \mathrm{L}\end{array}$
$\begin{array}{lllll}\mathrm{L} & \mathrm{H} & \mathrm{H} & \mathrm{L} & \mathrm{L}\end{array}$ ;SHIFT THREE
$\begin{array}{lllllllllllllllll}\text { L } & \text { H } & \text { L } & \text { H } & \text { H } & \text { H } & \text { H } & \text { H } & \text { H } & \text { H } & \text { H } & \text { H } & \text { L } & \text { L } & \text { L } & \text { L } & \text { Z } \\ \text { L } & \text { H } & \text { L } & \text { H } & \text { H } & \text { H } & \text { H } & \text { H } & \text { H } & \text { L } & \text { H } & \text { L } & \text { L } & \text { L } & \text { H } & \text { L } & \text { Z }\end{array}$

DESCRIPTION
NIBBLE SHIFTER C IS THE THIRD SLICE OF THE FOUR CASCADED NIBBLE SHIFTER PALS. AGAIN, THE FUCNTIONS ARE THE SAME, WITH THIS SLICE HAVING DATA INPUTS FROM SBUS $\langle 13,9,5,1\rangle$.

PAL16H8
PAT025
NIBBLE SHIFTER C adVanced micro devices
*D9725
*FO*
LOOOO 11111111111111111111111111111101 * L0032 11111101111111111111111111111111 * L0256 11111111111111111111111111111111 * L0288. 111111111101 1111 1111111110101111 * L0320 11111111110111111111111111101011 * L0352 11111111111111111111110110011111 * L0384 11111111111111011111111111111111 * L0416 11111111111111111101111111111111 * L0512 11111111111111111111111111111111 * L0544 11110111111111111011011111011111 * L0576-1111 1111011111110111101111011111 * L0608 11111111111101110111011111011111 * L0640 11011111111111111011011111101111 * L0672 1101111111111111011110111110 1111.* L0704 11011111111111110111011111101111 L0736 01111111111111111011101111111111 * L0768 11111111111111111111111111111111 * L0800 11111111011111111011011111011111 * L0832 11111111111101110111101111011111 * L0864 01111111111111111011011111101111 * L0896 11011111111111110111101111101111 * L0928 11011111111111110111011111101111 * L0960 11110111111111111011101111111111 * L1024 11111111111111111111111111111111 * L1056 11111111111101111011011111011111 * L1088 11110111111111111011101111101111 L1120 01111111111111110111101111101111 * L1152 11011111111111110111011111101111 * L1184 11111111011111111011101111111111 * L1280 11111111111111111111111111111111 * L1312, 11111111011111111011011111101111 * L1344 11110111111111110111101111101111 *
 L1408 111111111111101111011101111111111 * C82EB*
V0001 $01110000001 \times 1 \mathrm{LHHHHH1}$ * V0002 $01110000001 \times 0 L H H H H 1$ * V0003 01011010101 X1LHHLHH1 * V0004 01011010101 XOHLHLHH1 * V0005 01100101001X1LLLLLL1 V0006 01100101001 XOHHLLHH1 V0007 $01011111101 \times 1 L L L H L L 1$ * v0008 01011111101 XOHLLLLL1 * 8DF2

PAL DESIGN SPECIFICATION JENNY YEE 10/4/82


PAL16H8
PAT026
NIBBLE SHIFTER D
ADVANCED MICRO DEVICES
S4 S3 S2 S1 S0 R3 R2 R1 R0 GND OE NC SRNSL IO I1 I2 I3 ZOE Z VCC
;NIBBLE SHIFTER D OUTPUTS
IF (OE*ZOE) Z = ZOE*/ZOE

| ZOE | $=13$ |  |
| :---: | :---: | :---: |
|  | I2 |  |
|  | I1 |  |
|  | SRNSL* | IO*/R1*/RO |
| I3 | = | S3*/R3*/R2 |
|  | SRNSL* | S2*/R3* R2 |
|  | SRNSL* | S1* R3* R2 |
|  | SRNSL* | S0* R3* R2 |
|  | /SRNSL* | S4*/R3* R2 |
|  | /SRNSL* | S4* R3*/R2 |
|  | /SRNSL* | S4* R3* R2 |

$\mathrm{I} 2=\mathrm{S} 2 * /$ R3* $^{*} / \mathrm{R} 2$
SRNSL* S1*/R3* R2
SRNSL* SO* R3*/R2
/SRNSL* S3*/R3* R2
/SRNSL* S4* R3*/R2 /SRNSL* S4* R3* R2
$\mathrm{Il}=\quad \mathrm{S} 1^{*} / \mathrm{R} 3 * / \mathrm{R} 2$
SRNSL* SO*/R3* R2
/SRNSL* S2*/R3* R2 /SRNSL* S3* R3*/R2 /SRNSL* S4* R3* R2 $\mathrm{IO}=\mathrm{SO} * / \mathrm{R} 3 * / \mathrm{R} 2$ /SRNSL* S1*/R3* R2 /SRNSL* S2* R3*/R2 /SRNSL* S3* R3* R2

PAL DESIGN SPECIFICATION JEFF KITSON 10/4/82

FUNCTION TABLE
S4 S3 S2 S1 S0
R3 R2 R1 R0 SRNSL OE I3 I2 I1 IO ZOE Z
;SHIFT ZERO
$\begin{array}{lllllllllllllllllll}\text { L } & \text { H } & \text { H } & \text { H } & \text { L } & & \text { L } & \text { L } & \text { L } & \text { L } & \text { H } & \text { L } & \text { H } & \text { H } & \text { H } & \text { L } & \text { H } & \text { Z } \\ \text { L } & \text { H } & \text { H } & \text { H } & \text { L } & & & \text { L } & \text { L } & \text { L } & \text { L } & \text { L } & \text { L } & \text { H } & \text { H } & \text { H } & \text { L } & \text { H } & \text { Z }\end{array}$
;SHIFT ONE

|  | L | H L | H | H | L | L | H | L | Z |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L H L H H | L | H L | H | L | L | L | L | H | Z |
| ;SHIFT Two |  |  |  |  |  |  |  |  |  |
| L H H L L | H | L H | L | H | L | L | L | L | Z |
| L H H L L | H | L H | L | , | L | L | H | H | Z |
| ;SHIFT THREE |  |  |  |  |  |  |  |  |  |
| L. H L H H | H | H H | H | H | L | H | L | L |  |
| L H L H H |  | H H | H | L | L |  | L | H |  |

DESCRIPTION
NIBBLE SHIFTER D IS THE LAST OF THE FOUR NIBBLE SHIFTER SLICES.
IT USES DATA INPUTS SBUS $\langle 12,8,4,0\rangle$.

PAL16H8
PAL DESIGN SPECIFICATION PATO26
NIBBLE SHIFTER D adVanced micro devices *D9725
*FO*
L0000 11111111111111111111111111111101 *
L0032 11111101111111111111111111111111 *
L0256 11111111111111111111111111111111 *
L0288 11111111110111111111111111111111 *
L0320 11111111111111011111111111111111 *
L0352 11111111111111111101111111111111 *
L0384 11111111111111111111110110011011 *
L0512 11111111111111111111111111111111 *
L0544 01111111111111111011101111111111 *
L0576 11110111111111111011011111011111 *
L0608 11111111011111110111011111011111 *
L0640 11111111111101110111011111011111 *
L0672 11011111111111111011011111101111 *
L0704 11011111111111110111101111101111 *
L0736 11011111111111110111011111101111 *
L0768 11111111111111111111111111111111 *
L0800 1111011111111111101110111111 1111*
L0832 1111111101111111101101111101 1111*
L0864 11111111111101110111101111011111 *
L0896 01111111111111111011011111101111 *
L0928 11011111111111110111101111101111 *
L0960 11011111111111110111011111101111 *
L1024 1111111111111111111111111111 1111**
L1056 11111111011111111011101111111111 *
L1088 11111111111101111011011111011111 *
L1120 11110111111111111011011111101111 *
L1152 01111111111111110111101111101111 *
L1184 11011111111111110111011111101111 *
L1280-1111 1111111111111111111111111111 *
L1312 11111111111101111011101111111111 *
L1344 11111111011111111011011111101111 *
L1376 11110111111111110111101111101111 *
L1408 01111111111111110111011111101111 *
C7F25*
V0001 01110000000x1LHHHHZ1 * V0002 $01110000000 \times 0$ LHHHEZ1 *
V0003 01011010100X1LHHLHZ1 *
V0004 01011010100X0HLHLHZ1 *
v0005 01100101000x1LLLLLZ1 *
V0006 $01100101000 \times 0$ HHLLHZ1
V0007 01011111100X1LLLHHZ1 *
V0008 $01011111100 \times 0 \mathrm{HLLLLZ1}$
8617

## LOGIC DIAGRAM FOR: <br> NIBBLE SHIFTER D USING AmPAL16H8A

Columns: Inputs (0-31)
Rows: Product Terms (0-63)


PAL16R8
PAT017
INSTRUCTION REGISTER
ADVANCED MICRO DEVICES
CLK D5 $\begin{array}{lllllll} & \text { D4 } & \text { D3 } & \text { D2 } & \text { D1 } \\ \text { D }\end{array}$
/OE MO M1 M2 IRO IR1 IR2 IR3 IR4 VCC
;INSTRUCTION REGISTER OUTPUT SIGNALS

/IR4 $\quad:=$| $C E / D 4$ |
| :---: |
|  |
|  |
| $/ C E * / I R 4$ |$+$

/IR3 $:=\mathrm{CE}$ / $\mathrm{D} 3+$
/IR2 := CE\%/D2 + /CE*/IR2
$/ \mathrm{IR1} \quad:=\begin{gathered}\mathrm{CE} \% / \mathrm{D} 1 \\ / \mathrm{CE}^{*} / \mathrm{IR1}\end{gathered}$
/IRO $\quad:=\begin{gathered}\mathrm{CE} * / \mathrm{DO} \\ / \mathrm{CE} * / \text { IRO }\end{gathered}$
/M2 $\quad:=/$ CE $^{*} / \mathrm{M} 2$
CE*/D5
CE* D5* D4* D3*/D2*/D1*/D0
CE* D5* D4* D3*/D2*/D1* D0
CE* D5* D4* D3*/D2* D1*/D0
/M1 $\quad:=/ \mathrm{CE}^{*} / \mathrm{M1}$
CE* D5*/D4*/D3
CE* D5*/D4* D3
CE* D5* D4* D3*/D2*/D1*/D0
CE* D5* D4* D3*/D2*/D1* D0
$:=/ C E * / M 0$
CE* D5*/D4*/D3
CE* D5* D4*/D3
CE* D5* D4* D3*/D2*/D1*/D0
CE* D5* D4* D3*/D2* D1*/D0

PAL DESIGN SPECIFICATION JENNY YEE 10/4/82
$+$
$+$

$$
+
$$

$$
+
$$

$$
\begin{aligned}
& + \\
& + \\
& + \\
& +
\end{aligned}
$$

$$
+
$$

$$
+
$$

$$
+
$$

$$
+
$$

$$
+
$$

$$
+
$$

$$
+
$$

FUNCTION TABLE
CLK /OE /CE D5 D4 D3 D2 D1 D0
IR4 IR3 IR2 IR1 IRO M2 M1 MO ;LOAD REGISTERS FROM THE DBUS AND OUTPUT ONTO Q


DESCRIPTION
THE INSTRUCTION REGISTER (IR) IS IMPLEMENTED USING TWO
AMPAL16R8AS AND ONE AM29825. THE INSTRUCTION REGISTER TAKES 16BITS OF INPUT DATA FROM THE DBUS, PREDECODES THE OPCODE AND ADDRESSING MODES, GENERATING A 10-BIT FIELD FOR THE MAPPING PROM. IN ADDITION TO THIS, IR<11:0> IS PASSED THROUGH TO THE VALUE REGISTER, WHICH USES THIS DATA TO GENERATE CONDITIONAL BRANCH ADDRESSES, IMMEDIATE DATA VALUES, AND REGISTER FILE ADDRESSES.

PAL16R8
PAT017
INSTRUCTION REGISTER
ADVANCED MICRO DEVICES
*D9724
*FO*
L0000 11111011111111111111111111111011 *
L0032 11101111111111111111111111110111 *
L0256 11111111101111111111111111111011 *
L0288 11111110111111111111111111110111 *
L0512 11111111111110111111111111111011 *
L0544 11111111111011111111111111110111 *
L0768 11111111111111111011111111111011 *
L0800 11111111111111101111111111110111
L1024 11111111111111111111101111111011
L1056 11111111111111111110111111110111 *
L1280 11111111111111111111111011110111
L1312 10111111111111111111111111111011
L1344 01110111011110111011101111111011 *
L1376 01110111011110111011011111111011 *
L1408 01110111011110110111101111111011 *
L1536 11111111111111111111111111100111 *
L1568 01111011101111111111111111111011 *
L1600 01111011011111111111111111111011 *
L1632 01110111011110111011101111111011
L1664 01110111011110111011011111111011
L1792 11111111111111111111111111110110
L1824 01111011101111111111111111111011 *
L1856 0111 0111101111111111111111111011 *
L1888 01110111011110111011101111111011 *
L1920 01110111011110110111101111111011 *
C5BD1*
V0001 C010101X000HHLHLHLH1 *
v0002 C100010X000LLHLHLLL1
V0003 C101101X000HLHHLHHL1
V0004 C110010x000LHHLHLLH1
v0005 C111000X000LLLLLLHH1
v0006 C111001X000HLLHLLHH1
V0007 C111010x000LHLLHLHH1
V0008 C111011Х000HHHHHLHH1
V0009 C111101 Х000НHHHLHHH1 V0010 CXXXXXXX100HHHHLHHH1 * 5196

PAL DESIGN SPECIFICATION JENNY YEE 10/4/82

```
LOGIC DIAGRAM FOR:
INSTRUCTION REGISTER USING AmPAL16R8A
```

Columns: Inputs (0-31)
Rows: Product Terms (0-63)


PAL16R6
PATO22
VALUE REGISTER AND REGISTER FILE ADVANCED MICRO DEVICES
CLK IR1 IR2 IR3 SL3 SL2 SL1 SL0 /CE GND
/OE IR4 VR4 VR3 VR2 VR1 B A DR VCC
;VALUE REGISTER AND REGISTER FILE OUTPUTS

| /A | $\begin{gathered} :=/ \text { SL } 1 * / \text { SLO }^{*} / \text { VR } 4 \\ \text { SLO } 4 / A \\ \text { SL1 } 1 / \text { SLO } / \text { IR1 } \end{gathered}$ | $+$ |
| :---: | :---: | :---: |
| /B | := /SL3*/SL2*/B | + |
|  | /SL3* SL2*/SL1*/IR1 | $+$ |
|  | /SL3* SL2* SL1*/IR4 | + |
|  | SL3*/SL2*/SL1*/VR4 | + |
|  | SL3*/SL2* SL1* SLO*/DR | + |
|  | SL3*/SL2* SL1*/SL0*/IR1 |  |
| /VR1 | $:=/ C E^{*} / \mathrm{VR} 1$ | + |
|  | CE*/IR1 |  |
| /VR2 | $:=/ C E * / V R 2$ | + |
|  | CE*/IR2 |  |
| /VR3 | $:=/ C E * / V R 3$ | + |
|  | CE*/IR3 |  |
| /VR4 | $:=/ C E * / V R 4$ | + |
|  | CE*/IR4 |  |

PAL DESIGN SPECIFICATION
JENNY YEE 10/4/82

FUNCTION TABLE

| $\text { ; }{ }^{\text {LOAD VR }}$ | REGISTE |  | X | X | L | L | H | L | X | X X | L | L | H | L |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ; HOLD THI | IS VALUE |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H X | X | X | X | X | X | X | X | X | X X | L | L | H | L |
| ;LOADING | ALL VAL | UES | FOR | A AN | ND B |  |  |  |  |  |  |  |  |  |
| ; $\mathrm{A}=\mathrm{IR1}$ | B=IR4 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H L | H | H | L | L | H | L | H | L | H L | L | L | H | L |
| ; $\mathrm{A}=\mathrm{VR} 4$ | $\mathrm{B}=\mathrm{B}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H L | L | L | L | L | H | L | H | L | L L | L | L | H | L |
| ${ }_{\mathrm{C}} \mathrm{A}=\mathrm{A}$ | ${ }_{B}^{B}=\mathrm{B}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H L | L | X | H | L | H | L | H | L | L L | L | L | H | L |
| ; $\mathrm{A}=$ IR1 | $\mathrm{B}=\mathrm{B}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H L | L | H | L | L | H | L | H | L | H L | L | L | H | L |
| ; $\mathrm{A}=\mathrm{VR} 4$ | $\mathrm{B}=\mathrm{IR} 1$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C. L | H L | H | L | L | L | H | L | H | L | L H | L | L | H | L |
| ; $\mathrm{A}=\mathrm{A}$ | $\mathrm{B}=\mathrm{IR1}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H L | H | L | H | H | L | H | L | L | L L | L | L | H | L |
| $; A=A$ | $\mathrm{B}=$ IR4 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ; $\mathrm{A}=$ VR 4 | $\begin{gathered} \mathrm{H} \\ \mathrm{~B}=\mathrm{L} \\ \mathrm{~L} \end{gathered}$ | H | H | H | H | L | H | L | L | L H | L | L | H | L |
| C L | H H | L | L | L | H | L | H | L | L | L L | L | L | 11 | L |
| ; $\mathrm{A}=\mathrm{A}$ | $\mathrm{B}=\mathrm{VR} 4$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H H | L | L | H | H | L | H | L | L | L L | L | L | H | L |
| ; $\mathrm{A}=$ IR1 | $\mathrm{B}=\mathrm{IR1}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H H | L | H | L | L | H | L | H | L | H H | L | L | H | L |
| ; $\mathrm{A}=\mathrm{A}$ | $\mathrm{B}=\mathrm{DR}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H H | L | H | H | L | H | L | H | L | H L | L | L | H | L |
| ; $\mathrm{A}=\mathrm{VR} 4$ | $B=1$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H H | H | L | L | L | H | L | H | L | L H | L | L | H | L |
| ; $\mathrm{A}=\mathrm{A}$ | $\mathrm{B}=1$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H H | H | X | H | L | H | L | H | L | L H | L | L | H | L |
| ; $\mathrm{A}=\mathrm{IR1}$ | $\mathrm{B}=1$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C L | H H | H | H | L | L | H | L | H | L | H H | L | L | H | L |

DESCRIPTION
THE VALUE REGISTER IS NECESSARY FOR DOUBLE-PIPELINING. THIS register, along with the decrement register, control all of the addressing required for the register file. the value register is IMPLEMENTED USING 3 IDENTICALLY PROGRAMMED AMPAL16R6AS. THE VALUE REGISTER GENERATES DATA INFORMATION ON VR $\langle 11: 0\rangle$ (WHICH IS SIMPLY IR<11:0> DELAYED BY ONE CLOCK CYCLE), AND THE A AND B ADDRESSES FOR THE REGISTER FILE ON A ADR<2:0> AND B ADR<2:0>, RESPECTIVELY. THE A AND B ADDRESS SELECTION IS CONTROLLED BY THE RFAR SEL<3:0> FROM MICROCODE.

PAL16R6
PAT022
VALUE REGISTER AND REGISTER FILE adVanced micro devices
*D9724
*FO*
L0256 $1: 1111111111111111111101110101111$ * L0288 11111110111111111111111101111111 * L0320 10111111111111111111011110111111 * L0512 11111111111010111011111111111111 * L0544 10111111111110110111101111111111 * L0576 11111111111110110111011111111110 * L0608 11111111111101111011101111101111 * L0640 1110111111110111101101110111 1111 * L0672 10111111111101111011011110111111 * L0768 11111111111111101111111111110111 *
L0800 10111111111111111111111111111011 * L1024 11111111111111111110111111110111 * L1056 11111011111111111111111111111011 * L1280 11111111111111111111111011110111 * L1312 11111111101111111111111111111011 * L1536 11111111111111111111111111100111 * L1568 11111111111111111111111111111010 * C3EEO*
V0001 C010xxxx0000LLHLXXX1 * v0002 CXXXXXXX100XLLHLXXX1 * V0003 C10101101000LLHLLHO1 * V0004 C10100001000LLHLLLO1 * V0005 C10100X11000LLHLLL01 * V0006 C10100101000LLHLLHO1 * V0007 C10101001000LLHLHL01 * v0008 C01001011001LLHLLLO1 * V0009 C01001111001LLHLHLO1 * v0010 C01010001001LLHLLLO1 * V0011 C01010011001LLHLLL01 * V0012 C10110101000LLHLHHO1 * V0013 C10110111000LLHLLHO1 * V0014 C10111001000LLHLHLO1 * V0015 C10111X11000LLHLHL01 * V0016 C10111101000LLHLHHO1 * 3139

## LOGIC DIAGRAM FOR:

VALUE REGISTER AND REGISTER FILE ADDRESS REGISTER USING AmPAL16R6A
Columns: Inputs (0-31)


PAL16R4
PAT016
DECREMENT REGISTER
ADVANCED MICRO DEVICES
CLK D2 D1 D0 CBR VR11 S1 SO /OER GND
/OE R0 R1 Q0 Q1 $\quad$ Q2 $\quad$ NC $\quad$ R2 $\quad$ CXV VCC
;DECREMENT REGISTER OUTPUT SIGNALS
IF (OER) /R2 =
/Q2
. $\mathrm{Q} 2 .:=/ \mathrm{Sl}^{*} * / \mathrm{SO} 0 / \mathrm{Q} 2$ /S1* S0*/R2 S1*/S0*/D2 $\mathrm{S} 1 * \mathrm{SO}^{*} \mathrm{Q} 2 * / \mathrm{Q} 1 * / \mathrm{QO}$ S1* SO*/Q2* Q0 S1* SO*/Q2* Q1
/Q1 $:=/ \mathrm{S} 1 * / \mathrm{SO}^{*} / \mathrm{Q} 1$ /S1* SO*/R1 $\mathrm{S} 1 * / \mathrm{SO}$ \%/D1 S1* SO* Q1*/Q0 S1* SO*/Q1* Q0
/Q0 $:=/ \mathrm{S} 1 * / \mathrm{SO}^{*} / \mathrm{QO}$
/S1* S0*/R0 $\mathrm{S} 1 * / \mathrm{SO}$ */D0 Si* SO* Q0
$\mathrm{IF}(\mathrm{OER}) / \mathrm{R} 1=/ \mathrm{Q} 1$
$I F(O E R) / R O=/ Q O$
$/ \mathrm{CXV}=\mathrm{CBR} *$ VR11 /CBR*/VR11

PAL DESIGN SPECIFICATION JEFF KITSON 10/4/82

FUNCTION TABLE
CLK /OER /OE S1 S0 D2 D1 D0 CBR VR11 R2 R1 R0 CXV Q2 Q1 Q0
; LOAD REGISTERS FROM RBUS AND OUTPUT ONTO Q
$\begin{array}{lccccccccccccccc}\text { C } & \text { H } & \text { L } & \text { L } & H & X & X & X & X & X & \text { L } & \text { H } & \text { L } & \text { X } & \text { L } & \text { H } \\ \text {; LOAD } & \text { LEGISTERS } & \text { FROM } & \text { DBUS } & \text { AND } & \text { OUTPUT } & \text { ONTO } & \text { Q } & & & & & & & \end{array}$ $\begin{array}{lllllllllllllllll}\text { C } & \text { H } & \text { L } & \text { H } & \text { L } & \text { H } & \text { L } & \text { H } & \text { X } & \text { X } & \text { Z } & \text { Z } & \text { Z } & \text { X } & \text { H } & \text { L } & \text { H }\end{array}$
; HOLD THE VALUE AND OUTPUT ONTO Q
;DECREMENT VALUE AND OUTPUT ONTO Q

| C | H | L | H | H | X | X | X |  |  | X | 2 | Z | Z | X | H | L | L |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C | H | L | H | H | X | X | X |  |  | X | Z | Z | Z | X | L | H | H |
| C | H | L | H | H | X | X | X |  |  | X | Z | Z | Z | X | L | H | L |
| C | H | L | H | H | X | X | X |  |  | X | Z | Z | Z | X | L | L | H |
| C | H | L | H | H | X | X | X |  |  | X | Z | Z | Z | X | L | L | L |
| C | H | L | H | H | X | X | X |  |  | X | Z | Z | Z | X | H | H | H |
| C | H | L | H | H | X | X | X |  |  | X | Z | Z | Z | X | H | H | L |
| C | H | L. | H | H | X | X | X |  |  | X | Z | Z | Z | X | H | L | H |
| ;OUTPU |  | THE | VAL |  | NTO | THE | R |  |  | NOT | ONTO | Q |  |  |  |  |  |
| X | L | H | X | X | X | X | X | X |  | X | H | L | H | X | Z | Z | Z |
| ; TEST |  | NDIT | ION | L BR | RaNC | P P | POL | T | XOR |  |  |  |  |  |  |  |  |
| L | X | X | X | X | X | X | X |  |  | L | X | X | X | L | X | X | X |
| L | X | X | X | X | X | X | X | I |  | H | X | X | X | H | X | X | X |
| L | X | X | X | X | X | X | X | H |  | L | X | X | X | H | X | X | X |
| L | X | X | X | X | X | X | X | H |  | H | X | X | X | L | X | X | X |

DESCRIPTION
THE DECREMENT REGISTER IS IMPLEMENTED USING A SINGLE AMPAL16R4A. IT IS LOADED FROM RBUS<2:0> WHEN THE REGISTER IS SELECTED BY IMMEDIATE OR REGISTER ADDRESSING MODES, OR FROM DBUS<2:0> WHEN A MEMORY ADDRESSING MODE IS USED. LOADING OR DECREMENTING IS CONTROLLED BY DR SEL<1:0> VIA MICROCODE. THE DECREMENT REGISTER, IN CONJUNCTION WITH THE VALUE REGISTER, PROVIDE ALL OF THE ADDRESSING REQUIRED FOR THE REGISTER FILE. SEQUENTIAL ADDRESSING OF THE REGITER FILE (FOR LDM AND STM INSTRUCTIONS) IS QUICK AND EASY WITH THE DECREMENT REGISTER. IT IS ALSO USED TO PROVIDE AN OFFSET TO THE MEMORY ADDRESS WHERE THE DATA IS TO BE STORED INTO OR LOADED FROM.

PAL16R4
PAT016
DECREMENT REGISTER
ADVANCED MICRO DEVICES
*D9724
*F0*
L0000 11111111111111111111111111111111 *
L0032 11111111111101110111111111111111 *
L0064 11111111111110111011111111111111 *
L0256 11111111111111111111111111111011 *
L0288 $11111111 ; 111111101111111111111111$ *
L0768 11111111111111101111101110111111 *
L0800 11111110111111111111101101111111 *
L0832 10111111111111111111011110111111 *
L0864 11111111111111011110011001111111 *
L0896 11111111111111101111010101111111 *
L0928 11111111111111101101011101111111 *
L1024 11111111111111111110101110111111 *
L1056 11111111111111111111101101101111 *
L1088 11111011111111111111011110111111 *
L1120 1111.1111111111111101011001111111 *
L1152 11111111111111111110010101111111 *
L1280 11111111111111111111101010111111 *
L1312 11111111111111111111101101111110 *
L1344 11111111101111111111011110111111 *
L1376 11111111111111111111010101111111 :
L1536 11111111111111111111111111111011 *
L1568 11111111111111111110111111111111 *
L1792 11111111111111111111111111111011 *
L1824 11111111111111111111111011111111 *
C5754*
V0001 CXXXXX0110001LHLXOX1
V0002 C101XX10100ZZHLHXZX1
V0003 CXXXXX00100ZZHLHXZX1
V0004 CXXXXX11100ZZLLHXZX1
V0005 CXXXXX11100ZZHHLXZX1
V0006 CXXXXX11100ZZLHLXZX1
V0007 CXXXXX11100ZZHLLXXX1
V0008 CXXXXX11100ZZLLLXZX1
V0009 CXXXXX11100ZZHHHXZX1
V0010 CXXXXX11100ZZLHHXZX1
V0011 CXXXXX11100ZZHLHXZX1
V0012 XXXXXXXX001HLZZZXHX1
V0013 0XXX00XXXOXXXXXXXXL1
V0014 0XXX01XXXOXXXXXXXXH1
V0015 0xXX10XXX0XXXXXXXXH1
V0016 0XXX11XXX0XXXXXXXXL1 * 7DD3

PAL DESIGN SPECIFICATION JEFF KITSON 10/4/82

## LOGIC DIAGRAM FOR:

DECREMENT REGISTER USING AmPAL16R4A
Columns: Inputs (0-31)


PAL16H8
PAL DESIGN SPECIFICATION
PAT012 JENNY YEE 10/4/82
RBUS CONSTANT CONTROL A
ADVANCED MICRO DEVICES
VR6 VR7 VR10 NC NC NC /OEH /OEL S GND
$\begin{array}{llllllllll}\text { NC } & R 9 & R 8 & R 7 & R 6 & R 5 & R 4 & R 1 & R 0 & V C C\end{array}$
;RBUS A OUTPUT SIGNAL

| IF (OEL) | R0 | $=$ VR6*S |
| :--- | :--- | :--- |
| IF (OEL) | R1 | $=$ VR7*S |
| IF (OEH) | R4 | $=$ VR10*S |
| IF (OEH) | R5 | $=$ VR10*S |
| IF (OEH) | R6 | $=V R 10^{*} S$ |
| IF (OEH) | R7 | $=V R 10^{*} S$ |
| IF (OEH) | R8 | $=V R 10^{*} S$ |
| IF (OEH) | R9 | $=V R 10^{*} S$ |

FUNCTION TABLE
VR6 VR7 VR10 /OEH /OEL S R0 R1 R4 R5 R6 R7 R8 R9


DESCRIPTION
THE RBUS CONTROL PERFORMS SIGN EXTENSION FOR SHORT IMMEDIATE SOURCE OPERANDS AND PUTS CONSTANT VALUES ON THE RBUS. THE FUNCTION IS CONTROLLED BY THE RBUS SELECT SIGNAL FROM MICROCODE. ITS IMPLEMENTATION REQUIRES TWO AMPAL16H8AS. RBUS CONTROL A MANIPULATES RBUS〈9:4,1:0> USING INPUTS FROM THE VALUE REGISTER, VR〈10,7,6>.

PAL16H8
PAT012
RBUS CONSTANT CONTROL A ADVANCED MICRO DEVICES
*D9725
*FO*
L0000 11111111111111111111111110111111 L0032 11011111111111111111111111110111 * L0256 11111111111111111111111110111111 * L0288 01111111111111111111111111110111 * L0512 1111111111111111111110111111.1111 * L0544 11110111111111111111111111110111 * L0768 11111111111111111111101111111111 * L0800 11110111111111111111111111110111 * L1024 11111111111111111111101111111111 * L1056 11110111111111111111111111110111 * L1280 11111111111111111111101111111111 * L1312 11110111111111111111111111110111 * L1536 11111111111111111111101111111111 * L1568 11110111111111111111111111110111 * L1792 11111111111111111111101111111111 * L1824 11110111111111111111111111110111 * C3E17*
V0001 XXXXXX1000XZZZZZZZLL1 * V0002 00xXXX1010XZZZZZZLL1 V0003 01XXXX1010XZZZZZZHL1 V0004 10xXXX1010XZZZZZZLH1 V0005 11XXXX1010XZZZZZZHH1 V0006 XX0XXX0110XLLLLLLZZ1 V0007 XX1XXX0110XHHHHHHZZ1 V0008 XXXXXX0100XLLLLLLLZZ1 V0009 111XXX0010ХНННННННН1 V0010 XXXXXX0000XLLLLLLLLL1 $0 C 71$

PAL DESIGN SPECIFICATION JENNY YEE 10/4/82


PAL16H8
PAL DESIGN SPECIFICATION
PAT013
RBUS CONSTANT CONTROL B
ADVANCED MICRO DEVICES
VR8 VR9 VR10 NC NC NC /OEH /OEL S GND
$\begin{array}{llllllllll}\text { NC } & R 15 & R 14 & R 13 & R 12 & R 11 & R 10 & R 3 & R 2 & \text { VCC }\end{array}$
;RBUS B OUTPUT SIGNALS

|  | (OEL) | R2 | $=\mathrm{VR} 8 * S$ |
| :---: | :---: | :---: | :---: |
|  | (0EH) | R3 | $=$ VR9*S |
|  | (OEH) | R10 | $=$ VR10*S |
|  | (OEH) | R11 | $=\mathrm{VR10}$ - S |
|  | (OEH) | R12 | $=\mathrm{VR} 10^{* S}$ |
|  | (OEH) | R13 | $=$ VR10*S |
|  | (0EH) | R14 | $=\mathrm{VR10}$-S |
| IF | ( OEH ) | R15 | $=\mathrm{VR} 10 * \mathrm{~S}$ |

FUNCTION TABLE
VR8 VR9 VR10 /OEH /OEL S R2 R3 R10 R11 R12 R13 R14 R15

| ; SELECT R2 ONLY |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X X | X |  | H | L | L | L | Z | Z | Z | Z | Z | Z | Z |
| H X | X |  | H | L | H | H | Z | Z | Z | Z | Z | Z | Z |
| L X | X |  | H | L | H | L | Z | Z | Z | Z | Z | Z | Z |
| ; SELECT R3 TO R15 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| X X | X |  | L | H | L | Z | L | L | L | L | L | L | L |
| X L | L |  | L | H | H | Z | L | L | L | L | L | L | L |
| X H | H |  | L | H | H | Z | H | H | H | H | H | H | H |
| X H | L |  | L | H | H | Z | H | L | L | L | L | L | L |
| X L | H |  | L | H | H | Z | L | H | H | H | H | H | H |
| ;SELECT R2 T0 R15 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| X X | X |  | L | L | L | L | L | L | L | L | L | L | L |

DESCRIPTION
THE RBUS CONTROL B HANDLES RBUS $\langle 15: 10,3: 2>$. ITS INPUTS ARE PROVIDED BY VR<10:8>.

PAL16H8
PAT013
RBUS CONSTANT CONTROL B
ADVANCED MICRO DEVICES
*D9725
*FO*
L0000 11111111111111111111111110111111 *
L0032 11011111111111111111111111110111 *
L0256 11111111111111111111101111111111 *
L0288 01111111111111111111111111110111 *
L0512 11111111111111111111101111111111 *
L0544 11110111111111111111111111110111 *
L0768 11111111111111111111101111111111 *
L0800 11110111111111111111111111110111 *
L1024 11111111111111111111101111111111 *
L1056 11110111111111111111111111110111 *
L1280 11111111111111111111101111111111 *
L1312 11110111111111111111111111110111 *
L1536 11111111111111111111101111111111 *
2156811110111111111111111111111110111 *
L1792 11111111111111111111101111111111 *
L1824 11110111111111111111111111110111 * C3DF9*
V0001 XXXXXX1000XZZZZZZZL1
v0002 1XXXXX1010XZZZZZZZH1 *
V0003 0xXXXX1010xZZZZZZZL1
V0004 XXXXXX0100XLLLLLLLZ1 *
V0005 X00XXX0110XLLLLLLLZ1 *
V0006 X11XXX0110XHHHHHHHZ1
V0007 X10XXX0110XLLLLLLHZ1
V0008 X01XXX0110XHHHHHLZZ1
V0009 XXXXXX0000XLLLLLLLLL
052 C

PAL DESIGN SPECIFICATION JENNY YEE 10/4/82

## LOGIC DIAGRAM FOR:

RBUS CONSTANT CONTROL B USING AmPAL16H8
Columns: Inputs (0-31)
Rows: Product Terms ( $0-63$ )


PAL16R6
PAL DESIGN SPECIFICATION
PAT014
CBR CONTROL
ADVANCED MICRO DEVICES
CLK Z N C V VR10 VR9 VR8 ZN GND /OE CV CBR NXORV VF CF NF ZF NC VCC
;CBR CONTROL OUTPUT SIGNALS

| /2F | $:=\frac{\mathrm{ZN} * / \mathrm{Z}}{/ \mathrm{ZN} * / \mathrm{ZF}}$ | $+$ |
| :---: | :---: | :---: |
| /NF | $:=\frac{\mathrm{ZN} * / \mathrm{N}}{} / \mathrm{ZN} * / \mathrm{NF}$ | + |
| /CF | $:=\frac{C V * / C}{/ C V * / C F}$ | + |
| /VF | $:=\frac{C V * / V}{} / C V * / V F$ | + |
| /NXORV | $:=/ \mathrm{ZN} * / \mathrm{CV} * / \mathrm{NXORV}$ | + |
|  | /ZN* CV* NF*V | + |
|  | /ZN* $\mathrm{CV} * / \mathrm{NF} * / \mathrm{V}$ | + |
|  | ZN*/CV*/N*/VF | + |
|  | ZN*/CV* N* VF | + |
|  | ZN* CV*/N*/V | $+$ |
|  | ZN* CV* ${ }^{*} *$ |  |
| /CBR | $:=/$ VR10 ${ }^{*} /$ VR9 $^{*} /$ VR8 $^{*} / \mathrm{NF}$ |  |
|  | /VR10*/VR9* VR8*/ZF |  |
|  | /VR10* VR9* VR8*/CF |  |
|  | VR10*/VR9*/VR8*/VF |  |
|  | VR10*/VR9* VR8*/NXORV |  |
|  | VR10* VR9*/VR8*/NXORV*/ZF |  |
|  | VR10* VR9* VR8*/ZF*/NF |  |

FUNCTION TABLE

CLK /OE ZN CV VR10 VR9 VR8 $\quad$ Z $\quad \mathrm{N}$ C V ZF NF CF VF NXORV CBR
;LOAD Z,N,C,AND V REGISTERS (TEST NXORV)
 ; HOLD Z,N,C,AND V REGISTERS (TEST NXORV) C L L L L X X X ;TEST NXORV UNDER OTHER CONDITIONS

| C | L | H | L | X | X | X | L | H | X | X | L | H | H | L | H | X |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


;TESTCBR FOR ALL COMBINATIONS OF VR
;AUTOMATIC BRANCH--ALWAYS ONE
$\begin{array}{lllllllllll}\text { C } & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{X} & \mathrm{X} & \mathrm{X} & \mathrm{X}\end{array}$
;BRANCH ON ZF
$\begin{array}{lllllllllllllllllll}\text { C } & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{H} & \mathrm{X} & \text { X } & \text { X } & \text { X } & \text { L. } & \text { H } & \text { L } & \text { H } & \text { L } & \text { L }\end{array}$
;BRANCH ON NF
C L L L
L $\quad \mathrm{H} \quad \mathrm{L} \quad \mathrm{X} \quad \mathrm{X}$ X
$\begin{array}{lllllll}L & H & L & H & L & H\end{array}$
;BRANCH ON CF
$\begin{array}{lllllll}\mathrm{L} & \mathrm{H} & \mathrm{H} & \mathrm{X} & \mathrm{X} & \mathrm{X} & \mathrm{X}\end{array}$
$\begin{array}{llllll}\mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{L}\end{array}$
;BRANCH ON VF
$\begin{array}{llllllllll}\text { C } & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{L} & \mathrm{X} & \mathrm{X} & \mathrm{X} \\ \text {;BRANCH } & \mathrm{ON} & \mathrm{X}\end{array}$
$\begin{array}{llllll}L & H & L & H & L & H\end{array}$
$\begin{array}{llllllllll}\text { C } & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{X} & \mathrm{X} & \mathrm{X}\end{array} \mathrm{X}$
L. $\begin{array}{lllll}\mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{L}\end{array}$
;BRANCH ON NXORV OR ZF
$\begin{array}{llllllllllllllllll}\text { C } & \text { L } & \text { L } & \text { L } & \text { H } & \text { H } & \text { L } & \text { X } & \text { X } & \text { X } & \text { X } & \text { L } & \text { H } & \text { L } & H & \text { L } & & \text { L }\end{array}$
;BRANCH ON NF OR ZF
$\begin{array}{lllllllllll}\text { C } & \mathrm{L} & \mathrm{L} & \mathrm{L} & \mathrm{H} & \mathrm{H} & \mathrm{H} & \mathrm{X} & \mathrm{X} & \mathrm{X} & \mathrm{X}\end{array}$
$\begin{array}{llllll}\mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{H} & \mathrm{L} & \mathrm{H}\end{array}$

DESCRIPTION
THE CBR CONTROL PAL GENERATES ALL THE CONTROL NECESSARY FOR THE EXECUTION OF CONDITIONAL BRANCH INSTRUCTIONS, SIGN EXTENSION FOR SHORT IMMEDIATE DESTINATION OPERANDS, AND CONSTANT GENERATION. THE IMPLEMENTATION REQUIRES ONE AMPAL16R6A. BRANCH CONDITIONS ARE GENERATED FROM THE FOUR CONDITIONS CODES: ZERO(Z), MINUS(N), OVERFLOW(V), AND CARRY(C). THE CONDITION BEING TESTED IS SELECTED BY VR<10:8>.

PAL16R6
PAL DESIGN SPECIFICATION
PAT014
CBR CONTROL
ADVANCED MICRO DEVICES
*D9724
*FO*
L0256 10111111111111111111111111110111 *
L0288 11111110111111111111111111111011 *
L0512 11111011111111111111111111110111 * L0544 1111111111101111111111111111 1011 * L0768 11111111101111111111111111111101 L0800 11111111111111101111111111111110 * L1024 11111111111110111111111111111101 L1056 11111111111111111110111111111110 * L1280 11111111111111111111111011111010 * L1312 11111111110101111111111111111001 * L1344 11111111111010111111111111111001 * L1376 11111011111111111110111111110110 * L1408 11110111111111111101111111110110 * L1440 11111011111110111111111111110101 * L1472 11110111111101111111111111110101 * L1536 11111111111011111011101110111111 * L1568 11111110111111111011101101111111 * L1600 11111111111111101011011101111111 *
 L1664 11111111111111110111101001111111 * L1696 11111110111111110111011010111111 * L1728 11111110111011110111011101111111 * C4C20*
V0001 C1010XXX1001XLLHLHX1
V0002 CXXXXXXX0000XLLLHLHX1 *
V0003 C01XXXXX1000XHLHHLX1
V0004 CXX01XXX0001XLHLHLX1 :
V0005 CXXXX0000000HLHLHLX1
V0006 CXXXX0010000LLHLHLX1
V0007 CXXXX0100000HLHLHLX1
V0008 CXXXX0110000LLHLHLXX1
V0009 CXXXX1000000HLHLLHLX1
V0010 CXXXX1010000LLLHLHLX1
V0011 CXXXX1100000LLHLHLX1'
V0012 CXXXX1110000HLHLHLX1 * 4800


PAL16H8
PAT014
SBUS CONTROL A
ADVANCED MICRO DEVICES
VR0 VR1. VR2 VR4 VR7 VR11 CBR SL1 SL0 GND

; SBUS A OUTPUT SIGNAL

| IF (OE) | SO | $=$ | /SL1* SL0 |
| :---: | :---: | :---: | :---: |
|  |  |  | SL1*/SL0* VRO |
|  |  |  | SL1* SLO*/VRO* VR11*/CBR |
|  |  |  | SL1* SLO*/VRO*/VR11* CBR |
| IF (OE) | S1 | $=$ | SL1*/SL0* VR1 |
|  |  |  | SL1* SLO*/VR1* VR11*/CBR |
|  |  |  | SL1* SLO*/VR1*/VR11* CBR |




| $\mathrm{IF}(\mathrm{OE}) \mathrm{S} 7=$ | $\mathrm{SL1}^{*} / \mathrm{SLO}^{*} \mathrm{VR} 4$ |
| ---: | :--- |
|  | $\mathrm{SL1}^{*} \mathrm{SLO}^{*} / \mathrm{VR} 7^{*} \mathrm{VR11} * / \mathrm{CBR}$ |
|  | $\mathrm{SL1}^{*} \mathrm{SLO}^{*} / \mathrm{VR} 7^{*} / \mathrm{VR11}{ }^{*} \mathrm{CBR}$ |$+$



| $\mathrm{IF}(\mathrm{OE}) \mathrm{S} 9 \quad=$ | $\mathrm{SL1*/SL0}^{*}$ VR4SL1* SLO*/VR7* VR11*/CBR$+$ |
| ---: | :--- |
|  | $\mathrm{SL1}^{*} \mathrm{SLO}^{*} / \mathrm{VR} 7^{*} / \mathrm{VR11} 1^{*} \mathrm{CBR}$ |$+$

$\begin{aligned} \mathrm{IF}(\mathrm{OE}) \mathrm{S} 10= & \mathrm{SL1}^{*} / \mathrm{SLO}^{*} \text { VR4 } \\ & \mathrm{SL1}^{*} \mathrm{SLO}^{*} / \mathrm{VR} 7^{*} \text { VR11*/CBR }\end{aligned}+$

FUNCTION TABLE
VR0 VR1 VR2 VR4 VR7 VR11 CBR SL1 SL0 /OE S0 S1 $\begin{aligned} & \text { S2 } \\ & \text { S4 } \\ & \text { S7 } \\ & \text { S8 } \\ & \text { S9 }\end{aligned}$ S10
;SELECT ZEROS

;SELECT ONES

| $X$ | $X$ | $X$ | $X$ | $X$ | $X$ | $X$ | L | H | L | $H$ | L | L | L | L | L | L | L |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| ; SELECT | VRO | TO | VR4 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | H | L | H | X | X | X | H | L | L | L | H | L | H | H | H | H |
| H |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| $H$ | $L$ | $H$ | $L$ | $X$ | $X$ | $X$ | $H$ | $L$ | $L$ | $H$ | $L$ | $H$ | $L$ | $L$ | L | L | L |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

;SELECT CBR OFFSET VR(0-7) OR ZEROS

| H | H | H | H | H | L | H | H | H | L | L | L | L | L | L | L | L | L |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| L | H | L | H | L | L | H | H | H | L | H | L | H | L | H | H | H | H |
| H | L | H | L | H | H | L | H | H | L | L | H | L | H | L | L | L | L |
| L | L | L | L | L | H | L | H | H | L | H | H | H | H | H | H | H | H |

DESCRIPTION
THE IMPLEMENTATION OF THE SBUS CONTROL REQUIRES TWO AMPAL16H8AS. THE FUNCTIONS PERFORMED BY THE PALS ARE CONTROLLED BY MICROCODE INPUTS SBUS SEL<1:0>. FOR IMMEDIATE DESTINATION OPERANDS, THESE PALS PERFORM SIGN EXTENSION. IF A CBR INSTRUCTION IS SELECTED, A SIGN EXTENDED BRANCH OFFSET IS DERIVED FROM VR<9:0>. VR<11> AND THE CBR FLAG INITIATE A bRanch when they are the same polarity, at which time the offset is ADDED TO THE PC. IF THE BRANCH CONDITION IS NOT MET, -1 IS ADDED TO THE PC TO RESUME PROPER INSTRUCTION EXECUTION. THE SBUS CONTROL A PAL CONTROLS SBUS<10:7,4,2:0>.

PAL16H8
PaT014
SBUS CONTROL A
ADVANCED MICRO DEVICES
*D9725
*FO*
L0000 11111111111111111111111111111110 *
L0032 11111111111111111111111110110111 *
L0064 1101111111111111111111110111 1011 *
L0096 11101111111111110111101101110111 *
L0128 11101111111111111011011101110111 *
L0256 11111111111111111111111111111110 *
L0288 01111111111111111111111101111011 *
LO320 10111111111111110111101101110111 *
L0352 10111111111111111011011101110111 *
L0512 11111111111111111111111111111110 *
L0544 11110111111111111111111101111011 *
L0576 11111011111111110111101101110111
L0608 11111011111111111011011101110111 *
L0768 1111 1111111111111111111111111110 *
L0800 11111111011111111111111101111011 *
L0832 11111111101111110111101101110111
L0864 11111111101111111011011101110111
L1024 11111111111111111111111111111110
L1056 11111111011111111111111101111011
L1088 11111111111110110111101101110111
L1120 11111111111110111011011101110111
L1280 11111111111111111111111111111110 *
L1312 11111111011111111111111101111011
L1344 11111111111110110111101101110111 *
L1376 11111111111110111011011101110111
L1536 11111111111111111111111111111110 *
L1568 1111111101111111111111110111 1011*
L1600 11111111111110110111101101110111 *
L1632 11111111111110111011011101110111 *
L1792 11111111111111111111111111111110 *
L1824 11111111011111111111111101111011 *
L1856 11111111111110110111101101110111 *
L1888 11111111111110111011011101110111 *
C7A48*
V0001 XXXXXXX0000LLLLLLLLL1 *
V0002 XXXXXXX0100LLLLLLLH1 *
V0003 0101XXX1000HHHHHLHL1
V0004 1010XXX1000LLLLLLLLH1
V0005 11111011100 LLLLLLLL
V0006 01010011100 HHHHLHLH 1
V0007 10101101100 LLLLHLHL 1
VOOO8 $00000101100 \mathrm{HHHHHHHH1}$ *
88F1

PAL DESIGN SPECIFICATION JEFF KITSON 10/4/82

VR3 VR4 VR5 VR6 VR7 VR11 CBR S1 S0 GND

;SBUS CONTROL OUTPUT SIGNAL
$\begin{aligned} \text { IF (OE) } S 3= & \mathrm{S} 1^{*} / \mathrm{SO}^{*} \text { VR3 } \\ & \mathrm{S}^{*} \mathrm{SO}^{*} / \mathrm{VR} 3^{*} \text { VR11*/CBR } \\ & \mathrm{S} 1^{*} \mathrm{~S} 0^{*} / \mathrm{VR} 3^{*} / \mathrm{VR} 11^{*} \mathrm{CBR}\end{aligned}+$
IF (OE) S5 $=\mathrm{S} 1^{*} / \mathrm{SO}^{*}$ VR4
+
+
S1* SO*/VR5* VR11*/CBR +
S1* S0*/VR5*/VR11* CBR
IF (OE) $\mathrm{S6}=\mathrm{Si}^{*} / \mathrm{SO}^{*}$ VR4 $\quad \mathrm{S} 1^{*} \mathrm{~S} 0^{*} / \mathrm{VR}^{*}$ VR11*/CBR +
S1* SO*/VR6*/VR11* CBR
IF (OE) $\mathrm{S} 11=\mathrm{S} 1 * / \mathrm{SO} *$ VR4
+
+
S1* SO*/VR7* VR11*/CBR +
S1* S0*/VR7*/VR11* CBR
IF (OE) $\mathrm{S} 12=\mathrm{S} 1^{*} / \mathrm{SO}{ }^{*}$ VR4
$+$
S1* SO*/VR7* VR11*/CBR +
S1* S0*/VR7*/VR11* CBR
IF (OE) $\mathrm{S} 13=\mathrm{S} 1^{*} / \mathrm{SO} 0^{*}$ VR4
S1* S0*/VR7* VR11*/CBR + +
S1* S0*/VR7*/VR11* CBR
IF (OE) $\mathrm{S} 14=\mathrm{S} 1 * / \mathrm{S} 0^{*}$ VR4
S1* SO*/VR7*VR11*/CBR + +
S1* S0*/VR7*/VR11* CBR
IF (OE) $\quad \begin{aligned} \mathrm{S} 15= & \mathrm{S} 1 * / \mathrm{SO} \text { VR4 } \\ & \mathrm{S} 1 * \mathrm{SO} / \mathrm{VR7*} \text { VR11*/CBR } \quad+ \\ & \mathrm{S}^{*} \mathrm{SO} 0^{*} / \mathrm{VR} 7 * / V R 11 * \mathrm{CBR}\end{aligned}$

FUNCTION TABLE
VR3 VR4 VR5 VR6 VR7 VR11 CBR S1 S0 /OE S3 S5 S6 S11 S12 S13 S14 S15
;SELECT ZEROS


DESCRIPTION
THE IMPLEMENTATION OF THE SBUS CONTROL REQUIRES TWO AMPALI6H8AS. THE FUNCTIONS PERFORMED BY THE PALS ARE CONTROLLED BY MICROCODE INPUTS SBUS SEL $\langle 1: 0\rangle$. FOR IMMEDIATE DESTINATION OPERANDS, THESE PALS PERFORM SIGN EXTENSION. IF A CBR INSTRUCTION IS SELECTED, A SIGN EXTENDED BRANCH OFFSET IS DERIVED FROM VR<9:0>. VR<11> AND THE CBR FLAG INITIATE A bRanch when they are the same polarity, at which time the offset is adDED TO THE PC. IF THE BRANCH CONDITION IS NOT MET, -1 IS ADDED TO THE PC TO RESUME PROPER INSTRUCTION EXECUTION. THE SBUS CONTROL B PAL CONTROLS SBUS $\langle 15: 11,6: 5,3>$.

PAL16H8
Pat019
SBUS CONTROL B
ADVANCED MICRO DEVICES
*D9725
*FO*
L0000 11111111111111111111111111111110 * L0032 11011111111111111111111101111011 * L0064 11101111111111110111101101110111 * L0096 11101111111111111011011101110111 * L0256 11111111111111111111111111111110 * L0288 01111111111111111111111101111011 * L0320 11111011111111110111101101110111 * L0352 11111011111111111011011101110111 * Lo512 11111111111111111111111111111110 * L0544 01111111111111111111111101111011 * L0576 11111111101111110111101101110111 * L0608 11111111101111111011011101110111 *
 L0800 01111111111111111111111101111011 * L0832 11111111111110110111101101110111 * L0864 11111111111110111011011101110111 * L1024 111111111111111111111111111111110 * L1056 01111111111111111111111101111011 L1088 11111111111110110111101101110111 L1120 11111111111110111011011101110111 * L1280 11111111111111111111111111111110 * L1312 01111111111111111111111101111011 * L1344 11111111111110110111101101110111 * L1376 11111111111110111011011101110111 * L1536 11111111111111111111111111111110 * L1568 01111111111111111111111101111011 * L1600 11111111111110110111101101110111 * L1632 11111111111110111011011101110111 * L1792 11111111111111111111111111111110 * L1824 01111111111111111111111101111011 * L1856 11111111111110110111101101110111 * L1888 11111111111110111011011101110111 * C7631*
V0001 XXxxxxx0000LLLLLLLLL1 * V0002 XXXXXXX0100LLLLLLLL1 * V0003 0101XXX1000HHHHHHHL
V0004 1010xXx1000LLLLLLLLH1
V0005 1X111101100LLLLLLLLL v0006 0x101101100LLLLLLHLH1
V0007 1X010011100HHHHHLHL1
V0008 0х000011100НнННнННН1 80F0


PAL16R4
PATO20
PAL DESIGN SPECIFICATION
PROGRAM COUNTER A ADVANCED MICRO DEVICES

| CLK | Y3 | Y2 | Y1 | Y0 | CI | S1 | S0 /OEA GND |  |
| ---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| /OER | A0 | A1 | R0 | R1 | R2 | R3 | A2 | A3 |

;PROGRAM COUNTER A OUTPUT


/R2 :=/S0*/S1*/Y2 + SO* $/ \mathrm{S} 1^{*} \mathrm{R} 2^{*} \mathrm{R} 1^{*} \mathrm{RO}$ * $\mathrm{CI}+$ SO*/S1*/R2*/CI + | $\mathrm{SO} 0^{*} / \mathrm{S} 1^{*} / \mathrm{R} 2^{*} / \mathrm{R1}$ | + |
| :--- | :--- |
| $\mathrm{SO} \mathrm{O}^{*} / \mathrm{S} 1 * / \mathrm{R} 2^{*} / \mathrm{RO}$ | + | S1*/R2

$/ \mathrm{R} 1 \quad:=/ \mathrm{SO} * / \mathrm{S} 1 * / \mathrm{Y} 1$
$+$
SO*/S1* R1* RO* CI
+
+

+ SO \%/S $1 * / \mathrm{R} 1 * / \mathrm{RO}+$ S1*/R1

$$
\begin{aligned}
& / \mathrm{RO} \quad:=/ \mathrm{SO} 0^{*} / \mathrm{S} 1^{*} / \mathrm{YO} \\
& \mathrm{SO}^{*} / \mathrm{S} 1 * \mathrm{RO} \mathrm{RO}^{*} \mathrm{CI} \\
& \text { SO*/S1*/RO*/CI }+ \\
& \text { S1*/RO }
\end{aligned}
$$

| IF (OEA) $/ \mathrm{A} 1$ | $=/ \underset{S}{\mathrm{~S} 1 \% / \mathrm{R} 1}$ | + |
| :--- | :--- | :--- |
| IF (OEA) $/ \mathrm{AO}$ | $=\underset{S}{\mathrm{~S} 1 * / R 0}$ | + |

FUNCTION TABLE
CLK /OEA /OER. S1 SO Y3 Y2 Y1 Yo CI A3 A2 A1 A0 R3 R2 R1 R0


## DESCRIPTION

THE PROGRAM COUNTER EXAMPLE USED HERE SHOWS HOW PALS CAN BE USED
IN THE DESIGN TO IMPLEMENT DATA STEERING. THE PC IS IMPLEMENTED
AS AN INCREMENTING REGISTER THAT CAN BE PARALLEL LOADED FROM THE
YBUS. THE PC IS USED TO SOURCE THE ABUS WITH MEMORY ADDRESSES
FOR INSTRUCTIONS, AND ALSO SOURCES THE RBUS FOR RELATIVE BRANCH
CALCULATIONS. PROGRAM COUNTER A GENERATES ZEROS IN THE 12 MOST SIGNIFICANT BITS FOR TRAPS AND INTERRUPTS AS WELL. THESE 3 IDENTICALLY PROGRAMMED AMPAL16R4AS, CALLED PROGRAM COUNTER A, ARE THE 3 MOST SIGNIFICANT SLICES OF THE 4-SLICE PROGRAM COUNTER.

PALI6R4
PAT020
PROGRAM COUNTER A
ADVANCED MICRO DEVICES
*D9724
*FO*
L0000 111111111111111111111111.11111011 *
L0032 111111111111011111111101111111111 *
L0064 11111111.111111111111011111111111 *
L0256 11111111111111111111111111111011 *
L0288 1111111111111110.1111101111111111 *
L0320 11111111111111111111011111111111 *
L0512 10111111111111111111101110111111 *
L0544 11111111110111010101100101111111 *
L0576 11111111111011111011101101111111 *
L0608 11111111111011101111101101111111 *
L0640 11111111111011111110101101111111 *
L0672 11111111111011111111101001111111 *
L0704 11111111111011111111011111111111 *
L0768 1111: 1011111111111111101110111111 *
L0800 11111111111111010101100101111111 *
L0832 11111111111111101011101101111111 *
‘L0864 11111111111111101110101101111111 *
L0896 11111111111111101111101001111111 *
L0928 11111111111111101111011111111111 *
L1024 11111111101111111111101110111111 *
L1056 11111111111111110101100101111111 *
L1088 11111111111111111010101101111111 *
L1120 11111111111111111110101001111111 *
L1152 11111111111111111110011111111111 *
L1280 11111111111110111111101110111111 *
L1312 11111111111111110111100101111111 *
L1344 11111111111111111011101001111111 *
L1376 11111111111111111111011011111111 *
L1536 11111111111111111111111111111011 *
L1568 11111111111111111110101111111111 *
L1600 11111111111111111111011111111111 *
L1792 11111111111111111111111111111011 *
L1824 $111111111 \quad 11111111111110101111.1111$ *
L1856 11111111111111111111011111111111 *
C7B62*
V0001 C0101X00100ZZHLHLZZ1 *
V0002 CXXXX001100ZZHLHLZZ1 *
V0003 CXXXX101100ZZLHHLZZ1 *
V0004 CXXXX101100ZZHHHLZZ1 *
V0005 CXXXX101100ZZLLLLHZZ1
V0006 CXXXX101100ZZHLLLHZZ1
V0007 CXXXX101100ZZLHLHZZ1 *
V0008 CXXXX101100ZZHHLHZZ1
V0009 CXXXX101100ZZLLHHZZ1 *
V0010 CXXXX101100ZZHLHHZZ1 *
V0011 CXXXX101100ZZLHHHZZ1 *
V0012 CxxxX101100ZZHHHHZZ1 *
V0013 CXXXX101100ZZLLLLZZ1
V0014 CXXXX101100ZZHLLLZZ1 *
V0015 CXXXX101100ZZLHLLZZZ1 *
V0016 CXXXX101100ZZHHLLZZ1
V0017 CXXXX101100ZZLLHLZZ1
V0018 CXXXX101100ZZHLHLZZ1 *
V0019 CXXXXX1X100ZZHL.HLZZ1 V0020 XXXXXXXX001HLZZZZHL1 * V0021 XXXXXX1X001LIZZZZLL1 F390

PAL DESIGN SPECIFICATION JENNY YEE $10 / 4 / 82$


PAL16R4
PATO21
PAL DESIGN SPECIFICATION
JEFF KITSON 10/4/82

PROGRAM COUNTER B
ADVANCED MICRO DEVICES
CLK Y3 Y2 Y1 Y0 CI S1 S0 /OEA GND
/OER A0 A1 R0 R1 R2 R3 A2 A3 VCC
; PROGRAM COUNTER B OUTPUT SIGNALS
$\operatorname{IF}(\mathrm{OEA}) / \mathrm{A} 3 \quad=/ \underset{\mathrm{S} 1}{\mathrm{~S} 1 \% / \mathrm{R} 3}+$
$\operatorname{IF}($ OEA ) $/ \mathrm{A} 2=/ \mathrm{S} 1 * / \mathrm{R} 2$ S1*/S0
/R3 : = /SO*/S1*/Y3 $\mathrm{SO}^{*} / \mathrm{S}_{1}^{*} \mathrm{R} 3^{*} \mathrm{R} 2 * \mathrm{R1*} \mathrm{RO}^{*} \mathrm{CI}{ }^{+}+$ SO*/S1*/R3*/CI
$+$ SO*/S1*/R3*/R2 + SO*/S1*/R3*/R1 + SO \%/S1*/R3*/RO + S1*/R3
$/ \mathrm{R} 2 \quad:=\quad / \mathrm{SO} * / \mathrm{S} 1^{*} / \mathrm{Y} 2$ SO*/S1* R2* R1* RO* CI + $\mathrm{SO} * / \mathrm{S} 1 * / \mathrm{R} 2 * / \mathrm{CI}+$ SO*/S1*/R2*/R1 + SO */S1*/R2*/RO + S1*/R2
$/ \mathrm{R1} \quad:=/ \mathrm{SO}^{*} / \mathrm{S} 1^{*} / \mathrm{Y} 1$ SO*/S1*R1*RO* CI SO*/S1*/R1*/CI SO*/S1*/R1*/RO S1*/R1
/RO $\quad:=/ \mathrm{SO} * / \mathrm{S} 1 * / \mathrm{YO}$ SO*/S1* RO* CI SO*/S1*/RO*/CI S1*/R0
$\operatorname{IF}$ (OEA) $/ \mathrm{Al}=/ \mathrm{R} 1 * / \mathrm{S} 1$
$\operatorname{IF}$ (OEA) $/ \mathrm{AO}=/ \mathrm{S} 1^{*} / \mathrm{RO}$

FUNCTION TABLE

|  | /OEA | /OER | SR S1 S0 | Y3 Y2 |  |  |  |  |  | A3 | A2 |  | A1 | A0 |  | R3 | R2 | R1 |  | R0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ; LOAD REGISTERS FROM YbuS and OUTPUT ONTO RBUS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | H | L | L L | L H | L | H | X |  |  |  |  |  | Z |  | 2 | L | H | L |  | H |
| ; INCREMENT REGISTERS REG=REG + CI |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | H | L | L H | $X \quad \mathrm{X}$ | X | X |  |  |  | 2 |  |  | 2 |  | 2 | L | H | L |  | H |
| C | H | L | L H | X X | X | X | H |  |  | 2 |  |  | Z |  | 2 | L | H | H |  | L |
| C | H | L | L H | $X$ X | X | X | H |  |  | 2 | 2 |  | 2 |  | Z | L | H | H |  | H |
| C | H | L | L H | X X | X | X | H |  |  | 2 |  |  | 2 |  | Z | H | L | L |  | L |
| C | H | L | L H | X X | X | X |  |  |  | 2 | 2 |  | 2 |  | Z | H | L | L |  | H |
| C | H | L | L H | X | X | X | H |  |  | Z | 2 |  | 2 |  | Z | H | L | H |  | L |
| C | H | L | L H | X X | X | X |  |  |  | 2 | 2 |  | Z |  | 2 | H | L | H |  | H |
| C | H | L | L H | X X | X | X | H |  |  | 2 | Z |  | 2 |  | 2 | H | H | L |  | L |
| C | H | L | L H | $X$ X | X | X | H |  |  | Z | Z |  | Z |  | Z | H | H | L |  | H |
| C | H | L | L H | X X | X | X | H |  |  | 2 |  |  | 2 |  | Z | H | H | H |  | L |
| C | H | L | L H | X X | X | X | H |  |  | 2 | Z |  | 2 |  | 2 | H | H | H |  | H |
| C | H | L | L H | X X | X | X | H |  |  | 2 | 2 |  | 2 |  | 2 | L | L | L |  | L |
| C | H | L | L H | X X | X | X |  |  |  | 2 |  |  | Z |  | z | L | L | L |  | H |
| C | H | L | L H | X X | X | X | H |  |  | Z |  |  | 2 |  | Z | L | L | H |  | L |
| C | H | L | L H | X X | X | X | H |  |  | Z | 2 |  | Z |  | Z | L | L | H |  | H |
| C | H | L | L H. | X X | X | X | H |  |  | Z |  |  | Z |  | Z | L | H | L |  | L |
| C | H | L | L H | X X | X | X | H |  |  |  |  |  | 2 |  | Z | L | H | L |  | H |
| ; HOLD VALUE IN REGISTERS AND OTPUT ONTO RBUS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | H | L | H X | X X | X | X | $X$ |  |  | 2 |  |  | 2 |  | Z |  | H | L |  | H |
| ; OUTPUT THE |  |  | CURRENT | Value | ONT | TO | THE |  | BUS | AND |  |  |  |  |  | HE R |  |  |  |  |
| X | L | H | L X | X X | X | X |  |  |  | L |  |  | L |  | H | Z | 2 | Z |  | Z |
| $\underset{\mathrm{x}}{\text {; OUTPUT }} \underset{\mathrm{L}}{\text { TWO }}$ |  |  | ONTO THE | ABUS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | H L | X X | X | X | X |  |  | L |  |  | H |  | L | Z | Z | Z |  | Z |
| ; OU | TPUT S | SIX | ONTO THE | ABUS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | L | H | H H | X X | X | X | X |  |  | L |  |  | H |  | L | Z | Z | Z |  | Z |

DESCRIPTION
PROGRAM COUNTER B IS THE LEAST SIGNIFICANT SLICE OF THE PROGRAM COUNTER. THIS SLICE OF THE PROGRAM COUNTER IS FUNCTIONALLY THE SaME as Program counter a. the constants two and six are generated FOR TRAPS AND INTERRUPTS.

PAL16R4
PAT021
PROGRAM COUNTER B
ADVANCED MICRO DEVICES
*D9724
*FO*
L0000 11111111111111111111111111111011
L0032 11111111111011111111101111111111
L0064 11111111111111111111011111111111 *
L0256 11111111111111111111111111111011 *
L0288-1111 1111111111101111101111111111 *
L0320 11111111111111111111011110111111 *
L0512 10111111111111111111101110111111 *
L0544 11111111110111010101100101111111 *
L0576 11111111111011111011101101111111 *
L0608 11111111111011101111101101111111 *
L0640 11111111111011111110101101111111 *
L0672 11111111111011111111101001111111 *
L0704 11111111111011111111011111111111 *
L0768 11111011111111111111101110111111 *
L0800 11111111111111010101100101111111 *
L0832 11111111111111101011101101111111 *
L0864 11111111111111101110101101111111 *
L0896 11111111111111101111101001111111 *
L0928 11111111111111101111011111111111 *
L1024 11111111101111111111101110111111 *
L1056 11111111111111110101100101111111 *
L1088 11111111111111111010101101111111 *
L1120 111111111111111111101010.01111111 *
L1152 11111111111111111110011111111111 *
L1280 11111111111110111111101110111111 *
L1312 11111111111111110111100101111111 *
L1344 11111111111111111011101001111111 *
L1376 11111111111111111111011011111111 *
L1536 1111 1111111111111111111111111011 *
L1568 11111111111111111110101111111111 *
$\begin{array}{lllllllll}\text { L1792 } & 1111 & 1111 & 1111 & 1111 & 1111 & 1111 & 1111 & 1011\end{array}$
L1824 11111111111111111111101011111111 *
L1856 11111111111111111111011111111111 *
C7774*
V0001 C0101X00100ZZHLHLZZ1 *
V0002 CXXXX001100ZZHLHLZZ1 *
V0003 CXXXX101100ZZLHHLZZ1 *
V0004 CXXXX101100ZZHHHLZZ1 *
V0005 CXXXX101100ZZLLLLHZZ1 *
V0006 CXXXX101100ZZHLLHZZ1 *
V0007 CXXXX101100ZZLHLHZZ1 *
V0008 CXXXX101100ZZHHLHZZ1
V0009 CXXXX101100ZZLLHHZZ1
V0010 CXXXX101100ZZHLHHZZ1
V0011 CXXXX101100ZZLHHHZZ1
V0012 CXXXX101100ZZHHHHZZ1
V0013 CXXXX101100ZZLLLLZZ1 *
V0014 CXXXX101100ZZHLLLZZ1
V0015 CXXXX101100ZZLHLLZZ1
V0016 CXXXX101100ZZHHLLZZ1.
V0017 CXXXX101100ZZLLHLZZZ1
V0018 CXXXX101100ZZHLHLZZ1 *
V0019 CXXXXX1X100ZZHLHLZZ1 *
V0020 XXXXXX0X001HLZZZZHL1
V0021 XXXXXX10001LHZZZZLL1 *
V0022 XXXXXX11001LHZZZZHL1 *
F275

PAL DESIGN SPECIFICATION
JEFF KITSON 10/4/82

## LOGIC DIAGRAM FOR: <br> PROGRAM COUNTER B USING AmPAL16R4A

Columns: Inputs (0-31)


PAL16H8
PAT015
PC CARRY GENERATOR
ADVANCED MICRO DEVICES
A0 A1 A2 A3 A4 A5 A6 A7 A8 GND
A9 C01 C02 C03 A10 Al1 SL1 CI NC VCC

PAL DESIGN SPECIFICATION JEFF KITSON 10/4/82
; PC CARRY GENERATOR OUTPUT SIGNALS
C03

$$
=\mathrm{SL1} * \mathrm{CI}
$$

/SL1*CI*AO*A1*A2*A3*A4*A5*A6*A7*A8*A9*A10*A11
C 02 = SL1*CI + /SL1* ${ }^{\mathrm{CI}}{ }^{*} \mathrm{AO}^{*} \mathrm{~A} 1^{*} \mathrm{~A}^{2}{ }^{*} \mathrm{~A}^{*}{ }^{*} \mathrm{~A}^{*}{ }^{*} \mathrm{~A}^{*}{ }^{*} \mathrm{~A}^{*} \mathrm{~A} 7$
$\mathrm{CO1}$
$=\mathrm{SL} 1 * \mathrm{CI}$
/SL1*CI*AO*A1*A2*A3
FUNCTION TABLE
A0 A1 A2 A3 A4 A5 A6 A7 A8 A9 A10 A11 CI SL1 C01 C02 C03

| X | X | X | X | X | X | X | X | X | X | X | X | H | H | H | H | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| H | H | H | H | H | H | H | H | H | H | H | H | H | L | H | H | H |
| H | H | H | H | H | H | H | H | L | L | L | L | H | L | H | H | L |
| H | H | H | H | L | L | L | L | H | H | H | H | H | L | H | L | L |
| L | L | L | H | H | H | H | H | H | H | H | H | L | L | L | L |  |

DESCRIPTION
THE 4-BIT OUTPUTS FROM THE 3 LEAST SIGNIFICANT SLICES OF THE 4SLICE PC ARE USED TO CREATE A 12-BIT INPUT TO THE PC CARRY GENERATOR. THE PC CARRY GENERATOR TAKES THESE INPUTS AND GENERATES THE CARRY-IN FOR THE 3 MOST SIGNIFICANT SLICES OF THE PROGRAM COUNTER. THE PC CARRY GENERATOR IS CONTROLLED BY THE PC SELECT INPUT FROM MICROCODE.

PAL16H8
PAL DESIGN SPECIFICATION
PAT015
PC CARRY GENERATOR
ADVANCED MICRO DEVICES
*D9725
*F0*
L1280 11111111111111111111111111111111 *
L1312 11111101110111111111111111111111 *
L1344 01010101011001010101011101110101 *
L1536 11111111111111111111111111111111 *
L1568 11111101110111111111111111111111 *
L1600 01010101011001110111011101111111 *
L1792 11111111111111111111111111111111 *
L1824 11111101110111111111111111111111 *
L1856 01010101011011111111111111111111 * C211E*
V0001 XXXXXXXXXOXHHHXX11X1 * V0002 11111111101HHH1101XI * V0003 11111111000 HHL 0001 XI * V0004 11110000101HLL1101X1 * V0005 $00001111101 \mathrm{LLL} 1101 \mathrm{X1}$ * A5CF


PAL16R4
PATO10
MEMORY ADDRESS REGISTER
ADVANCED MICRO DEVICES
CLK Y3 Y2 Y1 YO S1 S0 A3 /BI GND
/OE /BO A0 B0 B1 B2 B3 A1 A2 VCC
;MAR OUTPUT SIGNALS
/B3 $\quad:=/ \mathrm{S1}^{*} / \mathrm{SO}^{*} / \mathrm{B} 3$
/S1* SO*/Y3 S1*/S0*/A3
$\mathrm{S} 1 * \mathrm{SO}^{*} \mathrm{~B} 3 * / \mathrm{B} 2 * / \mathrm{Bl} * / \mathrm{BO} * \mathrm{BI}$ S1* SO*/B3* B2
S1* SO*/B3* B1 S1* SO*/B3* BO S1*SO*/B3*/BI
/B2
$:=/ \mathrm{S} 1 * / \mathrm{SO} * / \mathrm{B} 2$
/S1* SO*/Y2
$\mathrm{S} 1 * / \mathrm{SO}$ */A2
$\mathrm{S} 1 * \mathrm{SO} * \mathrm{~B} 2 * / \mathrm{B} 1 * / \mathrm{BO} * \mathrm{BI}$
S1* SO*/B2* B1
S1* SO*/B2* BO S1* SO*/B2*/BI
/B1

$$
:=/ \mathrm{S} 1^{*} / \mathrm{S} 0^{*} / \mathrm{B} 1
$$

$$
/ \mathrm{S} 1 \div \mathrm{SO}^{*} / \mathrm{Y} 1
$$ $\mathrm{S} 1 * / \mathrm{SO}$ */Al S1* S0* B1*/BO*BI S1* SO*/B1* BO $\mathrm{S} 1 * \mathrm{~S} 0^{*} / \mathrm{B} 1^{*} / \mathrm{BI}$

/BO

$$
:=/ \mathrm{S} 1^{*} / \mathrm{SO}^{*} / \mathrm{BO}
$$ /S1* S0*/Y0 $\mathrm{S} 1 * / \mathrm{SO} * / \mathrm{AO}$ S1* SO* BO* BI Sl* SO* ${ }^{*} \mathrm{BO}^{*} / \mathrm{BI}$

BO
$=/ \mathrm{B} 3 * / \mathrm{B} 2 * / \mathrm{B} 1 * / \mathrm{BO} * \mathrm{BI}$

PAL DESIGN SPECIFICATION
JENNY YEE 10/4/82

[^2]FUNCTION TABLE
CLK /OE S1 SO Y3 Y2 Y1 Y0 A3 A2 A1 A0 /bI /BO B3 B2 B1 B0


## DESCRIPTION

THE MEMORY ADDRESS REGISTER (MAR) IS USED FOR PLACING ADDRESSES ON THE MEMORY ADDRESS BUS WHEN FETCHING OPERANDS FROM MEMORY FOR SOURCE AND DESTINATION. IT IS ALSO USED TO HOLD THE MEMORY DESTINATION ADDRESS FOR STORING RESULTS FROM AN OPERATION. THE MAR HAS THE CAPABILITY TO DECREMENT TO SUPPORT THE SPECIAL LOAD MEMORY AND STORE MEMORY INSTRUCTIONS. THESE MAR OPERATIONS ARE CONTROLLED BY MAR SEL<1:0>. THE MAR IS IMPLEMENTED USING FOUR AMPAL16R4AS.

PAL16R4
PAT010
MEMORY ADDRESS REGISTER
ADVANCED MICRO DEVICES
*D9724
*FO*
L0512 11111111111011111011101111111111 *
L0544 10111111111111111011011111111111 *
L0576 11111111111111110111101110111111 * L0608 11111111110111100110011011111011 * L0640 1111111111101101011101111111.1111 * L0672 11111111111011110101011111111111 * L0704 11111111111011110111010111111111 * L0736 11111111111011110111011111110111 * L0768 11111111111111101011101111111111 *
L0800 11111011111111111011011111111111 *
L0832 11101111111111110111101111111111 *
L0864 11111111111111010110011011111011 *
L0896 11111111111111100101011111111111 *
L0928 11111111111111100111010111111111 *
L0960 11111111111111100111011111110111 *
L1024 11111111111111111010101111111111 *
L1056 11111111101111111011011111111111 *
L1088 11111110111111110111101111111111 *
L1120 11111111111111110101011011111011 *
L1152 11111111111111110110010111111111 *
L1184 11111111111111110110011111110111 *
L1280 11111111111111111011101011111111 *
L1312 11111111111110111011011111111111 *
L1344 11111111111111110111101111101111 *
L1376 11111111111111110111010111111011 *
L1408 11111111111111110111011011110111 *
L1792 111111111111111111111111111111111 *
L1824 11111111111011101110111011111011 *
C63A8*
V0001 C010101XX00XXHLHLXX1 *
V0002 CXXXX101X00XOLHLH101 *
V0003 CXXXX00XX00XXLHLHXX1 *
V0004 CXXXX11X100HXLHLHXX1
V0005 CXXXX11X000HXHLLHXX1
V0006 CXXXX11X000HXLLLHXX1 *
V0007 CXXXX11X000HXHHHLXX1
V0008 CXXXX11X000HXLHHLXX1 *
V0009 CXXXX1 1X000HXHLHLXX1 *
V0010 CXXXX11X000HXLLHLXX1 *
V0011 CXXXX11X000HXHHLLXX1 *
V0012 CXXXX11X000HXLHLLXX1 *
V0013 CXXXX11X000HXHLLLLXXI *
V0014 CXXXX11X000LXLLLLXXX1 *
V0015 CXXXX1IX000HXHHHHXX1 *
V0016 CXXXX1 $1 \times 000$ HXLHHHXX1 * .
V0017 CXXXX11X000HXHLHHXX1
V0018 CXXXX11X000HXLLHHXX1
V0019 CXXXX11X000HXHHLHXX1
V0020 CXXXX11X000HXLHLHXX1 *
B9E4


PAL16R4
PAT011
MEMORY DATA REGISTER (1) ADVANCED MICRO DEVICES
CLK Y3 Y2 Y1 YO NC /CE S /OED GND
/OER /DO /D1 /R0 /R1 /R2 /R3 /D2 /D3 VCC
;MDR OUTPUT SIGNALS
IF (OED) D3 $=\mathrm{R} 3$
IF (OED) D2 $=\mathrm{R} 2$


R2

R1 $\begin{aligned}:= & / \mathrm{CE*R1} \\ & C \mathrm{CE}^{*} \mathrm{~S}^{*} \mathrm{D} 1 \\ & \mathrm{CE} * / \mathrm{S}^{*} / \mathrm{Y} 1\end{aligned}+$
RO $\quad:=\underset{C E * R O}{ } \quad+$ CE*/S*/YO

IF (OED) D1 $=\mathrm{R} 1$
IF (OED) DO $=$ RO

PAL DESIGN SPECIFICATION JENNY YEE

10/4/82

FUNCTION TABLE
CLK OED OER S Y3 Y2 Y1 Y0 /CE /D3 /D2 /D1 /DO /R3 /R2 /R1 /RO
;LOAD REGISTERS FROM YBUS AND OUTPUT ONTO RBUS

| C | L | H | L | L | H | L | H | L | Z | Z | Z | Z | L | H | L | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | ; LOAD REGISTERS FROM DBUS AND OUTPUT ONTO RBUS

 ; HOLD VALUE AND OUTPUT ONTO RBUS

| C | L | H | X | X | X | X | X | H |  | Z | Z | Z | Z |  | H | L | H |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

; OUTPUT VALUE ONTO DBUS AND NOT ONTO RBUS


DESCRIPTION
THE MEMORY DATA REGISTER 1 (MDR1) IS AN I/O REGISTER WITH MULTIPLE INPUT AND OUTPUT PATHS TO FACILITATE READING AND WRITING DATA FROM MEMORY. IT MAY BE LOADED FROM EITHER THE YBUS (WRITE) OR DBUS (READ) AND OUTPUT ON THE RBUS (READ) OR DBUS (WRITE). IT IS IMPLEMENTED USING FOUR AMPAL16R4AS AND CONTROLLED FROM MICROCODE.

PAL16R4
PATO11
MEMORY DATA REGISTER (1)
ADVANCED MICRO DEVICES
*D9724
*FO*
L0000 11111111111111111111111111111011 *
L0032 11111111111011111111111111111111 *
L0256 11111111111111111111111111111011 *
L0288 11111111111111101111111111111111 *
L0512 11111111111011111111011111111111 *
L0544 11101111111111111111101101111111 *
$\begin{array}{lllllllllllll}2 & 10571 & 1111 & 1111 & 1111 & 1111 & 1011 & 1011 & 1111 & *\end{array}$

L0800 11111110111111111111101101111111 *
L0832 11111011111111111111101110111111 *
L1024 111111111111111111110011111111111 *
L1056 11111111111111111111101101101111 *
L1088 11111111101111111111101110111111 *
L1280 11111111111111111111011011111111 *
L1312 11111111111111111111101101111110 *
L1344 11111111111110111111101110111111 *
$\begin{array}{llllllllll}\text { L1536 } & 1111 & 1111 & 1111 & 1111 & 1111 & 1111 & 1111 & 1011\end{array}$
$\begin{array}{llllllllll}\text { L1568 } & 1111 & 1111 & 1111 & 1111 & 1110 & 1111 & 1111 & 1111 & * \\ \text { L1792 } & 1111 & 1111 & 1111 & 1111 & 1111 & 1111 & 1111 & 1011 & *\end{array}$
L1824 11111111111111111111111011111111 *
C4A70*
V0001 C0101X00100ZZHLHLZZ1 *
V0002 CXXXXX0110001LHLHO11 *
V0003 CXXXXXIX100ZZLHLHZZ1 *
V0004 CXXXXXX1X000LHLHLHLH1 *
015E

PAL DESIGN SPECIFICATION JENNY YEE 10/4/82

## LOGIC DIAGRAM FOR:

MDR $_{1}$ USING AmPAL16R4A
Columns: Inputs (0-31)


PAL16R6
PAT018
MICROBRANCH CONTROL
ADVANCED MICRO DEVICES

CLK S2 S1 S0 DR0 DR1 DR2 INT LDINT GND /OE VRO INTENB/OEVEC /OEJMP /OEMAP2 /OEMAP1 INTFLAG CXV VCC ;MICROBRANCH EQUATIONS

| /INTFLAG | : $=$ | /INT |  |
| :---: | :---: | :---: | :---: |
| OEMAP1 | := | /S2*/S1*/S0 | + |
|  |  | /S2* S1* S0*/INTENB | + |
|  |  | /S2* S1* S0*/INTFLAG |  |
| OEMAP2 | := | /S2*/S1* S0 |  |
| OEJMP | := | /S2* S1*/S0 | + |
|  |  | S2*/S1*/S0* DRO | $+$ |
|  |  | S2*/S1* DR1 | + |
|  |  | S2*/S1* DR2 | + |
|  |  | S2*/S1* S0*/DR0 | + |
|  |  | S2*. S1*/S0*/CXV |  |
| OEVEC |  | /S2* S1* S0* INTFLAG* INTENB | + |
|  |  | S2*/S1*/S0*/DRO*/DR1*/DR2 | + |
|  |  | S2*/S1* SO* DR0*/DR1*/DR2 | + |
|  |  | S2* S1*/SO* CXV |  |
| /INTENB |  | = LDINT*/VRO | + |
|  |  | /LDINT*/INTENB |  |

FUNCTION TABLE
CLK /OE S2 Sl SO DR2 DR1 DRO INT LDINT VRO CXV INTFLAG INTENB OEMAP1 OEMAP2 OEJMP OEVEC


| ; UNCONDTIONAL BRANCH |  |
| :---: | :---: |
| C L L L L X X X X X X X | X X H L L L |
| C L L L H X X X X X X X | - X X L H L L |
| C L L H L X X X X X X X | X X L L H L |
| ; SET INTENB AND INTFLAG |  |
| C L X X X X X X H H H X | H H X X X X |
| ;TEST FOR INTERRUPTS |  |
| C L L H H X X X L X X X | L H L L L H |
| C L L H H X X X H H L X | H L H L L L |
| C L L H H X X X X X X X | X X H L L L |
| ;DECREMENT COUNTER $=0$ |  |
| C L H L L L L L X X X X | X X L L L H |
| C L H L L L L H X X X X | X X L L H L |
| C L H L L X H X X X X X | X X L L H L |
| C L H L L H X X X X X X | X X L L H L |
| ; DECREMENT COUNTER $=1$ |  |
| C L H L H L L H X X X X | X X L L L H |
| C L H L H X X L X X X X | X X L L H L |
| C L H L H X H H X X X X | X X L L H L |
| C L H L H H X H X X X X | X X L L H L |
| ;TEST FOR CONDITIONAL BRANCH |  |
| C L H H L X X X X X X L | X X L L H L |
| C L H H L X X X X X X H | X X L L L H |

## DESCRIPTION

THE MICROBRANCH PAL, AN AMPAL16R6A, IS USED TO CONTROL BRANCHING IN THE MICROSEQUENCER. IT OPERATES BY SELECTING THE PROPER BRANCH CONDITION (UNCONDITIONAL, INTERRUPT, COUNTER=0, COUNTER=1, CBR FLAG), TESTING THE CONDITION, AND THEN ACTIVATING ONE OF FOUR POSSIBLE ADDRESS SOURCE OUTPUT ENABLES DEPENDENT UPON THE STATUS OF THE CONDITION TESTED. THE SELECT INPUTS ARE FROM MICROCODE PROM AND THE OUTPUT ENABLES GENERATED BY THE MICROBRANCH PAL ARE ACTUALLY PART OF THE MICROCODE PIPELINE REGISTER.
NOTE ALSO THAT INTERRUPT SYNCHRONIZATION AND CONTROL are also integrated into the microbranch pal.

PAL16R6
PAL DESIGN SPECIFICATION
PAT018
MICROBRANCH CONTROL
ADVANCED MICRO DEVICES
*D9724
*FO*
L0256 11111111111111111111111110111111 * L0512 1011. 1011101111111111111111111111 *
L0544 10110111011111111111111111101111 * L0576 10110110011111111111111111111111 *
L0768 10111011011111111111111111111111 *
L1024 10110111101111111111111111111111 *
L1056 01111011101101111111111111111111
L1088 01111011111111110111111111111111
L1120 01111011111111111111011111111111
1115201111011011110111111111111111111 *
L1184 01100111101111111111111111111111 *
1128010110101011111111111111111011111 *
L1312 01111011101110111011101111111111 *
L 134401111011011101111011101111111111 *
L1376 01010111101111111111.111111111111 *
L1536 11111111111111111111111111110110 *
L1568 11111111111111111111111111101011 *
C3FEF*
V0001 C000XXXXX00XXHHHLXX1 *
V0002 C001XXXXX00XXHHLHXX1
V0003 C010XXXXX00XXHLHHXX1
V0004 CXXXXXX11001HXXXXHX1
V0005 C011XXX0X00XHLHHHLXI
V0006 C011XXX11000LHHHLLXX1
V0007 C011XXXXX00XXHHHLXX1
V0008 C100000XX00XXLHHHXX1
V0009 C100100XX00XXHLHHXX1
v0010 C100X1XXX00XXHLHHXX1
V0011 C100XX1XX00XXHLHHXX1
V0012 C101100XX00XXLHHHXX1
V0013 C1010XXXX00XXHLHHXX1
V0014 C10111XXXOOXXHLHHXX1
V0015 C1011X1XX00XXHLHHXX1
V0016 C110XXXXX00XXHLHHX01 *
v0017 C110XXXXX00XXLHHHX11 * 43CA

## LOGIC DIAGRAM FOR:

 ${ }_{\mu}$ BRANCH CONTROL USING AmPAL16R6AColumns: Inputs (0-31)
Rows: Product Terms (0-63)


## Section 6

## Testing, Programming, Reliability Information

## Factory Testing of PALs

Advanced Micro Devices' PALs include special test circuitry designed to permit thorough $A C$ and $D C$ testing to be accomplished on an unprogrammed unit. This test circuitry is used to insure good programming yield and to verify that devices will meet all parametric and switching specifications after programming.

Programming circuitry testing includes tests to assure unique addressing of all fuses. To accomplish this, special test pads are provided which are accessible only during wafer probing. Using these, Advanced Micro Devices confirms that each driver is capable of sinking sufficient current to blow fuses and has appropriate saturation characteristics for $A C$ performance. The ability of all circuitry in the programming path to handle the large currents and voltages necessary to blow fuses reliably is also thoroughly checked.
Each PAL has special test fuses. These test fuses are blown during factory testing and demonstrate beyond reasonable doubt that the device is capable of opening all fuses when programmed by the user. They also increase the confidence level in unique addressing.
The special probing pads and test fuses are all employed in programmability testing. This testing coupled with AMD's excellent process control gives industry leading programming yields ( $>98 \%$ ) for all AMD PALs.
Special test circuitry, enabled by means of high voltage signals, checks functionality and DC parameters under conditions that simulate post programming operations. Most of the circuitry and levels that can be involved in operation after programming are checked under worst case conditions. For example, all input buffers are tested for functionality by switching them through a special path to a single output
and all product term AND-gates are switched and sensed for uniqueness and functionality.

The fuses blown during programmability testing also permit $100 \%$ AC testing of a critical path in every device prior to shipment from the factory. These provide correlatable measures of the propagation delay times that the user can expect from his devices after he has placed his own logic in the PAL.

Because of the large.percentage of die area devoted to fixed logic circuitry, all programmable devices from all manufacturers exhibit some percentage of units which fail to function to the desired truth table, even though all fuses are correctly programmed. AMD's special test circuits and extensive factory testing procedures have virtually eliminated this problem. However, to eliminate the possibility of any potential failures reaching the assembly line, the user should exercise the PAL after programming to insure that it functions correctly. This can be performed on an I/C tester, or on some PAL programmers, using user defined test vectors or by comparison against a known good unit.

Test vectors are relatively easy to generate for combinatorial designs using PALs. Sequential function testing is more difficult. AMD PALs are designed to provide the capability of loading the output registers to any desired value during testing. This feature, known as PRELOAD, simplifies functional testing of sequential devices. The following section, Logic Verification for PALs, describes PRELOAD in more detail and provides some guidelines for developing test procedures.

# Logic Verification for PALs 

## by Brad Kitson Advanced Micro Devices

The purpose of logic verification is to prove that a device functions correctly before it is put in a system. A completely reliable logic verification procedure should test all logic transitions of a device, through its normal inputs and outputs, and at normal TTL operating levels. This guarantees all parts of a device are functionally tested in the same way that they will be used in a system.

## BENEFITS OF LOGIC VERIFICATION

The benefits of logic verification are to provide confidence that a device will function in a board. It also reduces production test time and cost because less board and system debug time is necessary. It is estimated that each succeeding level of testing during system production costs up to an order of magnitude more than the preceding level. So; should logic verification find a faulty device before it is put in a board and tested, significant test cost is saved. Should the faulty device be found before getting to system test or final on-site installation check-out, even more is saved. Programmable logic can implement functions on-chip that used to be done
in multiple devices on a board. Thus some board-level testing can be done on programmable logic by logic verification, saving even more testing time and cost. Logic verification can also be beneficial during the initial design phase with programmable logic. The system designer can program a new design into a device and perform logic verification to see if the device performs the function correctly.

## FUSE VERIFY FOR PROMs

With PROMs, logic verification is straightforward. A PROM is simply a read only memory with fuses as the information storage elements. Since the logic function of a PROM is to read out stored information at a given address, logic verification requires reading out and verifying correct status of the fuses at each address, after programming. Therefore, if a PROM verifies as correctly programmed, it is logically correct. Figure 1 shows the block diagram of a PROM. The fuse array is addressed by the input decode and is read from the outputs.


03862A-171

Figure 1. PROM

## FUSE VERIFY FOR PROGRAMMABLE LOGIC

Fuse verification, however, doesn't perform logic verification for programmable logic. Programmable logic devices are programmed and fuse verified like PROMs, but don't logically function like PROMs. Figure 2 shows the block diagram of a registered PAL. The input decode of Figure 1 is again present as an input to the fuse array, but is enabled for programming and fuse verifying only. Instead, additional direct inputs and registered feedback inputs of the PAL serve as the logical inputs to its fuse array. The logical inputs must be disabled during fuse verification thereby losing any logical information from the direct inputs and state information from the feedback inputs. Therefore, fuse verification only helps prove correct programming. Figure 3 shows the block diagram of a combinatorial PAL. The programmable output enable and feedback buffers of this device are also untested during fuse verification. Arrows in Figures 2 and 3 denote the untested hardware blocks.

## INPUT DON'T CARES

Figure 4 shows a simple design example utilizing two separate state machines. The microprogram for both machines is
shown in Table 1. If both machines are implemented individually in SSI/MSI, relatively few don't care conditions result.

Table 1
FSM A

| Current <br> State | Input <br> X | Next <br> State |
| :---: | :---: | :---: |
| 0 | X | 1 |
| 1 | X | 2 |
| 2 | X | 3 |
| 3 | 1 | 2 |
| 3 | 0 | 3 |

FSM B

| Current <br> State | Input <br> $\mathbf{Y}$ | Next <br> State |
| :---: | :---: | :---: |
| 0 | X | 1 |
| 1 | X | 3 |
| 2 | 1 | 1 |
| 2 | 0 | 3 |
| 3 | X | 2 |

03862A-172

Figure 2. Registered PAL


Figure 4

This is because the SSI/MSI used will only be enough to perform the function desired. In contrast, Table 2 shows the microprogram for the implementation of the design example in a single PAL. Since inputs are present for both machines and the PAL is a superset of either function, a large number of don't cares result. The point to be made here is that all don't care conditions must be tested to prove that both machines are still independent. In the example of Figure 4, to fully test FSM A, each state must be tested with every possible state of FSM B. Only in this way can one be sure that FSM A is independent of FSM B. Futhermore, every combination of states in FSM A and FSM B must be tested with all permutations of the input vectors. Table 3 shows the transitions necessary to fully test the first line in Table 2, i.e., the transition of FSM A state 0 to state 1 . In general, the implementation of a logic function in a PAL, or other programmable device, will result in many don't cares since the device will be a superset of the function desired. So, one of the main requirements of logic verification is to prove that don't care conditions indeed don't care. To test all don't cares, an exhaustive list of input vectors is required. Also, in this case, a method is needed to repeatedly get into each state to test each don't care.

## PRELOAD

The capability of Advanced Micro Devices' PALs to PRELOAD internal feedback registers facilitates logical verification for sequential programmable logic. Two complications exist when PRELOAD is not available. First, getting into a given state to test transitions out of that state becomes much more difficult. For example, referring to Figure 4, getting into state 3 of FSM A could require sequencing through states 0,1 , and 2. Furthermore, this would have to be repeated for each test of state 3. Moreover, to test a state in FSM A with a state in FSM B might require a lengthy and sometimes impossible sequence until the desired combination is obtained, i.e., the only way to get into FSM A state 2 and FSM B state $2(2,2)$ from state $(0,0)$ would be to sequence through ( 1,1 ), ( 2,3 ), ( 3,2 ), and ( 3,3 ). This is a difficult task to test just one state transition. With PRELOAD, state $(2,2)$ can be entered directly and tested. Second, power-up initialization becomes very difficult to test. Typically, a state machine has additional don't care states that only affect power-up. Should any of these don't care states be entered on power-up the machine must be able to exit them to start normal operations. Without PRELOAD these states can't be entered and tested to see if they can be exited. PRELOAD allows for these
states to be entered directly and tested. States 0 and 1 of FSM A and state 0 of FSM B are examples of don't care states.

Table 2

| Combined State |  |  |  | Next State |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| FSM | FSM | Inputs |  | FSM |  |
| A | B | X | Y | A | B |
| 0 | X | X | X | 1 | X |
| 1 | X | X | X | 2 | X |
| 2 | X | X | X | 3 | X |
| 3 | X | 1 | X | 2 | X |
| 3 | X | 0 | X | 3 | X |
| X | 0 | X | X | X | 1 |
| X | 1 | X | X | X | 3 |
| X | 2 | X | I | X | 1 |
| X | 2 | X | 0 | X | 3 |
| X | 3 | X | X | X | 2 |

03862A-176

Table 3

| State |  |  |  | Next State <br> FSM |  | FSM | Inputs |  | FSM |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | X | Y | 1 |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 1 |  |  |  |  |  |
| 0 | 0 | 0 | 1 | 1 |  |  |  |  |  |
| 0 | 0 | 1 | 0 | 1 |  |  |  |  |  |
| 0 | 0 | 1 | 1 | 1 |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 1 |  |  |  |  |  |
| 0 | 1 | 0 | 1 | 1 |  |  |  |  |  |
| 0 | 1 | 1 | 0 | 1 |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 1 |  |  |  |  |  |
| 0 | 2 | 0 | 0 | 1 |  |  |  |  |  |
| 0 | 2 | 0 | 1 | 1 |  |  |  |  |  |
| 0 | 2 | 1 | 0 | 1 |  |  |  |  |  |
| 0 | 2 | 1 | 1 | 1 |  |  |  |  |  |
| 0 | 3 | 0 | 0 | 1 |  |  |  |  |  |
| 0 | 3 | 0 | 1 | 1 |  |  |  |  |  |
| 0 | 3 | 1 | 0 | 1 |  |  |  |  |  |
| 0 | 3 | 1 | 1 |  |  |  |  |  |  |

## PAL Programming

AMD PALs are manufactured using the high performance IMOX oxide isolated process and high reliability platinumsilicide fuses. These technologies require the use of specific programming equipment which has been designed to ensure consistent programming yields in excess of $98 \%$. To maintain these extremely high programming yields, AMD subjects all approved PAL programming equipment to a complete testing and qualification procedure which assures the user that the programmer will program AMD PALs reliably.

The fusing algorithm, which is described in detail in the reliability report, is designed to minimize tight tolerance requirements on the programming equipment. A chip enable input is used to gate the fusing current from a programming source voltage on the PAL output. The delivery of fusing current is therefore controlled by the switching speed of the internal PAL circuitry, not by the circuitry in the programmer. This should minimize the need for constant recalibration of a programmer. However, it is recommended that a user's log be maintained with each machine to collect a record of the hours of service use and programming yield of each lot. The programming equipment should be calibrated after every 50 hours of service or whenever programming yields fall below $98 \%$ with AMD PALs.

## PROGRAMMER APPROVAL CRITERIA

Full details of the required programming parameters, waveforms and addressing schemes are provided on each device data sheet. All AMD PAL.s, standard, high speed ('A' versions) and half power ('L' versions) use the same algorithm and can be programmed on identical modules and adapters.

The minimum requirements for approval of a programmer by AMD are that it
-Programs and fuse verifies AMD PALs with the appropriate conditions described on the device data sheet and provides consistent yields in excess of $98 \%$
-Programs the security fuse
-Can program an AMD PAL after master loading from another manufacturer's device.

A desirable feature is the ability to perform logical verification following fuse verification. This will prevent the assembly of a PAL having a logical failure, which cannot be detected from the fuse array alone, into a system.

As noted in the section on testing, all AMD PALs have additional circuitry built into the device to aid detection of logical failures at this point.
Another important feature is the ability to generate output in the JEDEC industry standard Programmable Logic Data Transfer Format. This insures that the equipment will program PALs from all suppliers without special modification or awkward copying procedures.

## QUALIFIED PROGRAMMING EQUIPMENT

The list of AMD qualified PAL programmer models appears below. New programming equipment and vendors are constantly under evaluation. Contact your local AMD Field Applications Engineer or the factory to determine the approval status of any equipment not listed here.
AMD is committed to maintaining continued close working relationships with the major PAL programmer manufacturers so that new programmable logic devices will be properly supported in a timely manner.

| Vendor | Programmer <br> Model(s) | AMD PAL <br> Personality <br> Module | Socket <br> Adapter |
| :--- | :--- | :--- | :--- |
| Data I/O <br> 10525 Willows Rd. N.E. <br> Redmond, WA 98052 | Model-100, 29, <br> 19, or 17 | Logicpak <br> $950-1942-001$ | $715-1947-003$ |
| Digilec, Inc. <br> 7335 E. Acoma Dr. <br> Dept-103 <br> Scottsdale, AZ 85260 | Under Development |  |  |
| Kontron Electronics, Inc. <br> 630 Price Avenue <br> Redwood City, CA 94063 | Model-MPP-80S <br> or EPP80 | MOD-33 | SA37 |
| Stag Microsystems <br> 528-5 Weddel Drive <br> Sunnyvale, CA 94086 | Model-PPX (or) | PPM2200 | Am202S |
| Structured Design, Inc. <br> 1700 Wyatt Drive <br> Suite 3 <br> Santa Clara, CA' 95084 | SD-1000 | On-Board | On-Board |

# AMD Programmable Array Logic Reliability <br> by W. Sievers Advanced Micro Devices 

Advanced Micro Devices' Programmable Array Logic (PAL) devices are based on two key technologies with many years of high volume production experience behind them.

1) IMOX-the basic process technology employed is IMOX, an advanced ion-implanted, oxide isolated structure. IMOX provides very high performance devices with predictable manufacturing yields. It has accumulated many millions of hours of life test history through its application to the Am27S series of PROMs and the Am2900 family of bipolar microprocessors.
A comprehensive report on IMOX reliability titled IMOX RELIABILITY REPORT (AMD publication \#03687A-MPR) is available for those interested in a detailed presentation of this subject.
2) Platinum-silicide fuses-this fuse structure was originally developed for use on Advanced Micro Devices' families of junction isolated PROMs. It quickly established a new standard of excellence for high programming yields and long term reliability. Several years ago it was applied to a new generation of ultra high performance PROMs based on the IMOX process.

This combination of IMOX and platinum-silicide fuses has an outstanding record of reliability which has been verified repeatedly through in-house life testing and by high reliability customer qualification testing and system use.
Advanced Micro Devices' PALs are fabricated with this same combined process technology. Not only is the technology for building PALs and PROMs the same, but also the programming algorithm and programming circuitry used to program the platinum-silicide fuses are the same in all characteristics of importance. The result is that the fusing conditions seen by an AMD PAL fuse are the same as those seen by an AMD PROM fuse.
Due to the common process technology, fuse design and fuse programming circuitry design, reliability and programming yield results are expected to be the same for PALs and PROMs. Data accumulated to date on PALs appears to confirm this expectation.

This report describes:

1) The characteristics of the platinum-silicide fuse and programming conditions for the fuse.
2) The dynamic and static burn-in circuits used for HTRB reliability testing.
3) Reliability results accumulated to date on IMOX PROMs and PALs.

## PLATINUM-SILICIDE FUSE

## Fusing Technique

Advanced Micro Devices' PAL circuits are designed to use a programming algorithm which minimizes the requirements on the programmer yet allows the circuit to fuse the platinumsilicide links quickly and reliably.
The sequence of events to program a fuse are:

1) $V_{C C}$ power is applied to the chip.
2) The address of the fuse to be programmed is selected by TTL levels on the appropriate address pins.
3) The outputs are disabled (Pin 1 serves this purpose on PALs).
4) The programming voltage is then applied to one output.
5) A fuse enable is accomplished by raising an input to a level above normal TTL operating voltage. (Pin 11 is used for this on PALs.) This action gates the current flow through the proper fuse, resulting in an open fuse in a few microseconds.
6) The output programming voltage is lowered and then removed.
7) The device is enabled and clocked if required. The output state then indicates whether successful programming has occurred. If programming has not occurred a sequence of much longer pulses is applied until programming occurs.
8) The sequence of 2 through 7 is repeated for each bit which must be programmed.
There are several advantages to this technique relative to that used by other PAL manufacturers. First, the two high current power sources, $\mathrm{V}_{\mathrm{CC}}$ and the voltage applied to the output, do not have critical timing requirements. As the fusing current is gated through the fuse actively, there is no dependence on the rise rate of the programming voltage. A fast application of fusing current is desirable for optimum fusing. Since the output programming voltage does not have to be applied rapidly, breakdown and latchback problems attributed to fast voltage rise times on the output are avoided.

This programming procedure has a second major advantage. If the fuse does not open during the first attempt to blow it, longer programming pulses are used. With the platinum-silicide fuse ionger programming pulses may be safely applied with no danger of developing a reliability problem. The algorithm can therefore be designed to minimize the time required to program by using a fast first pulse to maximize the probability that any circuit will program. Then a longer pulse can be applied to the occasional fuse that does not open with the first short pulse. Most devices do fuse satisfactorily with all short pulses.

Circuit defects resistant to discovery with pre-programming testing and random marginally wide fuses make it important to have a material not adversely affected by application of near DC programming conditions. The platinum-silicide fuse is such an element.

## Fuse Characteristics

When a fast (less than 500 ns rise time) current pulse is applied to a fuse, the fuse voltage rises abruptly to a value approaching the level expected from calculation of the room temperature resistance. However, it quickly falls to a value of

approximately 2 V . This value is nearly independent of the applied curent. During the period of time the fuse is molten, the fuse current drops very abruptly to zero indicating the separation of the platinum-silicide into two distinct sections. Scanning Electron Microscope photographs of the resulting fuses (Figure 1) indicate that the typical case is a sharp clean separation in excess of a micron. This separation occurs in the center of the fuse because the "bow-tie" structure (Figure 2) concentrates the energy density in the center away from the aluminum interconnect lines. The energy density in the center of the fuse creates temperatures substantially greater than those required to melt the silicide. Melted material is then "wicked" from the center of the fuse to either side due to surface tension.


03862A-179

Unprogrammed Fuse
Programmed Fuse
Figure 1


Figure 2. Bow-tle Fuse Design

## RELIABILITY OF FUSES PROGRAMMED UNDER NON-OPTIMAL CONDITIONS

The marginally opened fuse has been studied at AMD in detail even though it rarely occurs in practice. Under conditions where the fuse is purposely blown at much slower rates, it is possible for the fuse to assume a high impedance state which is sensed as an open fuse by the circuit. This occurs when the fuse cools before separation is achieved. Electrical and SEM studies of fuses blown under these conditions indicate that a small conductive path of silicon remains of sufficiently high resistance to prevent the power transfer required for complete opening on subsequent applications of power.

Under these slow-blow conditions, sufficient time exists for the heat flow to carry a significant amount of energy away from the fuse preventing the normal abrupt separation.
To investigate what might happen if a fuse were subjected to these under-blow conditions a large number of fuses were deliberately programmed this way at AMD. After over two thousand hours of life testing these devices with underblown fuses, there have been no faitures. It is clear from the study that partially blown platinum-silicide fuses are stable even though it will rarely occur in a circuit which has been programmed under normal conditions. Advanced Micro Devices believes that such fuses do not represent a reliability hazard based on this study and the results of other studies run on PROMs.
It should be noted that most manufacturers carefully specify the conditions under which their devices must be programmed
in order to avoid reliability problems. Reliability data available on these devices must be assumed to have been generated using optimally programmed devices.
Advanced Micro Devices believes that the study described here and over forty billion fuse hours of data from life testing many different production lots of PROMs and PALs demonstrates the outstanding reliability record of the platinumsilicide fuse under a wide variety of conditions.

## Reliability Testing Data

Data on the reliability of PAL and PROM devices with platinum-silicide fuses has been gathered over millions of device hours and more than 40 billion fuse hours of testing at $125^{\circ} \mathrm{C}$. This data is shown in Table 1 to project a unit failure at $60 \%$ confidence of $0.0003 \%$ per 1000 hours at $70^{\circ} \mathrm{C}$.
The life test circuits used in this work conform to MIL-STD-883 Method 1005 conditions C and D and are shown in Figure 3.

## SUMMARY

In high temperature operating life tests (HTOL) to date, PALs are exhibiting the same excellent reliability results shown by other IMOX and platinum-silicide fuse products. HTOL testing is an ongoing activity with all product lines at AMD. Updates of these results are generated periodically and can be obtained through inquiry to the AMD Programmable Logic Product directorate.

Table 1. Bipolar PROM and PAL Reliability Summary

| Product | Production Lots | Units <br> Tested | Total Unit Hours (thousands) | Total Fuse Hours (billions) | Unit <br> Failures | Fuse Related Failures | Unit Failure Rate@60\% Confidence $\% / 1000 \mathrm{hrs}$ at $125^{\circ} \mathrm{C}$ | Unit Failure Rate* @ $60 \%$ Confidence $\% / 1000 \mathrm{hrs}$ at $70^{\circ} \mathrm{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 27 \mathrm{~S} 18 / 19 \\ & \text { (256-bit PROM) } \\ & \hline \end{aligned}$ | 5 | 491 | 982 | 0.251 B | 0 | 0 | 0.10 | 0.0010 |
| $\begin{aligned} & 27 \mathrm{~S} 20 / 21 \\ & \text { (1K bit PROM) } \end{aligned}$ | 16 | 1321 | 2207 | 2.260 B | $2^{* *}$ | 0 | 0.14 | 0.0013 |
| $\begin{aligned} & 27 \mathrm{~S} 12 / 13 \\ & \text { (2K bit PROM) } \end{aligned}$ | 11 | 571 | 1840 | 3.7688 | 0 | 0 | 0.05 | 0.0005 |
| $27 S 15$ $27 S 27$ $27 S 28 / 29$ $27 S 32 / 33$ (4K bit PROM) | 24 | 1870 | 1408 | 5.767 B | 0 | 0 | 0.07 | 0.0007 |
| 27S180/181 <br> ( 8 K bit PROM) | 12 | 463 | 926 | 7.5868 | 0 | 0 | 0.11 | 0.0010 |
| $\begin{aligned} & 27 \mathrm{~S} 184 / 185 \\ & \text { IMOX } \\ & \text { (8K bit PROM) } \end{aligned}$ | 15 | 556 | 1112 | $9.109 \mathrm{~B}$ | 0 | 0 | 0.09 | 0.0008 |
| $\begin{aligned} & 27 \mathrm{~S} 190 / 191 \\ & \text { IMOX } \\ & \text { (16K bit PROM) } \end{aligned}$ | 2 | 69 | 795 | 13.025B | 0 | 0 | 0.12 | 0.0011 |
| 20-pin IMOX PALs | 10 | 976 | 700 | 1.434 B | 0 | 0 | 0.13 | 0.0012 |
| Totals for PALs and PROMs | 95 | 6317 | 9970 | 43.200 B | $2^{*}$ | 0 | 0.031 | 0.0003 |

03862A-181

[^3]

Figure 3. Life Test Circuits for AMD PALs

## Section 7

## General



Ordering Information
AMD Sales Offices
.


## U.S. AND CANADIAN SALES OFFICES

SOUTHWEST AREA
Advanced Micro Devices
360 N. Sepulveda, Suite 2075
El Segundo, California 90245
Tel: (213) 640-3210
Advanced Micro Devices
10050 N. 25th Street
Suite 235
Phoenix, Arizona 85021
Tel: (602) 242-4400
Advanced Micro Devices
4000 MacArthur Boulevard
Suite 5000
Newport Beach, California 92660
Tel: (714) 752-6262
Advanced Micro Devices
5955 De Soto Avenue, Suite 241
Woodland Hills, California 91367
Tel: (213) 992-4155
Advanced Micro Devices
9455 Ridgehaven Court
Suite 230
San Diego, California 92123
Tel: (619) 560-7030

## NORTHWEST AREA

Advanced Micro Devices
2700 Augustine Drive, Suite 109
Santa Clara, California 95051
Tel: (408) 727-1300
Advanced Micro Devices
1873 South Bellaire Street
Suite 920
Denver, Colorado 80222
Tel: (303) 691-5100

NORTHWEST AREA (Cont.)
Advanced Micro Devices
One Lincoln Center, Suite 230
10300 Southwest Greenburg Road
Portland, Oregon 97223
Tel: (503) 245-0080
Advanced Micro Devices
Honeywell Ctr., Suite 1002
600 108th Avenue N.E.
Bellevue, Washington 98004
Tel: (206) 455-3600

## MID-AMERICA AREA

Advanced Micro Devices 500 Park Boulevard, Suite 940 Itasca, Illinois 60143
Tel: (312) 773-4422
Advanced Micro Devices
9900 Bren Road East, Suite 601
Minnetonka, Minnesota 55343
Tel: (612) 938-0001
Advanced Micro Devices
3592 Corporate Drive, Suite 108
Columbus, Ohio 43229
Tel: (614) 891-6455
Advanced Micro Devices
8240 MoPac Expressway
Two Park North, Suite 385
Austin, Texas 78759
Tel: (512) 346-7830
Advanced Micro Devices
6750 LBJ Freeway, Suite 1160
Dallas, Texas 75240
Tei: (214) 934-9099

MID-ATLANTIC AREA
Advanced Micro Devices
40 Crossways Park Way
Woodbury, New York 11797
Tel: (516) 364-8020
Advanced Micro Devices 290 Elwood Davis Road
Suite 316
Liverpool, New York 13088
Tel: (315) 457-5400
Advanced Micro Devices
2 Kilmer Road
Edison, New Jersey 08817
Tel: (201) 985-6800
Advanced Micro Devices
107 Lakeside Drive
Horsham, Pennsylvania 19044
Tel: (215) 441-8210
TWX: 510-665-7572
Advanced Micro Devices
205 South Avenue
Poughkeepsie, New York 12601
Tel: (914) 471-8180
TWX: 510-248-4219
NORTHEAST AREA
Advanced Micro Devices
6 New England Executive Park
Burlington, Massachusetts 01803
Tel: (617) 273-3970
Advanced Micro Devices (Canada) Ltd.
2 Sheppard Avenue East
Suite 1610
Willowdale, Ontario
Canada M2N5Y7
Tel: (416) 224-5193

## SOUTHEAST AREA

Advanced Micro Devices
Parkway Center
One Parkway Drive Building
7257 Parkway Drive, Suite 204
Dorsey, Maryland 21076
Tel: (301) 796-9310
Advanced Micro Devices
7850 Ulmerton Road, Suite 1A
argo, Florida 33541
Tel: (813) 535-9811

## Advanced Micro Devices

4740 North State Road \#7
Suite 102
Ft. Lauderdale, Florida 33319
Tel: (305) 484-8600
Advanced Micro Devices
6755 Peachtree Industrial Boulevard
Suite 104
Atlanta, Georgia 30360
Tel: (404) 449-7920
Advanced Micro Devices
8 Woodlawn Green, Suite 220
Woodlawn Road
Charlotte, North Carolina 28210
Tel: (704) 525-1875

## INTERNATIONAL SALES OFFICES

## BELGIUM

Advanced Micro Devices
Overseas Corporation
Avenue de Tervueren, 412, bte 9
B-1150 Bruxelles
Tel: (02) 7719993
TELEX: 61028

## FRANCE

Advanced Micro Devices, S.A.
Silic 314, Immeuble Helsinki
74, rue d'Arcueil
F-94588 Rungis Cedex
Tel: (01) 687.36.66
TELEX: 202053

## GERMANY

Advanced Micro Devices GmbH
Rosenheimer Str. 139
D-8000 Muenchen 80
Tel: (089) 401976
TELEX: 05-23883
Advanced Micro Devices GmbH
Harthaeuser Hauptstrasse 4
D-7024 Filderstadt 3
Tel: (07158) 3060
TELEX: 07-21211
Advanced Micro Devices GmbH
Zur Worth 6
D-3108 Winsen/Aller
Tel: (05143) 5362
TELEX: 925287

## HONG KONG

Advanced Micro Devices
1303 World Commerce Centre
Harbour City
11 Canton Road
Tsimshatsui, Kowloon
Tel: (852) 3695377
TELEX: 50426
FAX: (852) 1234276
ITALY
Advanced Micro Devices S.r.L.
Centro Direzionale
Palazzo Vasari, $3^{\circ}$ Piano
1-20090 MI2 - Segrate (MI)
Tel: (02) 215 4913-4-5
TELEX: 315286

## JAPAN

Advanced Micro Devices, K.K.
Dai 3 Hoya Building
8-17, Kamitakaido 1 chome
Suginami-ku, Tokyo 168
Tel: (03) 329-2751
TELEX: 2324064
FAX: (03) 3260262

## SWEDEN

Advanced Micro Devices AB
Box 7013
S-172 07 Sundbyberg
Tel: (08) 981235
TELEX: 11602

## UNITED KINGDOM

Advanced Micro Devices (U.K.) L.td.
A.M.D. House,

Goldsworth Road,
Woking,
Surrey GU21 1JT
Tel: Woking (04862) 22121
TELEX: 859103

Advanced Micro Devices maintains a network of representatives and distributors in the U.S. and around the world. For a sales agent nearest you, call one of the AMD offices above.

ADVANCED
MICRO
DEVICES, INC.
901 Thompson Place P.O. Box 3453

Sunnyvale, California 94088 (408) 732-2400

TWX: 910-339-9280 TELEX: 34-6306

TOLL FREE (800) 538-8450


[^0]:    *See individual data sheets, Section 2.

[^1]:    "Manager, Processor Development, Computervision Corp., Bedtord, MA, at the time this paper was written. This paper reprinted with the permission of Computervision Corp.

[^2]:    $+\quad$; HOLD
    $+\quad$;LOAD YBUS INTO MAR ; LOAD ABUS INTO MAR ;DECREMENT

[^3]:    *Assuming on activation energy of 1.0 eV .
    *"Oxide failure.

